From 324d5960af46309a700f6a3d71510a78ff161a0c Mon Sep 17 00:00:00 2001 From: sasha-astiadi Date: Fri, 3 May 2024 06:39:20 +0200 Subject: [PATCH] hero_web --- LICENSE | 21 + README.md | 30 + android-chrome-192x192.png | Bin 0 -> 12799 bytes android-chrome-512x512.png | Bin 0 -> 39457 bytes apple-touch-icon.png | Bin 0 -> 11955 bytes browserconfig.xml | 9 + favicon-16x16.png | Bin 0 -> 1480 bytes favicon-32x32.png | Bin 0 -> 1923 bytes favicon.ico | Bin 0 -> 15086 bytes hero.html | 397 + images/.DS_Store | Bin 0 -> 6148 bytes images/banner.png | Bin 0 -> 139415 bytes images/benefit.png | Bin 0 -> 26838 bytes images/benefit.zip | Bin 0 -> 255174 bytes images/brand1.png | Bin 0 -> 4472 bytes images/brand2.png | Bin 0 -> 7728 bytes images/brand3.png | Bin 0 -> 12336 bytes images/brand4.png | Bin 0 -> 6651 bytes images/brand5.png | Bin 0 -> 2351 bytes images/brand6.png | Bin 0 -> 10751 bytes images/build.png | Bin 0 -> 320598 bytes images/cloud.svg | 4 + images/dashboard.png | Bin 0 -> 751666 bytes images/download.png | Bin 0 -> 1173 bytes images/experiences.png | Bin 0 -> 97780 bytes images/farmer.png | Bin 0 -> 98030 bytes images/feature-1.png | Bin 0 -> 120890 bytes images/feature-2.png | Bin 0 -> 117640 bytes images/feature.png | Bin 0 -> 379213 bytes images/feature4.png | Bin 0 -> 209718 bytes images/hero.png | Bin 0 -> 153301 bytes images/hero1.svg | 1 + images/hero2.png | Bin 0 -> 108880 bytes images/hero2.svg | 1 + images/hero3.svg | 1 + images/hero4.png | Bin 0 -> 377976 bytes images/hero5.png | Bin 0 -> 83397 bytes images/icon1.png | Bin 0 -> 26486 bytes images/icon1.svg | 1 + images/icon2.svg | 1 + images/icon3.svg | 1 + images/ict.png | Bin 0 -> 8505 bytes images/id.png | Bin 0 -> 87858 bytes images/kds.png | Bin 0 -> 140051 bytes images/learn.png | Bin 0 -> 145259 bytes images/logo.svg | 1 + images/my1.png | Bin 0 -> 121014 bytes images/mycelium.png | Bin 0 -> 275993 bytes images/node.png | Bin 0 -> 242232 bytes images/node1.png | Bin 0 -> 14654 bytes images/node2.png | Bin 0 -> 11692 bytes images/node3.png | Bin 0 -> 10465 bytes images/ourworld.png | Bin 0 -> 33762 bytes images/plug.png | Bin 0 -> 77546 bytes images/sikana.png | Bin 0 -> 16456 bytes images/social_network.png | Bin 0 -> 13554 bytes images/stat1.svg | 1 + images/stat2.svg | 1 + images/stat3.svg | 1 + images/stat4.svg | 1 + images/vverse.png | Bin 0 -> 15626 bytes images/xp1.svg | 1 + images/xp2.svg | 1 + images/xp3.svg | 1 + images/xp4.svg | 1 + index.html | 540 + input.css | 3 + mstile-150x150.png | Bin 0 -> 8630 bytes mycelium.html | 468 + node_modules/.DS_Store | Bin 0 -> 18436 bytes node_modules/.bin/acorn | 1 + node_modules/.bin/cssesc | 1 + node_modules/.bin/detective | 1 + node_modules/.bin/mini-svg-data-uri | 1 + node_modules/.bin/nanoid | 1 + node_modules/.bin/resolve | 1 + node_modules/.bin/tailwind | 1 + node_modules/.bin/tailwindcss | 1 + node_modules/.package-lock.json | 826 + node_modules/@nodelib/.DS_Store | Bin 0 -> 6148 bytes node_modules/@nodelib/fs.scandir/LICENSE | 21 + node_modules/@nodelib/fs.scandir/README.md | 171 + .../@nodelib/fs.scandir/out/adapters/fs.d.ts | 20 + .../@nodelib/fs.scandir/out/adapters/fs.js | 19 + .../@nodelib/fs.scandir/out/constants.d.ts | 4 + .../@nodelib/fs.scandir/out/constants.js | 17 + .../@nodelib/fs.scandir/out/index.d.ts | 12 + node_modules/@nodelib/fs.scandir/out/index.js | 26 + .../fs.scandir/out/providers/async.d.ts | 7 + .../fs.scandir/out/providers/async.js | 104 + .../fs.scandir/out/providers/common.d.ts | 1 + .../fs.scandir/out/providers/common.js | 13 + .../fs.scandir/out/providers/sync.d.ts | 5 + .../@nodelib/fs.scandir/out/providers/sync.js | 54 + .../@nodelib/fs.scandir/out/settings.d.ts | 20 + .../@nodelib/fs.scandir/out/settings.js | 24 + .../@nodelib/fs.scandir/out/types/index.d.ts | 20 + .../@nodelib/fs.scandir/out/types/index.js | 2 + .../@nodelib/fs.scandir/out/utils/fs.d.ts | 2 + .../@nodelib/fs.scandir/out/utils/fs.js | 19 + .../@nodelib/fs.scandir/out/utils/index.d.ts | 2 + .../@nodelib/fs.scandir/out/utils/index.js | 5 + node_modules/@nodelib/fs.scandir/package.json | 44 + node_modules/@nodelib/fs.stat/LICENSE | 21 + node_modules/@nodelib/fs.stat/README.md | 126 + .../@nodelib/fs.stat/out/adapters/fs.d.ts | 13 + .../@nodelib/fs.stat/out/adapters/fs.js | 17 + node_modules/@nodelib/fs.stat/out/index.d.ts | 12 + node_modules/@nodelib/fs.stat/out/index.js | 26 + .../@nodelib/fs.stat/out/providers/async.d.ts | 4 + .../@nodelib/fs.stat/out/providers/async.js | 36 + .../@nodelib/fs.stat/out/providers/sync.d.ts | 3 + .../@nodelib/fs.stat/out/providers/sync.js | 23 + .../@nodelib/fs.stat/out/settings.d.ts | 16 + node_modules/@nodelib/fs.stat/out/settings.js | 16 + .../@nodelib/fs.stat/out/types/index.d.ts | 4 + .../@nodelib/fs.stat/out/types/index.js | 2 + node_modules/@nodelib/fs.stat/package.json | 37 + node_modules/@nodelib/fs.walk/LICENSE | 21 + node_modules/@nodelib/fs.walk/README.md | 215 + node_modules/@nodelib/fs.walk/out/index.d.ts | 14 + node_modules/@nodelib/fs.walk/out/index.js | 34 + .../@nodelib/fs.walk/out/providers/async.d.ts | 12 + .../@nodelib/fs.walk/out/providers/async.js | 30 + .../@nodelib/fs.walk/out/providers/index.d.ts | 4 + .../@nodelib/fs.walk/out/providers/index.js | 9 + .../fs.walk/out/providers/stream.d.ts | 12 + .../@nodelib/fs.walk/out/providers/stream.js | 34 + .../@nodelib/fs.walk/out/providers/sync.d.ts | 10 + .../@nodelib/fs.walk/out/providers/sync.js | 14 + .../@nodelib/fs.walk/out/readers/async.d.ts | 30 + .../@nodelib/fs.walk/out/readers/async.js | 97 + .../@nodelib/fs.walk/out/readers/common.d.ts | 7 + .../@nodelib/fs.walk/out/readers/common.js | 31 + .../@nodelib/fs.walk/out/readers/reader.d.ts | 6 + .../@nodelib/fs.walk/out/readers/reader.js | 11 + .../@nodelib/fs.walk/out/readers/sync.d.ts | 15 + .../@nodelib/fs.walk/out/readers/sync.js | 59 + .../@nodelib/fs.walk/out/settings.d.ts | 30 + node_modules/@nodelib/fs.walk/out/settings.js | 26 + .../@nodelib/fs.walk/out/types/index.d.ts | 8 + .../@nodelib/fs.walk/out/types/index.js | 2 + node_modules/@nodelib/fs.walk/package.json | 44 + node_modules/@popperjs/core/LICENSE.md | 20 + node_modules/@popperjs/core/README.md | 376 + node_modules/@popperjs/core/dist/cjs/enums.js | 65 + .../@popperjs/core/dist/cjs/enums.js.flow | 3 + .../@popperjs/core/dist/cjs/enums.js.map | 1 + .../@popperjs/core/dist/cjs/popper-base.js | 1086 + .../core/dist/cjs/popper-base.js.flow | 3 + .../core/dist/cjs/popper-base.js.map | 1 + .../@popperjs/core/dist/cjs/popper-lite.js | 1419 + .../core/dist/cjs/popper-lite.js.flow | 3 + .../core/dist/cjs/popper-lite.js.map | 1 + .../@popperjs/core/dist/cjs/popper.js | 1991 + .../@popperjs/core/dist/cjs/popper.js.flow | 3 + .../@popperjs/core/dist/cjs/popper.js.map | 1 + .../@popperjs/core/dist/esm/createPopper.js | 259 + .../core/dist/esm/dom-utils/contains.js | 23 + .../esm/dom-utils/getBoundingClientRect.js | 36 + .../dist/esm/dom-utils/getClippingRect.js | 70 + .../dist/esm/dom-utils/getCompositeRect.js | 58 + .../dist/esm/dom-utils/getComputedStyle.js | 4 + .../dist/esm/dom-utils/getDocumentElement.js | 6 + .../dist/esm/dom-utils/getDocumentRect.js | 29 + .../esm/dom-utils/getHTMLElementScroll.js | 6 + .../core/dist/esm/dom-utils/getLayoutRect.js | 25 + .../core/dist/esm/dom-utils/getNodeName.js | 3 + .../core/dist/esm/dom-utils/getNodeScroll.js | 11 + .../dist/esm/dom-utils/getOffsetParent.js | 68 + .../core/dist/esm/dom-utils/getParentNode.js | 19 + .../dist/esm/dom-utils/getScrollParent.js | 16 + .../dist/esm/dom-utils/getViewportRect.js | 40 + .../core/dist/esm/dom-utils/getWindow.js | 12 + .../dist/esm/dom-utils/getWindowScroll.js | 10 + .../dist/esm/dom-utils/getWindowScrollBarX.js | 13 + .../core/dist/esm/dom-utils/instanceOf.js | 23 + .../core/dist/esm/dom-utils/isScrollParent.js | 10 + .../core/dist/esm/dom-utils/isTableElement.js | 4 + .../dist/esm/dom-utils/listScrollParents.js | 26 + node_modules/@popperjs/core/dist/esm/enums.js | 31 + node_modules/@popperjs/core/dist/esm/index.js | 8 + .../core/dist/esm/modifiers/applyStyles.js | 84 + .../core/dist/esm/modifiers/arrow.js | 101 + .../core/dist/esm/modifiers/computeStyles.js | 181 + .../core/dist/esm/modifiers/eventListeners.js | 49 + .../@popperjs/core/dist/esm/modifiers/flip.js | 147 + .../@popperjs/core/dist/esm/modifiers/hide.js | 61 + .../core/dist/esm/modifiers/index.js | 9 + .../core/dist/esm/modifiers/offset.js | 54 + .../core/dist/esm/modifiers/popperOffsets.js | 25 + .../dist/esm/modifiers/preventOverflow.js | 142 + .../@popperjs/core/dist/esm/popper-base.js | 3 + .../@popperjs/core/dist/esm/popper-lite.js | 11 + .../@popperjs/core/dist/esm/popper.js | 20 + .../@popperjs/core/dist/esm/types.js | 0 .../dist/esm/utils/computeAutoPlacement.js | 47 + .../core/dist/esm/utils/computeOffsets.js | 70 + .../@popperjs/core/dist/esm/utils/debounce.js | 15 + .../core/dist/esm/utils/detectOverflow.js | 63 + .../core/dist/esm/utils/expandToHashMap.js | 6 + .../@popperjs/core/dist/esm/utils/format.js | 9 + .../core/dist/esm/utils/getAltAxis.js | 3 + .../core/dist/esm/utils/getAltLen.js | 3 + .../core/dist/esm/utils/getBasePlacement.js | 4 + .../core/dist/esm/utils/getFreshSideObject.js | 8 + .../esm/utils/getMainAxisFromPlacement.js | 3 + .../dist/esm/utils/getOppositePlacement.js | 11 + .../utils/getOppositeVariationPlacement.js | 9 + .../core/dist/esm/utils/getVariation.js | 3 + .../@popperjs/core/dist/esm/utils/math.js | 3 + .../core/dist/esm/utils/mergeByName.js | 14 + .../core/dist/esm/utils/mergePaddingObject.js | 4 + .../core/dist/esm/utils/orderModifiers.js | 44 + .../core/dist/esm/utils/rectToClientRect.js | 8 + .../@popperjs/core/dist/esm/utils/uniqueBy.js | 11 + .../core/dist/esm/utils/validateModifiers.js | 81 + .../@popperjs/core/dist/esm/utils/within.js | 8 + node_modules/@popperjs/core/dist/umd/enums.js | 71 + .../@popperjs/core/dist/umd/enums.js.map | 1 + .../@popperjs/core/dist/umd/enums.min.js | 6 + .../@popperjs/core/dist/umd/enums.min.js.flow | 3 + .../@popperjs/core/dist/umd/enums.min.js.map | 1 + .../@popperjs/core/dist/umd/popper-base.js | 1092 + .../core/dist/umd/popper-base.js.map | 1 + .../core/dist/umd/popper-base.min.js | 6 + .../core/dist/umd/popper-base.min.js.flow | 3 + .../core/dist/umd/popper-base.min.js.map | 1 + .../@popperjs/core/dist/umd/popper-lite.js | 1425 + .../core/dist/umd/popper-lite.js.map | 1 + .../core/dist/umd/popper-lite.min.js | 6 + .../core/dist/umd/popper-lite.min.js.flow | 3 + .../core/dist/umd/popper-lite.min.js.map | 1 + .../@popperjs/core/dist/umd/popper.js | 1997 + .../@popperjs/core/dist/umd/popper.js.map | 1 + .../@popperjs/core/dist/umd/popper.min.js | 6 + .../core/dist/umd/popper.min.js.flow | 3 + .../@popperjs/core/dist/umd/popper.min.js.map | 1 + node_modules/@popperjs/core/index.d.ts | 1 + .../@popperjs/core/lib/createPopper.d.ts | 9 + .../@popperjs/core/lib/createPopper.js | 259 + .../@popperjs/core/lib/createPopper.js.flow | 296 + .../core/lib/dom-utils/contains.d.ts | 1 + .../@popperjs/core/lib/dom-utils/contains.js | 23 + .../core/lib/dom-utils/contains.js.flow | 25 + .../lib/dom-utils/getBoundingClientRect.d.ts | 2 + .../lib/dom-utils/getBoundingClientRect.js | 36 + .../dom-utils/getBoundingClientRect.js.flow | 38 + .../core/lib/dom-utils/getClippingRect.d.ts | 3 + .../core/lib/dom-utils/getClippingRect.js | 70 + .../lib/dom-utils/getClippingRect.js.flow | 101 + .../core/lib/dom-utils/getCompositeRect.d.ts | 2 + .../core/lib/dom-utils/getCompositeRect.js | 58 + .../lib/dom-utils/getCompositeRect.js.flow | 63 + .../core/lib/dom-utils/getComputedStyle.d.ts | 1 + .../core/lib/dom-utils/getComputedStyle.js | 4 + .../lib/dom-utils/getComputedStyle.js.flow | 8 + .../lib/dom-utils/getDocumentElement.d.ts | 2 + .../core/lib/dom-utils/getDocumentElement.js | 6 + .../lib/dom-utils/getDocumentElement.js.flow | 15 + .../core/lib/dom-utils/getDocumentRect.d.ts | 2 + .../core/lib/dom-utils/getDocumentRect.js | 29 + .../lib/dom-utils/getDocumentRect.js.flow | 37 + .../lib/dom-utils/getHTMLElementScroll.d.ts | 4 + .../lib/dom-utils/getHTMLElementScroll.js | 6 + .../dom-utils/getHTMLElementScroll.js.flow | 8 + .../core/lib/dom-utils/getLayoutRect.d.ts | 2 + .../core/lib/dom-utils/getLayoutRect.js | 25 + .../core/lib/dom-utils/getLayoutRect.js.flow | 29 + .../core/lib/dom-utils/getNodeName.d.ts | 2 + .../core/lib/dom-utils/getNodeName.js | 3 + .../core/lib/dom-utils/getNodeName.js.flow | 6 + .../core/lib/dom-utils/getNodeScroll.d.ts | 5 + .../core/lib/dom-utils/getNodeScroll.js | 11 + .../core/lib/dom-utils/getNodeScroll.js.flow | 14 + .../core/lib/dom-utils/getOffsetParent.d.ts | 1 + .../core/lib/dom-utils/getOffsetParent.js | 68 + .../lib/dom-utils/getOffsetParent.js.flow | 92 + .../core/lib/dom-utils/getParentNode.d.ts | 1 + .../core/lib/dom-utils/getParentNode.js | 19 + .../core/lib/dom-utils/getParentNode.js.flow | 21 + .../core/lib/dom-utils/getScrollParent.d.ts | 1 + .../core/lib/dom-utils/getScrollParent.js | 16 + .../lib/dom-utils/getScrollParent.js.flow | 18 + .../core/lib/dom-utils/getViewportRect.d.ts | 6 + .../core/lib/dom-utils/getViewportRect.js | 40 + .../lib/dom-utils/getViewportRect.js.flow | 46 + .../core/lib/dom-utils/getWindow.d.ts | 1 + .../@popperjs/core/lib/dom-utils/getWindow.js | 12 + .../core/lib/dom-utils/getWindow.js.flow | 16 + .../core/lib/dom-utils/getWindowScroll.d.ts | 5 + .../core/lib/dom-utils/getWindowScroll.js | 10 + .../lib/dom-utils/getWindowScroll.js.flow | 14 + .../lib/dom-utils/getWindowScrollBarX.d.ts | 1 + .../core/lib/dom-utils/getWindowScrollBarX.js | 13 + .../lib/dom-utils/getWindowScrollBarX.js.flow | 18 + .../core/lib/dom-utils/instanceOf.d.ts | 4 + .../core/lib/dom-utils/instanceOf.js | 23 + .../core/lib/dom-utils/instanceOf.js.flow | 29 + .../core/lib/dom-utils/isScrollParent.d.ts | 1 + .../core/lib/dom-utils/isScrollParent.js | 10 + .../core/lib/dom-utils/isScrollParent.js.flow | 8 + .../core/lib/dom-utils/isTableElement.d.ts | 1 + .../core/lib/dom-utils/isTableElement.js | 4 + .../core/lib/dom-utils/isTableElement.js.flow | 6 + .../core/lib/dom-utils/listScrollParents.d.ts | 2 + .../core/lib/dom-utils/listScrollParents.js | 26 + .../lib/dom-utils/listScrollParents.js.flow | 33 + node_modules/@popperjs/core/lib/enums.d.ts | 34 + node_modules/@popperjs/core/lib/enums.js | 31 + node_modules/@popperjs/core/lib/enums.js.flow | 91 + node_modules/@popperjs/core/lib/index.d.ts | 6 + node_modules/@popperjs/core/lib/index.js | 8 + node_modules/@popperjs/core/lib/index.js.flow | 13 + .../core/lib/modifiers/applyStyles.d.ts | 4 + .../core/lib/modifiers/applyStyles.js | 84 + .../core/lib/modifiers/applyStyles.js.flow | 98 + .../@popperjs/core/lib/modifiers/arrow.d.ts | 13 + .../@popperjs/core/lib/modifiers/arrow.js | 101 + .../core/lib/modifiers/arrow.js.flow | 142 + .../core/lib/modifiers/computeStyles.d.ts | 38 + .../core/lib/modifiers/computeStyles.js | 181 + .../core/lib/modifiers/computeStyles.js.flow | 263 + .../core/lib/modifiers/eventListeners.d.ts | 8 + .../core/lib/modifiers/eventListeners.js | 49 + .../core/lib/modifiers/eventListeners.js.flow | 54 + .../@popperjs/core/lib/modifiers/flip.d.ts | 16 + .../@popperjs/core/lib/modifiers/flip.js | 147 + .../@popperjs/core/lib/modifiers/flip.js.flow | 177 + .../@popperjs/core/lib/modifiers/hide.d.ts | 4 + .../@popperjs/core/lib/modifiers/hide.js | 61 + .../@popperjs/core/lib/modifiers/hide.js.flow | 76 + .../@popperjs/core/lib/modifiers/index.d.ts | 9 + .../@popperjs/core/lib/modifiers/index.js | 9 + .../core/lib/modifiers/index.js.flow | 10 + .../@popperjs/core/lib/modifiers/offset.d.ts | 18 + .../@popperjs/core/lib/modifiers/offset.js | 54 + .../core/lib/modifiers/offset.js.flow | 71 + .../core/lib/modifiers/popperOffsets.d.ts | 4 + .../core/lib/modifiers/popperOffsets.js | 25 + .../core/lib/modifiers/popperOffsets.js.flow | 26 + .../core/lib/modifiers/preventOverflow.d.ts | 30 + .../core/lib/modifiers/preventOverflow.js | 142 + .../lib/modifiers/preventOverflow.js.flow | 220 + .../@popperjs/core/lib/popper-base.d.ts | 3 + .../@popperjs/core/lib/popper-base.js | 3 + .../@popperjs/core/lib/popper-base.js.flow | 7 + .../@popperjs/core/lib/popper-lite.d.ts | 5 + .../@popperjs/core/lib/popper-lite.js | 11 + .../@popperjs/core/lib/popper-lite.js.flow | 21 + node_modules/@popperjs/core/lib/popper.d.ts | 7 + node_modules/@popperjs/core/lib/popper.js | 20 + .../@popperjs/core/lib/popper.js.flow | 35 + node_modules/@popperjs/core/lib/types.d.ts | 167 + node_modules/@popperjs/core/lib/types.js | 0 node_modules/@popperjs/core/lib/types.js.flow | 199 + .../core/lib/utils/computeAutoPlacement.d.ts | 12 + .../core/lib/utils/computeAutoPlacement.js | 47 + .../lib/utils/computeAutoPlacement.js.flow | 85 + .../core/lib/utils/computeOffsets.d.ts | 8 + .../core/lib/utils/computeOffsets.js | 70 + .../core/lib/utils/computeOffsets.js.flow | 82 + .../@popperjs/core/lib/utils/debounce.d.ts | 1 + .../@popperjs/core/lib/utils/debounce.js | 15 + .../@popperjs/core/lib/utils/debounce.js.flow | 17 + .../core/lib/utils/detectOverflow.d.ts | 11 + .../core/lib/utils/detectOverflow.js | 63 + .../core/lib/utils/detectOverflow.js.flow | 109 + .../core/lib/utils/expandToHashMap.d.ts | 3 + .../core/lib/utils/expandToHashMap.js | 6 + .../core/lib/utils/expandToHashMap.js.flow | 11 + .../@popperjs/core/lib/utils/format.d.ts | 1 + .../@popperjs/core/lib/utils/format.js | 9 + .../@popperjs/core/lib/utils/format.js.flow | 5 + .../@popperjs/core/lib/utils/getAltAxis.d.ts | 1 + .../@popperjs/core/lib/utils/getAltAxis.js | 3 + .../core/lib/utils/getAltAxis.js.flow | 5 + .../@popperjs/core/lib/utils/getAltLen.d.ts | 1 + .../@popperjs/core/lib/utils/getAltLen.js | 3 + .../core/lib/utils/getAltLen.js.flow | 5 + .../core/lib/utils/getBasePlacement.d.ts | 2 + .../core/lib/utils/getBasePlacement.js | 4 + .../core/lib/utils/getBasePlacement.js.flow | 8 + .../core/lib/utils/getFreshSideObject.d.ts | 2 + .../core/lib/utils/getFreshSideObject.js | 8 + .../core/lib/utils/getFreshSideObject.js.flow | 11 + .../lib/utils/getMainAxisFromPlacement.d.ts | 2 + .../lib/utils/getMainAxisFromPlacement.js | 3 + .../utils/getMainAxisFromPlacement.js.flow | 8 + .../core/lib/utils/getOppositePlacement.d.ts | 2 + .../core/lib/utils/getOppositePlacement.js | 11 + .../lib/utils/getOppositePlacement.js.flow | 11 + .../utils/getOppositeVariationPlacement.d.ts | 2 + .../utils/getOppositeVariationPlacement.js | 9 + .../getOppositeVariationPlacement.js.flow | 10 + .../core/lib/utils/getVariation.d.ts | 2 + .../@popperjs/core/lib/utils/getVariation.js | 3 + .../core/lib/utils/getVariation.js.flow | 6 + .../@popperjs/core/lib/utils/math.d.ts | 3 + node_modules/@popperjs/core/lib/utils/math.js | 3 + .../@popperjs/core/lib/utils/math.js.flow | 4 + .../@popperjs/core/lib/utils/mergeByName.d.ts | 2 + .../@popperjs/core/lib/utils/mergeByName.js | 14 + .../core/lib/utils/mergeByName.js.flow | 22 + .../core/lib/utils/mergePaddingObject.d.ts | 2 + .../core/lib/utils/mergePaddingObject.js | 4 + .../core/lib/utils/mergePaddingObject.js.flow | 12 + .../core/lib/utils/orderModifiers.d.ts | 2 + .../core/lib/utils/orderModifiers.js | 44 + .../core/lib/utils/orderModifiers.js.flow | 59 + .../core/lib/utils/rectToClientRect.d.ts | 2 + .../core/lib/utils/rectToClientRect.js | 8 + .../core/lib/utils/rectToClientRect.js.flow | 12 + .../@popperjs/core/lib/utils/uniqueBy.d.ts | 1 + .../@popperjs/core/lib/utils/uniqueBy.js | 11 + .../@popperjs/core/lib/utils/uniqueBy.js.flow | 14 + .../core/lib/utils/validateModifiers.d.ts | 1 + .../core/lib/utils/validateModifiers.js | 81 + .../core/lib/utils/validateModifiers.js.flow | 151 + .../@popperjs/core/lib/utils/within.d.ts | 2 + .../@popperjs/core/lib/utils/within.js | 8 + .../@popperjs/core/lib/utils/within.js.flow | 11 + node_modules/@popperjs/core/package.json | 119 + node_modules/acorn-node/.DS_Store | Bin 0 -> 6148 bytes node_modules/acorn-node/.travis.yml | 22 + node_modules/acorn-node/CHANGELOG.md | 94 + node_modules/acorn-node/LICENSE.md | 95 + node_modules/acorn-node/README.md | 65 + node_modules/acorn-node/build.js | 36 + node_modules/acorn-node/index.js | 38 + node_modules/acorn-node/lib/bigint/index.js | 71 + .../acorn-node/lib/class-fields/index.js | 70 + .../acorn-node/lib/dynamic-import/index.js | 86 + .../acorn-node/lib/export-ns-from/index.js | 43 + .../acorn-node/lib/import-meta/index.js | 55 + .../acorn-node/lib/numeric-separator/index.js | 61 + .../lib/private-class-elements/index.js | 135 + .../lib/static-class-features/index.js | 139 + node_modules/acorn-node/package.json | 51 + node_modules/acorn-node/test/index.js | 154 + node_modules/acorn-node/walk.js | 57 + node_modules/acorn-walk/CHANGELOG.md | 131 + node_modules/acorn-walk/LICENSE | 19 + node_modules/acorn-walk/README.md | 126 + node_modules/acorn-walk/dist/walk.d.ts | 112 + node_modules/acorn-walk/dist/walk.js | 463 + node_modules/acorn-walk/dist/walk.js.map | 1 + node_modules/acorn-walk/dist/walk.mjs | 443 + node_modules/acorn-walk/dist/walk.mjs.map | 1 + node_modules/acorn-walk/package.json | 34 + node_modules/acorn/.DS_Store | Bin 0 -> 6148 bytes node_modules/acorn/CHANGELOG.md | 620 + node_modules/acorn/LICENSE | 21 + node_modules/acorn/README.md | 269 + node_modules/acorn/bin/acorn | 4 + node_modules/acorn/dist/acorn.d.ts | 209 + node_modules/acorn/dist/acorn.js | 5186 + node_modules/acorn/dist/acorn.js.map | 1 + node_modules/acorn/dist/acorn.mjs | 5155 + node_modules/acorn/dist/acorn.mjs.d.ts | 2 + node_modules/acorn/dist/acorn.mjs.map | 1 + node_modules/acorn/dist/bin.js | 64 + node_modules/acorn/package.json | 35 + node_modules/anymatch/LICENSE | 15 + node_modules/anymatch/README.md | 87 + node_modules/anymatch/index.d.ts | 19 + node_modules/anymatch/index.js | 104 + node_modules/anymatch/package.json | 48 + node_modules/arg/LICENSE.md | 21 + node_modules/arg/README.md | 317 + node_modules/arg/index.d.ts | 44 + node_modules/arg/index.js | 195 + node_modules/arg/package.json | 28 + .../binary-extensions/binary-extensions.json | 260 + .../binary-extensions.json.d.ts | 3 + node_modules/binary-extensions/index.d.ts | 14 + node_modules/binary-extensions/index.js | 1 + node_modules/binary-extensions/license | 9 + node_modules/binary-extensions/package.json | 38 + node_modules/binary-extensions/readme.md | 41 + node_modules/braces/CHANGELOG.md | 184 + node_modules/braces/LICENSE | 21 + node_modules/braces/README.md | 593 + node_modules/braces/index.js | 170 + node_modules/braces/lib/compile.js | 57 + node_modules/braces/lib/constants.js | 57 + node_modules/braces/lib/expand.js | 113 + node_modules/braces/lib/parse.js | 333 + node_modules/braces/lib/stringify.js | 32 + node_modules/braces/lib/utils.js | 112 + node_modules/braces/package.json | 77 + node_modules/camelcase-css/README.md | 27 + node_modules/camelcase-css/index-es5.js | 24 + node_modules/camelcase-css/index.js | 30 + node_modules/camelcase-css/license | 21 + node_modules/camelcase-css/package.json | 34 + node_modules/chokidar/.DS_Store | Bin 0 -> 6148 bytes node_modules/chokidar/LICENSE | 21 + node_modules/chokidar/README.md | 308 + node_modules/chokidar/index.js | 973 + node_modules/chokidar/lib/constants.js | 65 + node_modules/chokidar/lib/fsevents-handler.js | 524 + node_modules/chokidar/lib/nodefs-handler.js | 654 + .../node_modules/glob-parent/CHANGELOG.md | 110 + .../chokidar/node_modules/glob-parent/LICENSE | 15 + .../node_modules/glob-parent/README.md | 137 + .../node_modules/glob-parent/index.js | 42 + .../node_modules/glob-parent/package.json | 48 + node_modules/chokidar/package.json | 85 + node_modules/chokidar/types/index.d.ts | 188 + node_modules/color-name/LICENSE | 8 + node_modules/color-name/README.md | 11 + node_modules/color-name/index.js | 152 + node_modules/color-name/package.json | 28 + node_modules/cssesc/.DS_Store | Bin 0 -> 6148 bytes node_modules/cssesc/LICENSE-MIT.txt | 20 + node_modules/cssesc/README.md | 201 + node_modules/cssesc/bin/cssesc | 116 + node_modules/cssesc/cssesc.js | 110 + node_modules/cssesc/man/cssesc.1 | 70 + node_modules/cssesc/package.json | 51 + node_modules/defined/.DS_Store | Bin 0 -> 6148 bytes node_modules/defined/.travis.yml | 4 + node_modules/defined/LICENSE | 18 + node_modules/defined/example/defined.js | 4 + node_modules/defined/index.js | 5 + node_modules/defined/package.json | 46 + node_modules/defined/readme.markdown | 53 + node_modules/defined/test/def.js | 22 + node_modules/defined/test/falsy.js | 9 + node_modules/detective/.DS_Store | Bin 0 -> 6148 bytes node_modules/detective/.travis.yml | 17 + node_modules/detective/CHANGELOG.md | 26 + node_modules/detective/LICENSE | 18 + node_modules/detective/bench/detect.js | 7 + .../detective/bench/esprima_v_acorn.txt | 18 + node_modules/detective/bin/detective.js | 11 + node_modules/detective/example/strings.js | 6 + node_modules/detective/example/strings_src.js | 3 + node_modules/detective/index.js | 80 + node_modules/detective/package.json | 37 + node_modules/detective/readme.markdown | 81 + node_modules/detective/test/both.js | 26 + node_modules/detective/test/chained.js | 9 + node_modules/detective/test/complicated.js | 58 + node_modules/detective/test/es2019.js | 15 + node_modules/detective/test/es6-module.js | 9 + node_modules/detective/test/files/both.js | 4 + node_modules/detective/test/files/chained.js | 5 + .../detective/test/files/es6-module.js | 5 + .../detective/test/files/for-await.js | 5 + .../detective/test/files/generators.js | 5 + .../detective/test/files/isrequire.js | 14 + node_modules/detective/test/files/nested.js | 22 + .../detective/test/files/optional-catch.js | 4 + .../detective/test/files/rest-spread.js | 9 + .../test/files/set-in-object-pattern.js | 10 + node_modules/detective/test/files/shebang.js | 5 + .../detective/test/files/sparse-array.js | 3 + node_modules/detective/test/files/strings.js | 13 + node_modules/detective/test/files/word.js | 13 + node_modules/detective/test/files/yield.js | 4 + node_modules/detective/test/generators.js | 9 + node_modules/detective/test/isrequire.js | 20 + node_modules/detective/test/nested.js | 9 + node_modules/detective/test/noargs.js | 26 + node_modules/detective/test/parseopts.js | 62 + node_modules/detective/test/rest-spread.js | 9 + node_modules/detective/test/return.js | 9 + .../detective/test/set-in-object-pattern.js | 12 + node_modules/detective/test/shebang.js | 9 + node_modules/detective/test/sparse-array.js | 14 + node_modules/detective/test/strings.js | 9 + node_modules/detective/test/word.js | 12 + node_modules/detective/test/yield.js | 9 + node_modules/didyoumean/LICENSE | 14 + node_modules/didyoumean/README.md | 134 + node_modules/didyoumean/didYouMean-1.2.1.js | 274 + .../didyoumean/didYouMean-1.2.1.min.js | 17 + node_modules/didyoumean/package.json | 27 + node_modules/dlv/README.md | 76 + node_modules/dlv/dist/dlv.es.js | 2 + node_modules/dlv/dist/dlv.es.js.map | 1 + node_modules/dlv/dist/dlv.js | 2 + node_modules/dlv/dist/dlv.js.map | 1 + node_modules/dlv/dist/dlv.umd.js | 2 + node_modules/dlv/dist/dlv.umd.js.map | 1 + node_modules/dlv/index.js | 7 + node_modules/dlv/package.json | 30 + node_modules/fast-glob/.DS_Store | Bin 0 -> 6148 bytes node_modules/fast-glob/LICENSE | 21 + node_modules/fast-glob/README.md | 795 + .../node_modules/glob-parent/CHANGELOG.md | 110 + .../node_modules/glob-parent/LICENSE | 15 + .../node_modules/glob-parent/README.md | 137 + .../node_modules/glob-parent/index.js | 42 + .../node_modules/glob-parent/package.json | 48 + node_modules/fast-glob/out/index.d.ts | 27 + node_modules/fast-glob/out/index.js | 68 + .../fast-glob/out/managers/patterns.d.ts | 6 + .../fast-glob/out/managers/patterns.js | 21 + .../fast-glob/out/managers/tasks.d.ts | 22 + node_modules/fast-glob/out/managers/tasks.js | 80 + .../fast-glob/out/providers/async.d.ts | 11 + node_modules/fast-glob/out/providers/async.js | 28 + .../fast-glob/out/providers/filters/deep.d.ts | 16 + .../fast-glob/out/providers/filters/deep.js | 62 + .../out/providers/filters/entry.d.ts | 20 + .../fast-glob/out/providers/filters/entry.js | 60 + .../out/providers/filters/error.d.ts | 8 + .../fast-glob/out/providers/filters/error.js | 15 + .../out/providers/matchers/matcher.d.ts | 33 + .../out/providers/matchers/matcher.js | 50 + .../out/providers/matchers/partial.d.ts | 4 + .../out/providers/matchers/partial.js | 38 + .../fast-glob/out/providers/provider.d.ts | 19 + .../fast-glob/out/providers/provider.js | 48 + .../fast-glob/out/providers/stream.d.ts | 11 + .../fast-glob/out/providers/stream.js | 31 + .../fast-glob/out/providers/sync.d.ts | 9 + node_modules/fast-glob/out/providers/sync.js | 23 + .../out/providers/transformers/entry.d.ts | 8 + .../out/providers/transformers/entry.js | 26 + .../fast-glob/out/readers/reader.d.ts | 15 + node_modules/fast-glob/out/readers/reader.js | 33 + .../fast-glob/out/readers/stream.d.ts | 14 + node_modules/fast-glob/out/readers/stream.js | 55 + node_modules/fast-glob/out/readers/sync.d.ts | 12 + node_modules/fast-glob/out/readers/sync.js | 43 + node_modules/fast-glob/out/settings.d.ts | 164 + node_modules/fast-glob/out/settings.js | 57 + node_modules/fast-glob/out/types/index.d.ts | 31 + node_modules/fast-glob/out/types/index.js | 2 + node_modules/fast-glob/out/utils/array.d.ts | 2 + node_modules/fast-glob/out/utils/array.js | 22 + node_modules/fast-glob/out/utils/errno.d.ts | 2 + node_modules/fast-glob/out/utils/errno.js | 7 + node_modules/fast-glob/out/utils/fs.d.ts | 4 + node_modules/fast-glob/out/utils/fs.js | 19 + node_modules/fast-glob/out/utils/index.d.ts | 8 + node_modules/fast-glob/out/utils/index.js | 17 + node_modules/fast-glob/out/utils/path.d.ts | 8 + node_modules/fast-glob/out/utils/path.js | 33 + node_modules/fast-glob/out/utils/pattern.d.ts | 42 + node_modules/fast-glob/out/utils/pattern.js | 169 + node_modules/fast-glob/out/utils/stream.d.ts | 3 + node_modules/fast-glob/out/utils/stream.js | 17 + node_modules/fast-glob/out/utils/string.d.ts | 2 + node_modules/fast-glob/out/utils/string.js | 11 + node_modules/fast-glob/package.json | 94 + node_modules/fastq/.DS_Store | Bin 0 -> 6148 bytes node_modules/fastq/.github/dependabot.yml | 11 + node_modules/fastq/.github/workflows/ci.yml | 50 + node_modules/fastq/LICENSE | 13 + node_modules/fastq/README.md | 309 + node_modules/fastq/bench.js | 66 + node_modules/fastq/example.js | 14 + node_modules/fastq/example.mjs | 11 + node_modules/fastq/index.d.ts | 37 + node_modules/fastq/package.json | 52 + node_modules/fastq/queue.js | 283 + node_modules/fastq/test/example.ts | 81 + node_modules/fastq/test/promise.js | 221 + node_modules/fastq/test/test.js | 566 + node_modules/fastq/test/tsconfig.json | 11 + node_modules/fill-range/LICENSE | 21 + node_modules/fill-range/README.md | 237 + node_modules/fill-range/index.js | 249 + node_modules/fill-range/package.json | 69 + node_modules/flowbite/.DS_Store | Bin 0 -> 6148 bytes node_modules/flowbite/LICENSE.md | 21 + node_modules/flowbite/README.md | 778 + node_modules/flowbite/dist/datepicker.js | 3119 + node_modules/flowbite/dist/datepicker.js.map | 1 + node_modules/flowbite/dist/datepicker.min.js | 2 + .../flowbite/dist/datepicker.turbo.js | 3141 + .../flowbite/dist/datepicker.turbo.js.map | 1 + .../flowbite/dist/datepicker.turbo.min.js | 2 + node_modules/flowbite/dist/flowbite.css | 7979 ++ node_modules/flowbite/dist/flowbite.js | 4434 + node_modules/flowbite/dist/flowbite.js.map | 1 + node_modules/flowbite/dist/flowbite.min.css | 1 + node_modules/flowbite/dist/flowbite.min.js | 2 + .../flowbite/dist/flowbite.min.js.map | 1 + .../flowbite/dist/flowbite.phoenix.js | 4438 + .../flowbite/dist/flowbite.phoenix.js.map | 1 + .../flowbite/dist/flowbite.phoenix.min.js | 2 + .../flowbite/dist/flowbite.phoenix.min.js.map | 1 + node_modules/flowbite/dist/flowbite.turbo.js | 4438 + .../flowbite/dist/flowbite.turbo.js.map | 1 + .../flowbite/dist/flowbite.turbo.min.js | 2 + .../flowbite/dist/flowbite.turbo.min.js.map | 1 + .../lib/cjs/components/accordion/index.d.ts | 15 + .../cjs/components/accordion/index.d.ts.map | 1 + .../lib/cjs/components/accordion/index.js | 151 + .../lib/cjs/components/accordion/index.js.map | 1 + .../cjs/components/accordion/interface.d.ts | 10 + .../components/accordion/interface.d.ts.map | 1 + .../lib/cjs/components/accordion/interface.js | 3 + .../cjs/components/accordion/interface.js.map | 1 + .../lib/cjs/components/accordion/types.d.ts | 17 + .../cjs/components/accordion/types.d.ts.map | 1 + .../lib/cjs/components/accordion/types.js | 3 + .../lib/cjs/components/accordion/types.js.map | 1 + .../lib/cjs/components/carousel/index.d.ts | 54 + .../cjs/components/carousel/index.d.ts.map | 1 + .../lib/cjs/components/carousel/index.js | 246 + .../lib/cjs/components/carousel/index.js.map | 1 + .../cjs/components/carousel/interface.d.ts | 20 + .../components/carousel/interface.d.ts.map | 1 + .../lib/cjs/components/carousel/interface.js | 3 + .../cjs/components/carousel/interface.js.map | 1 + .../lib/cjs/components/carousel/types.d.ts | 27 + .../cjs/components/carousel/types.d.ts.map | 1 + .../lib/cjs/components/carousel/types.js | 3 + .../lib/cjs/components/carousel/types.js.map | 1 + .../lib/cjs/components/collapse/index.d.ts | 16 + .../cjs/components/collapse/index.d.ts.map | 1 + .../lib/cjs/components/collapse/index.js | 98 + .../lib/cjs/components/collapse/index.js.map | 1 + .../cjs/components/collapse/interface.d.ts | 12 + .../components/collapse/interface.d.ts.map | 1 + .../lib/cjs/components/collapse/interface.js | 3 + .../cjs/components/collapse/interface.js.map | 1 + .../lib/cjs/components/collapse/types.d.ts | 7 + .../cjs/components/collapse/types.d.ts.map | 1 + .../lib/cjs/components/collapse/types.js | 3 + .../lib/cjs/components/collapse/types.js.map | 1 + .../lib/cjs/components/dial/index.d.ts | 23 + .../lib/cjs/components/dial/index.d.ts.map | 1 + .../flowbite/lib/cjs/components/dial/index.js | 142 + .../lib/cjs/components/dial/index.js.map | 1 + .../lib/cjs/components/dial/interface.d.ts | 16 + .../cjs/components/dial/interface.d.ts.map | 1 + .../lib/cjs/components/dial/interface.js | 3 + .../lib/cjs/components/dial/interface.js.map | 1 + .../lib/cjs/components/dial/types.d.ts | 13 + .../lib/cjs/components/dial/types.d.ts.map | 1 + .../flowbite/lib/cjs/components/dial/types.js | 3 + .../lib/cjs/components/dial/types.js.map | 1 + .../lib/cjs/components/dismiss/index.d.ts | 13 + .../lib/cjs/components/dismiss/index.d.ts.map | 1 + .../lib/cjs/components/dismiss/index.js | 68 + .../lib/cjs/components/dismiss/index.js.map | 1 + .../lib/cjs/components/dismiss/interface.d.ts | 9 + .../cjs/components/dismiss/interface.d.ts.map | 1 + .../lib/cjs/components/dismiss/interface.js | 3 + .../cjs/components/dismiss/interface.js.map | 1 + .../lib/cjs/components/dismiss/types.d.ts | 8 + .../lib/cjs/components/dismiss/types.d.ts.map | 1 + .../lib/cjs/components/dismiss/types.js | 3 + .../lib/cjs/components/dismiss/types.js.map | 1 + .../lib/cjs/components/drawer/index.d.ts | 21 + .../lib/cjs/components/drawer/index.d.ts.map | 1 + .../lib/cjs/components/drawer/index.js | 314 + .../lib/cjs/components/drawer/index.js.map | 1 + .../lib/cjs/components/drawer/interface.d.ts | 17 + .../cjs/components/drawer/interface.d.ts.map | 1 + .../lib/cjs/components/drawer/interface.js | 3 + .../cjs/components/drawer/interface.js.map | 1 + .../lib/cjs/components/drawer/types.d.ts | 22 + .../lib/cjs/components/drawer/types.d.ts.map | 1 + .../lib/cjs/components/drawer/types.js | 3 + .../lib/cjs/components/drawer/types.js.map | 1 + .../lib/cjs/components/dropdown/index.d.ts | 29 + .../cjs/components/dropdown/index.d.ts.map | 1 + .../lib/cjs/components/dropdown/index.js | 254 + .../lib/cjs/components/dropdown/index.js.map | 1 + .../cjs/components/dropdown/interface.d.ts | 22 + .../components/dropdown/interface.d.ts.map | 1 + .../lib/cjs/components/dropdown/interface.js | 3 + .../cjs/components/dropdown/interface.js.map | 1 + .../lib/cjs/components/dropdown/types.d.ts | 19 + .../cjs/components/dropdown/types.d.ts.map | 1 + .../lib/cjs/components/dropdown/types.js | 3 + .../lib/cjs/components/dropdown/types.js.map | 1 + .../flowbite/lib/cjs/components/index.d.ts | 2 + .../lib/cjs/components/index.d.ts.map | 1 + .../flowbite/lib/cjs/components/index.js | 32 + .../flowbite/lib/cjs/components/index.js.map | 1 + .../lib/cjs/components/modal/index.d.ts | 26 + .../lib/cjs/components/modal/index.d.ts.map | 1 + .../lib/cjs/components/modal/index.js | 274 + .../lib/cjs/components/modal/index.js.map | 1 + .../lib/cjs/components/modal/interface.d.ts | 21 + .../cjs/components/modal/interface.d.ts.map | 1 + .../lib/cjs/components/modal/interface.js | 3 + .../lib/cjs/components/modal/interface.js.map | 1 + .../lib/cjs/components/modal/types.d.ts | 17 + .../lib/cjs/components/modal/types.d.ts.map | 1 + .../lib/cjs/components/modal/types.js | 3 + .../lib/cjs/components/modal/types.js.map | 1 + .../lib/cjs/components/popover/index.d.ts | 32 + .../lib/cjs/components/popover/index.d.ts.map | 1 + .../lib/cjs/components/popover/index.js | 222 + .../lib/cjs/components/popover/index.js.map | 1 + .../lib/cjs/components/popover/interface.d.ts | 22 + .../cjs/components/popover/interface.d.ts.map | 1 + .../lib/cjs/components/popover/interface.js | 3 + .../cjs/components/popover/interface.js.map | 1 + .../lib/cjs/components/popover/types.d.ts | 16 + .../lib/cjs/components/popover/types.d.ts.map | 1 + .../lib/cjs/components/popover/types.js | 3 + .../lib/cjs/components/popover/types.js.map | 1 + .../lib/cjs/components/tabs/index.d.ts | 16 + .../lib/cjs/components/tabs/index.d.ts.map | 1 + .../flowbite/lib/cjs/components/tabs/index.js | 115 + .../lib/cjs/components/tabs/index.js.map | 1 + .../lib/cjs/components/tabs/interface.d.ts | 12 + .../cjs/components/tabs/interface.d.ts.map | 1 + .../lib/cjs/components/tabs/interface.js | 3 + .../lib/cjs/components/tabs/interface.js.map | 1 + .../lib/cjs/components/tabs/types.d.ts | 13 + .../lib/cjs/components/tabs/types.d.ts.map | 1 + .../flowbite/lib/cjs/components/tabs/types.js | 3 + .../lib/cjs/components/tabs/types.js.map | 1 + .../lib/cjs/components/tooltip/index.d.ts | 32 + .../lib/cjs/components/tooltip/index.d.ts.map | 1 + .../lib/cjs/components/tooltip/index.js | 204 + .../lib/cjs/components/tooltip/index.js.map | 1 + .../lib/cjs/components/tooltip/interface.d.ts | 23 + .../cjs/components/tooltip/interface.d.ts.map | 1 + .../lib/cjs/components/tooltip/interface.js | 3 + .../cjs/components/tooltip/interface.js.map | 1 + .../lib/cjs/components/tooltip/types.d.ts | 15 + .../lib/cjs/components/tooltip/types.d.ts.map | 1 + .../lib/cjs/components/tooltip/types.js | 3 + .../lib/cjs/components/tooltip/types.js.map | 1 + .../flowbite/lib/cjs/config/global.d.ts | 39 + .../flowbite/lib/cjs/config/global.d.ts.map | 1 + .../flowbite/lib/cjs/config/global.js | 3 + .../flowbite/lib/cjs/config/global.js.map | 1 + node_modules/flowbite/lib/cjs/dom/events.d.ts | 8 + .../flowbite/lib/cjs/dom/events.d.ts.map | 1 + node_modules/flowbite/lib/cjs/dom/events.js | 20 + .../flowbite/lib/cjs/dom/events.js.map | 1 + node_modules/flowbite/lib/cjs/index.d.ts | 47 + node_modules/flowbite/lib/cjs/index.d.ts.map | 1 + node_modules/flowbite/lib/cjs/index.js | 119 + node_modules/flowbite/lib/cjs/index.js.map | 1 + .../flowbite/lib/cjs/index.phoenix.d.ts | 29 + .../flowbite/lib/cjs/index.phoenix.d.ts.map | 1 + .../flowbite/lib/cjs/index.phoenix.js | 59 + .../flowbite/lib/cjs/index.phoenix.js.map | 1 + .../flowbite/lib/cjs/index.turbo.d.ts | 29 + .../flowbite/lib/cjs/index.turbo.d.ts.map | 1 + node_modules/flowbite/lib/cjs/index.turbo.js | 59 + .../flowbite/lib/cjs/index.turbo.js.map | 1 + node_modules/flowbite/lib/cjs/index.umd.d.ts | 30 + .../flowbite/lib/cjs/index.umd.d.ts.map | 1 + node_modules/flowbite/lib/cjs/index.umd.js | 46 + .../flowbite/lib/cjs/index.umd.js.map | 1 + .../lib/esm/components/accordion/index.d.ts | 15 + .../esm/components/accordion/index.d.ts.map | 1 + .../lib/esm/components/accordion/index.js | 147 + .../lib/esm/components/accordion/index.js.map | 1 + .../esm/components/accordion/interface.d.ts | 10 + .../components/accordion/interface.d.ts.map | 1 + .../lib/esm/components/accordion/interface.js | 2 + .../esm/components/accordion/interface.js.map | 1 + .../lib/esm/components/accordion/types.d.ts | 17 + .../esm/components/accordion/types.d.ts.map | 1 + .../lib/esm/components/accordion/types.js | 2 + .../lib/esm/components/accordion/types.js.map | 1 + .../lib/esm/components/carousel/index.d.ts | 54 + .../esm/components/carousel/index.d.ts.map | 1 + .../lib/esm/components/carousel/index.js | 242 + .../lib/esm/components/carousel/index.js.map | 1 + .../esm/components/carousel/interface.d.ts | 20 + .../components/carousel/interface.d.ts.map | 1 + .../lib/esm/components/carousel/interface.js | 2 + .../esm/components/carousel/interface.js.map | 1 + .../lib/esm/components/carousel/types.d.ts | 27 + .../esm/components/carousel/types.d.ts.map | 1 + .../lib/esm/components/carousel/types.js | 2 + .../lib/esm/components/carousel/types.js.map | 1 + .../lib/esm/components/collapse/index.d.ts | 16 + .../esm/components/collapse/index.d.ts.map | 1 + .../lib/esm/components/collapse/index.js | 94 + .../lib/esm/components/collapse/index.js.map | 1 + .../esm/components/collapse/interface.d.ts | 12 + .../components/collapse/interface.d.ts.map | 1 + .../lib/esm/components/collapse/interface.js | 2 + .../esm/components/collapse/interface.js.map | 1 + .../lib/esm/components/collapse/types.d.ts | 7 + .../esm/components/collapse/types.d.ts.map | 1 + .../lib/esm/components/collapse/types.js | 2 + .../lib/esm/components/collapse/types.js.map | 1 + .../lib/esm/components/dial/index.d.ts | 23 + .../lib/esm/components/dial/index.d.ts.map | 1 + .../flowbite/lib/esm/components/dial/index.js | 138 + .../lib/esm/components/dial/index.js.map | 1 + .../lib/esm/components/dial/interface.d.ts | 16 + .../esm/components/dial/interface.d.ts.map | 1 + .../lib/esm/components/dial/interface.js | 2 + .../lib/esm/components/dial/interface.js.map | 1 + .../lib/esm/components/dial/types.d.ts | 13 + .../lib/esm/components/dial/types.d.ts.map | 1 + .../flowbite/lib/esm/components/dial/types.js | 2 + .../lib/esm/components/dial/types.js.map | 1 + .../lib/esm/components/dismiss/index.d.ts | 13 + .../lib/esm/components/dismiss/index.d.ts.map | 1 + .../lib/esm/components/dismiss/index.js | 64 + .../lib/esm/components/dismiss/index.js.map | 1 + .../lib/esm/components/dismiss/interface.d.ts | 9 + .../esm/components/dismiss/interface.d.ts.map | 1 + .../lib/esm/components/dismiss/interface.js | 2 + .../esm/components/dismiss/interface.js.map | 1 + .../lib/esm/components/dismiss/types.d.ts | 8 + .../lib/esm/components/dismiss/types.d.ts.map | 1 + .../lib/esm/components/dismiss/types.js | 2 + .../lib/esm/components/dismiss/types.js.map | 1 + .../lib/esm/components/drawer/index.d.ts | 21 + .../lib/esm/components/drawer/index.d.ts.map | 1 + .../lib/esm/components/drawer/index.js | 310 + .../lib/esm/components/drawer/index.js.map | 1 + .../lib/esm/components/drawer/interface.d.ts | 17 + .../esm/components/drawer/interface.d.ts.map | 1 + .../lib/esm/components/drawer/interface.js | 2 + .../esm/components/drawer/interface.js.map | 1 + .../lib/esm/components/drawer/types.d.ts | 22 + .../lib/esm/components/drawer/types.d.ts.map | 1 + .../lib/esm/components/drawer/types.js | 2 + .../lib/esm/components/drawer/types.js.map | 1 + .../lib/esm/components/dropdown/index.d.ts | 29 + .../esm/components/dropdown/index.d.ts.map | 1 + .../lib/esm/components/dropdown/index.js | 250 + .../lib/esm/components/dropdown/index.js.map | 1 + .../esm/components/dropdown/interface.d.ts | 22 + .../components/dropdown/interface.d.ts.map | 1 + .../lib/esm/components/dropdown/interface.js | 2 + .../esm/components/dropdown/interface.js.map | 1 + .../lib/esm/components/dropdown/types.d.ts | 19 + .../esm/components/dropdown/types.d.ts.map | 1 + .../lib/esm/components/dropdown/types.js | 2 + .../lib/esm/components/dropdown/types.js.map | 1 + .../flowbite/lib/esm/components/index.d.ts | 2 + .../lib/esm/components/index.d.ts.map | 1 + .../flowbite/lib/esm/components/index.js | 28 + .../flowbite/lib/esm/components/index.js.map | 1 + .../lib/esm/components/modal/index.d.ts | 26 + .../lib/esm/components/modal/index.d.ts.map | 1 + .../lib/esm/components/modal/index.js | 270 + .../lib/esm/components/modal/index.js.map | 1 + .../lib/esm/components/modal/interface.d.ts | 21 + .../esm/components/modal/interface.d.ts.map | 1 + .../lib/esm/components/modal/interface.js | 2 + .../lib/esm/components/modal/interface.js.map | 1 + .../lib/esm/components/modal/types.d.ts | 17 + .../lib/esm/components/modal/types.d.ts.map | 1 + .../lib/esm/components/modal/types.js | 2 + .../lib/esm/components/modal/types.js.map | 1 + .../lib/esm/components/popover/index.d.ts | 32 + .../lib/esm/components/popover/index.d.ts.map | 1 + .../lib/esm/components/popover/index.js | 218 + .../lib/esm/components/popover/index.js.map | 1 + .../lib/esm/components/popover/interface.d.ts | 22 + .../esm/components/popover/interface.d.ts.map | 1 + .../lib/esm/components/popover/interface.js | 2 + .../esm/components/popover/interface.js.map | 1 + .../lib/esm/components/popover/types.d.ts | 16 + .../lib/esm/components/popover/types.d.ts.map | 1 + .../lib/esm/components/popover/types.js | 2 + .../lib/esm/components/popover/types.js.map | 1 + .../lib/esm/components/tabs/index.d.ts | 16 + .../lib/esm/components/tabs/index.d.ts.map | 1 + .../flowbite/lib/esm/components/tabs/index.js | 111 + .../lib/esm/components/tabs/index.js.map | 1 + .../lib/esm/components/tabs/interface.d.ts | 12 + .../esm/components/tabs/interface.d.ts.map | 1 + .../lib/esm/components/tabs/interface.js | 2 + .../lib/esm/components/tabs/interface.js.map | 1 + .../lib/esm/components/tabs/types.d.ts | 13 + .../lib/esm/components/tabs/types.d.ts.map | 1 + .../flowbite/lib/esm/components/tabs/types.js | 2 + .../lib/esm/components/tabs/types.js.map | 1 + .../lib/esm/components/tooltip/index.d.ts | 32 + .../lib/esm/components/tooltip/index.d.ts.map | 1 + .../lib/esm/components/tooltip/index.js | 200 + .../lib/esm/components/tooltip/index.js.map | 1 + .../lib/esm/components/tooltip/interface.d.ts | 23 + .../esm/components/tooltip/interface.d.ts.map | 1 + .../lib/esm/components/tooltip/interface.js | 2 + .../esm/components/tooltip/interface.js.map | 1 + .../lib/esm/components/tooltip/types.d.ts | 15 + .../lib/esm/components/tooltip/types.d.ts.map | 1 + .../lib/esm/components/tooltip/types.js | 2 + .../lib/esm/components/tooltip/types.js.map | 1 + .../flowbite/lib/esm/config/global.d.ts | 39 + .../flowbite/lib/esm/config/global.d.ts.map | 1 + .../flowbite/lib/esm/config/global.js | 2 + .../flowbite/lib/esm/config/global.js.map | 1 + node_modules/flowbite/lib/esm/dom/events.d.ts | 8 + .../flowbite/lib/esm/dom/events.d.ts.map | 1 + node_modules/flowbite/lib/esm/dom/events.js | 18 + .../flowbite/lib/esm/dom/events.js.map | 1 + node_modules/flowbite/lib/esm/index.d.ts | 47 + node_modules/flowbite/lib/esm/index.d.ts.map | 1 + node_modules/flowbite/lib/esm/index.js | 79 + node_modules/flowbite/lib/esm/index.js.map | 1 + .../flowbite/lib/esm/index.phoenix.d.ts | 29 + .../flowbite/lib/esm/index.phoenix.d.ts.map | 1 + .../flowbite/lib/esm/index.phoenix.js | 57 + .../flowbite/lib/esm/index.phoenix.js.map | 1 + .../flowbite/lib/esm/index.turbo.d.ts | 29 + .../flowbite/lib/esm/index.turbo.d.ts.map | 1 + node_modules/flowbite/lib/esm/index.turbo.js | 57 + .../flowbite/lib/esm/index.turbo.js.map | 1 + node_modules/flowbite/lib/esm/index.umd.d.ts | 30 + .../flowbite/lib/esm/index.umd.d.ts.map | 1 + node_modules/flowbite/lib/esm/index.umd.js | 44 + .../flowbite/lib/esm/index.umd.js.map | 1 + node_modules/flowbite/package.json | 121 + node_modules/flowbite/plugin-windicss.js | 588 + node_modules/flowbite/plugin.d.ts | 2 + node_modules/flowbite/plugin.js | 970 + node_modules/fsevents/LICENSE | 22 + node_modules/fsevents/README.md | 83 + node_modules/fsevents/fsevents.d.ts | 46 + node_modules/fsevents/fsevents.js | 82 + node_modules/fsevents/fsevents.node | Bin 0 -> 147128 bytes node_modules/fsevents/package.json | 62 + node_modules/function-bind/.editorconfig | 20 + node_modules/function-bind/.eslintrc | 15 + node_modules/function-bind/.jscs.json | 176 + node_modules/function-bind/.npmignore | 22 + node_modules/function-bind/.travis.yml | 168 + node_modules/function-bind/LICENSE | 20 + node_modules/function-bind/README.md | 48 + node_modules/function-bind/implementation.js | 52 + node_modules/function-bind/index.js | 5 + node_modules/function-bind/package.json | 63 + node_modules/function-bind/test/.eslintrc | 9 + node_modules/function-bind/test/index.js | 252 + node_modules/glob-parent/LICENSE | 15 + node_modules/glob-parent/README.md | 134 + node_modules/glob-parent/index.js | 75 + node_modules/glob-parent/package.json | 54 + node_modules/has/.DS_Store | Bin 0 -> 6148 bytes node_modules/has/LICENSE-MIT | 22 + node_modules/has/README.md | 18 + node_modules/has/package.json | 48 + node_modules/has/src/index.js | 5 + node_modules/has/test/index.js | 10 + node_modules/is-binary-path/index.d.ts | 17 + node_modules/is-binary-path/index.js | 7 + node_modules/is-binary-path/license | 9 + node_modules/is-binary-path/package.json | 40 + node_modules/is-binary-path/readme.md | 34 + node_modules/is-core-module/.eslintrc | 18 + node_modules/is-core-module/.nycrc | 9 + node_modules/is-core-module/CHANGELOG.md | 136 + node_modules/is-core-module/LICENSE | 20 + node_modules/is-core-module/README.md | 40 + node_modules/is-core-module/core.json | 153 + node_modules/is-core-module/index.js | 69 + node_modules/is-core-module/package.json | 65 + node_modules/is-core-module/test/index.js | 133 + node_modules/is-extglob/LICENSE | 21 + node_modules/is-extglob/README.md | 107 + node_modules/is-extglob/index.js | 20 + node_modules/is-extglob/package.json | 69 + node_modules/is-glob/LICENSE | 21 + node_modules/is-glob/README.md | 206 + node_modules/is-glob/index.js | 150 + node_modules/is-glob/package.json | 81 + node_modules/is-number/LICENSE | 21 + node_modules/is-number/README.md | 187 + node_modules/is-number/index.js | 18 + node_modules/is-number/package.json | 82 + node_modules/lilconfig/dist/index.d.ts | 38 + node_modules/lilconfig/dist/index.js | 247 + node_modules/lilconfig/package.json | 48 + node_modules/lilconfig/readme.md | 118 + node_modules/merge2/LICENSE | 21 + node_modules/merge2/README.md | 144 + node_modules/merge2/index.js | 144 + node_modules/merge2/package.json | 43 + node_modules/micromatch/LICENSE | 21 + node_modules/micromatch/README.md | 1011 + node_modules/micromatch/index.js | 467 + node_modules/micromatch/package.json | 119 + node_modules/mini-svg-data-uri/LICENSE | 21 + node_modules/mini-svg-data-uri/README.md | 109 + node_modules/mini-svg-data-uri/cli.js | 41 + node_modules/mini-svg-data-uri/index.d.ts | 7 + node_modules/mini-svg-data-uri/index.js | 55 + .../mini-svg-data-uri/index.test-d.ts | 5 + node_modules/mini-svg-data-uri/package.json | 26 + .../shorter-css-color-names.js | 56 + node_modules/minimist/.DS_Store | Bin 0 -> 6148 bytes node_modules/minimist/.travis.yml | 8 + node_modules/minimist/LICENSE | 18 + node_modules/minimist/example/parse.js | 2 + node_modules/minimist/index.js | 249 + node_modules/minimist/package.json | 45 + node_modules/minimist/readme.markdown | 98 + node_modules/minimist/test/all_bool.js | 32 + node_modules/minimist/test/bool.js | 178 + node_modules/minimist/test/dash.js | 31 + node_modules/minimist/test/default_bool.js | 35 + node_modules/minimist/test/dotted.js | 22 + node_modules/minimist/test/kv_short.js | 16 + node_modules/minimist/test/long.js | 31 + node_modules/minimist/test/num.js | 36 + node_modules/minimist/test/parse.js | 197 + node_modules/minimist/test/parse_modified.js | 9 + node_modules/minimist/test/proto.js | 60 + node_modules/minimist/test/short.js | 67 + node_modules/minimist/test/stop_early.js | 15 + node_modules/minimist/test/unknown.js | 102 + node_modules/minimist/test/whitespace.js | 8 + node_modules/nanoid/.DS_Store | Bin 0 -> 6148 bytes node_modules/nanoid/LICENSE | 20 + node_modules/nanoid/README.md | 39 + node_modules/nanoid/async/index.browser.cjs | 34 + node_modules/nanoid/async/index.browser.js | 34 + node_modules/nanoid/async/index.cjs | 35 + node_modules/nanoid/async/index.d.ts | 56 + node_modules/nanoid/async/index.js | 35 + node_modules/nanoid/async/index.native.js | 26 + node_modules/nanoid/async/package.json | 12 + node_modules/nanoid/bin/nanoid.cjs | 55 + node_modules/nanoid/index.browser.cjs | 34 + node_modules/nanoid/index.browser.js | 34 + node_modules/nanoid/index.cjs | 45 + node_modules/nanoid/index.d.cts | 91 + node_modules/nanoid/index.d.ts | 91 + node_modules/nanoid/index.js | 45 + node_modules/nanoid/nanoid.js | 1 + node_modules/nanoid/non-secure/index.cjs | 21 + node_modules/nanoid/non-secure/index.d.ts | 33 + node_modules/nanoid/non-secure/index.js | 21 + node_modules/nanoid/non-secure/package.json | 6 + node_modules/nanoid/package.json | 88 + node_modules/nanoid/url-alphabet/index.cjs | 3 + node_modules/nanoid/url-alphabet/index.js | 3 + node_modules/nanoid/url-alphabet/package.json | 6 + node_modules/normalize-path/LICENSE | 21 + node_modules/normalize-path/README.md | 127 + node_modules/normalize-path/index.js | 35 + node_modules/normalize-path/package.json | 77 + node_modules/object-hash/LICENSE | 22 + node_modules/object-hash/dist/object_hash.js | 1 + node_modules/object-hash/index.js | 453 + node_modules/object-hash/package.json | 53 + node_modules/object-hash/readme.markdown | 198 + node_modules/path-parse/LICENSE | 21 + node_modules/path-parse/README.md | 42 + node_modules/path-parse/index.js | 75 + node_modules/path-parse/package.json | 33 + node_modules/picocolors/LICENSE | 15 + node_modules/picocolors/README.md | 21 + node_modules/picocolors/package.json | 25 + node_modules/picocolors/picocolors.browser.js | 4 + node_modules/picocolors/picocolors.d.ts | 5 + node_modules/picocolors/picocolors.js | 58 + node_modules/picocolors/types.ts | 30 + node_modules/picomatch/CHANGELOG.md | 136 + node_modules/picomatch/LICENSE | 21 + node_modules/picomatch/README.md | 708 + node_modules/picomatch/index.js | 3 + node_modules/picomatch/lib/constants.js | 179 + node_modules/picomatch/lib/parse.js | 1091 + node_modules/picomatch/lib/picomatch.js | 342 + node_modules/picomatch/lib/scan.js | 391 + node_modules/picomatch/lib/utils.js | 64 + node_modules/picomatch/package.json | 81 + node_modules/pify/index.js | 68 + node_modules/pify/license | 21 + node_modules/pify/package.json | 48 + node_modules/pify/readme.md | 119 + node_modules/postcss-import/LICENSE | 20 + node_modules/postcss-import/README.md | 227 + node_modules/postcss-import/index.js | 344 + node_modules/postcss-import/lib/join-layer.js | 9 + node_modules/postcss-import/lib/join-media.js | 17 + .../postcss-import/lib/load-content.js | 5 + .../postcss-import/lib/parse-statements.js | 172 + .../postcss-import/lib/process-content.js | 59 + node_modules/postcss-import/lib/resolve-id.js | 42 + node_modules/postcss-import/package.json | 65 + node_modules/postcss-js/LICENSE | 20 + node_modules/postcss-js/README.md | 22 + node_modules/postcss-js/async.js | 15 + node_modules/postcss-js/index.js | 11 + node_modules/postcss-js/index.mjs | 8 + node_modules/postcss-js/objectifier.js | 83 + node_modules/postcss-js/package.json | 42 + node_modules/postcss-js/parser.js | 104 + node_modules/postcss-js/process-result.js | 11 + node_modules/postcss-js/sync.js | 12 + node_modules/postcss-load-config/LICENSE | 20 + node_modules/postcss-load-config/README.md | 500 + node_modules/postcss-load-config/package.json | 48 + .../postcss-load-config/src/index.d.ts | 71 + node_modules/postcss-load-config/src/index.js | 188 + .../postcss-load-config/src/options.js | 47 + .../postcss-load-config/src/plugins.js | 85 + node_modules/postcss-load-config/src/req.js | 10 + node_modules/postcss-nested/LICENSE | 20 + node_modules/postcss-nested/README.md | 198 + node_modules/postcss-nested/index.d.ts | 34 + node_modules/postcss-nested/index.js | 214 + node_modules/postcss-nested/package.json | 28 + node_modules/postcss-selector-parser/API.md | 873 + .../postcss-selector-parser/CHANGELOG.md | 513 + .../postcss-selector-parser/LICENSE-MIT | 22 + .../postcss-selector-parser/README.md | 49 + .../postcss-selector-parser/dist/index.js | 24 + .../postcss-selector-parser/dist/parser.js | 1243 + .../postcss-selector-parser/dist/processor.js | 206 + .../dist/selectors/attribute.js | 515 + .../dist/selectors/className.js | 69 + .../dist/selectors/combinator.js | 31 + .../dist/selectors/comment.js | 31 + .../dist/selectors/constructors.js | 102 + .../dist/selectors/container.js | 395 + .../dist/selectors/guards.js | 64 + .../dist/selectors/id.js | 37 + .../dist/selectors/index.js | 27 + .../dist/selectors/namespace.js | 101 + .../dist/selectors/nesting.js | 32 + .../dist/selectors/node.js | 239 + .../dist/selectors/pseudo.js | 38 + .../dist/selectors/root.js | 60 + .../dist/selectors/selector.js | 31 + .../dist/selectors/string.js | 31 + .../dist/selectors/tag.js | 31 + .../dist/selectors/types.js | 28 + .../dist/selectors/universal.js | 32 + .../dist/sortAscending.js | 13 + .../dist/tokenTypes.js | 95 + .../postcss-selector-parser/dist/tokenize.js | 271 + .../dist/util/ensureObject.js | 22 + .../dist/util/getProp.js | 24 + .../dist/util/index.js | 22 + .../dist/util/stripComments.js | 27 + .../dist/util/unesc.js | 93 + .../postcss-selector-parser/package.json | 78 + .../postcss-selector-parser.d.ts | 555 + node_modules/postcss-value-parser/LICENSE | 22 + node_modules/postcss-value-parser/README.md | 263 + .../postcss-value-parser/lib/index.d.ts | 177 + .../postcss-value-parser/lib/index.js | 28 + .../postcss-value-parser/lib/parse.js | 321 + .../postcss-value-parser/lib/stringify.js | 48 + node_modules/postcss-value-parser/lib/unit.js | 120 + node_modules/postcss-value-parser/lib/walk.js | 22 + .../postcss-value-parser/package.json | 58 + node_modules/postcss/LICENSE | 20 + node_modules/postcss/README.md | 28 + node_modules/postcss/lib/at-rule.d.ts | 137 + node_modules/postcss/lib/at-rule.js | 25 + node_modules/postcss/lib/comment.d.ts | 67 + node_modules/postcss/lib/comment.js | 13 + node_modules/postcss/lib/container.d.ts | 490 + node_modules/postcss/lib/container.js | 441 + .../postcss/lib/css-syntax-error.d.ts | 248 + node_modules/postcss/lib/css-syntax-error.js | 100 + node_modules/postcss/lib/declaration.d.ts | 148 + node_modules/postcss/lib/declaration.js | 24 + node_modules/postcss/lib/document.d.ts | 69 + node_modules/postcss/lib/document.js | 33 + node_modules/postcss/lib/fromJSON.d.ts | 9 + node_modules/postcss/lib/fromJSON.js | 54 + node_modules/postcss/lib/input.d.ts | 194 + node_modules/postcss/lib/input.js | 248 + node_modules/postcss/lib/lazy-result.d.ts | 190 + node_modules/postcss/lib/lazy-result.js | 550 + node_modules/postcss/lib/list.d.ts | 57 + node_modules/postcss/lib/list.js | 58 + node_modules/postcss/lib/map-generator.js | 368 + node_modules/postcss/lib/no-work-result.d.ts | 46 + node_modules/postcss/lib/no-work-result.js | 138 + node_modules/postcss/lib/node.d.ts | 536 + node_modules/postcss/lib/node.js | 381 + node_modules/postcss/lib/parse.d.ts | 9 + node_modules/postcss/lib/parse.js | 42 + node_modules/postcss/lib/parser.js | 609 + node_modules/postcss/lib/postcss.d.mts | 72 + node_modules/postcss/lib/postcss.d.ts | 441 + node_modules/postcss/lib/postcss.js | 101 + node_modules/postcss/lib/postcss.mjs | 30 + node_modules/postcss/lib/previous-map.d.ts | 81 + node_modules/postcss/lib/previous-map.js | 142 + node_modules/postcss/lib/processor.d.ts | 115 + node_modules/postcss/lib/processor.js | 67 + node_modules/postcss/lib/result.d.ts | 206 + node_modules/postcss/lib/result.js | 42 + node_modules/postcss/lib/root.d.ts | 87 + node_modules/postcss/lib/root.js | 61 + node_modules/postcss/lib/rule.d.ts | 117 + node_modules/postcss/lib/rule.js | 27 + node_modules/postcss/lib/stringifier.d.ts | 46 + node_modules/postcss/lib/stringifier.js | 353 + node_modules/postcss/lib/stringify.d.ts | 9 + node_modules/postcss/lib/stringify.js | 11 + node_modules/postcss/lib/symbols.js | 5 + .../postcss/lib/terminal-highlight.js | 70 + node_modules/postcss/lib/tokenize.js | 266 + node_modules/postcss/lib/warn-once.js | 13 + node_modules/postcss/lib/warning.d.ts | 147 + node_modules/postcss/lib/warning.js | 37 + node_modules/postcss/package.json | 88 + node_modules/queue-microtask/LICENSE | 20 + node_modules/queue-microtask/README.md | 90 + node_modules/queue-microtask/index.d.ts | 2 + node_modules/queue-microtask/index.js | 9 + node_modules/queue-microtask/package.json | 55 + node_modules/quick-lru/index.d.ts | 97 + node_modules/quick-lru/index.js | 123 + node_modules/quick-lru/license | 9 + node_modules/quick-lru/package.json | 43 + node_modules/quick-lru/readme.md | 111 + node_modules/read-cache/LICENSE | 20 + node_modules/read-cache/README.md | 46 + node_modules/read-cache/index.js | 78 + node_modules/read-cache/package.json | 34 + node_modules/readdirp/LICENSE | 21 + node_modules/readdirp/README.md | 122 + node_modules/readdirp/index.d.ts | 43 + node_modules/readdirp/index.js | 287 + node_modules/readdirp/package.json | 122 + node_modules/resolve/.DS_Store | Bin 0 -> 6148 bytes node_modules/resolve/.editorconfig | 37 + node_modules/resolve/.eslintrc | 65 + node_modules/resolve/.github/FUNDING.yml | 12 + node_modules/resolve/LICENSE | 21 + node_modules/resolve/SECURITY.md | 3 + node_modules/resolve/async.js | 3 + node_modules/resolve/bin/resolve | 50 + node_modules/resolve/example/async.js | 5 + node_modules/resolve/example/sync.js | 3 + node_modules/resolve/index.js | 6 + node_modules/resolve/lib/async.js | 329 + node_modules/resolve/lib/caller.js | 8 + node_modules/resolve/lib/core.js | 52 + node_modules/resolve/lib/core.json | 153 + node_modules/resolve/lib/homedir.js | 24 + node_modules/resolve/lib/is-core.js | 5 + .../resolve/lib/node-modules-paths.js | 42 + node_modules/resolve/lib/normalize-options.js | 10 + node_modules/resolve/lib/sync.js | 208 + node_modules/resolve/package.json | 71 + node_modules/resolve/readme.markdown | 301 + node_modules/resolve/sync.js | 3 + node_modules/resolve/test/core.js | 88 + node_modules/resolve/test/dotdot.js | 29 + node_modules/resolve/test/dotdot/abc/index.js | 2 + node_modules/resolve/test/dotdot/index.js | 1 + node_modules/resolve/test/faulty_basedir.js | 29 + node_modules/resolve/test/filter.js | 34 + node_modules/resolve/test/filter_sync.js | 33 + node_modules/resolve/test/home_paths.js | 127 + node_modules/resolve/test/home_paths_sync.js | 114 + node_modules/resolve/test/mock.js | 315 + node_modules/resolve/test/mock_sync.js | 214 + node_modules/resolve/test/module_dir.js | 56 + .../test/module_dir/xmodules/aaa/index.js | 1 + .../test/module_dir/ymodules/aaa/index.js | 1 + .../test/module_dir/zmodules/bbb/main.js | 1 + .../test/module_dir/zmodules/bbb/package.json | 3 + .../resolve/test/node-modules-paths.js | 143 + node_modules/resolve/test/node_path.js | 70 + .../resolve/test/node_path/x/aaa/index.js | 1 + .../resolve/test/node_path/x/ccc/index.js | 1 + .../resolve/test/node_path/y/bbb/index.js | 1 + .../resolve/test/node_path/y/ccc/index.js | 1 + node_modules/resolve/test/nonstring.js | 9 + node_modules/resolve/test/pathfilter.js | 75 + .../resolve/test/pathfilter/deep_ref/main.js | 0 node_modules/resolve/test/precedence.js | 23 + node_modules/resolve/test/precedence/aaa.js | 1 + .../resolve/test/precedence/aaa/index.js | 1 + .../resolve/test/precedence/aaa/main.js | 1 + node_modules/resolve/test/precedence/bbb.js | 1 + .../resolve/test/precedence/bbb/main.js | 1 + node_modules/resolve/test/resolver.js | 595 + .../resolve/test/resolver/baz/doom.js | 0 .../resolve/test/resolver/baz/package.json | 4 + .../resolve/test/resolver/baz/quux.js | 1 + .../resolve/test/resolver/browser_field/a.js | 0 .../resolve/test/resolver/browser_field/b.js | 0 .../test/resolver/browser_field/package.json | 5 + node_modules/resolve/test/resolver/cup.coffee | 1 + .../resolve/test/resolver/dot_main/index.js | 1 + .../test/resolver/dot_main/package.json | 3 + .../test/resolver/dot_slash_main/index.js | 1 + .../test/resolver/dot_slash_main/package.json | 3 + .../resolve/test/resolver/false_main/index.js | 0 .../test/resolver/false_main/package.json | 4 + node_modules/resolve/test/resolver/foo.js | 1 + .../test/resolver/incorrect_main/index.js | 2 + .../test/resolver/incorrect_main/package.json | 3 + .../test/resolver/invalid_main/package.json | 7 + .../resolver/malformed_package_json/index.js | 0 .../malformed_package_json/package.json | 1 + node_modules/resolve/test/resolver/mug.coffee | 0 node_modules/resolve/test/resolver/mug.js | 0 .../test/resolver/multirepo/lerna.json | 6 + .../test/resolver/multirepo/package.json | 20 + .../multirepo/packages/package-a/index.js | 35 + .../multirepo/packages/package-a/package.json | 14 + .../multirepo/packages/package-b/index.js | 0 .../multirepo/packages/package-b/package.json | 14 + .../resolver/nested_symlinks/mylib/async.js | 26 + .../nested_symlinks/mylib/package.json | 15 + .../resolver/nested_symlinks/mylib/sync.js | 12 + .../test/resolver/other_path/lib/other-lib.js | 0 .../resolve/test/resolver/other_path/root.js | 0 .../resolve/test/resolver/quux/foo/index.js | 1 + .../resolve/test/resolver/same_names/foo.js | 1 + .../test/resolver/same_names/foo/index.js | 1 + .../resolver/symlinked/_/node_modules/foo.js | 0 .../symlinked/_/symlink_target/.gitkeep | 0 .../test/resolver/symlinked/package/bar.js | 1 + .../resolver/symlinked/package/package.json | 3 + .../test/resolver/without_basedir/main.js | 5 + node_modules/resolve/test/resolver_sync.js | 726 + node_modules/resolve/test/shadowed_core.js | 54 + .../shadowed_core/node_modules/util/index.js | 0 node_modules/resolve/test/subdirs.js | 13 + node_modules/resolve/test/symlinks.js | 176 + node_modules/reusify/.coveralls.yml | 1 + node_modules/reusify/.travis.yml | 28 + node_modules/reusify/LICENSE | 22 + node_modules/reusify/README.md | 145 + .../benchmarks/createNoCodeFunction.js | 30 + node_modules/reusify/benchmarks/fib.js | 13 + .../reusify/benchmarks/reuseNoCodeFunction.js | 38 + node_modules/reusify/package.json | 45 + node_modules/reusify/reusify.js | 33 + node_modules/reusify/test.js | 66 + node_modules/run-parallel/LICENSE | 20 + node_modules/run-parallel/README.md | 85 + node_modules/run-parallel/index.js | 51 + node_modules/run-parallel/package.json | 58 + node_modules/source-map-js/LICENSE | 28 + node_modules/source-map-js/README.md | 765 + node_modules/source-map-js/lib/array-set.js | 121 + node_modules/source-map-js/lib/base64-vlq.js | 140 + node_modules/source-map-js/lib/base64.js | 67 + .../source-map-js/lib/binary-search.js | 111 + .../source-map-js/lib/mapping-list.js | 79 + node_modules/source-map-js/lib/quick-sort.js | 132 + .../source-map-js/lib/source-map-consumer.js | 1184 + .../source-map-js/lib/source-map-generator.js | 444 + node_modules/source-map-js/lib/source-node.js | 413 + node_modules/source-map-js/lib/util.js | 594 + node_modules/source-map-js/package.json | 71 + node_modules/source-map-js/source-map.d.ts | 115 + node_modules/source-map-js/source-map.js | 8 + .../supports-preserve-symlinks-flag/.DS_Store | Bin 0 -> 6148 bytes .../supports-preserve-symlinks-flag/.eslintrc | 14 + .../.github/FUNDING.yml | 12 + .../supports-preserve-symlinks-flag/.nycrc | 9 + .../CHANGELOG.md | 22 + .../supports-preserve-symlinks-flag/LICENSE | 21 + .../supports-preserve-symlinks-flag/README.md | 42 + .../browser.js | 3 + .../supports-preserve-symlinks-flag/index.js | 9 + .../package.json | 70 + .../test/index.js | 29 + node_modules/tailwindcss/.DS_Store | Bin 0 -> 6148 bytes node_modules/tailwindcss/CHANGELOG.md | 2187 + node_modules/tailwindcss/LICENSE | 21 + node_modules/tailwindcss/README.md | 37 + node_modules/tailwindcss/base.css | 1 + node_modules/tailwindcss/colors.d.ts | 3 + node_modules/tailwindcss/colors.js | 2 + node_modules/tailwindcss/components.css | 1 + node_modules/tailwindcss/defaultConfig.d.ts | 3 + node_modules/tailwindcss/defaultConfig.js | 2 + node_modules/tailwindcss/defaultTheme.d.ts | 3 + node_modules/tailwindcss/defaultTheme.js | 2 + .../tailwindcss/lib/cli-peer-dependencies.js | 20 + node_modules/tailwindcss/lib/cli.js | 805 + node_modules/tailwindcss/lib/constants.js | 37 + .../tailwindcss/lib/corePluginList.js | 179 + node_modules/tailwindcss/lib/corePlugins.js | 3659 + node_modules/tailwindcss/lib/css/LICENSE | 25 + .../tailwindcss/lib/css/preflight.css | 360 + node_modules/tailwindcss/lib/featureFlags.js | 61 + node_modules/tailwindcss/lib/index.js | 40 + .../tailwindcss/lib/lib/cacheInvalidation.js | 87 + .../lib/lib/collapseAdjacentRules.js | 56 + .../lib/lib/collapseDuplicateDeclarations.js | 80 + .../tailwindcss/lib/lib/defaultExtractor.js | 223 + .../tailwindcss/lib/lib/detectNesting.js | 34 + .../lib/lib/evaluateTailwindFunctions.js | 187 + .../tailwindcss/lib/lib/expandApplyAtRules.js | 470 + .../lib/lib/expandTailwindAtRules.js | 276 + .../tailwindcss/lib/lib/generateRules.js | 718 + .../lib/lib/getModuleDependencies.js | 48 + .../lib/lib/normalizeTailwindDirectives.js | 84 + .../lib/lib/partitionApplyAtRules.js | 53 + node_modules/tailwindcss/lib/lib/regex.js | 52 + .../lib/lib/resolveDefaultsAtRules.js | 154 + .../tailwindcss/lib/lib/setupContextUtils.js | 926 + .../lib/lib/setupTrackingContext.js | 169 + .../tailwindcss/lib/lib/sharedState.js | 51 + .../lib/lib/substituteScreenAtRules.js | 26 + .../lib/postcss-plugins/nesting/README.md | 42 + .../lib/postcss-plugins/nesting/index.js | 17 + .../lib/postcss-plugins/nesting/plugin.js | 84 + .../lib/processTailwindFeatures.js | 59 + node_modules/tailwindcss/lib/public/colors.js | 329 + .../tailwindcss/lib/public/create-plugin.js | 13 + .../tailwindcss/lib/public/default-config.js | 14 + .../tailwindcss/lib/public/default-theme.js | 14 + .../tailwindcss/lib/public/resolve-config.js | 19 + node_modules/tailwindcss/lib/util/bigSign.js | 8 + .../tailwindcss/lib/util/buildMediaQuery.js | 19 + .../tailwindcss/lib/util/cloneDeep.js | 17 + .../tailwindcss/lib/util/cloneNodes.js | 25 + node_modules/tailwindcss/lib/util/color.js | 90 + .../tailwindcss/lib/util/configurePlugins.js | 18 + .../tailwindcss/lib/util/createPlugin.js | 28 + .../lib/util/createUtilityPlugin.js | 48 + .../tailwindcss/lib/util/dataTypes.js | 235 + node_modules/tailwindcss/lib/util/defaults.js | 22 + .../tailwindcss/lib/util/escapeClassName.js | 19 + .../tailwindcss/lib/util/escapeCommas.js | 8 + .../lib/util/flattenColorPalette.js | 14 + .../lib/util/formatVariantSelector.js | 193 + .../tailwindcss/lib/util/getAllConfigs.js | 34 + .../tailwindcss/lib/util/hashConfig.js | 16 + .../tailwindcss/lib/util/isKeyframeRule.js | 8 + .../tailwindcss/lib/util/isPlainObject.js | 12 + .../lib/util/isValidArbitraryValue.js | 63 + node_modules/tailwindcss/lib/util/log.js | 50 + .../tailwindcss/lib/util/nameClass.js | 32 + .../tailwindcss/lib/util/negateValue.js | 18 + .../tailwindcss/lib/util/normalizeConfig.js | 250 + .../tailwindcss/lib/util/normalizeScreens.js | 58 + .../lib/util/parseAnimationValue.js | 88 + .../lib/util/parseBoxShadowValue.js | 76 + .../tailwindcss/lib/util/parseDependency.js | 63 + .../tailwindcss/lib/util/parseObjectStyles.js | 31 + .../tailwindcss/lib/util/pluginUtils.js | 187 + .../tailwindcss/lib/util/prefixSelector.js | 20 + .../lib/util/removeAlphaVariables.js | 18 + .../tailwindcss/lib/util/resolveConfig.js | 256 + .../tailwindcss/lib/util/resolveConfigPath.js | 51 + .../tailwindcss/lib/util/responsive.js | 19 + .../lib/util/splitAtTopLevelOnly.js | 90 + node_modules/tailwindcss/lib/util/tap.js | 9 + .../tailwindcss/lib/util/toColorValue.js | 8 + node_modules/tailwindcss/lib/util/toPath.js | 14 + .../lib/util/transformThemeValue.js | 61 + .../tailwindcss/lib/util/validateConfig.js | 21 + .../tailwindcss/lib/util/withAlphaVariable.js | 67 + node_modules/tailwindcss/nesting/index.js | 2 + node_modules/tailwindcss/package.json | 113 + node_modules/tailwindcss/peers/index.js | 77951 ++++++++++++++++ node_modules/tailwindcss/plugin.d.ts | 11 + node_modules/tailwindcss/plugin.js | 2 + node_modules/tailwindcss/prettier.config.js | 19 + node_modules/tailwindcss/resolveConfig.js | 2 + node_modules/tailwindcss/screens.css | 1 + .../tailwindcss/scripts/create-plugin-list.js | 10 + .../tailwindcss/scripts/generate-types.js | 52 + .../scripts/install-integrations.js | 27 + .../tailwindcss/scripts/rebuildFixtures.js | 68 + .../tailwindcss/src/cli-peer-dependencies.js | 15 + node_modules/tailwindcss/src/cli.js | 915 + node_modules/tailwindcss/src/constants.js | 17 + .../tailwindcss/src/corePluginList.js | 1 + node_modules/tailwindcss/src/corePlugins.js | 2441 + node_modules/tailwindcss/src/css/LICENSE | 25 + .../tailwindcss/src/css/preflight.css | 360 + node_modules/tailwindcss/src/featureFlags.js | 54 + node_modules/tailwindcss/src/index.js | 42 + .../tailwindcss/src/lib/cacheInvalidation.js | 52 + .../src/lib/collapseAdjacentRules.js | 58 + .../src/lib/collapseDuplicateDeclarations.js | 93 + .../tailwindcss/src/lib/defaultExtractor.js | 202 + .../tailwindcss/src/lib/detectNesting.js | 39 + .../src/lib/evaluateTailwindFunctions.js | 222 + .../tailwindcss/src/lib/expandApplyAtRules.js | 539 + .../src/lib/expandTailwindAtRules.js | 292 + .../tailwindcss/src/lib/generateRules.js | 714 + .../src/lib/getModuleDependencies.js | 39 + .../src/lib/normalizeTailwindDirectives.js | 84 + .../src/lib/partitionApplyAtRules.js | 52 + node_modules/tailwindcss/src/lib/regex.js | 74 + .../src/lib/resolveDefaultsAtRules.js | 163 + .../tailwindcss/src/lib/setupContextUtils.js | 966 + .../src/lib/setupTrackingContext.js | 187 + .../tailwindcss/src/lib/sharedState.js | 48 + .../src/lib/substituteScreenAtRules.js | 19 + .../src/postcss-plugins/nesting/README.md | 42 + .../src/postcss-plugins/nesting/index.js | 13 + .../src/postcss-plugins/nesting/plugin.js | 80 + .../src/processTailwindFeatures.js | 58 + node_modules/tailwindcss/src/public/colors.js | 300 + .../tailwindcss/src/public/create-plugin.js | 2 + .../tailwindcss/src/public/default-config.js | 4 + .../tailwindcss/src/public/default-theme.js | 4 + .../tailwindcss/src/public/resolve-config.js | 7 + node_modules/tailwindcss/src/util/bigSign.js | 3 + .../tailwindcss/src/util/buildMediaQuery.js | 20 + .../tailwindcss/src/util/cloneDeep.js | 11 + .../tailwindcss/src/util/cloneNodes.js | 24 + node_modules/tailwindcss/src/util/color.js | 73 + .../tailwindcss/src/util/configurePlugins.js | 23 + .../tailwindcss/src/util/createPlugin.js | 27 + .../src/util/createUtilityPlugin.js | 37 + .../tailwindcss/src/util/dataTypes.js | 254 + node_modules/tailwindcss/src/util/defaults.js | 17 + .../tailwindcss/src/util/escapeClassName.js | 8 + .../tailwindcss/src/util/escapeCommas.js | 3 + .../src/util/flattenColorPalette.js | 13 + .../src/util/formatVariantSelector.js | 213 + .../tailwindcss/src/util/getAllConfigs.js | 26 + .../tailwindcss/src/util/hashConfig.js | 5 + .../tailwindcss/src/util/isKeyframeRule.js | 3 + .../tailwindcss/src/util/isPlainObject.js | 8 + .../src/util/isValidArbitraryValue.js | 61 + node_modules/tailwindcss/src/util/log.js | 29 + .../tailwindcss/src/util/nameClass.js | 26 + .../tailwindcss/src/util/negateValue.js | 16 + .../tailwindcss/src/util/normalizeConfig.js | 262 + .../tailwindcss/src/util/normalizeScreens.js | 45 + .../src/util/parseAnimationValue.js | 68 + .../src/util/parseBoxShadowValue.js | 72 + .../tailwindcss/src/util/parseDependency.js | 49 + .../tailwindcss/src/util/parseObjectStyles.js | 19 + .../tailwindcss/src/util/pluginUtils.js | 204 + .../tailwindcss/src/util/prefixSelector.js | 14 + .../src/util/removeAlphaVariables.js | 24 + .../tailwindcss/src/util/resolveConfig.js | 283 + .../tailwindcss/src/util/resolveConfigPath.js | 55 + .../tailwindcss/src/util/responsive.js | 10 + .../src/util/splitAtTopLevelOnly.js | 71 + node_modules/tailwindcss/src/util/tap.js | 4 + .../tailwindcss/src/util/toColorValue.js | 3 + node_modules/tailwindcss/src/util/toPath.js | 26 + .../src/util/transformThemeValue.js | 54 + .../tailwindcss/src/util/validateConfig.js | 13 + .../tailwindcss/src/util/withAlphaVariable.js | 49 + .../tailwindcss/stubs/defaultConfig.stub.js | 954 + .../stubs/defaultPostCssConfig.stub.js | 6 + .../tailwindcss/stubs/simpleConfig.stub.js | 8 + node_modules/tailwindcss/tailwind.css | 5 + node_modules/tailwindcss/types/config.d.ts | 325 + .../tailwindcss/types/generated/.gitkeep | 0 .../tailwindcss/types/generated/colors.d.ts | 276 + .../types/generated/corePluginList.d.ts | 1 + node_modules/tailwindcss/types/index.d.ts | 7 + node_modules/tailwindcss/utilities.css | 1 + node_modules/tailwindcss/variants.css | 1 + node_modules/to-regex-range/LICENSE | 21 + node_modules/to-regex-range/README.md | 305 + node_modules/to-regex-range/index.js | 288 + node_modules/to-regex-range/package.json | 88 + node_modules/util-deprecate/History.md | 16 + node_modules/util-deprecate/LICENSE | 24 + node_modules/util-deprecate/README.md | 53 + node_modules/util-deprecate/browser.js | 67 + node_modules/util-deprecate/node.js | 6 + node_modules/util-deprecate/package.json | 27 + node_modules/xtend/.jshintrc | 30 + node_modules/xtend/LICENSE | 20 + node_modules/xtend/README.md | 32 + node_modules/xtend/immutable.js | 19 + node_modules/xtend/mutable.js | 17 + node_modules/xtend/package.json | 55 + node_modules/xtend/test.js | 103 + node_modules/yaml/.DS_Store | Bin 0 -> 6148 bytes node_modules/yaml/LICENSE | 13 + node_modules/yaml/README.md | 127 + .../yaml/browser/dist/PlainValue-b8036b75.js | 1275 + .../yaml/browser/dist/Schema-e94716c8.js | 682 + node_modules/yaml/browser/dist/index.js | 1002 + .../yaml/browser/dist/legacy-exports.js | 3 + node_modules/yaml/browser/dist/package.json | 1 + node_modules/yaml/browser/dist/parse-cst.js | 1904 + .../yaml/browser/dist/resolveSeq-492ab440.js | 2419 + node_modules/yaml/browser/dist/types.js | 4 + node_modules/yaml/browser/dist/util.js | 2 + .../yaml/browser/dist/warnings-df54cb69.js | 499 + node_modules/yaml/browser/index.js | 1 + node_modules/yaml/browser/map.js | 2 + node_modules/yaml/browser/pair.js | 2 + node_modules/yaml/browser/parse-cst.js | 1 + node_modules/yaml/browser/scalar.js | 2 + node_modules/yaml/browser/schema.js | 9 + node_modules/yaml/browser/seq.js | 2 + node_modules/yaml/browser/types.js | 1 + node_modules/yaml/browser/types/binary.js | 8 + node_modules/yaml/browser/types/omap.js | 3 + node_modules/yaml/browser/types/pairs.js | 3 + node_modules/yaml/browser/types/set.js | 3 + node_modules/yaml/browser/types/timestamp.js | 10 + node_modules/yaml/browser/util.js | 1 + node_modules/yaml/dist/Document-9b4560a1.js | 757 + node_modules/yaml/dist/PlainValue-ec8e588e.js | 876 + node_modules/yaml/dist/Schema-88e323a7.js | 525 + node_modules/yaml/dist/index.js | 79 + node_modules/yaml/dist/legacy-exports.js | 16 + node_modules/yaml/dist/parse-cst.js | 1753 + node_modules/yaml/dist/resolveSeq-d03cb037.js | 2161 + node_modules/yaml/dist/test-events.js | 162 + node_modules/yaml/dist/types.js | 23 + node_modules/yaml/dist/util.js | 19 + node_modules/yaml/dist/warnings-1000a372.js | 416 + node_modules/yaml/index.d.ts | 372 + node_modules/yaml/index.js | 1 + node_modules/yaml/map.js | 2 + node_modules/yaml/package.json | 106 + node_modules/yaml/pair.js | 2 + node_modules/yaml/parse-cst.d.ts | 191 + node_modules/yaml/parse-cst.js | 1 + node_modules/yaml/scalar.js | 2 + node_modules/yaml/schema.js | 9 + node_modules/yaml/seq.js | 2 + node_modules/yaml/types.d.ts | 407 + node_modules/yaml/types.js | 17 + node_modules/yaml/types.mjs | 17 + node_modules/yaml/types/binary.js | 8 + node_modules/yaml/types/omap.js | 3 + node_modules/yaml/types/pairs.js | 3 + node_modules/yaml/types/set.js | 3 + node_modules/yaml/types/timestamp.js | 10 + node_modules/yaml/util.d.ts | 86 + node_modules/yaml/util.js | 16 + node_modules/yaml/util.mjs | 18 + nodes.html | 409 + output.css | 2680 + package-lock.json | 1385 + package.json | 42 + site.webmanifest | 19 + tailwind.config.js | 14 + takepart.html | 331 + xperiences.html | 352 + 1737 files changed, 254531 insertions(+) create mode 100644 LICENSE create mode 100644 README.md create mode 100644 android-chrome-192x192.png create mode 100644 android-chrome-512x512.png create mode 100644 apple-touch-icon.png create mode 100644 browserconfig.xml create mode 100644 favicon-16x16.png create mode 100644 favicon-32x32.png create mode 100644 favicon.ico create mode 100644 hero.html create mode 100644 images/.DS_Store create mode 100644 images/banner.png create mode 100644 images/benefit.png create mode 100644 images/benefit.zip create mode 100644 images/brand1.png create mode 100644 images/brand2.png create mode 100644 images/brand3.png create mode 100644 images/brand4.png create mode 100644 images/brand5.png create mode 100644 images/brand6.png create mode 100644 images/build.png create mode 100644 images/cloud.svg create mode 100644 images/dashboard.png create mode 100644 images/download.png create mode 100644 images/experiences.png create mode 100644 images/farmer.png create mode 100644 images/feature-1.png create mode 100644 images/feature-2.png create mode 100644 images/feature.png create mode 100644 images/feature4.png create mode 100644 images/hero.png create mode 100644 images/hero1.svg create mode 100644 images/hero2.png create mode 100644 images/hero2.svg create mode 100644 images/hero3.svg create mode 100644 images/hero4.png create mode 100644 images/hero5.png create mode 100644 images/icon1.png create mode 100644 images/icon1.svg create mode 100644 images/icon2.svg create mode 100644 images/icon3.svg create mode 100644 images/ict.png create mode 100644 images/id.png create mode 100644 images/kds.png create mode 100644 images/learn.png create mode 100644 images/logo.svg create mode 100644 images/my1.png create mode 100644 images/mycelium.png create mode 100644 images/node.png create mode 100644 images/node1.png create mode 100644 images/node2.png create mode 100644 images/node3.png create mode 100644 images/ourworld.png create mode 100644 images/plug.png create mode 100644 images/sikana.png create mode 100644 images/social_network.png create mode 100644 images/stat1.svg create mode 100644 images/stat2.svg create mode 100644 images/stat3.svg create mode 100644 images/stat4.svg create mode 100644 images/vverse.png create mode 100644 images/xp1.svg create mode 100644 images/xp2.svg create mode 100644 images/xp3.svg create mode 100644 images/xp4.svg create mode 100644 index.html create mode 100644 input.css create mode 100644 mstile-150x150.png create mode 100644 mycelium.html create mode 100644 node_modules/.DS_Store create mode 120000 node_modules/.bin/acorn create mode 120000 node_modules/.bin/cssesc create mode 120000 node_modules/.bin/detective create mode 120000 node_modules/.bin/mini-svg-data-uri create mode 120000 node_modules/.bin/nanoid create mode 120000 node_modules/.bin/resolve create mode 120000 node_modules/.bin/tailwind create mode 120000 node_modules/.bin/tailwindcss create mode 100644 node_modules/.package-lock.json create mode 100644 node_modules/@nodelib/.DS_Store create mode 100644 node_modules/@nodelib/fs.scandir/LICENSE create mode 100644 node_modules/@nodelib/fs.scandir/README.md create mode 100644 node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/adapters/fs.js create mode 100644 node_modules/@nodelib/fs.scandir/out/constants.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/constants.js create mode 100644 node_modules/@nodelib/fs.scandir/out/index.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/index.js create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/async.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/async.js create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/common.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/common.js create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/providers/sync.js create mode 100644 node_modules/@nodelib/fs.scandir/out/settings.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/settings.js create mode 100644 node_modules/@nodelib/fs.scandir/out/types/index.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/types/index.js create mode 100644 node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/utils/fs.js create mode 100644 node_modules/@nodelib/fs.scandir/out/utils/index.d.ts create mode 100644 node_modules/@nodelib/fs.scandir/out/utils/index.js create mode 100644 node_modules/@nodelib/fs.scandir/package.json create mode 100644 node_modules/@nodelib/fs.stat/LICENSE create mode 100644 node_modules/@nodelib/fs.stat/README.md create mode 100644 node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/adapters/fs.js create mode 100644 node_modules/@nodelib/fs.stat/out/index.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/index.js create mode 100644 node_modules/@nodelib/fs.stat/out/providers/async.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/providers/async.js create mode 100644 node_modules/@nodelib/fs.stat/out/providers/sync.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/providers/sync.js create mode 100644 node_modules/@nodelib/fs.stat/out/settings.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/settings.js create mode 100644 node_modules/@nodelib/fs.stat/out/types/index.d.ts create mode 100644 node_modules/@nodelib/fs.stat/out/types/index.js create mode 100644 node_modules/@nodelib/fs.stat/package.json create mode 100644 node_modules/@nodelib/fs.walk/LICENSE create mode 100644 node_modules/@nodelib/fs.walk/README.md create mode 100644 node_modules/@nodelib/fs.walk/out/index.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/index.js create mode 100644 node_modules/@nodelib/fs.walk/out/providers/async.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/providers/async.js create mode 100644 node_modules/@nodelib/fs.walk/out/providers/index.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/providers/index.js create mode 100644 node_modules/@nodelib/fs.walk/out/providers/stream.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/providers/stream.js create mode 100644 node_modules/@nodelib/fs.walk/out/providers/sync.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/providers/sync.js create mode 100644 node_modules/@nodelib/fs.walk/out/readers/async.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/readers/async.js create mode 100644 node_modules/@nodelib/fs.walk/out/readers/common.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/readers/common.js create mode 100644 node_modules/@nodelib/fs.walk/out/readers/reader.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/readers/reader.js create mode 100644 node_modules/@nodelib/fs.walk/out/readers/sync.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/readers/sync.js create mode 100644 node_modules/@nodelib/fs.walk/out/settings.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/settings.js create mode 100644 node_modules/@nodelib/fs.walk/out/types/index.d.ts create mode 100644 node_modules/@nodelib/fs.walk/out/types/index.js create mode 100644 node_modules/@nodelib/fs.walk/package.json create mode 100644 node_modules/@popperjs/core/LICENSE.md create mode 100644 node_modules/@popperjs/core/README.md create mode 100644 node_modules/@popperjs/core/dist/cjs/enums.js create mode 100644 node_modules/@popperjs/core/dist/cjs/enums.js.flow create mode 100644 node_modules/@popperjs/core/dist/cjs/enums.js.map create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-base.js create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-base.js.flow create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-base.js.map create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-lite.js create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-lite.js.flow create mode 100644 node_modules/@popperjs/core/dist/cjs/popper-lite.js.map create mode 100644 node_modules/@popperjs/core/dist/cjs/popper.js create mode 100644 node_modules/@popperjs/core/dist/cjs/popper.js.flow create mode 100644 node_modules/@popperjs/core/dist/cjs/popper.js.map create mode 100644 node_modules/@popperjs/core/dist/esm/createPopper.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/contains.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getBoundingClientRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getClippingRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getCompositeRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getComputedStyle.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getDocumentElement.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getDocumentRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getHTMLElementScroll.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getLayoutRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getNodeName.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getNodeScroll.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getOffsetParent.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getParentNode.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getScrollParent.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getViewportRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getWindow.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getWindowScroll.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/getWindowScrollBarX.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/instanceOf.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/isScrollParent.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/isTableElement.js create mode 100644 node_modules/@popperjs/core/dist/esm/dom-utils/listScrollParents.js create mode 100644 node_modules/@popperjs/core/dist/esm/enums.js create mode 100644 node_modules/@popperjs/core/dist/esm/index.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/applyStyles.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/arrow.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/computeStyles.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/eventListeners.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/flip.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/hide.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/index.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/offset.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/popperOffsets.js create mode 100644 node_modules/@popperjs/core/dist/esm/modifiers/preventOverflow.js create mode 100644 node_modules/@popperjs/core/dist/esm/popper-base.js create mode 100644 node_modules/@popperjs/core/dist/esm/popper-lite.js create mode 100644 node_modules/@popperjs/core/dist/esm/popper.js rename read.me => node_modules/@popperjs/core/dist/esm/types.js (100%) create mode 100644 node_modules/@popperjs/core/dist/esm/utils/computeAutoPlacement.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/computeOffsets.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/debounce.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/detectOverflow.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/expandToHashMap.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/format.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getAltAxis.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getAltLen.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getBasePlacement.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getFreshSideObject.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getMainAxisFromPlacement.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getOppositePlacement.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getOppositeVariationPlacement.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/getVariation.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/math.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/mergeByName.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/mergePaddingObject.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/orderModifiers.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/rectToClientRect.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/uniqueBy.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/validateModifiers.js create mode 100644 node_modules/@popperjs/core/dist/esm/utils/within.js create mode 100644 node_modules/@popperjs/core/dist/umd/enums.js create mode 100644 node_modules/@popperjs/core/dist/umd/enums.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/enums.min.js create mode 100644 node_modules/@popperjs/core/dist/umd/enums.min.js.flow create mode 100644 node_modules/@popperjs/core/dist/umd/enums.min.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper-base.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper-base.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper-base.min.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper-base.min.js.flow create mode 100644 node_modules/@popperjs/core/dist/umd/popper-base.min.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper-lite.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper-lite.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper-lite.min.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper-lite.min.js.flow create mode 100644 node_modules/@popperjs/core/dist/umd/popper-lite.min.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper.js.map create mode 100644 node_modules/@popperjs/core/dist/umd/popper.min.js create mode 100644 node_modules/@popperjs/core/dist/umd/popper.min.js.flow create mode 100644 node_modules/@popperjs/core/dist/umd/popper.min.js.map create mode 100644 node_modules/@popperjs/core/index.d.ts create mode 100644 node_modules/@popperjs/core/lib/createPopper.d.ts create mode 100644 node_modules/@popperjs/core/lib/createPopper.js create mode 100644 node_modules/@popperjs/core/lib/createPopper.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/contains.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/contains.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/contains.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getClippingRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeName.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeName.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeName.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getParentNode.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getParentNode.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getParentNode.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getScrollParent.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getViewportRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindow.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindow.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindow.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/instanceOf.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/instanceOf.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/instanceOf.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isScrollParent.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isTableElement.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isTableElement.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/isTableElement.js.flow create mode 100644 node_modules/@popperjs/core/lib/dom-utils/listScrollParents.d.ts create mode 100644 node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js create mode 100644 node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js.flow create mode 100644 node_modules/@popperjs/core/lib/enums.d.ts create mode 100644 node_modules/@popperjs/core/lib/enums.js create mode 100644 node_modules/@popperjs/core/lib/enums.js.flow create mode 100644 node_modules/@popperjs/core/lib/index.d.ts create mode 100644 node_modules/@popperjs/core/lib/index.js create mode 100644 node_modules/@popperjs/core/lib/index.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/applyStyles.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/applyStyles.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/applyStyles.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/arrow.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/arrow.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/arrow.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/computeStyles.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/computeStyles.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/computeStyles.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/eventListeners.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/eventListeners.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/eventListeners.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/flip.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/flip.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/flip.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/hide.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/hide.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/hide.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/index.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/index.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/index.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/offset.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/offset.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/offset.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/popperOffsets.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/popperOffsets.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/popperOffsets.js.flow create mode 100644 node_modules/@popperjs/core/lib/modifiers/preventOverflow.d.ts create mode 100644 node_modules/@popperjs/core/lib/modifiers/preventOverflow.js create mode 100644 node_modules/@popperjs/core/lib/modifiers/preventOverflow.js.flow create mode 100644 node_modules/@popperjs/core/lib/popper-base.d.ts create mode 100644 node_modules/@popperjs/core/lib/popper-base.js create mode 100644 node_modules/@popperjs/core/lib/popper-base.js.flow create mode 100644 node_modules/@popperjs/core/lib/popper-lite.d.ts create mode 100644 node_modules/@popperjs/core/lib/popper-lite.js create mode 100644 node_modules/@popperjs/core/lib/popper-lite.js.flow create mode 100644 node_modules/@popperjs/core/lib/popper.d.ts create mode 100644 node_modules/@popperjs/core/lib/popper.js create mode 100644 node_modules/@popperjs/core/lib/popper.js.flow create mode 100644 node_modules/@popperjs/core/lib/types.d.ts create mode 100644 node_modules/@popperjs/core/lib/types.js create mode 100644 node_modules/@popperjs/core/lib/types.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/computeAutoPlacement.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js create mode 100644 node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/computeOffsets.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/computeOffsets.js create mode 100644 node_modules/@popperjs/core/lib/utils/computeOffsets.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/debounce.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/debounce.js create mode 100644 node_modules/@popperjs/core/lib/utils/debounce.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/detectOverflow.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/detectOverflow.js create mode 100644 node_modules/@popperjs/core/lib/utils/detectOverflow.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/expandToHashMap.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/expandToHashMap.js create mode 100644 node_modules/@popperjs/core/lib/utils/expandToHashMap.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/format.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/format.js create mode 100644 node_modules/@popperjs/core/lib/utils/format.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getAltAxis.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getAltAxis.js create mode 100644 node_modules/@popperjs/core/lib/utils/getAltAxis.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getAltLen.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getAltLen.js create mode 100644 node_modules/@popperjs/core/lib/utils/getAltLen.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getBasePlacement.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getBasePlacement.js create mode 100644 node_modules/@popperjs/core/lib/utils/getBasePlacement.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getFreshSideObject.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getFreshSideObject.js create mode 100644 node_modules/@popperjs/core/lib/utils/getFreshSideObject.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js create mode 100644 node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositePlacement.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositePlacement.js create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositePlacement.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js create mode 100644 node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/getVariation.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/getVariation.js create mode 100644 node_modules/@popperjs/core/lib/utils/getVariation.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/math.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/math.js create mode 100644 node_modules/@popperjs/core/lib/utils/math.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/mergeByName.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/mergeByName.js create mode 100644 node_modules/@popperjs/core/lib/utils/mergeByName.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/mergePaddingObject.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/mergePaddingObject.js create mode 100644 node_modules/@popperjs/core/lib/utils/mergePaddingObject.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/orderModifiers.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/orderModifiers.js create mode 100644 node_modules/@popperjs/core/lib/utils/orderModifiers.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/rectToClientRect.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/rectToClientRect.js create mode 100644 node_modules/@popperjs/core/lib/utils/rectToClientRect.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/uniqueBy.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/uniqueBy.js create mode 100644 node_modules/@popperjs/core/lib/utils/uniqueBy.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/validateModifiers.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/validateModifiers.js create mode 100644 node_modules/@popperjs/core/lib/utils/validateModifiers.js.flow create mode 100644 node_modules/@popperjs/core/lib/utils/within.d.ts create mode 100644 node_modules/@popperjs/core/lib/utils/within.js create mode 100644 node_modules/@popperjs/core/lib/utils/within.js.flow create mode 100644 node_modules/@popperjs/core/package.json create mode 100644 node_modules/acorn-node/.DS_Store create mode 100644 node_modules/acorn-node/.travis.yml create mode 100644 node_modules/acorn-node/CHANGELOG.md create mode 100644 node_modules/acorn-node/LICENSE.md create mode 100644 node_modules/acorn-node/README.md create mode 100644 node_modules/acorn-node/build.js create mode 100644 node_modules/acorn-node/index.js create mode 100644 node_modules/acorn-node/lib/bigint/index.js create mode 100644 node_modules/acorn-node/lib/class-fields/index.js create mode 100644 node_modules/acorn-node/lib/dynamic-import/index.js create mode 100644 node_modules/acorn-node/lib/export-ns-from/index.js create mode 100644 node_modules/acorn-node/lib/import-meta/index.js create mode 100644 node_modules/acorn-node/lib/numeric-separator/index.js create mode 100644 node_modules/acorn-node/lib/private-class-elements/index.js create mode 100644 node_modules/acorn-node/lib/static-class-features/index.js create mode 100644 node_modules/acorn-node/package.json create mode 100644 node_modules/acorn-node/test/index.js create mode 100644 node_modules/acorn-node/walk.js create mode 100644 node_modules/acorn-walk/CHANGELOG.md create mode 100644 node_modules/acorn-walk/LICENSE create mode 100644 node_modules/acorn-walk/README.md create mode 100644 node_modules/acorn-walk/dist/walk.d.ts create mode 100644 node_modules/acorn-walk/dist/walk.js create mode 100644 node_modules/acorn-walk/dist/walk.js.map create mode 100644 node_modules/acorn-walk/dist/walk.mjs create mode 100644 node_modules/acorn-walk/dist/walk.mjs.map create mode 100644 node_modules/acorn-walk/package.json create mode 100644 node_modules/acorn/.DS_Store create mode 100644 node_modules/acorn/CHANGELOG.md create mode 100644 node_modules/acorn/LICENSE create mode 100644 node_modules/acorn/README.md create mode 100755 node_modules/acorn/bin/acorn create mode 100644 node_modules/acorn/dist/acorn.d.ts create mode 100644 node_modules/acorn/dist/acorn.js create mode 100644 node_modules/acorn/dist/acorn.js.map create mode 100644 node_modules/acorn/dist/acorn.mjs create mode 100644 node_modules/acorn/dist/acorn.mjs.d.ts create mode 100644 node_modules/acorn/dist/acorn.mjs.map create mode 100644 node_modules/acorn/dist/bin.js create mode 100644 node_modules/acorn/package.json create mode 100644 node_modules/anymatch/LICENSE create mode 100644 node_modules/anymatch/README.md create mode 100644 node_modules/anymatch/index.d.ts create mode 100644 node_modules/anymatch/index.js create mode 100644 node_modules/anymatch/package.json create mode 100644 node_modules/arg/LICENSE.md create mode 100644 node_modules/arg/README.md create mode 100644 node_modules/arg/index.d.ts create mode 100644 node_modules/arg/index.js create mode 100644 node_modules/arg/package.json create mode 100644 node_modules/binary-extensions/binary-extensions.json create mode 100644 node_modules/binary-extensions/binary-extensions.json.d.ts create mode 100644 node_modules/binary-extensions/index.d.ts create mode 100644 node_modules/binary-extensions/index.js create mode 100644 node_modules/binary-extensions/license create mode 100644 node_modules/binary-extensions/package.json create mode 100644 node_modules/binary-extensions/readme.md create mode 100644 node_modules/braces/CHANGELOG.md create mode 100644 node_modules/braces/LICENSE create mode 100644 node_modules/braces/README.md create mode 100644 node_modules/braces/index.js create mode 100644 node_modules/braces/lib/compile.js create mode 100644 node_modules/braces/lib/constants.js create mode 100644 node_modules/braces/lib/expand.js create mode 100644 node_modules/braces/lib/parse.js create mode 100644 node_modules/braces/lib/stringify.js create mode 100644 node_modules/braces/lib/utils.js create mode 100644 node_modules/braces/package.json create mode 100644 node_modules/camelcase-css/README.md create mode 100644 node_modules/camelcase-css/index-es5.js create mode 100644 node_modules/camelcase-css/index.js create mode 100644 node_modules/camelcase-css/license create mode 100644 node_modules/camelcase-css/package.json create mode 100644 node_modules/chokidar/.DS_Store create mode 100644 node_modules/chokidar/LICENSE create mode 100644 node_modules/chokidar/README.md create mode 100644 node_modules/chokidar/index.js create mode 100644 node_modules/chokidar/lib/constants.js create mode 100644 node_modules/chokidar/lib/fsevents-handler.js create mode 100644 node_modules/chokidar/lib/nodefs-handler.js create mode 100644 node_modules/chokidar/node_modules/glob-parent/CHANGELOG.md create mode 100644 node_modules/chokidar/node_modules/glob-parent/LICENSE create mode 100644 node_modules/chokidar/node_modules/glob-parent/README.md create mode 100644 node_modules/chokidar/node_modules/glob-parent/index.js create mode 100644 node_modules/chokidar/node_modules/glob-parent/package.json create mode 100644 node_modules/chokidar/package.json create mode 100644 node_modules/chokidar/types/index.d.ts create mode 100644 node_modules/color-name/LICENSE create mode 100644 node_modules/color-name/README.md create mode 100644 node_modules/color-name/index.js create mode 100644 node_modules/color-name/package.json create mode 100644 node_modules/cssesc/.DS_Store create mode 100644 node_modules/cssesc/LICENSE-MIT.txt create mode 100644 node_modules/cssesc/README.md create mode 100755 node_modules/cssesc/bin/cssesc create mode 100644 node_modules/cssesc/cssesc.js create mode 100644 node_modules/cssesc/man/cssesc.1 create mode 100644 node_modules/cssesc/package.json create mode 100644 node_modules/defined/.DS_Store create mode 100644 node_modules/defined/.travis.yml create mode 100644 node_modules/defined/LICENSE create mode 100644 node_modules/defined/example/defined.js create mode 100644 node_modules/defined/index.js create mode 100644 node_modules/defined/package.json create mode 100644 node_modules/defined/readme.markdown create mode 100644 node_modules/defined/test/def.js create mode 100644 node_modules/defined/test/falsy.js create mode 100644 node_modules/detective/.DS_Store create mode 100644 node_modules/detective/.travis.yml create mode 100644 node_modules/detective/CHANGELOG.md create mode 100644 node_modules/detective/LICENSE create mode 100644 node_modules/detective/bench/detect.js create mode 100644 node_modules/detective/bench/esprima_v_acorn.txt create mode 100755 node_modules/detective/bin/detective.js create mode 100644 node_modules/detective/example/strings.js create mode 100644 node_modules/detective/example/strings_src.js create mode 100644 node_modules/detective/index.js create mode 100644 node_modules/detective/package.json create mode 100644 node_modules/detective/readme.markdown create mode 100644 node_modules/detective/test/both.js create mode 100644 node_modules/detective/test/chained.js create mode 100644 node_modules/detective/test/complicated.js create mode 100644 node_modules/detective/test/es2019.js create mode 100644 node_modules/detective/test/es6-module.js create mode 100644 node_modules/detective/test/files/both.js create mode 100644 node_modules/detective/test/files/chained.js create mode 100644 node_modules/detective/test/files/es6-module.js create mode 100644 node_modules/detective/test/files/for-await.js create mode 100644 node_modules/detective/test/files/generators.js create mode 100644 node_modules/detective/test/files/isrequire.js create mode 100644 node_modules/detective/test/files/nested.js create mode 100644 node_modules/detective/test/files/optional-catch.js create mode 100644 node_modules/detective/test/files/rest-spread.js create mode 100644 node_modules/detective/test/files/set-in-object-pattern.js create mode 100644 node_modules/detective/test/files/shebang.js create mode 100644 node_modules/detective/test/files/sparse-array.js create mode 100644 node_modules/detective/test/files/strings.js create mode 100644 node_modules/detective/test/files/word.js create mode 100644 node_modules/detective/test/files/yield.js create mode 100644 node_modules/detective/test/generators.js create mode 100644 node_modules/detective/test/isrequire.js create mode 100644 node_modules/detective/test/nested.js create mode 100644 node_modules/detective/test/noargs.js create mode 100644 node_modules/detective/test/parseopts.js create mode 100644 node_modules/detective/test/rest-spread.js create mode 100644 node_modules/detective/test/return.js create mode 100644 node_modules/detective/test/set-in-object-pattern.js create mode 100644 node_modules/detective/test/shebang.js create mode 100644 node_modules/detective/test/sparse-array.js create mode 100644 node_modules/detective/test/strings.js create mode 100644 node_modules/detective/test/word.js create mode 100644 node_modules/detective/test/yield.js create mode 100644 node_modules/didyoumean/LICENSE create mode 100644 node_modules/didyoumean/README.md create mode 100644 node_modules/didyoumean/didYouMean-1.2.1.js create mode 100644 node_modules/didyoumean/didYouMean-1.2.1.min.js create mode 100755 node_modules/didyoumean/package.json create mode 100644 node_modules/dlv/README.md create mode 100644 node_modules/dlv/dist/dlv.es.js create mode 100644 node_modules/dlv/dist/dlv.es.js.map create mode 100644 node_modules/dlv/dist/dlv.js create mode 100644 node_modules/dlv/dist/dlv.js.map create mode 100644 node_modules/dlv/dist/dlv.umd.js create mode 100644 node_modules/dlv/dist/dlv.umd.js.map create mode 100644 node_modules/dlv/index.js create mode 100644 node_modules/dlv/package.json create mode 100644 node_modules/fast-glob/.DS_Store create mode 100644 node_modules/fast-glob/LICENSE create mode 100644 node_modules/fast-glob/README.md create mode 100644 node_modules/fast-glob/node_modules/glob-parent/CHANGELOG.md create mode 100644 node_modules/fast-glob/node_modules/glob-parent/LICENSE create mode 100644 node_modules/fast-glob/node_modules/glob-parent/README.md create mode 100644 node_modules/fast-glob/node_modules/glob-parent/index.js create mode 100644 node_modules/fast-glob/node_modules/glob-parent/package.json create mode 100644 node_modules/fast-glob/out/index.d.ts create mode 100644 node_modules/fast-glob/out/index.js create mode 100644 node_modules/fast-glob/out/managers/patterns.d.ts create mode 100644 node_modules/fast-glob/out/managers/patterns.js create mode 100644 node_modules/fast-glob/out/managers/tasks.d.ts create mode 100644 node_modules/fast-glob/out/managers/tasks.js create mode 100644 node_modules/fast-glob/out/providers/async.d.ts create mode 100644 node_modules/fast-glob/out/providers/async.js create mode 100644 node_modules/fast-glob/out/providers/filters/deep.d.ts create mode 100644 node_modules/fast-glob/out/providers/filters/deep.js create mode 100644 node_modules/fast-glob/out/providers/filters/entry.d.ts create mode 100644 node_modules/fast-glob/out/providers/filters/entry.js create mode 100644 node_modules/fast-glob/out/providers/filters/error.d.ts create mode 100644 node_modules/fast-glob/out/providers/filters/error.js create mode 100644 node_modules/fast-glob/out/providers/matchers/matcher.d.ts create mode 100644 node_modules/fast-glob/out/providers/matchers/matcher.js create mode 100644 node_modules/fast-glob/out/providers/matchers/partial.d.ts create mode 100644 node_modules/fast-glob/out/providers/matchers/partial.js create mode 100644 node_modules/fast-glob/out/providers/provider.d.ts create mode 100644 node_modules/fast-glob/out/providers/provider.js create mode 100644 node_modules/fast-glob/out/providers/stream.d.ts create mode 100644 node_modules/fast-glob/out/providers/stream.js create mode 100644 node_modules/fast-glob/out/providers/sync.d.ts create mode 100644 node_modules/fast-glob/out/providers/sync.js create mode 100644 node_modules/fast-glob/out/providers/transformers/entry.d.ts create mode 100644 node_modules/fast-glob/out/providers/transformers/entry.js create mode 100644 node_modules/fast-glob/out/readers/reader.d.ts create mode 100644 node_modules/fast-glob/out/readers/reader.js create mode 100644 node_modules/fast-glob/out/readers/stream.d.ts create mode 100644 node_modules/fast-glob/out/readers/stream.js create mode 100644 node_modules/fast-glob/out/readers/sync.d.ts create mode 100644 node_modules/fast-glob/out/readers/sync.js create mode 100644 node_modules/fast-glob/out/settings.d.ts create mode 100644 node_modules/fast-glob/out/settings.js create mode 100644 node_modules/fast-glob/out/types/index.d.ts create mode 100644 node_modules/fast-glob/out/types/index.js create mode 100644 node_modules/fast-glob/out/utils/array.d.ts create mode 100644 node_modules/fast-glob/out/utils/array.js create mode 100644 node_modules/fast-glob/out/utils/errno.d.ts create mode 100644 node_modules/fast-glob/out/utils/errno.js create mode 100644 node_modules/fast-glob/out/utils/fs.d.ts create mode 100644 node_modules/fast-glob/out/utils/fs.js create mode 100644 node_modules/fast-glob/out/utils/index.d.ts create mode 100644 node_modules/fast-glob/out/utils/index.js create mode 100644 node_modules/fast-glob/out/utils/path.d.ts create mode 100644 node_modules/fast-glob/out/utils/path.js create mode 100644 node_modules/fast-glob/out/utils/pattern.d.ts create mode 100644 node_modules/fast-glob/out/utils/pattern.js create mode 100644 node_modules/fast-glob/out/utils/stream.d.ts create mode 100644 node_modules/fast-glob/out/utils/stream.js create mode 100644 node_modules/fast-glob/out/utils/string.d.ts create mode 100644 node_modules/fast-glob/out/utils/string.js create mode 100644 node_modules/fast-glob/package.json create mode 100644 node_modules/fastq/.DS_Store create mode 100644 node_modules/fastq/.github/dependabot.yml create mode 100644 node_modules/fastq/.github/workflows/ci.yml create mode 100644 node_modules/fastq/LICENSE create mode 100644 node_modules/fastq/README.md create mode 100644 node_modules/fastq/bench.js create mode 100644 node_modules/fastq/example.js create mode 100644 node_modules/fastq/example.mjs create mode 100644 node_modules/fastq/index.d.ts create mode 100644 node_modules/fastq/package.json create mode 100644 node_modules/fastq/queue.js create mode 100644 node_modules/fastq/test/example.ts create mode 100644 node_modules/fastq/test/promise.js create mode 100644 node_modules/fastq/test/test.js create mode 100644 node_modules/fastq/test/tsconfig.json create mode 100644 node_modules/fill-range/LICENSE create mode 100644 node_modules/fill-range/README.md create mode 100644 node_modules/fill-range/index.js create mode 100644 node_modules/fill-range/package.json create mode 100644 node_modules/flowbite/.DS_Store create mode 100644 node_modules/flowbite/LICENSE.md create mode 100644 node_modules/flowbite/README.md create mode 100644 node_modules/flowbite/dist/datepicker.js create mode 100644 node_modules/flowbite/dist/datepicker.js.map create mode 100644 node_modules/flowbite/dist/datepicker.min.js create mode 100644 node_modules/flowbite/dist/datepicker.turbo.js create mode 100644 node_modules/flowbite/dist/datepicker.turbo.js.map create mode 100644 node_modules/flowbite/dist/datepicker.turbo.min.js create mode 100644 node_modules/flowbite/dist/flowbite.css create mode 100644 node_modules/flowbite/dist/flowbite.js create mode 100644 node_modules/flowbite/dist/flowbite.js.map create mode 100644 node_modules/flowbite/dist/flowbite.min.css create mode 100644 node_modules/flowbite/dist/flowbite.min.js create mode 100644 node_modules/flowbite/dist/flowbite.min.js.map create mode 100644 node_modules/flowbite/dist/flowbite.phoenix.js create mode 100644 node_modules/flowbite/dist/flowbite.phoenix.js.map create mode 100644 node_modules/flowbite/dist/flowbite.phoenix.min.js create mode 100644 node_modules/flowbite/dist/flowbite.phoenix.min.js.map create mode 100644 node_modules/flowbite/dist/flowbite.turbo.js create mode 100644 node_modules/flowbite/dist/flowbite.turbo.js.map create mode 100644 node_modules/flowbite/dist/flowbite.turbo.min.js create mode 100644 node_modules/flowbite/dist/flowbite.turbo.min.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/accordion/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/carousel/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/collapse/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dial/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/dial/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dial/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/dial/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dial/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dial/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/dial/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/dismiss/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/drawer/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/dropdown/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/modal/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/modal/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/modal/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/modal/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/modal/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/modal/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/modal/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/popover/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/popover/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/popover/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/popover/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/popover/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/popover/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/popover/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/tabs/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/index.js create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/interface.js create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/interface.js.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/types.js create mode 100644 node_modules/flowbite/lib/cjs/components/tooltip/types.js.map create mode 100644 node_modules/flowbite/lib/cjs/config/global.d.ts create mode 100644 node_modules/flowbite/lib/cjs/config/global.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/config/global.js create mode 100644 node_modules/flowbite/lib/cjs/config/global.js.map create mode 100644 node_modules/flowbite/lib/cjs/dom/events.d.ts create mode 100644 node_modules/flowbite/lib/cjs/dom/events.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/dom/events.js create mode 100644 node_modules/flowbite/lib/cjs/dom/events.js.map create mode 100644 node_modules/flowbite/lib/cjs/index.d.ts create mode 100644 node_modules/flowbite/lib/cjs/index.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/index.js create mode 100644 node_modules/flowbite/lib/cjs/index.js.map create mode 100644 node_modules/flowbite/lib/cjs/index.phoenix.d.ts create mode 100644 node_modules/flowbite/lib/cjs/index.phoenix.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/index.phoenix.js create mode 100644 node_modules/flowbite/lib/cjs/index.phoenix.js.map create mode 100644 node_modules/flowbite/lib/cjs/index.turbo.d.ts create mode 100644 node_modules/flowbite/lib/cjs/index.turbo.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/index.turbo.js create mode 100644 node_modules/flowbite/lib/cjs/index.turbo.js.map create mode 100644 node_modules/flowbite/lib/cjs/index.umd.d.ts create mode 100644 node_modules/flowbite/lib/cjs/index.umd.d.ts.map create mode 100644 node_modules/flowbite/lib/cjs/index.umd.js create mode 100644 node_modules/flowbite/lib/cjs/index.umd.js.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/accordion/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/index.js create mode 100644 node_modules/flowbite/lib/esm/components/accordion/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/accordion/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/accordion/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/accordion/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/accordion/types.js create mode 100644 node_modules/flowbite/lib/esm/components/accordion/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/carousel/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/index.js create mode 100644 node_modules/flowbite/lib/esm/components/carousel/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/carousel/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/carousel/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/carousel/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/carousel/types.js create mode 100644 node_modules/flowbite/lib/esm/components/carousel/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/collapse/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/index.js create mode 100644 node_modules/flowbite/lib/esm/components/collapse/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/collapse/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/collapse/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/collapse/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/collapse/types.js create mode 100644 node_modules/flowbite/lib/esm/components/collapse/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dial/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/index.js create mode 100644 node_modules/flowbite/lib/esm/components/dial/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dial/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/dial/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dial/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dial/types.js create mode 100644 node_modules/flowbite/lib/esm/components/dial/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/index.js create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/types.js create mode 100644 node_modules/flowbite/lib/esm/components/dismiss/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/drawer/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/index.js create mode 100644 node_modules/flowbite/lib/esm/components/drawer/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/drawer/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/drawer/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/drawer/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/drawer/types.js create mode 100644 node_modules/flowbite/lib/esm/components/drawer/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/index.js create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/types.js create mode 100644 node_modules/flowbite/lib/esm/components/dropdown/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/index.js create mode 100644 node_modules/flowbite/lib/esm/components/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/modal/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/index.js create mode 100644 node_modules/flowbite/lib/esm/components/modal/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/modal/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/modal/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/modal/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/modal/types.js create mode 100644 node_modules/flowbite/lib/esm/components/modal/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/popover/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/index.js create mode 100644 node_modules/flowbite/lib/esm/components/popover/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/popover/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/popover/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/popover/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/popover/types.js create mode 100644 node_modules/flowbite/lib/esm/components/popover/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tabs/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/index.js create mode 100644 node_modules/flowbite/lib/esm/components/tabs/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tabs/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/tabs/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tabs/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tabs/types.js create mode 100644 node_modules/flowbite/lib/esm/components/tabs/types.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/index.js create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/index.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/interface.js create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/interface.js.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/types.d.ts create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/types.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/types.js create mode 100644 node_modules/flowbite/lib/esm/components/tooltip/types.js.map create mode 100644 node_modules/flowbite/lib/esm/config/global.d.ts create mode 100644 node_modules/flowbite/lib/esm/config/global.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/config/global.js create mode 100644 node_modules/flowbite/lib/esm/config/global.js.map create mode 100644 node_modules/flowbite/lib/esm/dom/events.d.ts create mode 100644 node_modules/flowbite/lib/esm/dom/events.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/dom/events.js create mode 100644 node_modules/flowbite/lib/esm/dom/events.js.map create mode 100644 node_modules/flowbite/lib/esm/index.d.ts create mode 100644 node_modules/flowbite/lib/esm/index.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/index.js create mode 100644 node_modules/flowbite/lib/esm/index.js.map create mode 100644 node_modules/flowbite/lib/esm/index.phoenix.d.ts create mode 100644 node_modules/flowbite/lib/esm/index.phoenix.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/index.phoenix.js create mode 100644 node_modules/flowbite/lib/esm/index.phoenix.js.map create mode 100644 node_modules/flowbite/lib/esm/index.turbo.d.ts create mode 100644 node_modules/flowbite/lib/esm/index.turbo.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/index.turbo.js create mode 100644 node_modules/flowbite/lib/esm/index.turbo.js.map create mode 100644 node_modules/flowbite/lib/esm/index.umd.d.ts create mode 100644 node_modules/flowbite/lib/esm/index.umd.d.ts.map create mode 100644 node_modules/flowbite/lib/esm/index.umd.js create mode 100644 node_modules/flowbite/lib/esm/index.umd.js.map create mode 100644 node_modules/flowbite/package.json create mode 100644 node_modules/flowbite/plugin-windicss.js create mode 100644 node_modules/flowbite/plugin.d.ts create mode 100644 node_modules/flowbite/plugin.js create mode 100644 node_modules/fsevents/LICENSE create mode 100644 node_modules/fsevents/README.md create mode 100644 node_modules/fsevents/fsevents.d.ts create mode 100644 node_modules/fsevents/fsevents.js create mode 100755 node_modules/fsevents/fsevents.node create mode 100644 node_modules/fsevents/package.json create mode 100644 node_modules/function-bind/.editorconfig create mode 100644 node_modules/function-bind/.eslintrc create mode 100644 node_modules/function-bind/.jscs.json create mode 100644 node_modules/function-bind/.npmignore create mode 100644 node_modules/function-bind/.travis.yml create mode 100644 node_modules/function-bind/LICENSE create mode 100644 node_modules/function-bind/README.md create mode 100644 node_modules/function-bind/implementation.js create mode 100644 node_modules/function-bind/index.js create mode 100644 node_modules/function-bind/package.json create mode 100644 node_modules/function-bind/test/.eslintrc create mode 100644 node_modules/function-bind/test/index.js create mode 100644 node_modules/glob-parent/LICENSE create mode 100644 node_modules/glob-parent/README.md create mode 100644 node_modules/glob-parent/index.js create mode 100644 node_modules/glob-parent/package.json create mode 100644 node_modules/has/.DS_Store create mode 100644 node_modules/has/LICENSE-MIT create mode 100644 node_modules/has/README.md create mode 100644 node_modules/has/package.json create mode 100644 node_modules/has/src/index.js create mode 100644 node_modules/has/test/index.js create mode 100644 node_modules/is-binary-path/index.d.ts create mode 100644 node_modules/is-binary-path/index.js create mode 100644 node_modules/is-binary-path/license create mode 100644 node_modules/is-binary-path/package.json create mode 100644 node_modules/is-binary-path/readme.md create mode 100644 node_modules/is-core-module/.eslintrc create mode 100644 node_modules/is-core-module/.nycrc create mode 100644 node_modules/is-core-module/CHANGELOG.md create mode 100644 node_modules/is-core-module/LICENSE create mode 100644 node_modules/is-core-module/README.md create mode 100644 node_modules/is-core-module/core.json create mode 100644 node_modules/is-core-module/index.js create mode 100644 node_modules/is-core-module/package.json create mode 100644 node_modules/is-core-module/test/index.js create mode 100644 node_modules/is-extglob/LICENSE create mode 100644 node_modules/is-extglob/README.md create mode 100644 node_modules/is-extglob/index.js create mode 100644 node_modules/is-extglob/package.json create mode 100644 node_modules/is-glob/LICENSE create mode 100644 node_modules/is-glob/README.md create mode 100644 node_modules/is-glob/index.js create mode 100644 node_modules/is-glob/package.json create mode 100644 node_modules/is-number/LICENSE create mode 100644 node_modules/is-number/README.md create mode 100644 node_modules/is-number/index.js create mode 100644 node_modules/is-number/package.json create mode 100644 node_modules/lilconfig/dist/index.d.ts create mode 100644 node_modules/lilconfig/dist/index.js create mode 100644 node_modules/lilconfig/package.json create mode 100644 node_modules/lilconfig/readme.md create mode 100644 node_modules/merge2/LICENSE create mode 100644 node_modules/merge2/README.md create mode 100644 node_modules/merge2/index.js create mode 100644 node_modules/merge2/package.json create mode 100755 node_modules/micromatch/LICENSE create mode 100644 node_modules/micromatch/README.md create mode 100644 node_modules/micromatch/index.js create mode 100644 node_modules/micromatch/package.json create mode 100644 node_modules/mini-svg-data-uri/LICENSE create mode 100644 node_modules/mini-svg-data-uri/README.md create mode 100755 node_modules/mini-svg-data-uri/cli.js create mode 100644 node_modules/mini-svg-data-uri/index.d.ts create mode 100644 node_modules/mini-svg-data-uri/index.js create mode 100644 node_modules/mini-svg-data-uri/index.test-d.ts create mode 100644 node_modules/mini-svg-data-uri/package.json create mode 100644 node_modules/mini-svg-data-uri/shorter-css-color-names.js create mode 100644 node_modules/minimist/.DS_Store create mode 100644 node_modules/minimist/.travis.yml create mode 100644 node_modules/minimist/LICENSE create mode 100644 node_modules/minimist/example/parse.js create mode 100644 node_modules/minimist/index.js create mode 100644 node_modules/minimist/package.json create mode 100644 node_modules/minimist/readme.markdown create mode 100644 node_modules/minimist/test/all_bool.js create mode 100644 node_modules/minimist/test/bool.js create mode 100644 node_modules/minimist/test/dash.js create mode 100644 node_modules/minimist/test/default_bool.js create mode 100644 node_modules/minimist/test/dotted.js create mode 100644 node_modules/minimist/test/kv_short.js create mode 100644 node_modules/minimist/test/long.js create mode 100644 node_modules/minimist/test/num.js create mode 100644 node_modules/minimist/test/parse.js create mode 100644 node_modules/minimist/test/parse_modified.js create mode 100644 node_modules/minimist/test/proto.js create mode 100644 node_modules/minimist/test/short.js create mode 100644 node_modules/minimist/test/stop_early.js create mode 100644 node_modules/minimist/test/unknown.js create mode 100644 node_modules/minimist/test/whitespace.js create mode 100644 node_modules/nanoid/.DS_Store create mode 100644 node_modules/nanoid/LICENSE create mode 100644 node_modules/nanoid/README.md create mode 100644 node_modules/nanoid/async/index.browser.cjs create mode 100644 node_modules/nanoid/async/index.browser.js create mode 100644 node_modules/nanoid/async/index.cjs create mode 100644 node_modules/nanoid/async/index.d.ts create mode 100644 node_modules/nanoid/async/index.js create mode 100644 node_modules/nanoid/async/index.native.js create mode 100644 node_modules/nanoid/async/package.json create mode 100755 node_modules/nanoid/bin/nanoid.cjs create mode 100644 node_modules/nanoid/index.browser.cjs create mode 100644 node_modules/nanoid/index.browser.js create mode 100644 node_modules/nanoid/index.cjs create mode 100644 node_modules/nanoid/index.d.cts create mode 100644 node_modules/nanoid/index.d.ts create mode 100644 node_modules/nanoid/index.js create mode 100644 node_modules/nanoid/nanoid.js create mode 100644 node_modules/nanoid/non-secure/index.cjs create mode 100644 node_modules/nanoid/non-secure/index.d.ts create mode 100644 node_modules/nanoid/non-secure/index.js create mode 100644 node_modules/nanoid/non-secure/package.json create mode 100644 node_modules/nanoid/package.json create mode 100644 node_modules/nanoid/url-alphabet/index.cjs create mode 100644 node_modules/nanoid/url-alphabet/index.js create mode 100644 node_modules/nanoid/url-alphabet/package.json create mode 100644 node_modules/normalize-path/LICENSE create mode 100644 node_modules/normalize-path/README.md create mode 100644 node_modules/normalize-path/index.js create mode 100644 node_modules/normalize-path/package.json create mode 100644 node_modules/object-hash/LICENSE create mode 100644 node_modules/object-hash/dist/object_hash.js create mode 100644 node_modules/object-hash/index.js create mode 100644 node_modules/object-hash/package.json create mode 100644 node_modules/object-hash/readme.markdown create mode 100644 node_modules/path-parse/LICENSE create mode 100644 node_modules/path-parse/README.md create mode 100644 node_modules/path-parse/index.js create mode 100644 node_modules/path-parse/package.json create mode 100644 node_modules/picocolors/LICENSE create mode 100644 node_modules/picocolors/README.md create mode 100644 node_modules/picocolors/package.json create mode 100644 node_modules/picocolors/picocolors.browser.js create mode 100644 node_modules/picocolors/picocolors.d.ts create mode 100644 node_modules/picocolors/picocolors.js create mode 100644 node_modules/picocolors/types.ts create mode 100644 node_modules/picomatch/CHANGELOG.md create mode 100644 node_modules/picomatch/LICENSE create mode 100644 node_modules/picomatch/README.md create mode 100644 node_modules/picomatch/index.js create mode 100644 node_modules/picomatch/lib/constants.js create mode 100644 node_modules/picomatch/lib/parse.js create mode 100644 node_modules/picomatch/lib/picomatch.js create mode 100644 node_modules/picomatch/lib/scan.js create mode 100644 node_modules/picomatch/lib/utils.js create mode 100644 node_modules/picomatch/package.json create mode 100644 node_modules/pify/index.js create mode 100644 node_modules/pify/license create mode 100644 node_modules/pify/package.json create mode 100644 node_modules/pify/readme.md create mode 100755 node_modules/postcss-import/LICENSE create mode 100644 node_modules/postcss-import/README.md create mode 100755 node_modules/postcss-import/index.js create mode 100644 node_modules/postcss-import/lib/join-layer.js create mode 100644 node_modules/postcss-import/lib/join-media.js create mode 100644 node_modules/postcss-import/lib/load-content.js create mode 100644 node_modules/postcss-import/lib/parse-statements.js create mode 100644 node_modules/postcss-import/lib/process-content.js create mode 100644 node_modules/postcss-import/lib/resolve-id.js create mode 100644 node_modules/postcss-import/package.json create mode 100644 node_modules/postcss-js/LICENSE create mode 100644 node_modules/postcss-js/README.md create mode 100644 node_modules/postcss-js/async.js create mode 100644 node_modules/postcss-js/index.js create mode 100644 node_modules/postcss-js/index.mjs create mode 100644 node_modules/postcss-js/objectifier.js create mode 100644 node_modules/postcss-js/package.json create mode 100644 node_modules/postcss-js/parser.js create mode 100644 node_modules/postcss-js/process-result.js create mode 100644 node_modules/postcss-js/sync.js create mode 100644 node_modules/postcss-load-config/LICENSE create mode 100644 node_modules/postcss-load-config/README.md create mode 100644 node_modules/postcss-load-config/package.json create mode 100644 node_modules/postcss-load-config/src/index.d.ts create mode 100644 node_modules/postcss-load-config/src/index.js create mode 100644 node_modules/postcss-load-config/src/options.js create mode 100644 node_modules/postcss-load-config/src/plugins.js create mode 100644 node_modules/postcss-load-config/src/req.js create mode 100644 node_modules/postcss-nested/LICENSE create mode 100644 node_modules/postcss-nested/README.md create mode 100644 node_modules/postcss-nested/index.d.ts create mode 100644 node_modules/postcss-nested/index.js create mode 100644 node_modules/postcss-nested/package.json create mode 100644 node_modules/postcss-selector-parser/API.md create mode 100644 node_modules/postcss-selector-parser/CHANGELOG.md create mode 100644 node_modules/postcss-selector-parser/LICENSE-MIT create mode 100644 node_modules/postcss-selector-parser/README.md create mode 100644 node_modules/postcss-selector-parser/dist/index.js create mode 100644 node_modules/postcss-selector-parser/dist/parser.js create mode 100644 node_modules/postcss-selector-parser/dist/processor.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/attribute.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/className.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/combinator.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/comment.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/constructors.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/container.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/guards.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/id.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/index.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/namespace.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/nesting.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/node.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/pseudo.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/root.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/selector.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/string.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/tag.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/types.js create mode 100644 node_modules/postcss-selector-parser/dist/selectors/universal.js create mode 100644 node_modules/postcss-selector-parser/dist/sortAscending.js create mode 100644 node_modules/postcss-selector-parser/dist/tokenTypes.js create mode 100644 node_modules/postcss-selector-parser/dist/tokenize.js create mode 100644 node_modules/postcss-selector-parser/dist/util/ensureObject.js create mode 100644 node_modules/postcss-selector-parser/dist/util/getProp.js create mode 100644 node_modules/postcss-selector-parser/dist/util/index.js create mode 100644 node_modules/postcss-selector-parser/dist/util/stripComments.js create mode 100644 node_modules/postcss-selector-parser/dist/util/unesc.js create mode 100644 node_modules/postcss-selector-parser/package.json create mode 100644 node_modules/postcss-selector-parser/postcss-selector-parser.d.ts create mode 100644 node_modules/postcss-value-parser/LICENSE create mode 100644 node_modules/postcss-value-parser/README.md create mode 100644 node_modules/postcss-value-parser/lib/index.d.ts create mode 100644 node_modules/postcss-value-parser/lib/index.js create mode 100644 node_modules/postcss-value-parser/lib/parse.js create mode 100644 node_modules/postcss-value-parser/lib/stringify.js create mode 100644 node_modules/postcss-value-parser/lib/unit.js create mode 100644 node_modules/postcss-value-parser/lib/walk.js create mode 100644 node_modules/postcss-value-parser/package.json create mode 100644 node_modules/postcss/LICENSE create mode 100644 node_modules/postcss/README.md create mode 100644 node_modules/postcss/lib/at-rule.d.ts create mode 100644 node_modules/postcss/lib/at-rule.js create mode 100644 node_modules/postcss/lib/comment.d.ts create mode 100644 node_modules/postcss/lib/comment.js create mode 100644 node_modules/postcss/lib/container.d.ts create mode 100644 node_modules/postcss/lib/container.js create mode 100644 node_modules/postcss/lib/css-syntax-error.d.ts create mode 100644 node_modules/postcss/lib/css-syntax-error.js create mode 100644 node_modules/postcss/lib/declaration.d.ts create mode 100644 node_modules/postcss/lib/declaration.js create mode 100644 node_modules/postcss/lib/document.d.ts create mode 100644 node_modules/postcss/lib/document.js create mode 100644 node_modules/postcss/lib/fromJSON.d.ts create mode 100644 node_modules/postcss/lib/fromJSON.js create mode 100644 node_modules/postcss/lib/input.d.ts create mode 100644 node_modules/postcss/lib/input.js create mode 100644 node_modules/postcss/lib/lazy-result.d.ts create mode 100644 node_modules/postcss/lib/lazy-result.js create mode 100644 node_modules/postcss/lib/list.d.ts create mode 100644 node_modules/postcss/lib/list.js create mode 100644 node_modules/postcss/lib/map-generator.js create mode 100644 node_modules/postcss/lib/no-work-result.d.ts create mode 100644 node_modules/postcss/lib/no-work-result.js create mode 100644 node_modules/postcss/lib/node.d.ts create mode 100644 node_modules/postcss/lib/node.js create mode 100644 node_modules/postcss/lib/parse.d.ts create mode 100644 node_modules/postcss/lib/parse.js create mode 100644 node_modules/postcss/lib/parser.js create mode 100644 node_modules/postcss/lib/postcss.d.mts create mode 100644 node_modules/postcss/lib/postcss.d.ts create mode 100644 node_modules/postcss/lib/postcss.js create mode 100644 node_modules/postcss/lib/postcss.mjs create mode 100644 node_modules/postcss/lib/previous-map.d.ts create mode 100644 node_modules/postcss/lib/previous-map.js create mode 100644 node_modules/postcss/lib/processor.d.ts create mode 100644 node_modules/postcss/lib/processor.js create mode 100644 node_modules/postcss/lib/result.d.ts create mode 100644 node_modules/postcss/lib/result.js create mode 100644 node_modules/postcss/lib/root.d.ts create mode 100644 node_modules/postcss/lib/root.js create mode 100644 node_modules/postcss/lib/rule.d.ts create mode 100644 node_modules/postcss/lib/rule.js create mode 100644 node_modules/postcss/lib/stringifier.d.ts create mode 100644 node_modules/postcss/lib/stringifier.js create mode 100644 node_modules/postcss/lib/stringify.d.ts create mode 100644 node_modules/postcss/lib/stringify.js create mode 100644 node_modules/postcss/lib/symbols.js create mode 100644 node_modules/postcss/lib/terminal-highlight.js create mode 100644 node_modules/postcss/lib/tokenize.js create mode 100644 node_modules/postcss/lib/warn-once.js create mode 100644 node_modules/postcss/lib/warning.d.ts create mode 100644 node_modules/postcss/lib/warning.js create mode 100755 node_modules/postcss/package.json create mode 100755 node_modules/queue-microtask/LICENSE create mode 100644 node_modules/queue-microtask/README.md create mode 100644 node_modules/queue-microtask/index.d.ts create mode 100644 node_modules/queue-microtask/index.js create mode 100644 node_modules/queue-microtask/package.json create mode 100644 node_modules/quick-lru/index.d.ts create mode 100644 node_modules/quick-lru/index.js create mode 100644 node_modules/quick-lru/license create mode 100644 node_modules/quick-lru/package.json create mode 100644 node_modules/quick-lru/readme.md create mode 100644 node_modules/read-cache/LICENSE create mode 100644 node_modules/read-cache/README.md create mode 100644 node_modules/read-cache/index.js create mode 100644 node_modules/read-cache/package.json create mode 100644 node_modules/readdirp/LICENSE create mode 100644 node_modules/readdirp/README.md create mode 100644 node_modules/readdirp/index.d.ts create mode 100644 node_modules/readdirp/index.js create mode 100644 node_modules/readdirp/package.json create mode 100644 node_modules/resolve/.DS_Store create mode 100644 node_modules/resolve/.editorconfig create mode 100644 node_modules/resolve/.eslintrc create mode 100644 node_modules/resolve/.github/FUNDING.yml create mode 100644 node_modules/resolve/LICENSE create mode 100644 node_modules/resolve/SECURITY.md create mode 100644 node_modules/resolve/async.js create mode 100755 node_modules/resolve/bin/resolve create mode 100644 node_modules/resolve/example/async.js create mode 100644 node_modules/resolve/example/sync.js create mode 100644 node_modules/resolve/index.js create mode 100644 node_modules/resolve/lib/async.js create mode 100644 node_modules/resolve/lib/caller.js create mode 100644 node_modules/resolve/lib/core.js create mode 100644 node_modules/resolve/lib/core.json create mode 100644 node_modules/resolve/lib/homedir.js create mode 100644 node_modules/resolve/lib/is-core.js create mode 100644 node_modules/resolve/lib/node-modules-paths.js create mode 100644 node_modules/resolve/lib/normalize-options.js create mode 100644 node_modules/resolve/lib/sync.js create mode 100644 node_modules/resolve/package.json create mode 100644 node_modules/resolve/readme.markdown create mode 100644 node_modules/resolve/sync.js create mode 100644 node_modules/resolve/test/core.js create mode 100644 node_modules/resolve/test/dotdot.js create mode 100644 node_modules/resolve/test/dotdot/abc/index.js create mode 100644 node_modules/resolve/test/dotdot/index.js create mode 100644 node_modules/resolve/test/faulty_basedir.js create mode 100644 node_modules/resolve/test/filter.js create mode 100644 node_modules/resolve/test/filter_sync.js create mode 100644 node_modules/resolve/test/home_paths.js create mode 100644 node_modules/resolve/test/home_paths_sync.js create mode 100644 node_modules/resolve/test/mock.js create mode 100644 node_modules/resolve/test/mock_sync.js create mode 100644 node_modules/resolve/test/module_dir.js create mode 100644 node_modules/resolve/test/module_dir/xmodules/aaa/index.js create mode 100644 node_modules/resolve/test/module_dir/ymodules/aaa/index.js create mode 100644 node_modules/resolve/test/module_dir/zmodules/bbb/main.js create mode 100644 node_modules/resolve/test/module_dir/zmodules/bbb/package.json create mode 100644 node_modules/resolve/test/node-modules-paths.js create mode 100644 node_modules/resolve/test/node_path.js create mode 100644 node_modules/resolve/test/node_path/x/aaa/index.js create mode 100644 node_modules/resolve/test/node_path/x/ccc/index.js create mode 100644 node_modules/resolve/test/node_path/y/bbb/index.js create mode 100644 node_modules/resolve/test/node_path/y/ccc/index.js create mode 100644 node_modules/resolve/test/nonstring.js create mode 100644 node_modules/resolve/test/pathfilter.js create mode 100644 node_modules/resolve/test/pathfilter/deep_ref/main.js create mode 100644 node_modules/resolve/test/precedence.js create mode 100644 node_modules/resolve/test/precedence/aaa.js create mode 100644 node_modules/resolve/test/precedence/aaa/index.js create mode 100644 node_modules/resolve/test/precedence/aaa/main.js create mode 100644 node_modules/resolve/test/precedence/bbb.js create mode 100644 node_modules/resolve/test/precedence/bbb/main.js create mode 100644 node_modules/resolve/test/resolver.js create mode 100644 node_modules/resolve/test/resolver/baz/doom.js create mode 100644 node_modules/resolve/test/resolver/baz/package.json create mode 100644 node_modules/resolve/test/resolver/baz/quux.js create mode 100644 node_modules/resolve/test/resolver/browser_field/a.js create mode 100644 node_modules/resolve/test/resolver/browser_field/b.js create mode 100644 node_modules/resolve/test/resolver/browser_field/package.json create mode 100644 node_modules/resolve/test/resolver/cup.coffee create mode 100644 node_modules/resolve/test/resolver/dot_main/index.js create mode 100644 node_modules/resolve/test/resolver/dot_main/package.json create mode 100644 node_modules/resolve/test/resolver/dot_slash_main/index.js create mode 100644 node_modules/resolve/test/resolver/dot_slash_main/package.json create mode 100644 node_modules/resolve/test/resolver/false_main/index.js create mode 100644 node_modules/resolve/test/resolver/false_main/package.json create mode 100644 node_modules/resolve/test/resolver/foo.js create mode 100644 node_modules/resolve/test/resolver/incorrect_main/index.js create mode 100644 node_modules/resolve/test/resolver/incorrect_main/package.json create mode 100644 node_modules/resolve/test/resolver/invalid_main/package.json create mode 100644 node_modules/resolve/test/resolver/malformed_package_json/index.js create mode 100644 node_modules/resolve/test/resolver/malformed_package_json/package.json create mode 100644 node_modules/resolve/test/resolver/mug.coffee create mode 100644 node_modules/resolve/test/resolver/mug.js create mode 100644 node_modules/resolve/test/resolver/multirepo/lerna.json create mode 100644 node_modules/resolve/test/resolver/multirepo/package.json create mode 100644 node_modules/resolve/test/resolver/multirepo/packages/package-a/index.js create mode 100644 node_modules/resolve/test/resolver/multirepo/packages/package-a/package.json create mode 100644 node_modules/resolve/test/resolver/multirepo/packages/package-b/index.js create mode 100644 node_modules/resolve/test/resolver/multirepo/packages/package-b/package.json create mode 100644 node_modules/resolve/test/resolver/nested_symlinks/mylib/async.js create mode 100644 node_modules/resolve/test/resolver/nested_symlinks/mylib/package.json create mode 100644 node_modules/resolve/test/resolver/nested_symlinks/mylib/sync.js create mode 100644 node_modules/resolve/test/resolver/other_path/lib/other-lib.js create mode 100644 node_modules/resolve/test/resolver/other_path/root.js create mode 100644 node_modules/resolve/test/resolver/quux/foo/index.js create mode 100644 node_modules/resolve/test/resolver/same_names/foo.js create mode 100644 node_modules/resolve/test/resolver/same_names/foo/index.js create mode 100644 node_modules/resolve/test/resolver/symlinked/_/node_modules/foo.js create mode 100644 node_modules/resolve/test/resolver/symlinked/_/symlink_target/.gitkeep create mode 100644 node_modules/resolve/test/resolver/symlinked/package/bar.js create mode 100644 node_modules/resolve/test/resolver/symlinked/package/package.json create mode 100644 node_modules/resolve/test/resolver/without_basedir/main.js create mode 100644 node_modules/resolve/test/resolver_sync.js create mode 100644 node_modules/resolve/test/shadowed_core.js create mode 100644 node_modules/resolve/test/shadowed_core/node_modules/util/index.js create mode 100644 node_modules/resolve/test/subdirs.js create mode 100644 node_modules/resolve/test/symlinks.js create mode 100644 node_modules/reusify/.coveralls.yml create mode 100644 node_modules/reusify/.travis.yml create mode 100644 node_modules/reusify/LICENSE create mode 100644 node_modules/reusify/README.md create mode 100644 node_modules/reusify/benchmarks/createNoCodeFunction.js create mode 100644 node_modules/reusify/benchmarks/fib.js create mode 100644 node_modules/reusify/benchmarks/reuseNoCodeFunction.js create mode 100644 node_modules/reusify/package.json create mode 100644 node_modules/reusify/reusify.js create mode 100644 node_modules/reusify/test.js create mode 100644 node_modules/run-parallel/LICENSE create mode 100644 node_modules/run-parallel/README.md create mode 100644 node_modules/run-parallel/index.js create mode 100644 node_modules/run-parallel/package.json create mode 100644 node_modules/source-map-js/LICENSE create mode 100644 node_modules/source-map-js/README.md create mode 100644 node_modules/source-map-js/lib/array-set.js create mode 100644 node_modules/source-map-js/lib/base64-vlq.js create mode 100644 node_modules/source-map-js/lib/base64.js create mode 100644 node_modules/source-map-js/lib/binary-search.js create mode 100644 node_modules/source-map-js/lib/mapping-list.js create mode 100644 node_modules/source-map-js/lib/quick-sort.js create mode 100644 node_modules/source-map-js/lib/source-map-consumer.js create mode 100644 node_modules/source-map-js/lib/source-map-generator.js create mode 100644 node_modules/source-map-js/lib/source-node.js create mode 100644 node_modules/source-map-js/lib/util.js create mode 100644 node_modules/source-map-js/package.json create mode 100644 node_modules/source-map-js/source-map.d.ts create mode 100644 node_modules/source-map-js/source-map.js create mode 100644 node_modules/supports-preserve-symlinks-flag/.DS_Store create mode 100644 node_modules/supports-preserve-symlinks-flag/.eslintrc create mode 100644 node_modules/supports-preserve-symlinks-flag/.github/FUNDING.yml create mode 100644 node_modules/supports-preserve-symlinks-flag/.nycrc create mode 100644 node_modules/supports-preserve-symlinks-flag/CHANGELOG.md create mode 100644 node_modules/supports-preserve-symlinks-flag/LICENSE create mode 100644 node_modules/supports-preserve-symlinks-flag/README.md create mode 100644 node_modules/supports-preserve-symlinks-flag/browser.js create mode 100644 node_modules/supports-preserve-symlinks-flag/index.js create mode 100644 node_modules/supports-preserve-symlinks-flag/package.json create mode 100644 node_modules/supports-preserve-symlinks-flag/test/index.js create mode 100644 node_modules/tailwindcss/.DS_Store create mode 100644 node_modules/tailwindcss/CHANGELOG.md create mode 100644 node_modules/tailwindcss/LICENSE create mode 100644 node_modules/tailwindcss/README.md create mode 100644 node_modules/tailwindcss/base.css create mode 100644 node_modules/tailwindcss/colors.d.ts create mode 100644 node_modules/tailwindcss/colors.js create mode 100644 node_modules/tailwindcss/components.css create mode 100644 node_modules/tailwindcss/defaultConfig.d.ts create mode 100644 node_modules/tailwindcss/defaultConfig.js create mode 100644 node_modules/tailwindcss/defaultTheme.d.ts create mode 100644 node_modules/tailwindcss/defaultTheme.js create mode 100644 node_modules/tailwindcss/lib/cli-peer-dependencies.js create mode 100755 node_modules/tailwindcss/lib/cli.js create mode 100644 node_modules/tailwindcss/lib/constants.js create mode 100644 node_modules/tailwindcss/lib/corePluginList.js create mode 100644 node_modules/tailwindcss/lib/corePlugins.js create mode 100644 node_modules/tailwindcss/lib/css/LICENSE create mode 100644 node_modules/tailwindcss/lib/css/preflight.css create mode 100644 node_modules/tailwindcss/lib/featureFlags.js create mode 100644 node_modules/tailwindcss/lib/index.js create mode 100644 node_modules/tailwindcss/lib/lib/cacheInvalidation.js create mode 100644 node_modules/tailwindcss/lib/lib/collapseAdjacentRules.js create mode 100644 node_modules/tailwindcss/lib/lib/collapseDuplicateDeclarations.js create mode 100644 node_modules/tailwindcss/lib/lib/defaultExtractor.js create mode 100644 node_modules/tailwindcss/lib/lib/detectNesting.js create mode 100644 node_modules/tailwindcss/lib/lib/evaluateTailwindFunctions.js create mode 100644 node_modules/tailwindcss/lib/lib/expandApplyAtRules.js create mode 100644 node_modules/tailwindcss/lib/lib/expandTailwindAtRules.js create mode 100644 node_modules/tailwindcss/lib/lib/generateRules.js create mode 100644 node_modules/tailwindcss/lib/lib/getModuleDependencies.js create mode 100644 node_modules/tailwindcss/lib/lib/normalizeTailwindDirectives.js create mode 100644 node_modules/tailwindcss/lib/lib/partitionApplyAtRules.js create mode 100644 node_modules/tailwindcss/lib/lib/regex.js create mode 100644 node_modules/tailwindcss/lib/lib/resolveDefaultsAtRules.js create mode 100644 node_modules/tailwindcss/lib/lib/setupContextUtils.js create mode 100644 node_modules/tailwindcss/lib/lib/setupTrackingContext.js create mode 100644 node_modules/tailwindcss/lib/lib/sharedState.js create mode 100644 node_modules/tailwindcss/lib/lib/substituteScreenAtRules.js create mode 100644 node_modules/tailwindcss/lib/postcss-plugins/nesting/README.md create mode 100644 node_modules/tailwindcss/lib/postcss-plugins/nesting/index.js create mode 100644 node_modules/tailwindcss/lib/postcss-plugins/nesting/plugin.js create mode 100644 node_modules/tailwindcss/lib/processTailwindFeatures.js create mode 100644 node_modules/tailwindcss/lib/public/colors.js create mode 100644 node_modules/tailwindcss/lib/public/create-plugin.js create mode 100644 node_modules/tailwindcss/lib/public/default-config.js create mode 100644 node_modules/tailwindcss/lib/public/default-theme.js create mode 100644 node_modules/tailwindcss/lib/public/resolve-config.js create mode 100644 node_modules/tailwindcss/lib/util/bigSign.js create mode 100644 node_modules/tailwindcss/lib/util/buildMediaQuery.js create mode 100644 node_modules/tailwindcss/lib/util/cloneDeep.js create mode 100644 node_modules/tailwindcss/lib/util/cloneNodes.js create mode 100644 node_modules/tailwindcss/lib/util/color.js create mode 100644 node_modules/tailwindcss/lib/util/configurePlugins.js create mode 100644 node_modules/tailwindcss/lib/util/createPlugin.js create mode 100644 node_modules/tailwindcss/lib/util/createUtilityPlugin.js create mode 100644 node_modules/tailwindcss/lib/util/dataTypes.js create mode 100644 node_modules/tailwindcss/lib/util/defaults.js create mode 100644 node_modules/tailwindcss/lib/util/escapeClassName.js create mode 100644 node_modules/tailwindcss/lib/util/escapeCommas.js create mode 100644 node_modules/tailwindcss/lib/util/flattenColorPalette.js create mode 100644 node_modules/tailwindcss/lib/util/formatVariantSelector.js create mode 100644 node_modules/tailwindcss/lib/util/getAllConfigs.js create mode 100644 node_modules/tailwindcss/lib/util/hashConfig.js create mode 100644 node_modules/tailwindcss/lib/util/isKeyframeRule.js create mode 100644 node_modules/tailwindcss/lib/util/isPlainObject.js create mode 100644 node_modules/tailwindcss/lib/util/isValidArbitraryValue.js create mode 100644 node_modules/tailwindcss/lib/util/log.js create mode 100644 node_modules/tailwindcss/lib/util/nameClass.js create mode 100644 node_modules/tailwindcss/lib/util/negateValue.js create mode 100644 node_modules/tailwindcss/lib/util/normalizeConfig.js create mode 100644 node_modules/tailwindcss/lib/util/normalizeScreens.js create mode 100644 node_modules/tailwindcss/lib/util/parseAnimationValue.js create mode 100644 node_modules/tailwindcss/lib/util/parseBoxShadowValue.js create mode 100644 node_modules/tailwindcss/lib/util/parseDependency.js create mode 100644 node_modules/tailwindcss/lib/util/parseObjectStyles.js create mode 100644 node_modules/tailwindcss/lib/util/pluginUtils.js create mode 100644 node_modules/tailwindcss/lib/util/prefixSelector.js create mode 100644 node_modules/tailwindcss/lib/util/removeAlphaVariables.js create mode 100644 node_modules/tailwindcss/lib/util/resolveConfig.js create mode 100644 node_modules/tailwindcss/lib/util/resolveConfigPath.js create mode 100644 node_modules/tailwindcss/lib/util/responsive.js create mode 100644 node_modules/tailwindcss/lib/util/splitAtTopLevelOnly.js create mode 100644 node_modules/tailwindcss/lib/util/tap.js create mode 100644 node_modules/tailwindcss/lib/util/toColorValue.js create mode 100644 node_modules/tailwindcss/lib/util/toPath.js create mode 100644 node_modules/tailwindcss/lib/util/transformThemeValue.js create mode 100644 node_modules/tailwindcss/lib/util/validateConfig.js create mode 100644 node_modules/tailwindcss/lib/util/withAlphaVariable.js create mode 100644 node_modules/tailwindcss/nesting/index.js create mode 100644 node_modules/tailwindcss/package.json create mode 100644 node_modules/tailwindcss/peers/index.js create mode 100644 node_modules/tailwindcss/plugin.d.ts create mode 100644 node_modules/tailwindcss/plugin.js create mode 100644 node_modules/tailwindcss/prettier.config.js create mode 100644 node_modules/tailwindcss/resolveConfig.js create mode 100644 node_modules/tailwindcss/screens.css create mode 100644 node_modules/tailwindcss/scripts/create-plugin-list.js create mode 100644 node_modules/tailwindcss/scripts/generate-types.js create mode 100644 node_modules/tailwindcss/scripts/install-integrations.js create mode 100644 node_modules/tailwindcss/scripts/rebuildFixtures.js create mode 100644 node_modules/tailwindcss/src/cli-peer-dependencies.js create mode 100644 node_modules/tailwindcss/src/cli.js create mode 100644 node_modules/tailwindcss/src/constants.js create mode 100644 node_modules/tailwindcss/src/corePluginList.js create mode 100644 node_modules/tailwindcss/src/corePlugins.js create mode 100644 node_modules/tailwindcss/src/css/LICENSE create mode 100644 node_modules/tailwindcss/src/css/preflight.css create mode 100644 node_modules/tailwindcss/src/featureFlags.js create mode 100644 node_modules/tailwindcss/src/index.js create mode 100644 node_modules/tailwindcss/src/lib/cacheInvalidation.js create mode 100644 node_modules/tailwindcss/src/lib/collapseAdjacentRules.js create mode 100644 node_modules/tailwindcss/src/lib/collapseDuplicateDeclarations.js create mode 100644 node_modules/tailwindcss/src/lib/defaultExtractor.js create mode 100644 node_modules/tailwindcss/src/lib/detectNesting.js create mode 100644 node_modules/tailwindcss/src/lib/evaluateTailwindFunctions.js create mode 100644 node_modules/tailwindcss/src/lib/expandApplyAtRules.js create mode 100644 node_modules/tailwindcss/src/lib/expandTailwindAtRules.js create mode 100644 node_modules/tailwindcss/src/lib/generateRules.js create mode 100644 node_modules/tailwindcss/src/lib/getModuleDependencies.js create mode 100644 node_modules/tailwindcss/src/lib/normalizeTailwindDirectives.js create mode 100644 node_modules/tailwindcss/src/lib/partitionApplyAtRules.js create mode 100644 node_modules/tailwindcss/src/lib/regex.js create mode 100644 node_modules/tailwindcss/src/lib/resolveDefaultsAtRules.js create mode 100644 node_modules/tailwindcss/src/lib/setupContextUtils.js create mode 100644 node_modules/tailwindcss/src/lib/setupTrackingContext.js create mode 100644 node_modules/tailwindcss/src/lib/sharedState.js create mode 100644 node_modules/tailwindcss/src/lib/substituteScreenAtRules.js create mode 100644 node_modules/tailwindcss/src/postcss-plugins/nesting/README.md create mode 100644 node_modules/tailwindcss/src/postcss-plugins/nesting/index.js create mode 100644 node_modules/tailwindcss/src/postcss-plugins/nesting/plugin.js create mode 100644 node_modules/tailwindcss/src/processTailwindFeatures.js create mode 100644 node_modules/tailwindcss/src/public/colors.js create mode 100644 node_modules/tailwindcss/src/public/create-plugin.js create mode 100644 node_modules/tailwindcss/src/public/default-config.js create mode 100644 node_modules/tailwindcss/src/public/default-theme.js create mode 100644 node_modules/tailwindcss/src/public/resolve-config.js create mode 100644 node_modules/tailwindcss/src/util/bigSign.js create mode 100644 node_modules/tailwindcss/src/util/buildMediaQuery.js create mode 100644 node_modules/tailwindcss/src/util/cloneDeep.js create mode 100644 node_modules/tailwindcss/src/util/cloneNodes.js create mode 100644 node_modules/tailwindcss/src/util/color.js create mode 100644 node_modules/tailwindcss/src/util/configurePlugins.js create mode 100644 node_modules/tailwindcss/src/util/createPlugin.js create mode 100644 node_modules/tailwindcss/src/util/createUtilityPlugin.js create mode 100644 node_modules/tailwindcss/src/util/dataTypes.js create mode 100644 node_modules/tailwindcss/src/util/defaults.js create mode 100644 node_modules/tailwindcss/src/util/escapeClassName.js create mode 100644 node_modules/tailwindcss/src/util/escapeCommas.js create mode 100644 node_modules/tailwindcss/src/util/flattenColorPalette.js create mode 100644 node_modules/tailwindcss/src/util/formatVariantSelector.js create mode 100644 node_modules/tailwindcss/src/util/getAllConfigs.js create mode 100644 node_modules/tailwindcss/src/util/hashConfig.js create mode 100644 node_modules/tailwindcss/src/util/isKeyframeRule.js create mode 100644 node_modules/tailwindcss/src/util/isPlainObject.js create mode 100644 node_modules/tailwindcss/src/util/isValidArbitraryValue.js create mode 100644 node_modules/tailwindcss/src/util/log.js create mode 100644 node_modules/tailwindcss/src/util/nameClass.js create mode 100644 node_modules/tailwindcss/src/util/negateValue.js create mode 100644 node_modules/tailwindcss/src/util/normalizeConfig.js create mode 100644 node_modules/tailwindcss/src/util/normalizeScreens.js create mode 100644 node_modules/tailwindcss/src/util/parseAnimationValue.js create mode 100644 node_modules/tailwindcss/src/util/parseBoxShadowValue.js create mode 100644 node_modules/tailwindcss/src/util/parseDependency.js create mode 100644 node_modules/tailwindcss/src/util/parseObjectStyles.js create mode 100644 node_modules/tailwindcss/src/util/pluginUtils.js create mode 100644 node_modules/tailwindcss/src/util/prefixSelector.js create mode 100644 node_modules/tailwindcss/src/util/removeAlphaVariables.js create mode 100644 node_modules/tailwindcss/src/util/resolveConfig.js create mode 100644 node_modules/tailwindcss/src/util/resolveConfigPath.js create mode 100644 node_modules/tailwindcss/src/util/responsive.js create mode 100644 node_modules/tailwindcss/src/util/splitAtTopLevelOnly.js create mode 100644 node_modules/tailwindcss/src/util/tap.js create mode 100644 node_modules/tailwindcss/src/util/toColorValue.js create mode 100644 node_modules/tailwindcss/src/util/toPath.js create mode 100644 node_modules/tailwindcss/src/util/transformThemeValue.js create mode 100644 node_modules/tailwindcss/src/util/validateConfig.js create mode 100644 node_modules/tailwindcss/src/util/withAlphaVariable.js create mode 100644 node_modules/tailwindcss/stubs/defaultConfig.stub.js create mode 100644 node_modules/tailwindcss/stubs/defaultPostCssConfig.stub.js create mode 100644 node_modules/tailwindcss/stubs/simpleConfig.stub.js create mode 100644 node_modules/tailwindcss/tailwind.css create mode 100644 node_modules/tailwindcss/types/config.d.ts create mode 100644 node_modules/tailwindcss/types/generated/.gitkeep create mode 100644 node_modules/tailwindcss/types/generated/colors.d.ts create mode 100644 node_modules/tailwindcss/types/generated/corePluginList.d.ts create mode 100644 node_modules/tailwindcss/types/index.d.ts create mode 100644 node_modules/tailwindcss/utilities.css create mode 100644 node_modules/tailwindcss/variants.css create mode 100644 node_modules/to-regex-range/LICENSE create mode 100644 node_modules/to-regex-range/README.md create mode 100644 node_modules/to-regex-range/index.js create mode 100644 node_modules/to-regex-range/package.json create mode 100644 node_modules/util-deprecate/History.md create mode 100644 node_modules/util-deprecate/LICENSE create mode 100644 node_modules/util-deprecate/README.md create mode 100644 node_modules/util-deprecate/browser.js create mode 100644 node_modules/util-deprecate/node.js create mode 100644 node_modules/util-deprecate/package.json create mode 100644 node_modules/xtend/.jshintrc create mode 100644 node_modules/xtend/LICENSE create mode 100644 node_modules/xtend/README.md create mode 100644 node_modules/xtend/immutable.js create mode 100644 node_modules/xtend/mutable.js create mode 100644 node_modules/xtend/package.json create mode 100644 node_modules/xtend/test.js create mode 100644 node_modules/yaml/.DS_Store create mode 100644 node_modules/yaml/LICENSE create mode 100644 node_modules/yaml/README.md create mode 100644 node_modules/yaml/browser/dist/PlainValue-b8036b75.js create mode 100644 node_modules/yaml/browser/dist/Schema-e94716c8.js create mode 100644 node_modules/yaml/browser/dist/index.js create mode 100644 node_modules/yaml/browser/dist/legacy-exports.js create mode 100644 node_modules/yaml/browser/dist/package.json create mode 100644 node_modules/yaml/browser/dist/parse-cst.js create mode 100644 node_modules/yaml/browser/dist/resolveSeq-492ab440.js create mode 100644 node_modules/yaml/browser/dist/types.js create mode 100644 node_modules/yaml/browser/dist/util.js create mode 100644 node_modules/yaml/browser/dist/warnings-df54cb69.js create mode 100644 node_modules/yaml/browser/index.js create mode 100644 node_modules/yaml/browser/map.js create mode 100644 node_modules/yaml/browser/pair.js create mode 100644 node_modules/yaml/browser/parse-cst.js create mode 100644 node_modules/yaml/browser/scalar.js create mode 100644 node_modules/yaml/browser/schema.js create mode 100644 node_modules/yaml/browser/seq.js create mode 100644 node_modules/yaml/browser/types.js create mode 100644 node_modules/yaml/browser/types/binary.js create mode 100644 node_modules/yaml/browser/types/omap.js create mode 100644 node_modules/yaml/browser/types/pairs.js create mode 100644 node_modules/yaml/browser/types/set.js create mode 100644 node_modules/yaml/browser/types/timestamp.js create mode 100644 node_modules/yaml/browser/util.js create mode 100644 node_modules/yaml/dist/Document-9b4560a1.js create mode 100644 node_modules/yaml/dist/PlainValue-ec8e588e.js create mode 100644 node_modules/yaml/dist/Schema-88e323a7.js create mode 100644 node_modules/yaml/dist/index.js create mode 100644 node_modules/yaml/dist/legacy-exports.js create mode 100644 node_modules/yaml/dist/parse-cst.js create mode 100644 node_modules/yaml/dist/resolveSeq-d03cb037.js create mode 100644 node_modules/yaml/dist/test-events.js create mode 100644 node_modules/yaml/dist/types.js create mode 100644 node_modules/yaml/dist/util.js create mode 100644 node_modules/yaml/dist/warnings-1000a372.js create mode 100644 node_modules/yaml/index.d.ts create mode 100644 node_modules/yaml/index.js create mode 100644 node_modules/yaml/map.js create mode 100644 node_modules/yaml/package.json create mode 100644 node_modules/yaml/pair.js create mode 100644 node_modules/yaml/parse-cst.d.ts create mode 100644 node_modules/yaml/parse-cst.js create mode 100644 node_modules/yaml/scalar.js create mode 100644 node_modules/yaml/schema.js create mode 100644 node_modules/yaml/seq.js create mode 100644 node_modules/yaml/types.d.ts create mode 100644 node_modules/yaml/types.js create mode 100644 node_modules/yaml/types.mjs create mode 100644 node_modules/yaml/types/binary.js create mode 100644 node_modules/yaml/types/omap.js create mode 100644 node_modules/yaml/types/pairs.js create mode 100644 node_modules/yaml/types/set.js create mode 100644 node_modules/yaml/types/timestamp.js create mode 100644 node_modules/yaml/util.d.ts create mode 100644 node_modules/yaml/util.js create mode 100644 node_modules/yaml/util.mjs create mode 100644 nodes.html create mode 100644 output.css create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 site.webmanifest create mode 100644 tailwind.config.js create mode 100644 takepart.html create mode 100644 xperiences.html diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..82da9c1 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2022 Themesberg + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..3a5f481 --- /dev/null +++ b/README.md @@ -0,0 +1,30 @@ + +## Getting started + +Make sure that you have [Node.js](https://nodejs.org/en/), [Tailwind CSS](https://tailwindcss.com/docs/installation) and [Flowbite](https://flowbite.com/docs/getting-started/quickstart/) installed. + +1. Run `npm install` inside your terminal + +2. Watch for files and compile Tailwind CSS + Flowbite: + +``` +npx tailwindcss -i ./input.css -o ./output.css --watch +``` + +3. To deploy you will only need the `index.html` file and the `output.css` styles. +for live preview on localhost, Run below: + +``` +npm run start +``` + + +Alternatively you can also just directly copy this code into your own projects, whether you use Laravel, React, Vue.js or other frameworks. + +## About us + +### Hero Labs + +Hero Labs provides a decentralized autonomous cloud technologies that allows anyone to become a cloud service provider. + +We aims to create a cloud where people and organizations can buy, sell, and use cloud resources autonomously,enable individuals to earn by providing compute, network, and storage capacity​. \ No newline at end of file diff --git a/android-chrome-192x192.png b/android-chrome-192x192.png new file mode 100644 index 0000000000000000000000000000000000000000..ad337a230b9a293d32ef2b1f96ecdc93b539467f GIT binary patch literal 12799 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

6SBhz(1Vg$oe5bVe-c{yTuDH0w`0go$k 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/%+gb|n^OlVUjGfDk1=JN_n?+#z1=-=$wYe+W7Ed7n`3@!Uu8 z6S0JSWyd{BlQze8$W)ue)Q1`3tZqp2d0Gb~uudjg8~*Rdr@-o%X5TEf4H%EsYynPs62pV%}$!LahN+dVeoc`-H2jlV`0EkWD$Q6-xP2!6b`t=|0 z?ov)Ye)Y@q8u|&tp;CYT)gqXn*#18@n;0j5LvxM{G6TY|qW}vvY)PZTpxbbUkQ!I0 z4VFCo1$;{}Rtee)^k4>J(IW_~@@{PK%!3!%17<8wMjzcup4seEcQJKJzb1bqT_t|| z#`T=?9kmv!t7kpVcVGNavEZJidP%~ee(!0~%Szw(5x&Bw7a>_QB4IQ^J2Id8uU0ym z{a}yD_NMy|EZ-ePB&W@yOYpV-x(55d-hcamul1#oOLuowblz1F@M;9hhV1%3BtFFm z3w!JxUga+M^aU>l4nZk6y-53LE}Z`Iq^g8$vCYv?@#OdcU4J`;~P&wrl;WM+bEh z&ZjSDN0DteN#pg(4p4j_fhe)$z4$bSVS6-vN>j_E7tY@?l8JSeKa?x`UkqSy=vc$d zSxk}B_&~{ds4==G_}l;fL1&}

4PjW}zglgcry_d>^)nF7K}LH8Cb_DH8F`Xuh#Q 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 Z1Nkm38nt@Fpa7_V9JjK!Y&hbV`aj=hAoc(N literal 0 HcmV?d00001 diff --git a/apple-touch-icon.png b/apple-touch-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..5c2ed09295654e1cc5de97beebc30851ee151c68 GIT binary patch literal 11955 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 literal 0 HcmV?d00001 diff --git a/browserconfig.xml b/browserconfig.xml new file mode 100644 index 0000000..b3930d0 --- /dev/null +++ b/browserconfig.xml @@ -0,0 +1,9 @@ + + + + + + #da532c + + + diff --git a/favicon-16x16.png b/favicon-16x16.png new file mode 100644 index 0000000000000000000000000000000000000000..6700735d9997d47b80872747af275262311f34e3 GIT binary patch literal 1480 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJOS+@4BLl<6e(pbstU$g(vPY0F z14ES>14Ba#1H&(%P{RubhEf9thF1v;3|2E37{m+a>m1mhsPcs!kC|B)yk?!kK zgEyrHZ;Nz5Qt9$f(&Zlm$qdD(<;L$y^xhQeyeiawRc`dQ%Jf~S{+oQwmq1jc^SZ+L zU8U)JAgVBVUuO8WSnqX_?yE-IPg8<^SD3sj)(0u5GJOw35M{-BZwj(pi z0R_>-|NsAgUDNy=FwLDW3GxG_Uo1c(cm3)lAui8(hmRgTG|ir!*|___u_Himd~c%` z6LaK_;~)+Y96i3-OJfsQ>d5hBQqKD!!a#`~1}-r6k)t~e5o{NPnw^Gl4p0d~Ggv#4 zu|Nx<`j2k*g1H6k6oeBYP7b+h%MbJqW0JSK%lYPehcba2_7YEDSN3P@tb&s2t8T8= z1WJp0x;TbNTux2^f)pX)=@X_*N=r**U<@;pjI^v|byZCj4K3qiWAigD<@MFgm5sHn zWp-9h)?*V6HZJD&*3OoWwytJ(SI=Wh7Y{d&&MxQA&h|Ig&zFy9v;W_4V8Me47YtSx zXwU9Aq0yG{f5r`q^*>sUEJ@iu<;s?l1rBa$VP$?!d2w}Vj*0;bR_s`^MQ7)pMVquX zTdiKUt#9GJgR3{L+^MR!ee2q_dlzr+UbuVt_Vx9Lj(AR9{>6W;S?w{Ow#d!TU%WUw z*F4@m{otX>ZZZADh+R25|8-4W9kxDlci!HAZM`-;duE&E-`th^yKk;_`P+M&%jM;n znfD*~$IQ+zYghE;#z)~Mr-c7p-1BWpf1SBmthC61k6|@uoORr~FT!@q8M@z^u%z zm&`4!EbKj5gjra@rNQKI3bXR&5QWn>uADe>=7`J@_R|d>3%v9gUWp5qd~!0K3bca3 M)78&qol`;+0NKZY-v9sr literal 0 HcmV?d00001 diff --git a/favicon-32x32.png b/favicon-32x32.png new file mode 100644 index 0000000000000000000000000000000000000000..952287121b76cf9a09c6e2ec2ff1b3bd2a197828 GIT binary patch literal 1923 zcmV-}2YmR6P)004R>004l5008;`004mK004C`008P>0026e000+ooVrmw00006 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 literal 0 HcmV?d00001 diff --git a/hero.html b/hero.html new file mode 100644 index 0000000..870e736 --- /dev/null +++ b/hero.html @@ -0,0 +1,397 @@ + + + + + + + + Hero by Mycelium Project + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

+ +
+ + +
+
+ +
+

Discover Hero,

+

Your Unified Digital Identity.

+

Hero is your unique, singular digital avatar, streamlining your online interactions by eliminating the need to duplicate identities across various platforms. With Hero, manage every aspect of your digital life through one secure, efficient identity.

+ +
+
+
+ + + + +
+
+ +
+
+

Do Anything. Do Everything.

+

From secure file sharing to encrypted communication, your Hero comes equipped with all the essential skills and capabilities needed to enhance the flexibility and security of your digital life.

+ +
    +
  • + + + + +
    + Communication +

    Chat, hold meetings, and video conferencing.

    +
    +
  • +
  • + + + + +
    + Finance +

    Use wallet features to transact and manage assets.

    +
    +
  • +
  • + + + + +
    + Collaborate +

    Engage in projects and tasks with your network.

    +
    +
  • + + + + +
    + Develop & Expand +

    Create tools or decentralized applications.

    +
    +
  • + + + + +
    + Creativity +

    Generate videos, documents, and other contents.

    +
    +
  • + + + + +
    + Filesharing +

    Directly send data and files without central servers.

    +
    +
  • +
  • + + + + +
    + Organization +

    Securely store and organize data.

    +
    +
  • +
  • + + + + +
    + Browser +

    Browse information securely without tracking.

    +
    +
  • +
+ +
+ +
+
+
+ + + + + + + +
+
+ +
+ +
+

Become the Center of Your Internet.

+

By eliminating the need for centralized servers, Hero allows you to be the only central point of data accumulation, communication and execution of digital capabilities.

+
+
+
+
+ + + + +
+
+
+

Why Join Hero

+

Hero is designed to benefit everyone by offering a new internet where members can engage in a community dedicated to inclusivity and growth

+
+
+ +
+ Icon representing Node & Earn +

Inclusivity

+

Everyone gains equal network access and there are no barriers to entry.

+
+ +
+ Icon representing Node & Earn +

Sovereignty

+

Only you have control of your data and decide who has access to it.

+
+ +
+ Icon representing Node & Earn +

Equality

+

Anyone can attain the opportunity to earn and to better their lives.

+
+
+
+
+ + + +
+
+
+

Be a Hero Today

+

Become the center of your digital life.

+ Get Started +
+
+ Free Trial Image +
+
+
+ + + + + + \ No newline at end of file diff --git a/images/.DS_Store b/images/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..bd2e660a3c80e9117e7cedd44d8166a44ead6e87 GIT binary patch literal 6148 zcmeHKF-`+P474Ej?K*1@7o)*rJ2nEvVG7^jpxL~E-K<+0MB@~7kj(g?H`BTB>QxLwO2OSlf42z z>h}Xq__MBwuQIGKcKnh5KZw2^$XaKnvkIC`rfQu0T zJVQ7P>zF0LjR9~k9+MG)d6t5+)N91>EJwUmUN0V#v)nvx#&hasuL;HDcEnqxoA+dS zDIf)o6}ZgplKuY{I5Ynr7ilL2q`<#Yz-OEL%^I&%y>;?(?6nPe0GRU$(6EjYxM;`V jXvf&F9j_uO^BUJU@5N(slp`MHVEq}OE;1?b*9sf}L53Yx literal 0 HcmV?d00001 diff --git a/images/banner.png b/images/banner.png new file mode 100644 index 0000000000000000000000000000000000000000..441e4e9de133f323dbf307e926a5f3eca85c9200 GIT binary patch literal 139415 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 z zGUb8#j-ZavYUp>2bl!&YQ)dn|z1K_!B5aQW{FfKyjd0|Q43ufMN+TXE?lXMXSC;p2 zX${hMbdiK@L~=kkqjSX^5FqXV;&Er0wJ%ecG;?RLZqdx_+kRC15LHtK!#I(*wNb;d z^(=3a+jA17a~@qBr%wbZ+gAZS);udqRUV**12|i+g(qM$`tfclX+AA20wM#U-pLbom zHXBkPRO`>7U%l@?h?vY^ebIGS1H_7uG~FUSVxeA8!Pu|&?#VNzeh{{c@))Pj+1W-g z*k)6Y!u6G`F`MQE7SLLru0sX1Rc<+WIaoX#;@Z~%J)%oi1;UfBrswM{q81}um&a|~ z;WZr%w|9XCdTz0w`F2?-m4!LT2m7JHrDU^gXR>>TfYaV9y4gn6_%B5 z7vu1yI$U^w8sx`)*l_0k21sODHgz5t+cn$N$%c>Iz~PN&&omMX%hJXJ6e=;;>stR& zVal1GRMBb?mu6EN`UuFbqn7CCMLfVz$HJUsHSE%j~Cyxqqc)68E4h8rZPv$ZzC z1y*NL1<_GlB_i9D0*V>(fS4FTaiDx14CYMF3;?nPiv&jc_rM|1?9E+E}*DPxLXfrlRzhHbnYD+ zcHlp~*{g3(o7dc0gOPNH4nc$N=uZKq#l!3^!gTE`Yw0BxfVF)?Js`=**{p!&?KZ!o zKm(=xw$RWBeETP}UNyG$V<)!VbMkk`rb&wecbYn z*<>&pK-zC*uI)tSNgy(S_@1)YRW$&p898#rCdddzB+aGX4 z*Z1L!`;%3|MdUzBC4WNz*-C_!jejeviGS+qUUdlOBLZZAeG;Di>Et1YAKKra%k>e^ zus+w*$KyZTR&Dn=^hyoBWL3^j4G*Wsv{f(=^VA}vgdknS8X^FD)6IPnCNV(yGYOi1 zM-?SMSkhKM>g!7^n*M39wrDe*hq1dt7s(nIAfgQT^3S~q0ei!^ zB+Y53*QNZ!X78~`+&)C#>c9ng41<$Ufv*Hge5k^t*Q&3iAeI#fh!g1z;1J-bVf4T}xF%+%`) zGvW3npirrsbX1&w5A;M4oosK|896Ka<%WADjzXoePtaC4f?HN8yEC1 zCOdb$t@|3k=gK4><^(aGS=4IZLkS`*TY$E(CUC~Gx1x%N%o%h8-R0xH{v-;M5yW_= zoLS78c;jN)O46w!EfttuJQd^HVuCnuY>vZ+ z3Q+yURi&ELaD|3BU5kfWTpz1m>5oXSLAaEyL-P6dULMip>^Q!*@aFlmfxGwfB+d_c zfQ;OU3mSI-XuHRp)7P)=H=T1S!Mau=%lveu5(r5s2JauWPbu90c9t&`)?n9(C^U7 z#$o%9nSBI4gT}0IM0f9Pt*ewK^qB^v6%}pyH$TwuZlcpyB@}v6t6oOpX|*UTJD-cF z72Nf6?$xFlExTM~@RKu?L|!jOLOJNdWX>ipdTZm3w-=`aBq~yP`puCW{^sNt`g}*v zyxOrmHz3!6qg4<@1L)|Kd`Rhnc}n-IDnN4#{d3GBU-1f$im|~tnu^xUo*+n62?PzX z1o=Z_uppJnO2j#M2&1%zurn_(0cYpQL0IBDC_u14*eWa*h5b?Q?b(=Ea03h_yIYR1qrE`g$tRXbyhaU`u`p6b8yLaxdtdChhtf`7KRJu=M zv&(FH&leiDK~JJSM(Bh^^8207#Y0?f@=;ghp_ifI52~S& z=-OfIvS&kM+Iu)cJEK5Ca^KhuBB>Z-pQEk3=(8~vVnB)%X2n|F0K7(FW>^6Q{yi+h z`*Vt?^2Vxj7h=RD>FDU~ZDNuYBzLkfJNmx0wi+V8L2<(8-^ilPPRoi( zOoM-Ym;X?wJ**dqHzBALPo#a&Y5(mFG#I}<6ZE^t?Em2DD}cIuzOO%YNOzY=3rKe( zol?>v-QC?FAX3t;bVzr1iwH=Aba%sl`Tpj8XBZeA=K1Wid-vXR&pEr85TGp6(KSZF zAh6(c*nnrHUkpp{k(0N<08_-8>EjRSp_>19Tk*aPnn?L5a|!O z@Bt-57E%@4-t}h2w7z$Ff*^h0nl%k2EC1nVEyHXT<~5|0+NVoxF(yLu9{Hvq?BW0;0t5vsQ2ROTn^ZhkqLqWkD1OUX)c7NIt-9 zq8M=X8pjw}d7p8$q5)s`U6V}72t?k)qYv5HmC;099E!NwHqG~=rSyBKJ&YHPg1^B= zFj-xBaDzpEG)+2&N%bT6P(~B|($+Rq?wk8?4nzIR?F83$_EHL#V_D{HAKuPv%}?~= zAWrN+oKPyHrwO6k;!Hjl@A}5X+m`ZvEBT82YGz)`D0gotWJZ(`fGgaWFfCZFnZGTC z=>Gvi3pM=|*pyd(^u z(0`**_#EBhhSXu%pV0Pb?WL2;_`+NjBmM_|f(9BBxIX>upLB~ic=U45qH+ch)*6d(^|q&vDevI@ zpTAH9cZDowTyTT_%{R*VDThkV(aZd`tCR|Rk+1&pFnt2q&knDF!$Tsa_Kx)BYS5|= z?=5?F0j8J|s0z?IxgY@<)zVeTw~2c+0uHSx4!mpcm$eah*GQ|o+h^lrwCC%5K_X34 zP7%OTdmQ4*DN9#9&vFtZG*W_0^z%8V(A>utCYwF2oA}T5mb#3-z7QfuSST!PNWJms z{Q?Nb4sMVJF2^PJk}t1LqnUL_ts0Cz{OX>%E*n-^SK1|w#1Jd#HF+|k1;EK&*Z1-( zU6sVkaIk^;G|MmHYy4j{`DUG7US{3hG08aqmZe0mRA<)AVxFxa0aVQI z@uME2@UyXhLrQiW66nNtNn>JMPyNP{w}XmW1qBF+!Q)u222kCASTcczIf=LEpg9oOayysNl0vt7O?Ew%av

nhqCz9ORkU(`*8UXnUFd-%+MM6j}iPRN@Du# z*(ID~6kMvQFgPaT-2srxaZ~kb0kijvZo`lGOe);>bd^Vh;ytw=& zPz`t-*~)(ag_+X{Ms*v^vEOIU@{?0k#LIJQLu2`sF<3BMiV|n>i=%m*HgB%t-`+oe zB3D^odp@{P;0izb~v$CcJ ziu$bPOY%M-B2nVr`h#2EUJQY*9yr@qzz}#)cHEB|_XYM9btBp&ly)sft90%`xk~QY z{@X&kl)r7R$5d}|v~wD3LnT#pzphHidWVVMKmnWHwg0a(XHP~2LH>-i0g9{KnUoteX@-FjcSkJ#I4m3uc;_kaIqYl&ugr8DL_s>M2y|iL@~y&2-g)cB;;m#7N8oXg(2pDZ2ze*qy4iJ`Koz2P_-8_h3zNMkAn8RnxZ~U zC6Lq#4XKW}g8H&ryn&g;>C*eN2}jZZPcHEl?yv@w0;T8W!3RfXC4H#zk}^%a>)zKT z?zI66^94W}6S^8y0lS|(CVsyagJU7QYh}a{DVKlIo{e50`WSo@O)NTizMa%G6DDM-F4gDzj~?cxe_@=*NGdBwq@jmc{`Vp zbr7A1pWyLCG2SK(l!)k-VThmw)IhFaZk)BLT*q1{F?%x!G#}|3W zVLEXxAS^7C|94|bB!cFxOuj7CWS^amAp0B6@@#xJP5eiGS=KXiC zlNE9(Ze*D>V58p%soD>G$Sjg3k0WDYQrnu^SW=|Op-e!y^SxtOSOAl{5N1Z zQDqDW&Drb3Z(~=x6>(od{D)9i zAqH6#N41i6D!}uUR@8g&V+0kUhpDrC9g(aQI@Jv~kR6v+v&<8!XCa=NoYg1ltp&zNRKq z|1W!tK@?WvSTCtt?MEvqBp@1MCNEc@=>0NIMv#Y6MkH6NdtSrf3;ks&s&=m6L6e?< zW!8tbaW}wx<(QuPT0=lw#Y2Yb^c8MY>nznQMtZ}R;ja*fkg!JKBld0CFG)+aQ5kfy zkmBD4^mvR$YPGEi~yuBBD+t zuNxsDp~Dz>4B|UumAFfEthqUzA;-yjWn7*YSHC{BUMmXI{X4qf9BVJ@S&&Ous`oQF zX@${1M4;QJfZR5BrEQI5eeUd?A( zylJKOM?S{=nHtyp2E5<98Ih$A49z(fL_0VzF0r-;DiPmfjb;vEp}j&yD2^DDZf{i+ z@43TKUnLodbSQ&F5Ow6}n%(2f*j1>kw({#+QhCq1X6)KbidS4PZQ4Jv_&JZOoSSPL|X5T#eh1#P)7APMih^gt`8n=Bc#DTDLGrc?Na`I3sVO19%D}@o$U$y7Smb#OVu-zMNHgT{vJ9k;8vHI|af_;Q{yCe_o zFz`qZ>f`wy+3USXqZ!q}0DWY{EosxIE{>(042$w^G1G6H`L98ZU-HT*vmwp$xxz4; z_}t%nin`)>=mwup`VwT9e^FA(wq@PYk?`brEplO1KSBi51*K{Q3WlR75H%@~n1W6y z!qo3!A}WubKxytk=&?KnbDIuIB{$5so&Fvi2s&MM7wT@4er$|bGC&`s$7b~qPa#Ukk=0mj|<_xAsNyJtTF3fGh{edv^$?R z!>)0ml*WD;k&puqx^6xDRaF&cgz3OAGtZ?JFAsmQ17B-DyVHX)Hh>X@b))r` zPdO1Hmizk!L z3RrNQD3OsB8dVITAsM_nQN(aG;K$jutpd`7bJe#x2c9yFXkXr_&|tkn7R~5 zjVHC@Q?((s(;y#_RM5yTZb-f*tK^krGA2R z%2zw=O6VvA{Sq8}rG~7K9}`fs6`Jiz6cFS5K<3O0_R5GBWEPxZk!fSCa<92EFX@6O z48+Cfc;|*KA~f>0KpAW*R_pgt4dlmeALpBC8k`M%KfdLgvw@G0K#u555^gvVK+rZ6 zlm14){v9pxtxkM~fZKWrxhvnuI(1A*R5=l15Cvj)o%Cyd(ZDxKgZ+Tzd zEZ&6`!NAA0R-Phfd8OWR+&d=j?5NJ}^)qWg3e<0RhoLtR9f%M6+juI?^hmQ%qnQLB zA8K+X0^)sca}6I66NB^vw^d`JFUe32x|{b4^^O{P^f;WAA5@`Xxqd=yZihcHJ-@ph z1K1>{zg(gbRB-&LJ|P2S$?;^q@E+uJb@W_iYVQmgj#BCU(j+2EGcr zkKT9X2V%pnIiZx2!BbFjeZTyYXRHSekuEg$hp?uXo5~i}@^Cj;&<6NIoCYcUx~E@| zqi%%J3=&)MiN`{Hd-v{#7Nd){cg!C(D;tbw(xy#y8Vnd_c9{|qI7)C*n0!*S8{)|k z3|Rw&Ab(*j;LLG#DFaj?eUS04kG8IcAiEwHDkJ4}5olymq(ryxCrvi@Oe>)vmKI{w zDl%_F%qL*XA}PwGkyoNe(E;XS*h4fP50alb_xxAY8@Gsn3`q?xp?K*`6G6=Zf%BwVd{SD)x>>c2 zhiWs;-tL+|%R~>Ss>t7=L5&Ba#}7mL8mc5r2^a5`!&MMFQvdn51ip-6oxnJ3@`ZEm zV1sHgF4)ftC=NU}Ut}LeU%erVwq6f$7|kNo+xID3O0z~yQ>ZgPzNF!uE@2Ru=rX1c z@39M%E|XAik#Nc&rTQDvXh(U|VU9pWU2s)k^4<*T>HG=G*0I{rz%upr6d=I~(o<~M zDGv}h%Oy$A=I`_CDK!% zfIfq*ad&0cvfe?yxSay9#Lpz)ePjZ6AiN{+wf`)q{Yv=hph~iaXzQHxypYjnNqoL)v)z7Qo?Dndsy9aoLAHA=JuC|=eyuWyG!dX*Z^U0DNy^v*0*uH z?e^tr&v7ixUImO0Yt}L^59OSRYvfRYJf#)=ZZ}(E|M-13&B{$m!M95wc65PFhcBA? zC!*$SP!Ju0tFbl9$vJW!6I1Zf;Z|*+bQ{)4+@7*x-{qUI+B!A7r~UaAZELj+{p+xc zmo=5AGetxTaZgFO9CbHm0^y3+^v{oJ+#5%0Tc9H&ZR_z*UU3Mdwxjg^$)+Nw*N{lLM_iV@OcT=z%Vs zf#gcVSI;4+DZKGv#=&FgsZkop^={}t?)Dr>b$+AuFzlF8zHNop0%zt-XrYagE3Gm% z@fS9JGFIw&hInJ3pKH%UqZEcwv+!HJOfyw}Jm+)D`?t~<68Qi}3)3mz)`;a2 zY{vGgOKxs@W$<`LO|0f#3@TcFU0+1Ai_JZAUsY#^{>!_-^%CO7;oJNTMXE# z-gjkuc^^{fTbkXFRD93YzG+;eL??1yaBe2=dvx#Z~G#{O?Jf9m@2D^U#BP{ zkO;$NbRf>z{5PE!2P)@8uGKmT>RDMTt<2osBbzVDTGr!VZ~M|lcYmKNYF|#^A?9)y zy7`12+yHOqc{e{6ZK4Pwm`DIF`tsl;kwm7c8U`!?N223QI-laYvp7VKEV&W)QQ4x~ zP61cP$!orxSJSNp4l9zyBDYrcEXr9+WcvN*c5bZW4t^}XmJp7+Mvk{4$62-#`R`rS z^qcb9X1Q0}=ga@b@_$KhE3BG|#)eg4K`G5T-haKa(qLaXj>0aoy00@bLyP}Kx;Nr8 z$`9=ZJ5nuW2XS1|bb@bgMvupK!mLy4|CM-A@G?FIFr zb!L_2GbRZ^pVxXjF7)YBGR1cjWdNcQW#4_LcEiQTA-aqDbdXrZwGq2zW={z-fV9rs zS+yrADtd-{+&bi@F?L*NV>6Sa@rnf8!P;E%%>@f7&`vMFug$um`KNZ~+i+S%C@)*+c(o$Su8l7l4`IWD;ZQnOEpc&byAP@{Jrhy_%6%0h4PiC8e8&FZr&S*&i zc!7Abh7E*9b$g=I#&NZ{`fX;N0O^4)TScWEBbumPe0|=zkjJOCGjxg*4J1hIVF0Ts z0H(%bWH^KjIl4_k!|=JE^@ShDbW3v~i{)CoN2<~F5_G+n@#=3tQ&1es#w8S_7b?4K zY-^g=NgL>74YJt!E>!iDlG7QGf`vVRq*GVoFXv!FkHgm6=bBs2wE*epG(vB%;&=OK zcZF9o07I#b@=Ht_!;a1FSIKl-k(c{14)JI4@Jf*y7UFA^xZVqT_j>fB2SL&iO`3dj zF>3+P@^iTSsQUL?p!IppK)Y@E&b(>-40`@gGKDq`fY8x>7jAAIpL#*rw3wdjohdJv zE??Vg$fu*AB8k{nb?ye2jEvft_a)6}-##^?c~w>-MV5{<*rsi4H{(Y31JbND!r_^P zTz^srlgMj()xNDO%3wCLXO}&+%K4X7c=$pYA0jN3bV0lN(dTV6PKE4mmLck%VIxROL}UeDA2}tD*ynoy3fdab46UH%j{fFYqJm^ zCN5R63g{e$L-}tRY2llU38I1B51vS({-%3LKU+t^sK2&V)lF>#o1zGUEfDp{- z7JWai*G? zxzczPXjh?^YEcH*5q+~Qg66Q1)fAc0aFY~^cO99e$12<$-Q!XB!k4Z8NElVgZ zV~Fw6Xw|)shs+Hwaj$w0Qc3qY$xCx4L&C{;SNn_h`q!#DZGHuP59Qw0Rj>HI?uji? zi&_%yMd@g4&LV+C5X1FQ^-ypcx0Gu7KHqkES(xnaVGIv}h9E@59<|uArVv_dz*3ZZYss8w;M_=FWK<=xS zgg8gBfklvoC5__k?GTr(PcpNYQ|F4Q`uhab{Xf~_P2)kDc<7~Sj({c$cO@S0%4skf z-Pw_itY~gd8f2JGb5Bf8%c5<;#gaG&{U&Ux{LMCg_Gk3iNV~<8-3MZkz4?*^MK;38 zeB#M=y)kP7l+In}&N{39r{6#w7e55yzvAQm(4pg({^)ix!e|@{A)>+V-F1u6dlD`h6K$61Fbmnmu>9Iq5(c zVXu)JPfSWB2dvG{MPKGD7>JTn8Y~dM!8cGY@(Dv*5 z85b}4NIcu_e|6+il9B@KpB(({!&M8ryRmE*o?1TsU`M5vVajWNK~IYZfTQh*+{fcO z$5cP&-y>iy#5H=f-+t$(ODmtP+7v(`Y!GM4m=N#8hyH5oviFPV8fscX-TAeP&*{t* zTjuheG9ZYH*H(~3F_yc*;uNa3UQa*AUfRo_4I4TfA%FAFKl9~4b%}C(lA4{YGi~5^ zr;{IXIMUFHkBeh>oM9;IGWs(V{>)#r)cp91`X`LhG+1MTRJEJ@xVVA^@pG>`3HP#x z`xevvHx^e0@B=a;NCinp+nxv@M}WkjwuK(p$v%W1Di-n5tvQPE;G7N1P(p6(<|S>G z(>CHg7}h<>G)mC`dth7*4c+XN%`(9Y>L1{xjfbL9{?=VyiWPA3d+zZ)FH8AbzQwy| zF*V)7|H@Iqpt_F=2zCNUT(m?`6BjW)6V{Y&hmb8?FoLVdb)zx>2JV|{hHUc=^yLHt zin={r;=Hj3Bc>dX2#E`o^s#E_&SC19s8Pu4#UP^@5I9dMX5$$L>&@n~3`|U2$>l8< z@WD-jO@oTR5dg6ng77)(WcuE({i`HPJFA3KX(on)hKcP;eAolASL^k75d*fGR~zm= zS4PkH%Je%k7nJ@*;t$8XAHjcCwiQohwJ6`5lP{3#&h6MoP!I)zkA!rC#_4f6wvZRF z(jj7$LUj)@yGy-iYn@k_CO_jE5 zPAHZ%b-Q}~V3W935ei@tOhh{P5h%Q!kCMjBT+l4=WlK|?`-1VlQ6`*u?DkQDi+qi0 z+5~oIQMb!VHGU*794uP5)Q>+lSMR?o^CAf_hkU+Ji6VVHN9Q#efJQLck$k3#-=dN; zklUmA_Xs^DkDE?Y)f2*G_|sp88M6?aoJy7WZf|+9H7UDZ zT6g4v3^%{>h`fLZG!b3R*#jmmd>I7ilc{Gk=7qBbnBeEfYvyNeg;)B7oK&(L zZZ2hNYDU`~2M4N5I;qfYf#Jak8mR?Na|%`SpD`knFrtZ*f7?a?;>JU5h7gq7=lcVu z@r<{pbJg~aJY}ru!xTA|5fZ~zTe_)~dF9{OTM*0?qt87)$EZ})tnS;#?LYG+>J-hS zkxTz7iv8n`3fi6mI;JhpT1|%DMHu#$SKn#eLglv}>xV8r8-pQy29Vl*>4G?*0qh_( zmN3a$3c$sD_wUFezdl~!fNz-HstlHjPjbCYDDN2a`Lj@sF$VKr^aCtS$s^rv*WIW% z6%1eBvC+P6{JQ<=2-a-uAokt$j1MIhFDE*`yD7z{3)#1>HPGD2$3#{xC}dw+4>fbL z2N69eU`U`6XpmxJ9bDTZ42)e}stm(G2ZumCwIiaI^NOn~D~IfRaw}^o8*X(SGty5b zpdvyRxsL|)l$Z~=KRwJTUXn5Csv>8|L)HErzLt429`eB>Jgu})o@N^@v`Mq1U6^_< z6;f(D*-|Qa{xH7&f!_1=(81>|Ky7w`Cfg)lnsqmDcWD#cC{~^rdb_X8?6=^8NkR)9 zH(VGfFwtYj-nmvK#&C)7_ComzXZ(*?aMw}w2GqEQNR8yHtQv9Zt75P5q#pP*E~CNK zD-SCp;hQ^;BlC5u`4qX+BX5LZK z(#POSXW*mzkXzd9XnjEMy3u_bt&u90&03Gy?)-ps%P3tBg zh&XVh6B{vrjPqZPjkZ`m%KlmJ zaN(ODBrZnOuonH}i-uU9&`V-!4FGf)a;V3%|1#McW99nr>Pwo7R}V_~QSq9O0YkQs zV2Tt*^cCERN)+bOJ4B?@@*|H}eS1kKE3&U2&f?=gqO>hXwfYDe=VeZGBrV>VKF(*L z5>HIfA~AL2zU&Q>f2F7BC+OsC9s!-R4R>y2ElX(mQz&3fvMP-+KEM&C&ij~|)mPN2 z2_M*%)&jLf!Z7DxvSjmv_N?nUIH{BBP{O>cHme6!xy|cN$3eib;%+^zE-xjrntCdp z^wP-nWVL-%qOnwCY{iCJvjTl1a}sjL4&jQnkgpZDWZ%kdH`QxD-J~c+%}bz|sw=AU zl4tk)Krum`ut9Ea=%yN!1b+Txo5~F)nGl*m2WKR=gE=Kzo(4NpR!BDL zwAtY(usb_IVO(h?)%?I=xi=BFaJcx|sY%+hnr{@1-#mq}_tw+1`8DJUYOq)ijvJ(H zD0v&)?>>u$Rc^>=8sDO$VpJo)30ZS3JOetqC2hZKy!!fCZEK_SBAwNbiTW#z;K-vr zzx$J=(nRC0YrFeasow_Y{_eC9X22JbK=m40gV{5_*inume<+MmGec0Mua5=?msmx^ ztiQ09idDQjH*KXe$7P^GZaZB_LAwCdET^HL@`E)Q<1GkdRN_Oy0m4!irP${y(9 z@Je(3-fFp}W4g5fG=(m)?&ZGBg@hK4iswuSl)w1KG+xaNLb1P5fXOvpUW9Gv2Sp7B z2Ra@zfO{fTZe$c(`rp(1VaT%y>>jJA?gW82E~gkGRX2u}tEVH@%*Q5`s#bZ8?dotJLY;j2`rdUa+K7`Lr4(F>K6y8hqHh>v?@IJ< zdq3V?Jp92&(8;OJlvYt+Tt5qqEtM{Nv*%k#e(MyZ$`9+TgLv8a4+1YB;AuZ|}A zM|T|w`1$G;Cn%Aa@~VMqeSBQWgM~{-#{X$B0KOw`QT7udNIF611d5DcVan(SFBv?N%Y4Z(R?ch zb(||o&bIjPFTAhJ1SLx%T=nffl9E3 zfROOb;4t&s)*Lik4uFwR2OW^plbf{O#fg88t| z`ag+b;4h>GioP4BVZN$Ep88`SpA+$;`UQh zLTh`Ba!}y1N3f~)e^O8xPZ$OIsv~Olm?zobDEzpA3r#h{*;YnrNr8Fd>O8*Nmdy$W zZ8rc}N1&5=Vk>rVO|Ne^dPR0njDp&Bp3!euwLW{f9q)7p&!Z0?m~+O$KQM1pvnPTS z@ejph2{hfq-h)~1JFD+bNVfRc3mHnGz4>(YynOzqJOE>2If zuiw+v_Y^o(P6i_a#_H;@{%nC6Gvv@dJzF>8)K}3y8T_92dGss6*_Oy}d{8T3U=j&o z5H8W329gAVyR@u1|D0mev+j%}Xj@@LgSO+C5bt(3y>jWp_H6J1ww7yo@^HsmhI8Sx zdV6JsbA>#O`G`?=R=^;PH|bbfgTDKv)$Qc>#b(jQ4b6dJ_?subDd z41ZTarEoCW%DOgzJ(Qpe+pN+ttRVzEBn93*NAXLt{!ca6hK_IC~U)TZM=p4J)(5F$@dCwl_Y>RZQq7Q6MzNS0GTe)v*JxYxootOa04{!F^3zQzuE zrIjG6~zqasmhjh|9O+bJ9 z5%yz=(~hPV3mW><^#`0g-UHqHETr8 z%y$E&$T%=SmXVR&4)%*`O7G^4OsVR!S8z-vkNAhmhV^P%cf*s_@BG;NJ5!%X1d|^y z2(d+ezZj+RvP$F(i^-Nk`dCmT+N{RkhQSg!uQKO%-3PfkG?&24f(aT zt^H8P14;!swY8sSw=UWH8~K5S9~kSdvIeu4JvOtN%_~>ssa;Fn{IF<%!JiJOMF}Wf zAJCp1E-wiKS0e@{WvK*h8!WoI?%UUtvXoOCAp=tdaB{7TZ07lu+_ojE*9F-w#fL3< z|Lilx$cRE7mbJ3f@@r@lr*r-!yi(Mbh;#d>OX;Y@mJAn zbF;G$WqbDTBnJjATCMf=(yf;H_;M%0Gymtw$v-4xAfG_hI?kgY*(qvTB+cCEh+s?By6cZ{3oVnqg0y(B-hGzN63dCicXdp6;AAd zmu6qzUxqc9P^MLU=SK;kNGsxA_Ap@$P-$4HzX+ywImC*>w84Q;aM4I7W@O;w{qnMz zFFYrXovk;syGs6fQWOb=7u{yRt=JWF*OE9QNx+jMh>VPKv%YV_<6jMdmJRr-iY@f` zfS4#-O|$u%<&(8p-Z*GYDDk2-6%3@IZ?&y5ODMou3UqdaLO@g zXT8bQTM#p)(WagG^R0VU>va=1kyA!YdL!0tL;ukt?v4BXyw?cT9s9QZ(nk!7FedLqE$ zx|$sNFe~-RGzHl>59STqys%7^;yY0SjvUgnvk_%oUF6vOV++OtI^e+*624pgr-GrQw6L@XZS2NXbV@! zcF|L{z_CweqY8xXUqG23iwQF}UPTu5Q!z?Re*75@Ux%TS`vuGNDKsiG~kGhJqJTZ6h`K@DAuh zDfgF_{Kj*Wh}H8pQmKDXf|sKJPJ@QgeI7{#!oybiE<|@BSylxH7Me0d49P>^M@@d_cW53<|Q6ykpOUeDE(3iQ#CSjVy?V(cdGNP zg^tcpJ-%*Ba-8+-+4Z)W{rvW!R>b#_=visRJX5VZQ7jj)S7d3k=dlY0{-%u?&L=E? zTuFnwnq7{cM$Gby(Sm9B3@1CUJT?n+2_`E^W69j>@!r3Or+8gMz4Qiw;)tkR`_`V2 z*Qv;xMNfkQ2N@GX`JA9gzYWVG3%eDx{kK_>!@dAs+c!9#R*<~cQAIvjM#zwcA5G>z z#zxANDZPLHTcBXc7)p@_Chc+jlHu&!)u66#>|c^%DW?*Jb7jQBi|6!t@m*z4Y7Mu( z-(h*%W_rDD?VQbXBHrDtO!di>kcXX$|IPh^=qr@fTmBjr=s-kZO9NB)IZRCJEoTEW zci56$n5aJt@IFOyVANJcVOuQ2Ru2Zy;$L-72rG*Im>ZVC*97+q%6z}Gm?k1vT$wkP zpEW8+;&{GbT)p5+g$LdGQ0NJlnAnEdS@`?(MRv+gNewDcDAsnxT#Q=wkak%<#;^y}Di2g0- zEDzl=FqQTuEs|(4DLh|iP?U%P^fV;`I!GojJ6aF2n+cuQj7ybjQ7Yd#-2vg833{UO zk-M#lrBr5LDa(~{bfDlHAM6keW@;9*v^e>`80;<`s-=GwX5!c9VIzlva4tT5*As@G z7Yyy&VXEa?V;6mSnKb%Muryqb`7vF-vpQkCAfdkd`#uhwL>NrI6z>9Bshp5wMh&Oq zY_^CSF1ALmF-0x{>lxX#x`FS>N{8&QYcl>It7abGy*tazqD{S&)s<=G)Ad*33#mAR zmW?uw)?ndfzeh6p%tfSH5%d!pwX(f}P*rJDs8t?*lsn?8g)!#nxQzo=qG)j5fHMA0 zlv+chiRm;%^d z2JllLQnCCC$=36Rz?JBPndMm`EaVl}S130$*Cqv%sc5ii0`_<4?lgAp%&qZLk50AY zxg@&O0&9(#%fMgt>7wd<6G#qs05-5A#~aNkRJQhuC(53FrzP7brt2tYJFgUPO0KQV z6Al#%RH4D8qHRFw>w8~d{(B=X2M;+kWf%<#5tc)OikD|O91TV7x0j#)^9_Nnto6^? znjxAG5;6ZZIP|-QilvehhrPg%Yx2|z%LI6eGsmG~&z+eXPEeB>_q?2JS+!EgguLqZ zlr)(QYj~qXv9u%vYb~)a?6TY21hjo!`HR({Em7NSjpGqdPaW4gA)D~%VVh1)O%`2M zl$bGhy!<4sx8^Ew=+&HIl)!J`-1$vxTXC~v36T5m#Lz)o!EPP~Xq z;`vI&caX0iqB~NuWryx9?!WV{G(RCq$bBtPNqVS$6iw2%KWqW~z(4Ngzu|;xaPjkuP?(d`RPG+0vr7 zGo8=TNZ~5E^mRIg;DKQ2bp3tQfBskP`mLq#Ofiv#2L zhmWZr@BVc^y?l_`;@U*b5#n?(`s)gqj$iFe` zGhhW%S4HrF+!3O0zqcK;SGsU}$3Tgr;ctvjMD+RO#4SE@+TV8}*r+LS%5YydI}?Gi z*=Z)Vk83<~7{9fer+{EJ&A+T3%>`KM{aA|L-!)>ZvKya##*-${pG8ZB?D z(szRS9;a6d&dJT&bP{rjz|a0*av$tlp~sSa-{t>2{Gn2sYv=MAheM8<P1wD$A3&~08sy4TPT zHaDxnOi$NcZHP!JYHeDtc}YaPzSm&M>Woobtz(&UYM5zk&c>$Q+(W_K@iFpRFZ6bq zIcvC(2|^`WTKkppqwcJrm1@X~iM7HKbK8n)Ynvs-VMq572zWrkP}>l)eX@e^Q!Kvt z_t?(j>CrTsP_*9~L+g8c@&pC_V}l&CmGOZFFrke!otCwXuX{o%jmJ@JyW@H1MReWR zdL?NV-9{d;CfFSM_&AXK^(%Vr7i|?Siz0Wgy4J-YM$Nj$M2!$ROG!E=4v`=1f9@~4 zNqJ&R>VC=><9NH)gzn+s<2RYbB2VRUb{XgeS^TB>yzkP~%*zQfbWuuncSp)Y;83LA zWP2w0--h#^L>avW2Ap+4*N+B2YFg`@HN6Vs(kyrT=$P#mMUdK-t>k_cF>_mCu2*1^ z9GokQ`M6iA8!U~_Hf;S<{G>*0$~CWFB$wA%44OVMmw`_B6mJrq9f5bPzUCqjjO7ex zPBXPJ=ZZ27icOT0aCo}1b-r2<5QIAq6F;_M$KT5UzhY0E{Zw*tTK2--!a?PdJ9XY0 z@R?lCO(y#3ABJXAm_2Rd>}JUc-D@`y;D%2QreUg1rk0flM=_McWN9;@wPA~yFajX& z#i7dnFt9b_0_P;b1^23h7DYU~7+pz8<{(P-WPsE&Zk&OJlK6FFRliTED^-s2e%6Kn zg6=pR8kwtx;U8Q{sKdX|!FMo+3p4uh#k2h8dznI-9VIN9;MNf0_IoELx_>6qTefs` zMa>XeicV0);@&Gub7c7)Dfv7u$$WdOzZYH>9&dx=_vFaH>2C+!Ys?4T2_L3@3^orzPXr^oAJ-G_Q~o74{c-Z;t={i8s-dQ=qx$hU_iM z4mt`{=+02F7$D?N!2^PWZd0g}n zK}0k@y8wpDQtB8U893%vB$>eTjxu8F-@oF0(H|3h;elrYIWuYTsp>&s|AUC!nG!^q zU?z%K@IFRBwTU|zDa;JWUS6qlwTlT}dU4#Y$do#P&~$w<6&cKCi|_6FgoN@ct)AQO zyz{fM39k3yNHM>9wkX7;rjW@zpbryB*S>~ zeCygZpqyKrfP)su;BeP4uMKa7^;mh30Qx60{?hs~b@^p%q`>jafN!x!#J~MU&_@*0 zxa`}sirzNJQ^PDEY0lMHKed4J=QmJsF>!q`M#S!}(fU*Bx~k&?Q}sJhkK?8Ix%{F2 zKZhxu;?S!AC@53IyiM%3o9@Y(6=yg{P*}N@0wztZQElMcuI@#L7TwHs0KUYudc)rl zbOKin_Hl0INoW!>Frn66;OJ{P%CNIQ#a|#h`sM&4*&9)>*LOT zeMQFv8x<9J;wB=|c)ztX(>tLQmGUG=@FLeOhlf)n-{cvrw0{|5Xeg7CbOY)TLP0@B zS1`J5f6(nI!D0VL(+Y|t#A-u77I}i%$h-A)lercaZ-RiABS%D?j6hx54-@9Z#4Fu+ z$~rBFKtMtFd6>t{ANoY@=-kglLb9@dHHPWrG*Sebc+-ah^+{qTbr!GtJ3Rghy;+dE zk{M`zY?*8-(Qm>ByQ%=EhH>vs(tGW}5fK&0MBp~Ba-#DNpCpp9HO)L6aJvLS!+G3A zKGg}i{flsTco;Da34s;O{UXkA`Gl5HXv%l==b0s_2#q)OO@tSpe=cin(O|^Y;Uh%~ z5+(^X*kHxIm(Nt>h~f8BIK4EoC5lvr^-{6aJFy@_8TMhkFB*w^ye2B z`M$eN>V1TF-1|japiM(V*a{=BR*R< zSmQ%cy+Nm!RN?R-;}))Q$f4V-|CGG%h(`S2b9nPq8mY`+{hV(KAHES?snq?6t7pxj z(}JUGKnhC5RO%iK4Lp`m}R?+8=4{8XnmoN5~WxgT;}4u{G~isesnT^ego{r2W=v zE^T&y)#EOl5ujl$Y9p^)KF|){_8dR@DpR<{&v&W)!@3^-aicd=C+iW6{?#lD43_M5W8wKObqQD4@bCe5plUy026 zn5AF1>rHK#^-f7T~!^?0I+dHS_OYb=vOOWJm%B4uXAv`yqMkk-9-|&M0XBjWU=H3cUx(b0VBjj&9>#z?cX+I*WCSsF`{XR2vY&Y=hZ8Lwb7{ND zZY~VGKVUrg9MgLfC!6o?EXVoap2Qa);+*DTLIQ}ORXt*l9CtJOz)apBZB?|<1r1LQ z$J7l~Lwpl;tmsubU;Cz}unC5GZJK(_>H~`{r->M2$0s_Y08+wFroHCFJ)S7d!fj1| zOag^LM%?UL+l}|pN;J3I^Yq(kV7Jr8N|)tiyQ?o?vOr&Hx?XQSC@D)8kY&(zg!4w$ z8SLP`{;C#uzF@MQ>T13TnEEy>H1-D8OF zSK7Jt%NDh34;INCn8=U(mL#fu4xSf!B74a74uFpT7ZP z@z9j@WRF=%@Aa${COT3$W>!C3V#`e=*;M8~j}Ip&(Ohwh``&bNc~A1Gkl5>sI`i_m z(1NLX&~L^BM;vp;)xmr2{pejg-)N{(p88A5Qu@6a8{}#boQdQLi8;!X(UfrJYpT8`O*Ru~j zskO!7av&MNq^%w>Lj9#wHlzjrc)`EL<;-CWXvmFIQ3$lKnS~UuEqoQRc1dK`k)}%OWS`9!Tnv}sY6Me zPz6BO-NWO3GWKLHXT4-oIzGanmAN5kPm`^`hMQfsZgbr*C5hup#%=dIYkf5D!ht6V z6*iYQ5wkkWPH=H{dxUG0<0nA|;IMhxyCo0x>b!?e8hHRscNX?Q@Bh6@gSm5A#JY_# z|E4#36qk%Xyz2IAdx~Fkixl$P`|S@URj}yY3Y1whW>KE4|8fAIqv?nc>Of0Lnbt)}&_w)=nR$xiB15BLjmg9&z{ z+#S!s?^reIyK)go$O*)baW8wkCF%jqbRHbjP;Fk71poRZ!sB&XUFW`oYyg|`w*{m9 z2H+U>0UTW3m&BW}m%eExj9V@9M8SDKi0BM`CYiw zrRRe5;i3_$Ire;k%=G~m`Xn3IFN$$5@4bDVRbO`mMO7yzLYU)U%#_x9pR4`yUZ*U< zZ!EsZSgX1rKiBZx%%oDIcA?Gp7JP$A^-Bid|E(!Jh@V!rme*Ew*2ujiB@56W!X@E% zJ!G2H|NGQ-^Pj~J@cZ(44F4jd#vp63K823kt#Q|H(kp3hqN0iwv!#^Ldv#1@tepas z@43}{m67c&1)cuog%5COLQl^>z8Pc84(?xS0CqWvCZH+9_LR2)y3O5HO|3=QOB{CN zmAR}XZyLCD=d0j%H<2$H|E4{pjEM<~e}@hm&sgp+F~U!jGY3?atUu52-?lt(A;7K) zVd-<+1F+Jjn_|JLyIB#=R~FcURggI{opHSN{O;o|Eg+R8VI64t)2Dw&bJzx?mA*9N zZBjerH8z7^=#djR`+!?1GJSQr5ElgWka`c4HZXa7&s7WP>7%xMBhUK zj%gQefe#0EJf#VK?+tO6^969wk9l?cS$4!$9jG#upr~Y%SXB*;Am7)A%g_76k$&Aa z<{7g8xQis9!3fZ2`v6d%BRgAal@+Rr+W-47zJ==Kc2OT!&pNmra6fsOU2lH+og>Pg zG|4)n;h``(VgqGqNOd(|XPKJ*x{_X1__EHuz*#C|(e(%o_VR&}?a>KD$_PXjH}ald z*^8f`;9=gQ5NEFT@x7YQ-F5Fx(uikjqtzQJ0+D8B((HC4!N^vr* zO-)iq?h*t#f2nWj3sB|BP(!N#m`afHcoXzCCz}789(H|bMh;s}0t4~QE%{qRavK8U z%mS_2Oxs^8?UJl2xuIhtYkA(uBW~T|`#wJYd%0?N`$5}UmnJAbRLyQ=(QCe*< zlU7Z;CSLzFMO1JK6oixacW8=7Z)YUQi$|Z!+Yb8<4p?Q%Se)sX3bnjFm#N;P#chXx zD^#I9iNl3F%e*e47Ok<0MSLFt6kJdV5rU~9FdTemTYd%QRc|Eh>BlN2bt87I8ryb+ zA$c89sZod!$+kxuj<1bd1Cd4)@rVP`One}@!U_HdFw3p`OHG|W7mj5hKyU-F;cnQZ z)^tuTzrhfcz3a+Krp5kaNzfegODcjehxrJ^yY>}e$ z%qb%D_MkoKFk zv7ubvcg|xQ?k<6eNopH}LxJ>mq^cRmhlhurlC;@86(yOsy&&Jx^VF>E-fUPi6_s_t zLzN=qkO*aeyu`XoZ)BE3(3dCIV(L~kbU$NwfxsH4#a2cm%iELFwU5`lw>yhxPu{Hv z*@0y)kX-p^8W45j zuy%h0*EqhrlvtHjSPg|e!m)5z()01#izgnrcpcqA0dhbKAJv#qtxzFp;^QspdRJCa zu=&~7vAnQsk>S1_3V)s31%%AloQ1{1Q$(}3pX!0X1`N^UbHj`JMdlt{bBt#3^ZO4Q zo7{2CWOI3DX@YxlI-QjCa&BvHG3(cuV*CyMTqqVAC4G;Na&)KZ?Avv;-!pJ6{mbRo z0TYcazT>V;K~4LcUtV#cqTLj2`{?OUc`Ab>%-Ph}6a0Wav_Y-EuEt~A%(&|4%4vuP zLQ(2Pb(DOcH=va=3wO9>Yz#ERQ`AH)^T4u6>)!jFNbToLh>W^< zyt;2~<%UmsGB}8Vao~c8BPtJ!k4Jg9sfPkXf`++*4ufRL*64IK)})Uyl`jJ8=nS+Y z%d!g|GZm}O6B<-nlC3{Q95)jWnYBnmlJ5$BZ|7sIA5`!+qb=whDb1d-3bc*|2{)+g zg3^j;4sT9{CQ8SQ+%_~i8|8tDRSVC{BWcg34h#g1h>h({ufKmX8HD|u~|H^ zK@%cEL@AFKcRVM)Gdhpd&~$5%K7EQf{euVR4(eyJ zKA5DHV4F&g@4&W^=7seV5{AwPR0jKwz~EHYnJw}j|8_n$c7+X(A-VTJ zr*;kgmlT_MR7eM*q-1Z`7}k)tmwRncVk~fXOl=_7B*nNe}g(RiD3N~o$I};2?P)HM2w8cc8m(!eY3PG|3nrTJ-vWb zS9)3q)z9jT%ou-t@)?tCYYnA<0YhYuZG?Qr)x4-GXQJ2WD7QJ}j34s$gf*z2DXml{ z=WSkdxzliElgz+ENLd@-I17#2GtsQX>$p{u$`x6coDGr9#n>&-fsJC_9h0APSii6J z+qDN_!RYM|yZ1n3O!XE8hRWF1JZwpBbW+7*MLsQCH5#f5`wa?|z?-#R8bJQHeB}Z2 z3&lh6t@}85B!lht^5BvgSK)&Dq$DH|{oiANsH>o;XlZMuqyP~}U%7BqebFT|H|yTj z>Et>4!W>zBbv2{)GsilJf*qo_w-=c4U6(nLHyXg;xQ z$M-h&8#Ip6o$wvA=HY$7MaX4v6(2{?ZL2>Xcm+(&ISX%IrBSSS4ARS4bSd76>G6KA zQ1L_0w}tToFo)xDU6t`=1$Bt+b&Mo_G9+r`>#d}v!C#xBm_Q210~Dy%kJRYu z#cjcbcx&VW1X1uOV6-koO4tm?7R?oDl?`rwNy5OLd;~Xlb)o+G^CgW>GUzae5W03L z)=z?JsrHtjYt=QUm>M254?;#DWqjS0yMGOm*ExkrS_b{9wQtV6>X_+gvlcMtVZTS& zzO|jho6C#|0%Y>jHVmT5{+t1e+)M^P%GF-x`1XauQbgF0;b1(jb>E#XXE_)b$;6af z#JU{qOUbBV{dLcww#`pPd(>!%uY|PguOJV#!6h1Jy>J@z^m03;0ji42VJ}`^c~r!8 zsuX~67JRkrpw4DPz?IY*os`HkGuJr$FKX>r-_jlKtr)DV%41_=rP#tnP24f-4~i~z zN){A|DJTa>NJ)tT1LFvVX)(?LAZnrcP&I^}?YmC@NEw~-(Gs|IwW*sXkh;5lwnU39 z@`LB-p7WiVvK}{Tf#b+UtAY0C)-8<6Vgne6mEJBIiKBwkH+KIbIjN4CApn*xS zm2ZTXo93y>eaU{v>gv?Ln#A{mn(uyZiC0Ts->F=D2$Uazus*uJRaH-~=SXAl<`4mj zeD1#JsJOj>4FWVoGHu$+ynReZQa2lq*q#wgHk!q-FSvOR#&!QKG&*5yU!#=|6rRYL z(P34$q4D_oIkm*$=qmZNdlaIkibPQKc(9Iu62K(T2C4>m<{={ayiS~i2gOosC9h8r z0`-&v99j!Qov`itAL9f1*v$L#!zn0EC-!D~| zp+G=pPDnVmibbng>maL*8yyemItNenv1%O2^;lWYiMn+`*1=CG(B9)@V#FvqilP#p z$ETHoxHP@mdQ^k>_%Rz9dr#uE(U{F^WoBUfEGgMCkdAI+p)?zyQ>K*Pd%z%CA=K1t zm#u_TC9u9WOy{>ZcT?HB3cYAR1i*Zw7I;#mqJaw!Kcj9{fLuv0_^v1m%NGb1MbH|~ zhCG!8msM~07D3(`dMpxJG#vCpk4ag5n&hwB{qb?lr!K|ocnpmxon(tSguCt?fP!RiZj0CUjud{4cGCu6C$AL@d923PD>kz1ihIY7$_uzLE=Y{>zMs(%o@U_Bd@Oziq#?*7o%mxX}D-=lP1RNMt+JslM z!~l~@*`2>BZ>Q!5^nWuNv)w(=&D$O>aqo>Zt6Bo#n|hZF@R^Gv$s|ZoNGKpg;3zg^ zm(T1td>?(hHYxDvgq7EDl~pSzsNLOqT1i zpLNx%qK6ATiN|OQUwtoLw;||}kT{=f1Cmp#`>%KBNjxFc)>9(x{$2@m+dN)fBHt#s zFNYLKtJ+lp9};aUywPOT`n`Iypnx^2+u^v8pO;hMc;uaXP=K~k{P>cI|Es6dSwkp1 ztFIdLSl!XtU;SnTEFFfBu5!Y7epY7*{g;&LB{Nl*;Z+h81te(Oa#q*Xh4_?l*0{uQ^cpU%wO`+RShdeQ z4m;t~xMqk2S6Q8fW`2ivyiva07wN2Z`dKh^YB&2vGGtyp9CdNvho19xEnI$_*zG4o zZQ&%9{>}K})atRh^9TM{(yn+D+gA8AJ7VVsOn5)&sNK*=lDWf}EKBEEz=aX3;?i5a z?ib$fC9ZktA|zf>%$hL#q{zM!eGHt(Glq-5_%`w}UsfTZha8;eY*+R6t|K-pI{78* zOdMsZ71G}5CYEa3QPOb}J@(A&Nt0r;R9Dy6XcLE*W51HRTp9aEw706F!6u+wX1N?8 zv7ckqp5S}QYoEi*w~uv1>e>Iv{A>%jfg?Yd%!~%+8TiFlR#fx?m(|z$Xd)1`*h3AF z5xj~A4Mbw}Q(xBSjKT3TxqOk5;+*61f6qLr1EZ)oYX z-A%OZ9ulDrF}NyLu}+g~&`pq#w4ZHG`wRtF%$(i%9;g|`Gs~tR{mgl1ZaOUvpi_cL zk;!ynO-ayz&qr-%Ei{b(%QxP^af-}ed+kJ4cGU6yeRL=$DBM`aFMqabC0CD6(`FG)X7vznW$4%D2 z^bhYwTw2SGae7RagyMRVBpP2-K}6|k90oStblH;PxJA%u=Qpxdd0izDW-kln|6-Zv zQ({SK5=Fk11^d?BavMit1Xc2wSg@ba+v4XQ38~>rz?`K{QDq}Ip8#?oXwFx~k$pcg z?M%j^nyoQ^#8#X*#dxX8Wde+&M_DJS+3`Qo*jGNd3wDhwd7NoIepGtdJg!imuYF_` z^0#q$56%8re>vIlh{`KR7d-bv$a^d>YHn^auRcExB~E8{=fm6DDmaN>A9~-rsv?7p z8wKNoTKa z1WbX8hz4v4l|-20iz(GCXDtXtLn_dM=0tB|LHLxkVBmn@$jZ&wkW{FZe4Q2t1^uX6 zg@Xhu(I{2{@d{Q(ImKQ`FP#774CmxT+)Q~{NzU5ka~`NjO#m3h;^c_~rK-QB#xi}{?3CuM$I!Dntk=U)w`s_FTmJH>Gr-Rx;-RC1s|fc~Hm z{*hw~J&OdrqQ#4Xxqskua+xqfK}}7q1SQ|Hzq|6=rt01;t3b&*MMiqr!F2RzT6-#^ zCPfZA&1gx}^@SaqOtD>nsqpgowAB=e^_YvvWF+2A>jV~W7r#=Za*4GQ()sF}zaF*w z0FEqJ%81zZlt1sx{qdo?REA4&1vzwc$AB(|lS7NRt*V={=W!M1FTXK-`Rppy^a*xU zL2iYfUG8Mu#EAF?T*HV+HIe#zw8?`7@-N(fPYKc9Nzp(Pw*zEOF#HJO0^>Pdc_Ar( zxVTBRuJi(PxfD?Y6hLrdf>*I)#Y+qZcftLf78esG0)}CPdYnH5z?b3p&lzty9BV;a zd`*Fx5wG^Mhx_T7CQsoGi5UatDIzv9tlOWY>EjS1DoTsl_ys~@pm0?U2a9s3t#K|- zCCc$$D>|)!puE6%u_8WB*SQi1d4r4h?--?(qfHBHruuPNF5a~|lv>>W8)ES}=RDc4 zJ_4|1ciyBMCI!=LMqsjR!{ZTssrvi<^7$@h@X>Xvidt%cZ)1=etz>xJ-gcx-m$VS3 z*a25H{68q3^DIRe_jrMOqFPQi*X~E_@a4yn zXp=D@tp26gsBfkys41PVLO_x3>(9de0`xEYjc0sC7s&^q9}6m=)}Y6lZUBc6Zn34= zyM1cO@<*Ke0hMFKg~CUaySTFQ8z#Er9O5xduuGxrtF+l<+vV!hQ)IVJmra?=$zO=R zR9$ucB&f=T%jS1@xGJOmY*-D?)oI&cuVBR3SSSnm1%+qzj88r7Wd7nH{_oKN_aD&M z6aK!Et2#Qf4{zJx+C-I=qg4;CvIGRii5a8Sx8#&nUgcfATkdxru2J10^bt`?I-g<1 zci6_;Z<003799_Rnl5fy2|ozn1c341uE>dFSxGM%3pC7zAlu=lfpKyr`|^~oQQ}nv z3S5wsVUAHM;JwU3-n`RmaKjW;)uJc?-GV5npwn@^i_eDcz~Jn9UfW;W*AnA0$U_C8 z=#Fj)&(`T2ax{*hf~;;z{QBxF#~5al95# zUCox)&;ie;rJ|fePKwfYz6a|FRh!mR~~#3f5;??&{Ew=1=e1^5UuTKCU_%Xc0IDZy$w(j z#V>8HRru#*(sDE@mVF()x(Zka>vHG~g1mhqCGDD;1p4fbX7PJJ4B$U@ipC_;DTk7} zb528V*-9%;KtO)}Y})R(^)z?0-(>e6rXmvdA>66rR}J>>a%^gB&zyD1Joi5YQ{?9A z2$!mid`N;9Oc?v-Tt_66`nfbIs)$7JR7`Nl#7=VBo8EGN@Pt}9W#lSHXJhMn{*)&~ z!a|fF1uggxo;D$5*;)@iI`3Lc(MH^3cLEh91rls{Wz3%)bz}<{t#uv$$s3%I;P9)Y zM3m&HeJrZjQm5@_d|R8=+s=%p0z(>mU$U3DZ6y&?w;NpQZ8h)fC)n21N>+vN>?~K< zsI9fY#>c8T_QvsviFtdruyG-%+Nw~O4izXUT1eQi0juKE;%lnIjS8X(D@_5JsKVwn z9MB3LRcE{%WI?a~ot(e1*;=fGZ97r_0{Z-_Z&;ye%#ht}^ABPM?xzD77W5D^5LSOW zwLYC>#iS=zndwLVF_NGlgMk3Q6hB*PCFW$%hY0PvMTkYGa+)D`+RJH|c%`Eto}X_P zobU}K^ah}8qo3c8sROe~EGoo&wkd5c0)!ZGa_W=8^uy3^MKB08yYZj(OLV74hyV$& zY2PaN{>BOU>bA+*Pe(;e>hs0m*oE@#1Nl1-er61|Eak~zR=`9rix2R@f0W9A*&CMm zf%unliLcM=OSW?xhP`pwp+~dY*K2d|%wHUjJku|xi=d@OL6R)5jA8qhd%too-1}4z z@$dxf)b)Zdfd-HS9#NMJ?_KarFvuC&)pRgzwU(dCl7NCrbjHIy^ zeNH(R&V%uadJQ)2jJF%B@I52yp$BeR;$PTw>kC-HGCV6 z6JBq_OGhcWA)GCpy5nPEd2(@suiSbzor93OW#7M*o)0N*y9mfQ z#RV>l)<(~)yNEAC7)Nm1m zf+um;E*5$F%JkPpDo zVM2pt@pPi6K!ao_wo+7{3;p>MB|@x_m)Lq%%zw>wh&^J!M~BWPd5*oFk;iS~e5Tf# z5lDiZ&uv}T5Oc)M+@`|bFz`(o z3xz?x74^`# zRf|Pb^?1Ec)pZ1SFSr-?uCk+s8`OS zI16CtlZqPnJz_A7%qD3nxMbwyIGuamnb0@P>7}EUYdA>eFB|W!HW&(ephp?HyaHr> z%es_zd@1I`>>Rk)qt>l8T99dMRN$Y^{y%C_JhBYldgLCH!5M<#!kb5e|c3lcq2oMADrLAfZ-7CI{{ zE8Vp!u`GoQK(?(ou|NV$4Vzbix4PxPymc*+KyjQ*;trB9O3~ug2$8g#_2D6q8y*qi zKt@I;vN1cGg_-N|-N16j&5p|WXFhNb>)RWJC!Kw}CN4IY6=*TKPY;4Z%I(2NfRS_>*xuPpuYVnBAE_N{d7xOEU~Qx zL4Ydx{;NtazHg_=I8?pa{_%vYe>~<65ndI((EJX;7YFHIsdB~ifWxF~_wuVfvrRWM z$<=KMYjzO>{UW7q%aZ6SF z+cSh8yD6(rk!6$~4n7+elA8h$9{!DFc@5D}@nMi7Cu4dS&4g0Cdu0M%+6&aonR)L5mvszI2{tYb9nu!rBpu2A( zuT20(A*%Cl=(hk0O@VLAQiCf(#7K+VJOEWAp1^zYapPZ!^;)l-gcfq0WX$jP4jT$K zY@+1zHc~|j-3mS_^d$RO@l8MJWKw@v)Kb#Z(>wf{l9AlpB~Qt^NhS;D<$?7c4HjfC zXAB%)mQIH z0?ERc*fLFgA4ge_92N4{FMi!}=6#!b3r)bc1Imnt`!(ydVBtHlB9$n zKJy{$g4o)#5en3J+VDMduZ5igB_NJ)RJE@wJD=5lrdhqDma1;1+z-ASswR=};J|q+ zQPE(eBueoI8ot(G4GJ+?S@41aFYPok@;+1?44fr}&8O&^;ngZ2USlI$vc!=(K6div zq)2`F?ASjrEvRozb$E)vl9asGU>4jB+eLsv2LLKHO?$r4dddf1)RkPLh4f+ zYc_j)>#3QerLQ&0aqVhr8PmLH1EMmNaN3_q=1*hNR57luVfWmdd{3V(S#(HoGm=0) zu>_8sIz`<+Fc?9#9*}gII4HMXzP9Nw4y=t+OALSkIa3oLRuZ!ac!0cz7Rg2&eJNsx zIR=)kE0lzU5}Bo`Qne#zr#c0IlK>4cgsqy>(A?bHM^KPX)JcvXel@Gv3!=fG3QwTH z9pJP<7_;gpl4({f>Y=ePBz%`B&Gr0J8w)V7_ zfVFoO(SEsp-Ow-G^^=D@ozM9JjXJ82OqH@&RvKapqcSRLR6$P>F~u}rg?4(m?7Mq2 zuB0+Lv#r)nK!K{YH8gb;SU+=(hAj|q6`r_lVS0N5ec_5Y@b?>9v}_G$oF!!(D!;CI^r(x}ye@%?nt$wRn zd-n6~Hh8A~gNP@PF3CfrDq#UwU?2JIZIx&(i&0(%=EQY8zaNv!tpM-QE-TR0`ny{| z8NjB3N|CVi@{__l2sV$-xzekdFRGWrqm3vOGkGPgXz_nM+*rbVgB#D_hDVe9#Hylu zR#((f3YvJF>KVoC%2hantE^o2xXpIv@~ZfKSnLn_)CsVu{r}ihAZ2R5vSx~lG07(aV!^*iCO2u)o=qvH?%_uClIA&JBpWba_uMqlL zv5Fj?FN#}n396fU!85=m0e_ssb%r9*TVY^f#b!y;wW#Fx3knK;D^znbZGoYEM@rVJ zSIbZE!^FTCC^=^rLWzis6!Fr6JHgLLNOi~b>O`HHQG`K66fqWM!^3k;OV4rA-Ktxr zZfJDP>*|69L|d<5SXtQ#7zC9*v%=|h+b}UQ5rqUc^P;XUTxT=&&dcfe+R0ZBE z?3BPKK!Ah=Trg;1I~P1eZqTfp_LU9naWjdv;2EC-AMv~lujBgR%aSEGflIh<57kE- za50%aPAys3@NZrLPnY}OG}Rw(`In&;{SH2lri zwqNW0i}*8zyFE{bloc!@9{dHjVvPwZc&^KWxy8*#3?gBxmq*ttuXNyR<}V?bfgv!| zenEF*Avp`{s}JZ@R8DT9IprU({F6qtJAkNobYj(SpPLS-4W#56MTZzVwu58UIpV6W zR4_qDMw$S?Hst~|67;wj)DPNv}r3C?5kt65lha8g63heJCVX(ym z`}t97Kb>DwgK>S$A|Wpw*lQr7>q`!tQv*Qh1lkD`wn&CefYKBy7$A~VRDw=Uptx{m z5V29n@?rJuH<#>nJ)bv`;duZnI>1+U`|&wH5k-J{=sTn8UsQxCP(zQgZY8cGmCtva zUIk8^`YI(rSLnPtPLzLYu+Wfhbk<;IPlhya@GtruD;ZbLi181|A`#{S@EanCM7i-5qO%Oj=(5%dwtqNMk(xt90er3%$JwV}UfV0nm~t zdi#a)Ra=>&s>8#>LMri`b;v8cJo)oE;x-Kg-Os9F-<1!2dUJfgc*r{^&YxC71Q>yI z|2;4vymr;y%}%x!toqy(EF~}c(Q6x$vuAK0q3%VFjIhgpeZpfyWy+pW;;^YaNc`^r zvy1|#Um6T-4=+-K&vK!H{X?iQ3Dn@Si`?U=7g101b+vzzuc&mmw;5Ago43Y(lXTR8 z-P}n(EgU&ntMD#K8ZU-2n%!BB2SNmtmd=`)g%-@zR8>Mc(@i&m$Nz$r03o>5*}NcM zFTAfn31}E1r{F@#&lm0-bVyBBFDNY~prC>3f4D%)MG-O1G^-qI6u7&xtLSFKrL)8J z%*8+HyMDx0RfI!@fA9u|NTBDoVpl2pk0~kW2DtR zV!0n7Hc<^`*#7AM3dl3W!YKZb5ffyIBJ?PuRgWo4Wp*oObK06%+Mo~J4cwaI#3`fO zrYcqw^dOgDX~vl2I&dwPmO*P^FJ4mwWEW?XsrmNzaO?1ggn+;%1%hVz^vjv2Vpey% z65S)JnM{s^D3u*OF5TSF>U8`J*S3%Af6pvN=I*wjV9q>$a?mE~TJmc=ECyz26;6!& zzBAO^&1iJ@^*ZRCICj=WEuoaV3#SuNM+P|8skevet4MVajX{Vc$?~k_7V)%wTT(BLT=_uH!-J4V zs08BcKSL@B=f253v9FcN5ZfQ^&lA@0*WqpHf^{v6M>qTci&x_2bu)A?QaB(Y2cz9c zdhge2^SqiVGV8DPW5QjDy;*aa6K723{4?a>Fl+h6SG|QM^KQbP-#;zvX*P!Z? z{VOB@c(4OizBb4P6bdRXZrG~&dd$zC6j>vcJ|aqs|1dml^|Qgi{Q#z|80YJbK@qqSU#Juv*Rgj8l-`3MFQCD z2KX_zF0a!)n%H#+x13v?lE_3&!95cx$x-MDrVG3Txf(fye0m)#F=UStLg_DgVMW4X zr2&(QcDEsH`o`r0_8%KD3ect2MM^V6wJeIWG|K3(+wtOCI-OcUS62$DVpQr&wa$We zT3s-3q1GG_nX!FU>#qcSM6YkDxogi+>QP%DTW_o2OUXZ2F=<93Thuh7f`W`p%qGQb zVw|D7x`e}>4;h0=K#FER+mdSpt8`kUR@x}1kwy@Wz#Q1n*^`jN_kM`}zzB=@BDHT&tqNj*gQq545@>j4 zOFt%%H!;HV6|Bg~12cz^BG&4uT*8+wkv*+xWUj_CeQk$A_=isfHU93d17 zL(R8T4l3#0)3!l$+QtLqDL(E`Nc9cDJttB!@|VjO@T^*N`z~LiHZy#U;ZCfj4dO|H z3Jw5&B74~Ou?-ys{4*U4!q7IFNgL#CW}+986(#K&SHo*EFxXmH*bFjoGChp)+#||T z)6x#fj;S(k4$&B$n|tsbaLWzc5H)XnL@F{qCNb%N2% zmu?T>Vj&V(=k{frXkzICK!#NWlX$)GZ*P$+zm5eE2pPN z)x9=`GqzZP6yGO723fNkMocERsM|I687K+cu|8Y;-*_xK5NQJCUl(_sLA$Mvqc z<7F{#N7H1ucK1N`shx8xe0g}`cX_Uplgy2!dgt9FJvy@(;13&th=G@0iyQ2%KVEpW zb#}h)Yuo7|q{~F5q;RMJtH;Jh7@*uT&hL(Ud`uG&Md0zG0!;0vEw|D=X?r2%n+?(z zNI6g}o_C1WI6pUQXw1Bxp;C8vjw0&WVz@wBffDG}HfPpo*#;*lgiF>UhZ26{1l>s$ zNzB!tc2WL%0X}Nhp!74*OtS;D#((y}q;vFq&q0*&gmA$&|6r}u>kB7aHNnf816#hS%h)5shi4O>2(v6Gm? zOH0A<@B!w~1}p&u`7Q~Jh3qIp_URD+Fpm>0Er|u%$@3GD=FcBs!jM1Y>4IEuF(S=B z%zSjO*74c<&E%5dxb@f>1n48HJMq<6NE;#qg>PXQes}6Z;_YS}Eb0(X_=V%9#aGa$ ziVS?=$R#ho#|K1baUaJx!{Gl;6$#*l!o?x^)S<^>$`l|^_y6z_xM+9JUYyidQ3-p2 z%GTD^;3wes>QhwIY(CBGe2h&$w!Z*WlUWdYBzR@Bjd_70ET$Ml^gsf(#PQsr z0mrH^@7kuUDGr`8x|qlNJf__ywnLPLzwhxt4Me-Tnk(Qu-C<(N27_OOWF0gNU*9k+ zpw{|xKI|9+5T+C2K_q&Iw?$})8l;cKl|iPsz%X8NS#292E|yJ+$&a$gKoUpT=_ez948U)jV$;!@##Yf{y}*9zYtY!fe{A{mxorVdx@g zjz*qv~T}}FYf7$?H8WwB+$gnAGKwxmijJ#C`Wcd9cP48ezNJ0ssF2M z=&JVt{uHjPtjzbo7*tO2ZnkL5!lt5sH-2IeASJ)IC{30Az8Lsd{`AfR)<=5!=x*?* zb^su$9O}oZt<|C|%%9FIm<^V(-Iv-k1IB|Ijb~1orUy)qq4~GnbPS3^dk)Hi!qSJ!T?v{2ci1?o@{;n&})V?kbjh-Xx#TQv zj(+?04chN9>$kdjK)Z^XYoDF_R`&-lG*)Krcj3IvNR5UGv%@-6E^&-xEpz~^mVI4{z8yU z%W}5;bL&OcpVCnbzq?wU1f1XE5dt%oAK6nA+*=WE4<HX#>ibg(f2 zkgifFC}sFuPAfS*T~~MKrrdTXU7I~AmO$iC%PTu=W#p(-08@Z)px@@G$!yv(F5C0Q ziQOq`-OVlhy;;4jtv;`ad&TF;dYPm$aaKQ$z9tEt#9 z<5)d#BEuSz$W!vaq6eVi7mU$AK%$H9z@)d~C=4x-Vb^%D2e|L!x7A>8PA2`YBY0LYMef^ zAceEZkIt|C{+~~vZPDe_%`UkFEGZUjlnz9<-g@Y}7znH*i2qXt6Le8mZ@}lPIU@lQ ztl3l!V&t#S=Av@-XoqtxQVv_0K|<@|xPLkspzf_+<_tA|r}eU%1$n9jD8Y$v(^xN{ za8{y4Rk?-a^Z&6ISp00TJhP~~4+msALBW%Ohp7c`^A*hSssDH($G*|V+~p>ljiY(n z+I%;ltvN6_oRBifa6Cd|GS6ojUL^nOIu!m8u7gJBEBn#(@^V~Tn>c&3i%{9m87z3y z=H;^xAt9o#={DWd2PUf3UANIuq3{QTBY=|P{lvwPD!t_Ce2CyR@31XGgon2(oFIDY z@WKMth3oGl9D4URUl0pmD*qiZ=XzLej*?baxiCXT-8sni^+5NH?tlU#d=JrabpuT( ziu`6Agadtxe`@8i2?4?TzrBSDQ5!pzN-bvO-#t@fJW+?F!Qd6#Z}_#I{uS_>S~pi) zM1{DfAFC?}0P!zPWfa;Y3FhpOH7_9oSgerQ+=0RNBvdq?LNF7+TAQsK z^8195?{*LDS5cge??2!lGN;7Fy$ea|ya6etc>m$Nf&qaW$V*hP_r)py?_^_{zW)MXh%0{6 zVnzGzgJh1I^!<=RdyNeTT)W%lKV;uJ!)R3YH=`j>sM|PFdFP$Y%$srL-heqxL036= zG|H;M9fu@QV#XFqLTTC>4_;QgmkU8Hb3%ZLUFEsb>$qU+CW`i9=TG^%GwbYLZS8w_ zsgfIS93d~{N-wyqx4--Nc8#G~2AcopEo*f)8&fwdvE7)cM;bAa56Su$?R+`&pbdj> zx}8K!olaPMIo;}R;F>9*yGJ$Y6HVW_QKS1a0i4JcMAD2#VIL+&uqBA+UQLJu_pewp zCHzJ|W;b(Sg8AB3d<}4%%VH=4()45EQGdt)jhx(dkUe)nMN>0)%^91SjUS_VGX*B` zXmBdO%?liuI0{D@GI~8weL!Xtsp}@=+}P*94v&84m}F) zMOV*WoU9V9tK2u2MapAaf!7PvKr4MwI}@ zAB4*e|G@LJ1{9D{5Wb>`k(JZaHgWj>$JAS}MfG@5qXP`x-JK%R(%p!Z)X>iiWvRq(+<(uOU z#@=~1N6-HhkVK3tKb;=a>$xnd^T>8rha{w>&A*q~L8}^B&hN+owqL*XW=Th@F@zuY#zhur4Hl2-Yae6StPH4Zz6HX^}42 zKonRpss6q}W;2Eki^mpA7PGpLv}ZD-fQqppXQz150ZgE8D|7s-XATREC6>>~;>R^P z-y;ro+y5jI9j#E~Z4Uc){IH$h`Nf15K>ADoQ;chH?$)S%IZ6 ztS0+g@}7<^%>S4CTr~ZBXjjYIUI2E3!%j)_E9S@r|38b-;bd=K!u1w8)tfUBp`!zl zEAC<37-N3pB@w7FzyQPHzP56uPfRR%O7_5!=i7p+kUlCa)eBA-H?CJ*2-ryc_Tz{7 zi{mbO*$fGN;LPa@@88zf#AKm2(?;BgnIGp!gT;`7k)n|Ds0>?NlVqcI5kipRwWoe3)QDMn-y(-n1 zKoE%#;WK|pP<_GF9^6VIc)F$jPG~*N4iCF5s`fB< zbJqq)KM8p&Qf^(g9uxd^DjhGi-oj(@SgCFwR-Xakq88mm)2l)t@3{aNIStmZ833|w z9eS?>nQN=?Nb;JWx(AxS>H_J!1&E<<0k<^*1t6Ybfuv-@#oJwBU}0t4hw~}`6+>?yti5&p#61!{G{>Iv4IInA> zY465A2E^$<285fV!R&ZR!+;V~ZG9qCt(0|RPB%@gAkl{mV{K_EsQs~{mLx9CYYnRw zkeiSM_DxPw^ODA;Nwwxg;Y8gvsMBD_^hxm0(M8HmgWupFV?P!BU=GWp#6#f+g0P(( zuK_^KAhwu&WnpHPbdpC#L*TOg0yUjH7{FpTF;ORCX09N)6EZj}*WkS^6VY!#s8ACH2$6$E_%ni&lLu%52aty&Hf4GIgaq5VZTHyTJ8bbBeBXA~2eTg?roq z<^BXXtMirT`(OU9@aN}Iavu&v+g43#X>M1%T(bnump|_&{7Z+dyN72NHl-@M6^P>b zIp*g+Kspoz(qS>gZ}+pZZdH8eyC+RtC}DRoLJwer<0*torr&$e11cxI*iUXik|lVXTK7`| zCLm|l8WR;2l?E0z7(PkWcpm$l% zmc|0`b6}*zU)XgX=ng9@(eAaPyXt&FIMvGL#$?`+Qm`5CKz6)aKLi~P-9{Hzgl6V= z#A%RSt^6v!;j%!G!g3wN&gI~^Pb=NuR1f3-Q|~Olro#mvtrkGpxq(IFK*SC&fNm>5 zw~;|uRPq!LIEYBWu0!SgL@XnLfn8m@_2Vu;$!Y|A@Q%S$>x@XB=+nT=p4*nUOPe*d z1TLl6M$SN^p`MkZv45B;10ahQ^nqG1bV%^9qnW~R#Pw>3t;^qwiyL4G*$lday;LD? zx~EFZ7tt91L}7Fc;LY;^PV9WL#na#_yWjCFF~9|KGtSagR`&eY$L1KpW{q5wkF@3~ zS3H#Vt+CmrZvRLwDXG`ZV>>(YiCm$$&>@tk1HyW2JZ_%4FYbQ&p#cGoN$)e6V4?3p z3IBSz$Ce+PX7|x{fU0y#kSx}AC0Yvv{eMw12Bied|8)+v{?qZn-xSh{(dc{1L;+z( z-7Q&nGW{hLPE`I`iVxY50RY6*HxrWF1hl`g&foTDfk?~Bo^^M3dnF}pvPNl$Rz5qw zyjRzpqvGSkO4%;NCL;^&qF@Z^3JniunBm=1Fhn{U(>tgP~K z)X*e*#7UXLjpc$=hCF_@4(rkofPe;8Ts6%u;zl@eCl%K@_AOAEXHX5k0>e;pN2iQf zas&1wvs5Zyq6%#hqRr180-yiU`pfh0?{NVC1#K9D(qN!7Wq`OPfahU^ne6QZcbr1{ zg{rnjl;FHl-{{raaO{oxyAFQ!@Y#xztrs6z&C0`}Dq!W22?IalEjl6~s(gd@+m|IQ zi?Zr}b6nYlb4H<|d|@nX;|ESLH||^p0f$05%VdLt8E~SVFV%e?Mwp%UKT&8_MGmAP z_J`LjuPOpt_E?Q~Pr7rn+(Di?z=y>JUF`=3la{Aec}SZx*obm?K093G1iGd0Fdk-9 z+iVgE{D*YL0~kgCqmW|T9 zfGuMP*$UeVDOif1b*|e`meDgypoHMSUmnKybzbwGL~b5g=VJx9SV&(e-2AmikEsA@ zI>i$O%ZS7vugUliMf>&Jfq#R6N5enB;#WU!bi1=eyi*W>Bq(G3$$~8yRc5+M@wBd>P^e*n%NjE(Jhq57U;GSo z(Uf;BB}srN_zuPs8=3+F_;9rAse2@Ja#GDVS{x*bz|JZ{ZoB^HtWQ|j{-(P>WjFD!SXLRx?jRDC#A&!|tltI)B}S7i0LT?bh-O(2Kkmxsw;N;^*^c20{=0wAvP? z4~fhP%D>_$hHyMgWdl$7&bMPAt@|HlU2a3-3JQk(;%{cAUd%2eght&ZPT}G4Z+cBL z3$;Kl5V+nTCEY?v1(Z`w-q$2Q4Bm#s;l#!|y7}3`dD6jkh#@bng}txnJcSClKd}h3 z+G3#y*Pqw2gq)lZL`uC-n9C%EBES0X{Piz|ZwVffGVbwP-Zb)d(5h!a4Sw&M_3jrQ zQ1HFqXj@2@3r)q4A%pI=TIf10p|!iXjYmPqgn=Jn7EC3&dmgH4Qu|5XvuxRcr3=WA zY4NP#1wdizCkE(24uJ>?3uMTDHPUdMZ6Yvo@#IyX_~p-Y0YOnzNr^@FL~i#?FKDIK z0>!M3R5V>zr{#Q~5FSvG{co(5TSSn*`kpgXbMFGI9za1Tj01u|MGl5eVI03HA1SPTumzW(#S=G_DOvOBP{+gBa5KE&(*+ z^{$0g8K|{603sT;=R=6hMa$g$nOuEQMTHALqfy-dB4~E4^YQ0j@3MF?bVIxVlnj`K zWM`y3ey{_}OR%O$Z2g5$WW@z{8IjBk@BY4b9^WYd)HyK(=H7IAFk)_s=s@Cx8)iL& zFp;2e+rjrhsPGU1>wa#=|7-*~h9BqhXJK}T@&CD0dQswb2DGS#t}`&QaNPiE0>k>^E#ptxK8m+WpJDjWe1m7b8qT%I^}d$7#g?-hnJtZSrZcb^aRUdND^XxuwWp{*7OfWi(&WC1pD7iurNJ^^IW@g zZ`s?YO2N|g!cmKdP(Dfms(@-lW}9ry{;so`jy=UnO%h7m*4X-8*9=|{RtbrRQ#o5} z>;C;|;3g_b@Bjs|;CQOCNM~?@$nVeZ2n1m^X#V4d2>tZa1%U_SPLgws9>+|KACM1$ zGp;8VTZ~oUhq3YfAA%WseS2i7Q*WWMpdyfgupNTg37w+9^xpA90u-n_b^f|T5h)Mh z48D(51p8J)XEPF3^{RZ{SA4Ex-h4!5^L1ZV!kiY2OW$Ed;TaJNYgV~NOFv?gg@q(} zePfMjCZ|(gD2?PMg6%-g^J~CxZhjo+0Q435x4y_&?R{Kn=3SiL&yA0#r)t`2029@$ z=Neja&n2I0GpC`{yG6ttlje8F61W~Mg%T#l^tk_>fK_5KRx_G&ie;n&b^}1eSSqS* zE)ak=3IzbectFrUO_nS=U-*swj(dg|9`OZi;*gLYI*qRm$z?9-7V~ARMVSs%)SjQ< zt#}P^Q>yd-V|noN!8o`ek7)uXK^0YaZk`r*-vw}~5yMphYk>{V=Fj=@E?aCWT3S=6 z;#hb0C%rdJ&<8iQTI1)lUIWjp->h%f{9c7_C|M4h_i6v*d31asX$t=W6W|k6;&(Cr z)?4_%+ulb1uTK2@fA!$JzF+Zx9^7*3r@?sl0|%hS=lnXeEgyE`%>PP)f;v)Tz2lrv zR~JYDbHryE(Mzj3u)JW4aOOn=hDWJ2>aqnWwoPkedbuek|cO^oPRKce!wE#j%Zp~!05SNOh` z1+Lr0MJN8!U!p2^`1h~@ZrIClI^Zt*YXXbZY?cnd|w(ylK#21=fj8ov*KI<#Y{gOGQ5o0Y7_}v2@&n!kOVDCl*QG}h};AGkc2v>D)fyt z6&U4mu}+o>AagL(oy$e+w}h{*u#Dpk!2^eOq*!NF80~8tpJci&@R!|@!nWT3h=hPa zQ!z9I@(}Idn(Vy;&T4?lXvS(C;Yb7O8z->1J-t`3dM%{vjPC94tU)v1(Hz`pudlf5 zY}41!tYKzaj9u=HqhRg?zR2N^&df~X<`YFGqS zSqT0yxMf`ZpBX1r0E%p2am7V02RnH7EiN_A>Yb*ZmIHLxkbsH~63*!Vp3oS#|MRX6 zp#9eSt7D%k2I}pD1tw2hy**uGxF|;~NS`24y!2SR?oAF%_JBNj&TB;hr&+QO zf`(+X!K}xMcH~QVm;3OWVhS~oj#UX=&5m_*A}pEIhBq;zR2keZ)~{MTI0$u!@%4eqoGT58flmvcuYI1EZV zsV)t|W$Ez9ReN`UA?1ReSZLq80SbuaNR}gNAk^Xi&aQw50dEcmm}v`z2=QEa`O5ph zXy6eL81L8t1-gStb)F%xMHLYELt5wvbWfB+AVM#CO+W=M|Lylmxft)ZDDnT1o+%&4 ztO3&+-L0=3p*CUq8G;@Zu&@u957iYmz586BYaRW8mGdeB#Z!|GZuLu+z88!5z7Jk7 zHjRQvpaB>mK*HGa_izbV#Bqb)gXMt|`XXhR6)sBuf2@*-Um<$zzt`mx?$#zJZH^9z zF*z7%XR98)B%v22o*HWN7-{5wDG;IvVq@c%y%QeEQkx)k5;ThSRzfP45vYm%Ez@X@ zIe8=+qKKzMobIiz&pctxCqF~QOSvNB*ZHg!64P(M@PZs&p@%qAXm(`Z=9_<+gZ=Dv zQSkKa`)`}o&Q|3lnRePZ8Jq(gs+K+@pV(RssvxJ+U(Sxdg`IGAbN}!$4z=%(pS$>N zC6h7IeO-9-qbaZ^j@;CkMNGz(76!He8`ZD88x}Kev3SI z)PD0=b9 zzV~v|=u@Nq>PeRIZVm$KL^xvuB_<~$ja+{#5;3dLiyPUIIqs6&J2`;D-4b+}Jy=KZ zizl9UMa1zrp3zWv)qr`ce`gk_BBY-`X!c3L@h?I>ai_g7Cmad(j;@Y914anpAKI2M*`R~YWNnh3Tczt^^z!tT#Q=HZ-X9HPsmq6H zux=xLkedM5{C11hou@er7VkcGr)A?Mk&o)=9M4_hN{Rq#_&p?`%DCeP0WUu<5pa z=A`}9fk~ldX4X~H-uVEE)2Y6;(IQmT43AL8^nMELTi1vlydjA)0H#8MN zoHqim*9IQM!7@HuZHz7n4E3ZE7#2(z;CeU@34wm&IeqBv88GZ1LZYGJhPbE^bYG#Y z`PztrRV94&R%!+q=z3}2zQy&q&FiVCCKuPVz{A-pbw@5Y7~guZQG_(G6PGG^6jYD5 zXHcD4W|pnYnp6m3MZeeMuzvkQ_kJF`SRBp~tmu+Y{0^dtsk+tG`Y5JG7AbH2iCbF^ z2UGsy$f{PuUue-r^($Zf;c7)8r$S`BZrotx8Ty+y+iy=v*zD}m3#P3KX74D@rn!Yr z&{$5DIzXkaq#=7nUi};e->C}OJmUy$&?mYvPvWi*~FF9U0apZ9T4c6%W>g`0}jATq_{%~ zYKkx?vfrPAZ!(XApPUR@r^~S0YtZ?#V-a$z;`tn>!GZQgg}F){74ne$ zrlb;)z(&*wHKnO-#n4+sn(x zp4-Q2D(t@dAjz1g#cfB#9vxc~VQ=D(F@$V&gCRe-OitGX$VB}K zI5?bo((n&}Z|u)#*tGPWKax!d><)-^>aLIypO4PUi0{8h34b`va z4GYYxE-pO6xmjGme(bKt3^ndB+`JqKP0f~5#y2Q>th`dH!F2M#cxW_@Bpy9*5xg-g zV)Z1jXA?Z`L#4mia)ktYb1WFT%u^NC**OgjB&U43G({@(Usx?G1C3dB;;4Au!8m4a z+}8rZgo#sbSk#bHyTqww6NiB9qs+&vJ>8bi<8DRX4sYqK?jp5SJ(<0JFYP|z2LeI& zc&O~~S552_lXNl({LEf}8DMS=z}##eBwRc%DLdWobnIOD6^Co>1pf zADH6=37cixnEwF0_WiyU!dBm2~1rg}(6c~+t{srlYE4eU)@kAGM_w{9&tJV$M z+7hZcn&FMg{SEAy@BWe-|D4COwJjVsI2bAAc}GYi4Y=YD?X+k~S=P;aQ3@&FY>NJd zuc^qgSO#3zf9M>_@>V$>&V^3j-MRpqbW^G~G331!P;hZUr7lN5B45(j5OCtc`-kzZ z2FId$=Xh_5N*gK9ozC;WR}kWo<3|Mt3uW8yK@APQi<{9!jK(^(Y(x-+7u1-YldUu{ z<5s03IM%vRAwq#);oLr{-qG2o`R1dUFJR^&rz_QP^l`*1k@fMmomG-1J^lKU?6c^= zYulKriz~BgY4feoCy&bLVU}-}Yx*$|O*LRO8Eyl=CvO7R=d47FkHn4DsdVyK;7ymw z=v^f2=tgJPk=V6b?!$MU<7--NgrFEQ=-;wl_8$XVH!Sj0xHj#*-!r zg-K`?2LyWeiAgg ziC0rGEZevba@m22HYKW(N$Z{Bo^BZfB6iQaU&E+D*#owkJJr%d$O7qGrPAanG8vJgb~3{p0B`4 zDXCEwHqOioZ__>*IJgkgN6kfYXrJckEjGfsUj@<9TN7zulPOY>JRL5RAsXG}q)sJJ z+<{j-50Cw*XCx>Ez@4fh`1%ui4KW;?_{xqjK|28}$ zj$fm$Zo$NH&g%wDl{_<~a9BQCySD<*>0X0|JA)V;AJ2Mqb!9BQZ_+u?w6GM;^*Iyt zF^}{o(|O=L62GMjQyp0Q+z<-e7BrEs4}GM}?hd|}@3AmhJf;x3pAo_89b9w}AgAWb zISKg44Fv*9i(TAu?$Eo1rVnSHQ*zE%ucFdP;#g8*br*8U;VhHJ;I050rKN`)zy>$S znB`l9KmuO+;&m89C;ytRNtn}L<85DVVE}6oa;<^_`Sn-ax6Z?PJr^taLhsW*ZPwRTn_Bo%wF=n~d6hD~Jbff=ve!t2+ltOvED12&;(As$mztxOACZ zXEQm}ji4IgZ~NX>eZtFc#B5rD zv1~9ZVwf+f)DU=5ZRSEZA~p`77!Va75JT(Y0Eod^YSZ(= zs_Ge(UtDRWRX1E)Hry}w4oSs)ea|S+Feo0-c&j=v$aXsiKmBYa32}cN9cDyTbqy+9 z$S1L5t^>gg-y^OZ2snGbv`)nsS+gw!+Yk4w{%)@ zr0#5944&w-Qs=!y|4N-nxMm%G81Xe`HPZ*E6iaZi7!H{N){`ILlKeod?W0VlyXG8_ zX4&FSA_>lT*i@2@K;1cvqt0?T)aBt`M3CfJw@jo{tkEMv43>Wj;<@vH6T3LBzJd&&~p=@i5=ImVO)KWmc{3{^5x0k)Q&%a=_ zx9`Al^(TW~(?Y`M01ptJJe8=!oxR)i*Yi8gs6wsYgTu?*fd?WKY_JhK=*^G;jE!S# zLhArr!%v_3P8wQ2HoznCqzlc&aXzG%ZWNW9T3YfYG&S8BkN91ClV4mqPfXKpB+OZ# zQD9&Co^5B_qFij(`rBb_I(kkxmIz`)d1Fg1R^Glq;7oHme?5K63(BWtkn0I$v&QT5 z6vUlcvcjiKAnkkCs`nJiE2mL{pyu)R69D0LulSE=G5+X0Y3Xiif}S3r1_!RK`Cr{! z7yY^+`qBA9QnP);x`#@ryF59&7&2R-^&l+s`7`F)@;$a$9~Lwfp0cqO6Rj$zriq&* zc`#%b5o!gyD@Y?R#GO6A9b1SbheH*4l%Z`9JOCr^C}g0oasClX0Jo8Lk?!Ahc@gl* z70jO|CXH2W7=F`3tpE!y7&tkPyw%Xsu*DqAXD%}N1$hS+Z->@BfYVU(+;xZ7AKkI- zn?(5cE?r$)&d&ZS2a6<#GDV{`R?JgJw-vP{2VvX3wx*tPZ|JFEzC53Q8qMS7dd+3!b-W>)SlnMe z9~y$LpaoLwuBA;QXNzo)9gv_VgQwyGIozC|YQy=w%5girZa~S&pEw-W+OQLFrLkq> z$p*q=-rX4{u!c5szYDFnqSSR^%k}maRhrR95Qlza^2C9r%xd8G=wJbb+r7>^ErrR+ zkNIFm`9IW1N|p_(rj$a8s(%b7?LAn3{3z$+`LBN|5Byfh8N#7kxvp&?n$}4yCKY}1e={`| zJP&3}JX$mDxeVa@u6I&{3l2h!4nEb=(rCNcF&!naDOMWEWf&X;2auk|hW1RtQ~@(- zq@HT%u_Dm!e)qn^xF_80WqvI#5GYKi_v8F;eCw0}i9`qO z$7(OPp=2C;nw?OL2;8wTLSvhbz^A9?!SRvYL{E57b=w7j-qY2Ggcm&sN?jnl9`$ zq6}sDYM${s|KS}%YwcyGA-rl87PX?^zO$ZNM(~kIuQ!h?Bg4)QR`FDtP(VI1@8M z;V_T*t^!nSh>=&4rTpu#3%}u}m_+m>i+{t^)%T0aQaQCsKkbJV0R#Pjwv1Ks%Y6D|pgbip4OkMfn|Gyg!06 zM{+C()$>mm&PtnivPLQub+iHYp-F|-3`tBApF_zP_w3DJSChtCLw`*m`KSRu@M{KEbB_@_3mXe_e*Z<^!QNi?V!uUXVd&0?0y`u9 zoBTtec~^>Ap9C@0l6gOcG%!*jX&`Jo>JN{3Tbvq@14)PG2#@L))=!#{yweZ^4x7Qf z91x7j(@#=bs*yD%F++j|x#YWs&h=}~z{_%n9zr09Aq7($X!i2ervf-X}04xCLGUOkeN29C){whvitbpB*`2&83r?ATkD@i z6`A)o8V4I2J0Aa=LgH6qfo-4EiOJ>Vgm#}>YKF{y^2Qx%=7S0e`+!bTVDJ$|e^u#e zBOslI(Z|9)gDk-TUmUid-{6$lIy?CV3YwVMdq(km{`qlV%=!b=-UVj&EJ@)mPn0Z( zV>LARDXEGRusa61Nc7E(!d=&GnldTd&y-Su^DCG4mVDFjIq|75aKxjrzH6(P$tEQ^ ztNoC{IxtiF?%KN3`lx#AXKJ;pDP6h_h%Fbjr4; zd30XP_Fw1m^8p1+e{gB^8?EU_!IKfR8$B(lN)l;fXL)OrMK3TYm=1eT$pdKqlZEo-umh=3 zf~lOzR!1h(6+9CB7z0f+zICT9n!KY%vKAE&G+l74vE8eC%k^<{K`$w$5cZYSG*$~r zB2itcsz(%umI4E$v%Tvchu*yJhter_AjMzedM9UHe=Km$&O)%jh?X*_B6*aS#h`;*l)Gtr>2Q62v(*;D95l?R%*!xZ#My z#HP!8;N<5Ax6tY#y0v8~^m6=7P6;J<-iT`PqEvF>MTr)PvuVczG(RYCDFPTF>Wx@PLy@o)G~NSiF7a|ie_@6+qiE|FSVeV$dSRQLZYDPzdw#H z0-m`_1L;=SOZLx;UYYuUEM9wBCNgelO&Y0+M+M+vfAJOa$sKaO3^(lFo#XPkJ#Y`t zS(xr8SB!Yx&g(%11;_Jk^)V>g9A4-u+3yB99nWbd{uDW+c7gtwd3FAliYK${;p(gs zw~*nECqIR@->z*=dyVa~Z5SO>SL$&f;$yO9To_odKb$CW=i*8@C%7yu7hpP%5?c#V z2zq)1Ogw35NQ}?C^p=1B4hF}YE&=(#3irJvW%uR#&#LVP5kcbf8rbFlr@{fW9eRcV z7mglU9tfw{Kr6-cP9M*8(>gLO?Iv*)7t+DrMum)0$1=9?o82(Nbbn3dccaUIA8-2V z!|*M9!RtI#k5xeZcL`M!aV$EfOgMP4WHFrL_+q&UJoLf3FFUSL+S%bP(iQaPsvA2$ zNe!^cFnEimYttd&_AZwaaXnqUJz4GVd(Zcmu#>2e*lqckv|-0F1J4pSxUscT3*kfb zHLAYzI}(%5l@_VM|MZUjP zaC{>daSh7L%LbrNTor9!=z6a>oBm_%FtP z4!C{e-J<{9^E)^y%J}Z6*FJAtnYV;yH6wa^;P4DeyL`U!+y`l8VDG31DrsMhSFm$e zakW&JOE#kd7J#hoIC4%}At!lkZx0zneArMa0^z4>2Nn*p@x0G@6}{X|IKpP92p?VU z{OFnCE){|=t;(#+_EXe?hph z3vb@{Rx)IeRhh$rF6-5}{0B4}R{?k*v*MfS%XfaIFl1R6;TLrBLDNza$(~KwtNB*w zkl%quKBoL+GzQ*3v4MP2+f2jDqz_jr7)=x6aSH@Pqs230%4jp~!0_vhIrL`Fy`YK_ z*zK*WyK2L#?x>cLyPiA|iA)aEuf)^}Q|ezOEPs;d`5b?6b-Vrt=OUVBQe^S`rC}MZ z73=$t;fo1ui2>RpBQOXz4%JYfouP7z#@w0v=2D#chi@Li5Yy(41X8< zDHh0uNJxDq%npw$*F18kt-h)qryqA#|0ut+K}r{-v55H@YW~#^kGz0bi4PB+QEC!C zjVp8}_SbiIk_62^-Csmns)v7+Yj(DkDb3s}RZK}H3}AGbBKGWwO=_jJzK=}E``W+C+yP9E;sQdm=+wXJE1r`58lr$^1+}_U zJ3^X%=&qj@)fg#H#0l!zw6b|UuytRXFl!yutSz>}UC;lpkr(H=c`94$YjseQ!}xm1 z*y?n<+W068EOEoUIjIO5`aa-6smp2JHZzyjiI!OKXc|>Wn*0aZ`!Zi;%ef({Rn*t> zFOxH~n$Qxk@Ccdce|7TNDsBg`ZD(QAy|voAy`y8zrSN1$5wHSf*1NeYzzUct$+(;f z)!H(SDH)9&KDQLvHV1h!uxay9KP34Ju{5Cx%aG4&{2E{uRmbk_TG4;7!Km4f?Z4Ln z0h-B!4%lXV`!)oa*u^KIK@w?TGYgfwRW6%;zZ1Y9w(CyTMge2+rG-qQrzcMBoL|i& z04vZ5d}z(vHCNJvVEsAUilkbgR>0w2l2cLN`ypPz@&?HIq-S;A49ip$k83Z1@x*8% zx6OqR_DYJLdp&GNT7LPEyeCWgspr9XCjofd`%CNwJv@~D>l0BlRC8Q!2Bf!?EvU3#6~(iTj^xNrq6SkV~0&))BL z$gL80Z6F{Wxx_NQvu2rJ-R?eg$Oemt7Bn=t0y%QXR09yJ=Od{m%{V7 zUQGkOyd0$R!$0l!c*?~>F5?%#(>dKUGBGPQ6k!r$ZU=fS?OsY^dfX-x?l zX4MIDflZDcbR1stt}@;W!+FBIvlEL}(x#@Qcwq;V@X3Wt?6CygJ>na!R3kz}GTW)2 z#-oSrj~@P@NU8SisluIVdU8=y>-aVmtk?~>@J7>g+1o@^Mow76b=3&0_*PY*V5X?{ zcD}fBzT8KoV3Bdx>|zXXWN`9R6v=>1mw!p_9UaN2&rEPqFkE3~mSB^ThV&XoEi`r# z0p~G*1^B?f@$50vc_w3L3uMo-8d$7Ez5+0gzWB4fd__~95?5f2hHFa znGsCLn(m3q%9g?fc<$KX`Rm2XQW8gLb0z0b`*X$Pf{B+!S^IL8E790CGB`l~wCI(QS@sHzP?(|29cQ(XGg$ZYLWVCP=0eWI&eWofs;$^;&eRk zTeEJ#s6IDuV^PU3?8;6vqcRlr6(%E9Ea|u0B;)A65Mu)Aqc!D|{{&Q(u^c_pT++Nx z4J$RpCGh_^y)~WBcVmx`$cw7W8?C#B(_}duj!5{8mce_&uID`o!uCLaT@0Za0uQ&F zC>EB`XKD4LZd%~a4UWGgX0*{U2n;uPFU=T-A91J-661!|)iLmq@i3uGo7O0+as#S? z@64WSXy2KMG~twEA`8E7tlYc%o|_AQ`UH!Gzwh1H-9Z!!n^w-e;l%~+ASH=ICi}ei ze)AI^GMUXlNKEqi)a!4V!YrXESh$}Vf`afmRguSG5#rM9mow{y9&W>P36N<(2?8@aoO z@3RXnxs#KVfvZ62Doxw4;h)23xo6sUo5|zi2yBn!x&nKU!70JC8nE(Z{O{k0Lkefm;33>?dslLY@7?7qERlSAGMMe~L7yYF? zPdoEegl2MctbsrbDF|NE5!3?1kqYUD`GYv>smD&8z!#b}EuI8_7SB3?w~e2oQ=!ql zD}Bx9Q2=Ku6VYu+cE|s=BKxa;2=Zs23k>##eyi*NwR&U?4d{eB+Bgc-CLlXze>&WY zE4tFhDqbiW8BD zEvsw<2UD9MJT|bewr%wCDW>E15o1$&7uN_K781p`lDY{FC+vz8^Z3zjm#e zQI#LL6SKaTvDn5cLas_=ihiqV@aw?KdbPCb8~V~ZUlX)ET*ef@{~7<_Z1YPT@||LY zlB7%x?|o}!;r9Mu20T9CdFiX}!McF&^)f{dd*Ez^plxohqtz7^ea!F+KvCBKCU899N{(**K6%ivukg$ywO_*{3VY zIJVO}Uts&b*?C%DLt;mw_NkfNJuV@wFR)5^?@gB)gy`t$gKr9HK64Utm`D+1>Uup@ zZGh;s0hb1jfIPOQV+0n$39TvKTBu7S7KIy^4kw*pxw+@c5 zdAiH2{n2uEmT7s?i3pL^((?D?M;s!n;4qDOly6VGQ- z_yPK}2T@hv&0B|oJOjb-!S9~2L?;g(6vlf-JRaK{1(Lv_Y)ux*_(ZH{#bxq^x?>z2 zT|3X0W~;$bA`*nT5b_EQ==!=ykmduZPx8C*O)dJI_ji!A3#l%#tOj1!GH8$Mob#5oG`6 zH|mQE)Z}n_DFQbAmcgCH#>Ex*Tte?>KNS@!-$nBpQ8EEnqFpu~^aFf)4UK%J_7Oyw z&x{fpsluH3L};)CGxm!X^=#{g4Hj9a!F!azyX2QCa*rvm8)9~yiR<4CA=V~H%q{OB z4KSG4z3G=h^}mTxKC3VsJ^ESIRE%$D=kDsdq^dWCkegm(_xW;-m=r62mD^v>_9z6E>srTde0=+Z9pRe)EuMe?J=2GEnqMsZRMDD_ zBq_4(f9)CQ`9bUYDPfber`gx%o8iut`i6hQzCXxlXdw9#(hb2VnI6@~uBKX52s<14isIMA)Kqdv z=f2P#W}}&3XKWt7)+;X5)}!qc6BBXxHr>Lt z!CAQQ#*^{G#>sS#2k_vZJDrf`J?|~9GF2zGfBNgsh2ew9_j^M&r_~{@a4>L5wd3Rh$Z|O+wM!__OoURGx)-$)WyvS+Y6&>S~%nfCD$lQ=wlo)$sS~>X32_ zoB~CS9GT;Jg|4N8n^lcYj@S zRX}`Pp5a*S#YdDnC3s2nk|Pmmf`W1sv#*GX3e1X^oQm?!`udF1Q`UB0dE6k?s8+X( z-;j_eY3Z9i8o!;f!{OirCniyZziCD$5@jX$MsMf&%qFX%vlbo*I(Bop>ox9z)bT0Y z?r5c6PIIQa;Tx_vkEWddth3eK-igtDu|>&Tt$97n)N7BQrl$kzzp@9z{>*q!i(F8k zqt~H#$};&4veM+gdo?g6nMStZ^?BfvgX_EFJ-jn7Rbl3emZVf-Uxk25wvNhybrd0k zuU-mLT__PnaVCS`vgs0hdiS;Qt+d&Av0mBDX{P*{Yx+u5m9Ds63z!uN0c>{`Uq z5^F3mxz~KR9}taB13WSEh335;+|Sw;8&NaurIMr_v#+FwcHU+AlB0IDW5L9TH4PBu zv^xjO6p<2RPYP;0YA)FFM4BjHx-0civpa5(kG08L%CReD3!z6}#FbT-Gtc)iOD9!F zYg#ARhct#1TFMoYXHwG{m6fBQXnr;R5<(epbw^X3yMjIgv%^Z*<`q zu)FD$(C^|;Ch##4LPts7o_*?Xs;w2q%LK}|uHq;sB$T#GH>eXDCucW+nww<^dOdBX zhCKaVrPqgnA@S3(CgLVRxcpmuc;lvrq|!Z_;pGOO^Z2vLF_OK1%VQZRg>rOShg zFAzgt?F7-6`|JVJJydN1qsE`&VJLAtHRF|UHQcD6bep`L+3}}8h!KmN5?OFoz&#Tg z?5qg?4_9v$R9Dw@jczvXPH+#df#6QC;K3odySuwPL4&)yyF+jbA-Dv0cmBomeswNR z6~!gRT5Hbk(PND6#vGQ|nwyf_`t`%)%a<7s z_FoT6hrbX`jQPf+sm&GW^2Lc| zh~fNRzVt=7td+K1n&<-qYG^1s|`ZEaG<) zN(pCbq!L#2`8itmV*vf51IaIXo(|G^uIQ#}V~tgT`m(n_C)O-!E8Q3ekr*NxyTVE+ zuw&nt&;Gs+_`0185K}UDlfw6W%U66dR7~3Dipl?sFW0F4?}*JKB)Wd>hTYsS$l51QUa-yufP_|G*)IsWF-H1R0y4CSEUwF;?tnw1Y#?@0$ z`nSeKY&tsR^orye1TSCJf)@X3r zwCM)}A{sQJx+-imM~~&Jx?;QsU+pL4)GW>%~gbeRG)GO`w7RW~PScV~uW2|o_cV<7X_EcVbCdBAa z=NOmdWSKqG8$$}m<#9}@sfB-0EjS@2*K}mq1WTd`D+PZWZd%^I29dtmV=vx~zrKzT z(+GERvfKI;`TO|BnE~o<>rIW?U&t=)0oBLMd-q`Y(fD*a#oZI=tl^sM=0mqU!mn{X zBMVDtuTSkdK!K(4{%r1q*pZLP<84-bnb|%_091cv3fS;|poj!Qr08k})z_yNZ0+ax z@&Hu~KRpoli`(d0#;ey~CGq_$obI=F(=5U#+gQHm=-Qj8r*&}?6SuMXm7uVn$7ZSC&dU zn^KaR^jC)*f!mFdWS-`VXpo0^QL%y%uKc#?f1_{|k9Z-<|G$P%#UWHds1h~k>16JdaH zf>E9(tzR;Z(4GJ+j{j?O-l>b=z+k|K2R7naa54n;pn$* z@I+NRFS?{ku1G5xFab9#V31-c{S>RF3SK3GPPE*gd@KO0@SB!N{iV!k)2YudK<8Jpj0!6?KfjD18#8N3was@oDV}j2gVvK!St)x^(?(J(khxngR=Jm8TjYmGgUMreZlp#>gAZR4# z%)$B}i2k{7{W1gNe+Dyl*mFB`qO79A(f}Ecj{kh;yA~RBpF5L_0J7phx9xJqz*cdI zBH)F9fLP1s!+=4hmd_MdG5(m$I00lk&suI$qJuZ3&L#3)lTSJdX6` z@|#xRC)WH#=xy9<^T!E3p<=K=D)FUH+L;uX(6I5RcDuz^l|0Mm69LajWhXWx4#bp~ zD{os{qX4Ud>mOdB83uLLy~Il~dD8QVm?_ul+h|v~-u(YkDD3DMvpSE@a~R`X(e4_D zMA{y7>V)><+jt#=i0I2AY+gYNmM#eoqJnFBPKnx^l6@y7TG?=2`C}lBx-eVCa(lsQ zr5~VMn?TOv@?INe4CoB;{aygbn`t) zdszH-a&?KA91?uk4H@xk0uPgj<>?jcG~LX(GUyzC{q^;BGJrG1qfusB1pwpVynGp3 z;9B$*tL{M!4P9TKZM)-#S#mlaRQRMnRBnrRLC`S9WV@hA4-;O zgG(t}!>nw}Z>D5}S};8*&0T5@byga{F`KBqJm5?LtR=&`-nuN#OKK#!V;5Ky5^k{Y z{?OsD1jVPiy}Zl?I=$iHk2K|G{f<*|1PY~p6bka^{JURIa3iEOYcJy!CA&&#!$?Q| zyhw2~eLoaB-5CuF!);MZ610E3=1xjV+DI#|W3`n#3vmO=Cz5Bk59yl9cHRu6Zs{4r z{-VM?-;B`x(ws;M^ZxrF67Ksm6HUXa0$$5M;L8_afS;ZNPi%aAzLGX+z8? z2>Q^1x`$wVzB5(vA6*@TkczQci}lF`n16YKaUEE1vF4lj<5-7FZA9{@5L&wkSm-pc-TrV^bjYnO~ z7TX*iOy#9UR&vDjuom>FK=BkPAJ~u2k4yGBGe-an#uBl_frGRD*>6^dH)qqcbuQ0i zSJ^@dV4)`=u5T*P9G3L#fBlXM1K0NZj?97Tr*rZm_9R11VEafN?sWJq1r;8u&+i>! zx&UJs5@y^ik)^T3!t&ria0m#X;fJ@Bbk+Xc-Cx)=bSK}ah1T;$FivdlHt{4sh?qVY zrR2=bcCWO)giCbJ7{_er7+~UPn^`qfXx4F!fk5w6ZLa~kP6fbwDz0fLY3u{!3!keyS2|GOx#=Y@dlL#gO z(42Y)3(>;D&HeEeCL9Wi|BR%S@~K#qIAjRw)ECoY0KUZr>QCnr=mXS>k^^Q=8J3Rs z3!3J#)jQ4kSbw3jv9U>iKj`a)Qkgu+CLb;8@NH_ahQ3i7kOk#>EZFpR$J5}tCF-hd zLblZbwuPLX9eh^JALO`)AD=)Nl+D*XY`TTLajj;Id+M=7E~Y5J8t2NHXBIeU@W6H; z#Kleq#__j{#lUARRw^%i=cc>=X*QRYZMYNjWTG@}R> zE)zDAcH#ypLL}Z1`eV8HSxTf9;|C@V+Y4BTBmBZat+5DZn}@)mxT(`+-AqhO>sj$2 zf@(oD@;>BuIt*7_%-tOl3p=MI3oPL6Jk2b{0pN6`e7t$%-~=;Z3^7W2QSJ;(K#^@0 zOKA=btVp2$`Wpucy;{`a5Bn`9BRraFC?*{kLa!<7y#4W!!$U9_5~O>Bh{wi*QEx)2 zxBlwb;?|14sgFKw_AFLH*^*dOqhMrGu)Q@1te|v9vA2hSLw+%l!NRoet4JGd`Mwgd z_~w8`l?X6mxdKstuHK`gpbkx6aO8xWg9^$}Y~%^qiUtE%;JYs{rPo>SaGnq7I|(d$ z(Zy}mLW1EBF*VL9obYc(KoLstrq&71LylnZZ|_YHC^{e`(=+D^9l7eWd}U`MyUygVkJmf&n1CL39P`?B1E@(kY+fDE;7f5A*lp|mHgclc@(kY${9 zbh69*-HIbqVD7$35Ctoe*=C6Vhr2r`ug-9wlr4J3oHkc8|01KVZ$1faN0uNY#sv|d zU^#~dsf6GQ9bijk(VS+7&Egb|cW0?EQIG{;X#@e^Ml3#O21e&|?%4yM8aC`T4}{?T zr26yL12E|M=KD~59*9~Fl991_eaZ&b;^^lSEHt<)_36-w;j#!-)WZVAVapv>Wka8r zAGSWz2`4)TES?tg@&b3!wE4}M9>pbNIB1W+`dv4$032j*mi$#Um6`F` zk`?)y+Z8S_z=0iSa;hi5{eWd{KKeRw>Q}A1C45~-teDF!u32Nc7U9WS&>l3Fw>!us z%aQhJHB&MH61)x_%~4_+!YYOue$hp#QJ5#6_1sjwP3i{opA5kALQAp3Wh3d8wkql7 zhRdYeg(Q4kt!yra(^JFKJS3xt^<~CoSa`m1oF4cL?wh}dbsV%nP}z#_0gPt3sj$KA zXowfs$pO&7P*nN5p}>e>3tCWb@1*7Kb(;83fjM<;C5@KFelpLX^j{*&gI5`g&>`ci zj)zYD-i(zTq8^&Ku8bK%`TB8*MA5ZNGc-)*e*OBPd7t=CMI-Wh>pV<W3{fT;6g|5prh3(#NKjswo*BXJq+H+G+n!IG9$qx*}ZZX>u_qSe6;C?2@fC=CVBb2 zXphDRiCzO2f8gi2&xHB1 zGDuxj-_m68$H%3=C?`RrFfWKI8iN>Y#!d3ffm{*DfVe?q0>~^P5Hkx_>o9%<5Nte8pfim;I7eNvEOAybF+v z3WD@re_~;!C~ucnPm)ryBf;pVIiq`h^&1UB@2{VpH|tNfrq*Y#35$Fx8vSY)hvGhm zF|)w9v9O5Rub&dfKO|UxH<@YMch!B5gc2I|Sw8w?W&jeDo>A#`RjFiVQN-dnBr`B@ zzxQ+v1I%O=6%!-E8stoKk6`FCv2E8BU(I0D7TgkV!gOQfsLaHto=fexAR({BV+(J#FojTO^Zu^Li! z{Wg}cVv5s;kGHJ>heCdeLx|mJ;h*LIZ44zy+4k28DHkY>13G(v-O~#+M2W3k@&_1b zhziuMR@{)G``UNC87AAy1LMb!8#vThTnt$`xGGG*I@-{n{FBccI@{MCFFafr4&hl` zUp5SNV17lP%ef80_W6c}oIHv@Y6F&ykx>;O$szAMO2Fl6#)cL)VD@xd8=g?nzGUl^ zi+^i8GFf~?cz6eTsh&1mOSYPte{1i`MHMzPP8-Y0di2j)=yYygI`A>T$qXXJN=+Yh zS2|V~Yti@u-*gM1z?)ULtR92P`J+k19;nHpNCe4#S9?>!DxY77WdNI}N_=kF*E3xO zew_rMzE$T;p^{3-Kf@4Ns1j-9yzEG-?>0j|*l~zuGnl9720)3UoQMb-2;iu%QWG-# zhN#Bk0K0BZQJq4Ylm6A|beKCyQc^=qw_EE+2FA}amMy(!R22M3K!u%?I}_E^Bu9g= zDq4_7gMd^HEz1g=ec)dRIe4od!p0H{TK$b8hMp;)R)NC#^qn>W5F?{4>VcDxSH;!mT^rM(g_9cf%vW{4Ig+st*v#VjFn8-IL4R zT|&c3MkLQ*Mb5dA`bo*ih~wi~|Fj-qeI3&Th9iM1f74>rFhp03+eHy$2Q!jr4-B_Q zuv&b<3JCDp_I09$5*`v<s^v-PQS%V>OC5>{gt}tl`;?u;*a2p+vf)HX zAK~)M{(YH2K&D14`xUrtlolWZ50)=21D9BILouuTsE#yFIQCP`|CK;F%W$+d?+ADc z^7fA)KWN|x^^#9FTn`oVs!de^SlHw;A?#!%t=Yy==WVWu$R zO^IGa8Zk!g&iWD zf=?R3ht+5rsuW@J^J7~X(%NRnkCh){0O<=j0Q{SU@>_Qu7p~IsXfV|OMjR*^UWBes z4gL9v+x)Ygd0e|^=}OMNv-(35*;)nIMwrNzibc zQ6h;+{5=Vxz7>*JKmeRM>6eq!!`mIlvNL_qFft+;N^1Y-amJpD&>+?(2!=lte%lZo zqXN*r1cLx=IEoO@U3(uN$?Me^+UKP&B@B*pqjbR#on-M!lL_Debk}*HRgi}&H0sd^ zz0MeYP=LBuE~j<|Dg8orw07b*IA(5r=FEu(PTeDu=FiFV(d!@ekZHkF?sWpN|8$0X zmp+^_YbyPlyh3|UagSVod+}yV%+dxF4@l6m>vtT1HI=%I?bKF$ zWJmp}7+cwM=cqNkgG=YBZ|pveM)s*qhgX{vjei<$$c@qhBi1w&0IZGy$d3>_ z+UMGMornOvtp_oT*HhC;0xy?M&zqMI7#i2d4?m+jQ|G}YCG!pzWU!|BjXRNYjWinm zwGxuToBqAl{URFRALXt(Cu@h!ZQ5@Y+8Xuov3^*v)8mqyf z53_T#KK%Au>bjv@pWSqNS{*;kC(JsOQ;ym$Sv{kgQ7K3(Vi{>b4M&jYe6Q7f`20V{ zvt!Xs@72>Knq#(-LL%!7tlVC(=m_}Io_vvt?xb-Ecc#3DUnBR5k1)0}=?1#r9wR4{ zagP3YD(;MrF~fz0v2;}})=H~Z|3Yb7ni5AdI{u>(@B(W=O53K>#|0{hKoYL`ep80v zP+IUMfe;9gEKx8FrX6BZc|;zW0j7YLBF#O#s!J@T#1{06?kD;06JW_Rf<{$UVnZ|J zps_25N4K~YLtHwNnb)7|%BCtr=9dc=_H@!HB3=}HT^P}GTA*GZjwK0PwHazACW#)A z+?HJydp9%9)^YIN9kcHkc`kxhtz0&keR)G7Q?$Qhp&^1rtTlzh9Y2EJ1I4bLbqx%b|yLf z(=p0La4#2kcJqDUCk3+7Q<*CqF#^Kdm=CufDj(#ViIP|f0HI&qg2m2vJQIsVaL-@) z^zFq)cjC0q)?F13ZwCMl1wp}h90gRNMwQ=Le>v4l$N>EOnU5Wg%7V#AM6P`N*JS9h z0BDBtKyd;$EnlE(Z=*#spkz}f=g|#j7RpBpTsOV2_0 zk0dxss_S(UM7w0f-wTk~Dy}%cKz{muNnc3GdO2U!7rC5TaD08A*b|gyS@`J3T>a6! zM&xt3O-p=J(*91vTqtgS9Cs(ho-0N< zYJ9m5_c(rSz@P|;6%rS38{Wo?_{rmqVmg&9qS%>@PZtg}*FZ%#y`|-_%X$`WhEeBE zueCTXZ)cVNpuQ)3uQ{MVJ%;7Yo&0>319SbMsGY(<6<$(OB5p4g4lFlqbaGP9TGnmY zCDI-KjF!w_r=K!Wm2o!tgHK}%n0{@u)?o8MVZ%$KKN6p!i$;iJLL)B?zd*#T`XuVx z8M-oY9DFvhaP-I3WI_@_n}xYk%|}tgofqNN9swmQpkn{=`)cwR0)YC79)gmabIi*x zLjc@f2|J)-)|-Ruf7h*b6rM7aS#OKxaPYS_?y(Gz|9;4w(W`V`y=pSXWgQ+1?IR>W zC8>gLZeEtx^+2EI{HCXQ&yJ*iSMkQm3smyBn?s>MR z_Ovbgiwx`;D)5)`+Q#mV)qm_Z1!9Cy0;-an zaPU$w4DQTbRGk6b1WcxE;=oI!`bSPP5{!Zrq;ve|0v6F^;UxZd|~z2SnqHy}Mb-tR3)k)rYSZH4~sPDoF`p8}ZkM`H*tX=z@3 z0)ly92SjaWr}QU$cHWHi30tI(^2I=i(dg|Z(;bQEt;~)mZ^n2RucZN2yN{v|*%uLE z_FuIJA1@74(;n2c&4=2Dd}%J9Jcx)q$kkB6v?HHK`8ozKZ``fvy zS8@|D*Y)&gafHS%%HBW798k)FZ*=p z-?z2G3OZjVik$~0IIlbTJ0L110(L_;l=nLyM9ko6v|U?k=ty-hN~;gNx5Gn%>6sZS zHI;=(@%*BS+S+*#5$RuH;Z(v5-NZIh_ASK_+@Wq zJ7FU&p(!YwxY7Leni)W4xc9DW8i%pclq!E z+s$_s+Qpy#S{2_oamP7zeL6=9N835L!mDLl{JQIRuL zyp;y=x+LqJw6Tq3WQDvpqSIDhP>#APiR5#AZq-r7GS^tJHXFm8VLfY~p zSX%HNXKb2zDlHSo;mv!r^R!wzMe8EgRbCX$oTluxE! zvS2hUijrvU)c9+JwB2hT^ms;Mz-ZzYK;3&a;I!W*8T39QRrruUH4V49l|lpfz>;zR z)?jptAytN7>^fPM;J0-PD4GgwdsyC2Ztn%fUG&F>N!SN7bnMJ7Efh+#b+*$A2FSx?L!Ya5H9?W-iVFseSp~LE`wXwvb+v19_c`W<-I{ z;fu*Y5WHdM<4<6Ae<&$jNu{OV>hF(EE-qt4nX6dCtj-a6r~AhZKG4N_D*q;0U@#p& zcu$YkY}!mn7fa%+ppd5`_HSffcIG|-nUXLf z4_fTV0}f!E19DGTaA}?|feV{)(t1fO22nN7Q(t8BV*(3zpIzKl<^CesRz)qP-mA8} z-1kXB0>Zr1kGYaWOS8i5Ut|9MVIHgf))(Ap0rn&Edo0ByyTf^@h6eVnS_z;%THP-8 z1PFV88;Q%i2z~wS^viha+8kV0;oyHnuk($zdaD6D#+K(=2})>CU*<;|`m>?=QYCbp zzr16KEOuTq&I(x8(?^sQZbtAnw>6ARwEdf+!y9PqdXF?3-Pl;r(+zKx=3f&a@h6)O zwquEPHv!coD-cc{sO^&(bX(migqSlq_){Wd9pyWrrx4Aotzm)R=GKAaSKpKz33zzg zK1PRZs;F3h#%*}Auw1@{C<#!iINVFxThm+HLjC2JqwHGbR{k~AsP@n7nX!JH(D{4* zvDeoRam~+PMOaSSl5g#&zN;7MIGe@aU-1XVL<7`qBTYBl5S_)vb`HOEJ* zH{?ICbk9fw&2%5(?H1_DN|)S;v%0Uk*pVqeg2UmfelWLX)bFLAA07>(5n;yGa&vbf z25mTw@7e&-5|^wOi`d#%K(#(`v0C$h05fj`(UOAaZ&2gWB;bY_t2Gmbp^Az< zaUO?+t=<^x{EVB(4?{aTy5>QDhs4Nu0u=acG!{9FbtwSY$W+}|>Sz;pmSv2HKoL>> zjyd$QfG8cW$*4+@Ewqaw`r*GAxtst9*qE3^m(&@usmWPcUqXX|X8rvk;80OdZj9Y! ze}esze{-C7Y>el9(%O%Sv4L0UwU@~pEwHREHD84;7E*!EiGZViF&(|UvE?OvEXMoo zP5Z`fj5A>}_S3TzD^chi`fkGA)Wa|QNpGd)&&bEf`s>FG%|D9^&YM6VNlsA_q!JbN zhFW*(jOFDa?f08X{F3v08X;>&1x4hM%gnnyF4B*9VQ2i*-P`VT<$i~nLMK4FQbjB% z1}nx_We%?bmfoldtw>gjd9#8djNDC~qN*wgpl!6bKx!scu((-G(_V_6!@3nNR8-`2 z#|^NZ!NeT7vn8uF7;f)MheZ;E)EW+Z&|iDTp#HXjnL6s&B`F*sm!X1}PGM*%baRe& zU0((Xvwvq+IzxRu3@)U@DJctdA}8$o-_?!;!lNFjJ|Hlf&6(#ELOAXkKj!l%hI~j+ zd!{WUC_1FEp24xAsi_jC#~hSN3jU!5XyI;PN-tktnUONlLqTAvj*CD8n5KP`Hdf12~x`+!(- zf?~>{DlPqXiwY0(X%-^!uFTIvzdjrwFB7>OtB90}b`ri-d;UcHz?9d}0ENo*RpK_a zgm}5Ej92m6_+yrPSuvL}2XBr3)kiKjoJ1-)s=`v@opSF`1sxsKh})l>o6!JEnL|*X z<#rzf>}??w@FFapQf)mR6H{`krlJTWQc)pAs6@&7U?_?6dphX-dirme0>#HT0y6UB zmn0b*N9)$V9`^@8^}lAn$O=fFC%{`^2?@s6SujieCtp1Y|5fgk@f%QNVM)X;Y^D_t zZ~8xZxT0TCRz0dBE8p8MG}Dpy(HgaCcKtDjiI9efEcAUE9s-w+`VECj!8JN--@lB7 z_S8^Ck#G`wblyef!UrM>quCwb+pD)N13n_fuo#z!kKXX=K%U&XPQ#H&`vk41h~9

Sv^nZ2c_# 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 z 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

K17+rLDn5Msf3V`wJ)i; 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

f^zl)KxUrUscgp0 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 WJtU=xLG~2}e2ELo2$czH`~H6kfV6D@ literal 0 HcmV?d00001 diff --git a/images/benefit.png b/images/benefit.png new file mode 100644 index 0000000000000000000000000000000000000000..e6cbd817dc47179d4d3e032aeaeffcad7d466290 GIT binary patch literal 26838 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

r|pS_z}zFA#yrnmaGNrR#TA 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

eoWPtJ@zP3 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 literal 0 HcmV?d00001 diff --git a/images/brand1.png b/images/brand1.png new file mode 100644 index 0000000000000000000000000000000000000000..757eb6a28feae346253486e213320abb225efd8b GIT binary patch literal 4472 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 literal 0 HcmV?d00001 diff --git a/images/brand2.png b/images/brand2.png new file mode 100644 index 0000000000000000000000000000000000000000..db6302c9bd279a0c4ce11794ac20f19bc3868422 GIT binary patch literal 7728 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 G3Hv|T_pC4g literal 0 HcmV?d00001 diff --git a/images/brand3.png b/images/brand3.png new file mode 100644 index 0000000000000000000000000000000000000000..faf73f5221f8a582f9402133066c3cb7ab088dd2 GIT binary patch literal 12336 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 QzF7eVx<-fs_*0+10EZ6KSpWb4 literal 0 HcmV?d00001 diff --git a/images/brand6.png b/images/brand6.png new file mode 100644 index 0000000000000000000000000000000000000000..1e8973b25e9a026725337069c4858a644d074c85 GIT binary patch literal 10751 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]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∓1x z667yIU{spLPa6)+w?uul2lV`*#T%Y-Gz?v%K#O{u$o2syUqLQ*O4bf6XI_SN)oO!h zt%d|7e~~WXLM=A^LXZlq!N9ntd!)IHPx38x-Qm(=c0J8yuo7H(PQJ)zt%)iP1=WM0 zCsl`$n!9|)GWDVI74h-1(pFcKu5Ciwc!Pj{@FO1#0X^VrC1q_p`u<5X?}O#)Toz7Q zuC^hEaVTKkA~~mNTUZyath@vLyoZBjN7(Kfizp+*j3r+NLrF@-W4?1uJ1{9SRs<{1 z)|Y;2(ExW4`(5^xP4 z5O{v>t-kyShs*W)r^ct)+by1V+2fQ9vkTd!qqtk;;42rx_r_@D%o=h@2&c_^2?l@I zycE^2Y#;U?czN8)hO~3rQ0mxO6A;{oBL>3?>*E{9ztffwEhR9ObK&KgfnBbkd`nV_ z-|_Ae+{fIx-d!y|{#BU=?dX(S=PSy|O7j>M;}bn|kLETqw@+^FEPwS70r~qzb(7op zbd!~TRGL#nuQv6zxUe@wB?Ari5yH>36i4&)yYTYZ+DqtEVg)>$9}3k~bR|i_Jr~2^ zfXDWBYC(d|WlkYW%eOwhwxeCbph;I^cbtyt;lYQ%#%bC9rQyNl@N-kvZTxU^eSJv6 zZhE_uxt6^w9-gGJY093JhFy~gVIP4aN+WSGQX26`9?Pk^YK%;!(KI~~QdsL6td8xX zqJ}JG10c3ev@*p%{z2qBIvSITFQ((bT%Kh>hlX@ z*PT;q!5@EjQG@IJt#ac6@hk;uW}uH=+-C!zJVdh8Nh76{c%Mr^#|7kha{R1ut&QI` z%qlWE)(YCS;ozOHfT8+~*}_R+U1ySteJU-pSY(r3l^GqERO`(5oIB+*`V&cN)4Ly| z6dQY28b+%Eb4xpepNE0V{hQvKBn&md= z3vCG*rxFIpZe%FCw{A2@2EEw#KiZ-Mp<9+Xmdu}=o_995);un2^gh@01>TCyPHGPP z8G3QF zrmSJ$P(Xy8B!nYQpnFUKc2g-$kK_U2z23v1x)tB}1Vq~>bLuYxD0117mGqV^OG$6$ zxeWQU1YR}k8%?fw_=@O}KT?I)n**)`-X1%nFLr*Ayly#rdi|kjKjQD9`?frS`t~|L zxz#U)Suibfm7~pU$_fZEvq<;vFr!#TQEM+*Rn^p2=RCTW5dC$?I_arVEOYaqYt~~; z)aHnDxSjlGDyv9)mg@HNh=a<%h$@Dw4mH&|CM!UV0uFlY`!^j!`WR0&V59>J`ok&? zBs3?FPh{QGOH8`zTCgLVy3k~XV;;RURM4XpAO^kAU7IMS2&!-^${7|aV9^%tms`&! z#oQ*Px_DaZ>buGe0-5Fq3b_3z6zw&0phy9B5}NJgV+wJ`g+GLqO2oaY!hgDv0Qti^ zLt1UF8|h8dr`8G*^rNyAcG96UsD|5Ytj+!WJm=kpzveZe{pHnDt!H~(x1ZL~iOU3L zXK_Dx#HH^22#HuhRub9$5dx3i0Cztc@G_d39U$a%bUyJup5gubw)|%6FY~*wtb=VW z=ri=CDA<-vJ)Jf`%6e7#{OQCtJoPNpnQJW5fa^NXNASK41F6YC5up#V6h1YWoZ%ya zgAAkN7uqQa{&!K3_Hn9=(ia1#kCt{mF9}02gjJa5w#mOWGO&F} zeX@hGt|Y}v{?TC8m}xwOjhhX3V2;_f7zC`mh*2%%D~^}1;V^Hm9vUielvCclPf1rj z-5b5+yf<}SU%Y>QFA@6toIie_6YXf8H_A;<<>Xtg&-QjJTo^%I&R5h%6LUQug{?#&z!z<4dhrjhnT9qFyn2JIHk4B0LkVm zGO|b)MPmj6oP37=z!+f7wTPpII{tl4#FjV4piJJ@wKP5syzxxEnOBCHwZh|rhg*P# za{PVrRH#(gpdrCAE=z&Hq{*xp<WR%{aex-XcPX|EXeJx_+PG^y#IZCH#9=|(pi9F*kV`r3@$Ll^DAO?PyJBbR;DQj zcBHCqz#bcSVqKP zDccAo8th|^i5SH5?$B|Gs0UuuD#(p$VUy;8?kf+#nS~8lmFMY(*a8EKTZsO74t4un z3{g4t+Y|UE17NLPMW1Yh9G|n&yFJ;Rv%l#R{lkl@X ze>hn9?pI=+-cel3dU$u1zn%RW5OBNlIFpdh{In1=7=%&dq2)bv+K}7I6mbn zN18p#)cw~xL3nf%TlawWS~4v&={=Wi$BLwNJsI|KRONGyK-Z{-wnTU)GCLd%UWi)k z+=9ciJ44#xhK4FYd0&acrX zW;yI1I?G4<-E-Gp@Fkl|E?&td+nlFci0lmLVuqPZ#J{Y$M!mlj4c!-qk`^|r42CFv zd{iht=&|cRrYOriSQTjLZq*hq=Zon7nLKpek}X7mEn*-7^U)n-|4CS}7fnDS0wddo z&4j|XEz6Utb;K3F-Onu<-@M89iiA)bIs9NQn3%u_F_$>sghEJ)(7%T4cFicj=*>$< zZiF~+QWPw3@MDk={eLew3#8@98`b@xh7NmUKYEDIo6(j~>Z^{8{=ANuP9CbLV>LDX zI0cL<(EtmT!`NPZvnv+iBMqAns6me=UKNTD9#n+k7CQ%m)m*t^R05x-0z?B9i+;zWHn3%Wo#eD_`CF@R;371T;X_|^#z02xqp^uC6Q z6#8;a8Q&EuyHn;y$DgY)6Z2%O>!@n&K>oaAPcHi8rV!yKW~$%qQFUzEHzvDj z$8%k?lFA2?aV?=+%Sz)|TpkXRFV+MS!&b=ZE-zI18O8>jyhNsH1DPPgDL$=}7v9Sd4=9JZ{Bk?DZ5b>+nf@Q;U;wIq4}h4*EDy61%cod)$shi$=RGL6ENb%q5W=wI%1Mw)F#rkaM2W-Xj*j9G*EZopx{17teAzA)xOu`B*eUxScCM3^EM`$`dY z#vU{ShcjLJJzqH+z4U1xhkd4t5?X5|HUw*Afp`B8kr{w-?(qi?Od;qJ4qDg4$;Nyt zwS0mo3XsNG2=7yh9YwMe#d-~#o zHeG)-q}H8VY+L=z@bBb;ja|eF!jwxhm#9Mbpp5P1!oD+1TRr(<_Z7ANUaMn15AmzN z_`?FYD(l5AF-hu>6_w{E;wslOqiywRZ*PvA$jgz(buM9P%~&x0%jcz?TLeOcAW4Lf z#TF5EBO_~e!mi|!eNH)jI&C&I2_Ub}h5h4&B?*8u&Z@Rp_HfG%XGHHrDD%Fx(v9tvupbA zcCgri@%BJWV!Ww1P~gY&N@fbTpP1FMfm8RZo_Rf=mIY8G@T9DSo#b?O<7PRyzLHDd zNzAEXiRjgd+vAgcT7;hlhe*PV*Xk?U{UZ2amR!kB>$z$E*Uu+yE~h>9&7MT{H&K3@sS+qbHz4rBpkW^!?j@^W_NP3Gf)TB zUS4Bt{oDH_7`$rqtlbaK4z?R8M0Q-scZbe#9#uqjP(lZyuP?tF0?svL!(bQj2Po-c zTj}g$W`(k+pKx8k+B6BwQLwOFD~S9GbOmPaahdAhr89HRbM_qQSg9wYc^w`=>_x)} zY=M|lmN{{R9kGPvdPEH!;P%Suv&_^a4FV#;A<6i#Xc^2^lBGTe+zgFrqY(I0O#Rs7 z_e;;3<>yW?Lh0DHknJExkXF)|5P>SLcuZ%AAj8*MiRLzOiMp}VHT8{e^k7WNQ}moG zVubL{`2^6-HgwV4K?*f&7M~!Aa-|vTo13yT&8J{dt)Z+du}>Tq=e9+yD>-F2>++o0 zVQII0U)}pJ-%+}$A_!ps|E18!zc4VEE=_?KZo#uChq;AB?VW@AhQQDPQj?>vo|_04 zr^J>7in>7@s7^yzvR+kQ+eEBvnrf(?CrWEYS=~7eAWk>P%IS;`cn4_UP4bO`e0xhH zKD50=SZTFjOUKD?oJYP?7`-y!FMa?$fBNI*el8AN^1E@N6@|cE9}i zSUh25!5zN*oxQ9IEGik$;6+vJb9X}Zv^*UZe=@G}b$8EGP80)v)^$!1r%@>F8?ys4 zced-cI?vgW$k=Q+Z`2(!V?EnfG(@UDu|HGStwyiTuk6UbR899E5mR)ODLV0;?Tejk zx&P2%EjhAnqJ4Cw3L5(R=sE(_6nVxQ)EWCoficf|C&u#t&2&P zcGwfp(|u8ZB(*#QJy*YF>yt###QxC$pr20xR#tEmE)*vYpXOHj$C&4K(Vq&FSPg7= zj;i-Y-=%M7L1#%y{yz0KO`wz&2?KT<$HTo(r-+(99!h28YE{OKz}B zp8nS#G8ApyErT$nPeDEMqLu_s-pp)Vv(icw>bM;2ixAW1h1iNB12%u1eevI7hQYM!U3u{DZXt<>h_UV8!YnD)F09Th zT)$eZd!#Iaj*MHs%$5r%AxY`bl!l8%aB=}i5=40>ws@tWT=}42{l&kB;cV3Q#|*Va zr500dOyL2RBkp*spVi4Iw739U(o87-6RTs@?xG6fUXc!+){RfoRBA6P9VGE`3C|z{ zF*c~lC8m+NmLVFk*!j=U;Xf)HFg&}ZMoSz-)o{r8)O0l02IF!JX5dYn;P*cWn+TjDNZRjX(vqG@AE1W$`RC9~+(Gr5f z(IEq!YksJE1dx@C)GyceqLS6<`!Sd=rxBR3Oedb*dJ<8z4593exL407db^eciBtOh z_EYhkae;gKl5#k#?NGovDB2l*rw;bvtu%~;Ld2hRHlkcs++|8~H~^_`T<&XPtr;K5 zV{EwNgT_pma&RZ~6r^C|DMC19UkC)UBYM`QDrvo$zJkVo9P#Ir-xnb`xz%IS6(m$T zh1}J^!OYvp1aS$@(FN!GjIt0X=jPFvM@t<4a}S-hqUyy1qzY7M@l=4wt-Z_7vpZ)_ zmjM8iJgFJA(1hteh{8F!Rp*11@;L+vEo<#064T&%Hh}@!FbJR~fkpZ+q|315T=mfy zPF}+Zr4UtgY=W^JNjwU)TNqC4cZfd3KHK)ukmowRD3IstXTyoP|>#;I>c!iq2Q#KYRpsOrGYz0vW&qgL6RL5dc#(w^B^bmWn$x zl{n7d=)!>+U+%oO>j@=OUV^s54$-uL=*I*l;T78^LDHL>s;$p)ZAF4*sfqA?I`lzT z)Y;#cB&99n>Fd}soz*Xe!wXILhc=ih!4(aFWrPHvg*bu2CKv>S$4(b2cehfuR1Ee$ z>c(EVFr{>sJ&I{n+u$4S~~sBSXnUclc$QtSE&g zDusO-h0VkO)l*uQd``4&;h$$ey1C6)+ijgeg@HsTnDCE{1;`OyQ`>~yMSKk^s446T z>57mh@=I*uEote|U>xesB93WZGMW#2qX#xz$b{=)+NpD(8U1c%?45OEuK!PkW@|() zAne&^G+4qcs#O9Al{z0}>V#@?b`hL>N3^%hQD#{I$xL~M#_HS*94a~=0BgV!&I}N%0r#y~9a6a4TLaANIybFKyZlJhndA zD6$6ajGSOR61xdb9toFL5&aTO%+yzBW=Fr=>X6^jzshVM{$FK=MKrHK=3GH=`}BW2opn@|(bo0pMp{z3yBnmXySuwV zq(ng4LrHgsfOJd8p&LZHq`MJ8zwLYP{l;Jn|IvZ)oM-Q~=9=@jP@O4Y@X&F0u8~5G z!ZHX7@Co?f5CJTL{9N_&Z5|6c9QPbbtWMZxIJx(97QS*h2`X$rt_fZu(2a=^4q0WD z#eZ|Nor>s+hC5_ovf5;wg76e}MV;S{ufGlhK4>mY5auj0N~@hnZ5?EN%Iy%gXVMUU~* zyLb1{wuVK=?nyHXlVZG;Wft~u|P{Q;jl}L`dP9KMUgco(eD9cH}+3ZWmL@=K*P1!?Szk>VVP18GMYrbD$kAnqzDUnFN-h;BjyBd>!+A z0(*V}qwim8*4~L0u-WCA>@BjzU*`&58+~WM8EI{W15@6)F-W38bOr%*39+bALRPzV zv2@iIiGesP07Ej@Ylsy2TPQCo(@yN5$!KeIfzNZ;ikA(iyKiBk)6>uBfxTQA**Z;D zFk!c^)Eem06|{C|WuDnh892k?>>ee`wieAx{2`t&ERRU;edPN?wsoFRjOFs|6RW+{xc_EpoBtAbU1X|?5?ai6 zo0=cn%P8T*Lv}q!aSnW3gZe8kXhh8OYxp5&a?wYgm`uc9rj_w<%W$dJq5W&zed2Kg zWEf1uiM1iavP6*q5!w0#iTg@_Di_3DXs|hRzw2HNonu*x9#(W1R+T?w5e5(O{QDG$ z{O?o1IzC4sDG?K|uAw|U1q*z5G!1Yc@o=x5s{Hz5J%}`7Iy@$%* zP+3hf96vba;jAK&RNx<$Ifaz>?3$KYFwVAY(id@J*)!@{sF)3Pti0x~oQ`DJhb*{2 z=L-jh$!a@#rxB-TB>s(OD+z#;v$!A?eRT2d?0c(41Juu;k@0o6h`sa%Xig4~z|r9; z`Wq}pp2t#VkW|>ZiYahX4Ct%rTqHLo++G!5t!DV;+{+pKiDmOfS+>%zTdm({4esD4b&!X}JhHV5D9b^n8?jAGOB%G`M z=eP8Yn^P0wMq|UD0e64kFVhCYp%++>L0(f@%HVYV1phz18pit3SzZ^;Q!Z2ZS2d$9 z-2M(1bShUd@NTtdzObj$C*+L@?$@THu<06>IV-0kwP2R+;EbxSZzxqQo<`}cw=xox zh~?}$p#a`CFb#>w!&DR{7vSuYC$dLeKLa2V93T+~abuLb z={p}e0~O9boXt)AbbaeUVP}vIr^ZLhtVCEpCM2?_!QYJ*l*JfptuX$5e8RKDzV2;? z`yFG&SV)=Y@mgsRkz0`IvY`wz_!i#JAS}QI?)(nKSy))GOya=;2Abe*)lWWHW(1`@ zFIv6SR}G)4;VS8d-|!5j%^@UYA+8<+mfmqW8~84GaDVLY(lt5YjKh*s78?|z<8!%k z)ks@kaFKxJPv?u5rW6HrnoN8OKNbsOkZ{mgCX+J=Z0at5MGc%4$VkSai9D_a0Q+Y| zsB=^5T5@Q0H3kQ#-l*a6o{(+Bs>ztX7yj6*PZ^d5uepeD;049u=?Uq?iTOEsZ8iZi zrbKG{<2v>uDU6s1VtZ-e6E!Z1G!wze@y}|04KBpg-PL~1bgB%TXwGW2{*Er&VYM>v zou$z8rz^wp1-9kpsD9e7Wf_x8_jj2@%iUqIAru*jK!?9iI9jeshd}a`ImJ5}wZn+~<%~ z=Dr<|koY`>KygcR`tq>pcmDXj#{QX}N(v;UR|KIb!=ngC%)!6-C|ePoPgxe@!-n6M zo_f|Nfvrt*UeE>wIn~k#AP}D@KQ4#cRdS>*3@jmXb~9gI*5ckxu@j{X!eI#`oVDON zj-eiY!Pnu{-!&_POz{_72qQS3D2ismiIZ3=v&orr?gV{{1JZ(jCJGpoOT-*m@D{?E zCg~(Zy7BRBua#`Ys_o~Yhv?Cx85rl39%G2t#A%IQTk?X;)^L)D7#d;vEXqiXzd z1kS-olW>y1zX$-<_+bPOUJXhMat@4RR!@!}Q0}vc9R^{GGX*3@)1|g`riaQCzT$Ge z_pYv?b#n>-btrgAsP*Ug_I+Ji1{3tR(esBpqi*l#4eH$tAVM`%o3>m0tGHSI=YX>5 z#Yl}Fa{NA0fGy$rvH;Yv^(erWCQAN~7V|J-1+Vof>`e{?`4wDBiG&=pq=4Gr^se<- z_Z#n|ULK#Ce z;6PqQ^1&h=BbCsi+kDsRSGy2T`x(Sz)6EcdTQI%(4nee#3Za`FG2BGKQhxI!w63w& zS9s)~+tf*|kW+0l2N*!uVtRNv(5Ly{UNQZ;MVIigiLoY_G55~BTtcx5RNa1x(J(97 z0wcl@T`3(@s(x+#wp?Dko_sy(O<&)^R@uI;5tYsG%sM6`wiQkWhHz|&7+dCD>yBGh z+CD)+jV-6w#Gn6t!{0p;y24ul_wRjM@}^htr+BEWJZq`9I^aNSM;^~5{wguu6paR# z%A4QGw_9z~v{J$ZkxE3mt==Fe)*7LAq^jT2ia({~PQe$EHUss$9Xql2tLeA0WF%bj zZMG(GKu_safWDDNYWAUF98Y*i`GftKiJ_f>dO&k_gBB?wV`i4wl)GF=DfOaQ>7tG1krylGX?@dLne1n4rD-tS@@Wa#O#5TW|NMjVm7LH zC86VQX2^=3Au-f_!+?$RVV*8=zbKtacrc#jadA~c2{qed~gBj;WFLvb2qpzWLzi`*CY;c1tdlIBid^DkIE! zPKCUsM#Jgr4+6X`l%0#@x>l&KFeZj-`Sfr*(oK_N>qd1!jcl72;OOJWrYc2RZ(haJ z)d2tyY%W9r!a*b`WT%bq(7MQeQL7|-$T(bDz8le~u&1$z&_d@Nu#3m&@#2-&)*h~h zQRd3qmH>j-iUQQ1#iYYiaP)-4O*WA1xA4a+Jp+XyzX(u?qcvc0A(G-U-m}#{sz;mN8tNnue3=lG!5Q_ zI4OMh$0%Yo9?}6gg3Sc~{}J5!Krk@!v3bshn~eZq^#B5_9Syo!+yh3Zmwp7NR^p5^ zi&FO0bjd%NuKi$JulZWZyao>$OlvVR`rgK1m9ta*v_+p!=91e($W>Kjbp^Uf$RJSiPGvZ^)j2>oHaM0dw~v zq`*PWr(ME?n2JLy=V(n>Z}Lz3%|b4e{=82I<%hVrGTRsIY;-5cF{iqL)PW1t4PT`^ zQz~vuLT#9<3kxx_tQ6E}RR4?tn3*?AsZRn$q53Oa*wd(M6EQFi4X}W&g7UEN&^V9sGb;vhOrlp))z}n%1sNDeAVXHbxB|{|TcoWV(^v7rKxt6y zC6O=qAu>}n#Cd#iIJ!G9@wqQ|z+7IbPF|Nto7B%9_XV0#a0@;TMwa@yI=0~4Ner4p zQ;Adga5q#!iwIA$@9)DnvI(-P8eO%tMe?pZ25-d7N{{^1;+B#^2t5Ld#1AqUssPC+o)^a6c(;d@ zP22!E8ufqW8P0cdwMBq2ld=^q=!nuVgAIJl=BlH-9H|9Kqyo33={Z()Be~%b+K0eo z?`tBbO&xE|XB?7*Bw%QxN+#gUtPJLWCe!saFhQ47x5E!y;T%VS%HC6!rAzUSK-KM# z11BLB4GiN7i(?`+4jreT} z$@-DDh4k^Ljtu++B&z4#=A7QWjIUyh06~q{1fA1ZV|oITyWhkQaqTUiJXLvM*Ek{P z064onlP z)g{&qL46hkYgYTgbzSh<`2UP@jS?L!=_>(yZ>5Ft2@og;%V2*6J!zT|jrZ(@_{(2& z(`9CY849I_c7?PWdQZ#(tB~oXxgPENg&>7gPHLnFZb%NWA#=nG4}U&)zLwvZ=goC+ zn9sfUE)IMU2m%1?9>kerbKWapFl<5npK6Kfx;{_$aGq%f7nEP0uAW?3P!e(J3%LN# z&sg2kA&09AremcNWi`e#WFB8)j!{+cZ@YP-{gH4&p7ijx-1{T|$T(sN|4SE8KzlhL0d6mbrr$;AF0V__Lh~g@@d5^P9g3!g2za<$-ZKa|TExTV^^$Np5JU|4p zMLd|nElk)uk|84-9dW+Cc&Um77%Nl^S~xiHb+^t$J#Xc=Hxbf}Yy!DixkwTI9DM_e z@kU3b8g4iI)4E;hWc&V7p)R6+A^uYCFnf7_#Zl)+1Q(^AfLgroIIYE#P{@=UUE90& z?dt4P&$_sfKQ*0nsD(Uy>x=7OiM>`zw0YwXH7{ENe+PA^+t>6D-5c%_6935lowM=l zw6ptIb{~v~q;a1(VE(h4SK4fzs$pOW;UyEuX(eYr zB6OkC1t;+s_t7d?T5K) z2tERy-nvG1AgW#zqZ7%szMp*idZ(=;n2Z%uDULsR0?LArlPwUi6z-QzdNLeneFmJHZno%Y@) zw&)E^IEvRTn=1*!6ZC=8PMc~QJkv{zn-jWL6xFyNur{{uRJVNSRjql?$-j7G;wqFX zCDuyguEpq=V+noVr}?eG2)k6^5Z(PNCw9N+Wii6?k;>CkK?qg=>TQam9b6PKL2^iF z|B_$uA`fnN(4;TFqs95OoI*%X-uq4H#;=5FLx#R@;z!=x!SLB*?=|@R7c+4~JcU~urk1YZEy*@w-b5b8w}Zo0$}QYa@xKr9K0Lrsyla{< zRw~$!DqmOimx`4uLM_6?CyAB2RWX$4slZz#qmcXED=QU6QE17 zd_{R1tp8jiotXtJ>*dU_5v4?4l@hWVtZW5}Ux(@xd|M|7VS8HW>S`T#G$Ny8EO*KO zy!G%GLxGE%(jgi;kEE5`1I7iSuT2$ypTEKp&>^S^x>)eCZj1OZx|0yXy{v5>^c9Cb zJfwijI((J2Pwi19@J9{zgf{+{A3<@AzmA*JsQ=E8bz-A|X>ZRM>TaTrf#qgV z5d8T)?y@6lxF14){(%^oU)Mj!U(bB~Kp8xwtRMG}3u)U@*z2IFShH2VEp38ugt?4% zZ7Ag9EE1^fb6>#cVJaxIEw^HD`e&*|!?5jW@p&eiCtk)!$?AV1EsrY5texo-vQUV}t1Z z9bCYE4{+((QI)cyqneXGT7|UEe~I2n(tb!>Pz=%_FKC8b_(yQo4IemJ{Iu58w&viD z1F2(Fz-hQClvJ{j9~nVY6V%LRxXc`A^N7ThQ_PVB>s6VMcehACl`1>^d^7MPJo%bvpNBhatbB7e4?QCDrm8 z1kd`g*;e`Calq4S#v+2BgG@yd6?we`b%jkhQm!|8;ItBe%zlYgNy3d(auLBuQB52l zsB2ZBS^`Wf;_a<6U@8&F+|^G2q)lb)AkB4-8(4ZN7YN@eT@-Rzj5>Ucf8 zX))g>$86_Q@s>-04G!*8Q1pji;jz(l(BEQ^u9s48nR=5XHE8-;PBn0PIp;qGx_!b; zcKSkxp$y-^f}8h3e*7!;S<{y)0v$RW99OH=ylAYxDS@9~?qQpHTLLe^6CCqZ^`MIuZZ1@s;{aD8VYsC>& zc0D}}>3XG|Wj()h>o2yp^TQ+;XInlu3C5J-NsfH7FXq!FUSAS>$R0_kK-MOjoy@cb z@oU_!o#X5iZ$(xj-x_3)3mpg+J4DbLINL$lPwTmg7&tb7j(Gr$fOKC^;(f^|_jRpS zehCueIG%e}ofmg9t@SjL&kI`mR9aIAUT%DN?YjZSVXlkK#GZcDTM->o+JwZHb6*r} zvtcy<#?g}CbSV+x+rcTW#wFMXx3ARU@HCs6Y?*TmSfS^aCAlsOz5Pl^kj@cs^m9L! z4{B~y6fj~G`tcO-;84NY2(^a~mn)hHw3=7Szm~nwT?)UDxoCb41N3ycSwHT~O5&-Z z5P)?!q$52Rf%tXz?66BYVHR+jh2ztf`g%Je8_y{N%DXy)ff3CbAQ-;aO~vkLL#h}{ z79Z@vx3bBpYnZxlV=9>1W0un(r=oe~0hboNuQnfot-jC50yfdX=XF@Jx^a_K5(ydL z?5I0`Nq_|{av&*~`9(vS;THxGT0UvU%UZssiL~0>*0do?2ZI_lP#M#yP7k1P(Q?dQLE&<=qwd?z{ic(sICF)fc16v1P9Q^h?t?9~qUBM~n=KU|sJOAq;#f zLUriBO=1u%Uvc_Ne<*aaK&JW4ztfiD7UwY&b~oW$(GizDShPhgq$m0iDUFHfB{ZEbk-%~Z}xEt&=o-}&~$XWlf_%-FA! zx#UmV^JcoCi3BEWJk~8x^uvHWNLda9uO7+ez(vb98+ zj;gXizkUu&?v3p@h9F8DH?sO_Hlm9Q;Q%A_HQ8sC#vB^~lf#v#G3vr5a{?$;e*_2> zL9ggJ1xFqn2cXN%VJnC?yu`kBSjHNR9%pK^HCRaVt7bkxWIs_K*@U=i1<=cc<$1 z{ZY*zBw@nbA!IUCf5nzOo9Cp?=Kk=qq%AYUPIc`=*v9)Gk$O6^jhRT|Y;3$gv#gP4 zzyp%`Z%Il;8$}gGrzLo5!kUtE&36hV`m=I}T9f>3O~R&5QE6F&;UZsp+bvH4LuEPL zsP59=aC09EGjM*WoE0}Aw7=5&2vPjY_mHCTL$Mx(u6ND%%jjMYU)OlG4QE%KfngNV zWxF|M0Uc9_{%{$9-tPrRaf{xuh^UQU`HV=lJgL1SQ7j{K%#5Ij4!aRC@I6<;k88*X zQNHBac+Ilvyc`>{zUOW~g85u{F(9{;rA;y!D+Zm@fS#NF&|k5@_gknqMHT}*PMdW3 zaqmRuK$`b40WRGx5WJdCJA#wv2Fz5VsgNBnb4!iwImyjKckGpKkWxeV503*q$nW96 zq62a@=M??Xk5^4rj{|&)2 zn-NGQOl@<&uTU>2*`dQ#h-0btZk(6bzkyv5WnK@vUKGJXrZ2oLFG2l)=Q)=*0NKONRlg9uqilLe#w?e-kP%q`UPjf10fQ zk(yW_+^M)dby67T4L@-gQYeb1qI~&$0jo>bGWw_<&*lc^H$SKw!d3l5Myl|mot_=X z2Z0A~&s&b5yFAkre6)-gwfw68-o_Yyb$f8}2~gqH(tR?=-hRR*YwR&szj=<=RNm`m zw{ZIidXWzKaP9eIya-{Gye>;+c7t@Y6kjge&8ZEB)pJVxJ!UM75oYb}m7CUhW&Wt- zt==s7n$MhKm-*pfKI_#yLt^RUU>4=&-~e=Wr>yt;ZjntpgB( zJk>y5Eb*pOqArb$SjM%x>*V1#f5dB7%{LO9C?K$OC;m#8Wn$fU^YtGQ*T89pY2&Y= z?$pGn>&-)9nZ|>U3>iX1=I!m4+$vECw?0#4zk;wk&)xjw3aQgS*R|CkaK0u@_7!v4 z+SGsk{(MzOdVY@vrkUDfw$`>2qY{LEca#iAk~#yEFnpmkHAw z6*umy785D0jYY+xg6!}ZbF%V0HFlR#t2^&9>Jj3wd~QXfA1Zh zD6}c?(bdXF#kkmxNUPK3N#||G6ZLB&Q6m%ajpq-4&;Jho+5h|V_1}IUiK3aO{OSJ` zD@a5R3_cn`P_E$4L}KFcG5SRg3e;*2WbWAoBgXEp1`g>5)+E64J8jISo~>qIVcC&Q z+d*UnnOsRXtiP1(Mt}Vc8F+AGuC{r211rymXWn`8;V^Pg0}uyrssp2MuLJZ1ZRhV( z8h=D7=q?Bj9N=O)M`bL1U#3rX;g-H=jRpnXT0ALb!MUFSZ1n!5JC2%3T5*Afz zQ1a|Vq)cCUNcQaIYM*Tu0kayZCh!3A5BYmG_tW;$K7fs5(BtApHAWTLKI2~cevf%!}>El$#!iJrQH6G zXVy%(a1pxw_V(ywTCAh{w?V-u;o+(2-+s$Us{SmRi}O3;hw?PQ2w}X$otR2hMZ2cgL#h;oSM71!&0z*@dZZ85{kEEb<&}?5OrV z^M?wk$%t)l`(MCcp~v_R5z%6Q=D!{xC=G-VCY5HJ@~BDf8Jm?o)z`)33Fu|b`7JfN zDv3YW{5hi-`|z~5^Wk96i8qsiXj!5F9Jw38mG9MRt9mj|9bV>j(PGtMm{jUn|}L%66{d4(yyAu$*(3bWdN^m8ScQPxCG{1YxFP|uA5YLmi1DHB91`v@*> z7Ou{LA4@G<->9cISAH^z+GZbck?S-*79l!a_UreWPsPy@H^< zTt&qa`Ck+V(-87?A%CK5W5Rjd{q6X>Crfow#c1vNrmYd(~a7phf z(%el79WV_Jm8(ucuxH-!`e!KS3Q~KfGGL?_(t#$vQA@B!Hs<$H^QraQ>|7eEtX~KC z>GwPlrNv}9JD;wVGAkMPHh6WGi|$f>Up0LzEa^v)!s5`F z&`TyLn*n23!%6cw&1$KT$J}j-xx6kpUTU(k9breuq@}&-a2?`1_xoi2PiTkNg@J+J z7c5`!FZP+GvapY$sff@>M|%A`iIM+X9|gbS{2BvyXV7%#7S>o3nDyj4#!*UULgahp!X6i5rZ5Kn8%f(t19UMcWt7W#y? z6C_el1BUprzI{0tp(Bg0*B{X`t5jnY+Q&+yFu6fy3@-o6Xb&*H0lcZ>EcEDQ!MDWe zHGG^r8DmmZi`Y+O`Crf;9K-4wappo2a9djuN>gEtxE;qpW_?S+UnZLrhU;23}n}@DDWTE52Qpy2Oe6YO;M(#|oVx_I;b=;H_$DZ)h0Fpnq#UJQJZ9 zw5~3f$ETO!<&2u+dhv=b11Vg~jhZ{7Q{^M|f*2XaIu4gsxmqg1T|DteE!@10`nq@H z<&~V%i&Cu{rJ9>Bf5zAg%JJgUIv203+l@bH+ZJ6Sl12{U3K@)+UltqXe@j$1#8z@U zISIa6PSC$#u{xYi4s+9ruD@x@9PQaJu#efYHzT5~rNLwp>6qPa$V#v}$+jY3qStyy`4~B2M--pQ!y*&A?

r*w+Ctd3g6)E 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 + + + \ No newline at end of file diff --git a/images/dashboard.png b/images/dashboard.png new file mode 100644 index 0000000000000000000000000000000000000000..2a1024f0cfa7e80ff69d0310d8b8f22027bb273b GIT binary patch literal 751666 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 -{WtKdoF!ys(|JPwCWsw{Bx@$r#I_UxGq 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

  • U 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 z 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 z.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Νyoe9v6Oyt~#YHiZ7F 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 sVE%-@TlqJ_xpT8x%kIDb2b@LLxc~qF literal 0 HcmV?d00001 diff --git a/images/farmer.png b/images/farmer.png new file mode 100644 index 0000000000000000000000000000000000000000..59e63ad044643d02b181effa9e10f0f32ff3975b GIT binary patch literal 98030 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 PcvPr7(o`&ye;)836$5?6 literal 0 HcmV?d00001 diff --git a/images/feature-1.png b/images/feature-1.png new file mode 100644 index 0000000000000000000000000000000000000000..1226b3fa874bad5dcd459780b31ae4a857eb6b04 GIT binary patch literal 120890 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 ^ppeUtsXp^Wri6syb>UBs!tuu1a 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�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%0DtBeCJ)l%CYy< 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 rVvyu+oQ3uu*Bpq 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 z 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 literal 0 HcmV?d00001 diff --git a/images/feature4.png b/images/feature4.png new file mode 100644 index 0000000000000000000000000000000000000000..720fa5ce3bf1ed127be6c49caa5d69fe0142ef4c GIT binary patch literal 209718 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 z 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�scAry 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%0Du7H5Z0fhAxr^N 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 QCgfD8lP*6o?XfBU0qmRKnE(I) literal 0 HcmV?d00001 diff --git a/images/hero.png b/images/hero.png new file mode 100644 index 0000000000000000000000000000000000000000..8edbbcadaa7fad6f7dfdeb8aba6b6baf00203d49 GIT binary patch literal 153301 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

      wH}K(Kr_E$;d1TYBE{zy;7K20 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 \ No newline at end of file diff --git a/images/hero2.png b/images/hero2.png new file mode 100644 index 0000000000000000000000000000000000000000..7d839b8a1c92fb0503971d2c5b572e828930ece6 GIT binary patch literal 108880 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 literal 0 HcmV?d00001 diff --git a/images/hero2.svg b/images/hero2.svg new file mode 100644 index 0000000..c389655 --- /dev/null +++ b/images/hero2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/hero3.svg b/images/hero3.svg new file mode 100644 index 0000000..5cefb41 --- /dev/null +++ b/images/hero3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/hero4.png b/images/hero4.png new file mode 100644 index 0000000000000000000000000000000000000000..8d70bb14f03fc385904d22861091a5352f5e437e GIT binary patch literal 377976 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 z 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 hTa+mH|MdS=b#Qg6mC@*=X{|lI#{U87U literal 0 HcmV?d00001 diff --git a/images/hero5.png b/images/hero5.png new file mode 100644 index 0000000000000000000000000000000000000000..45db49576423d839edae657e045cd09e44ab929b GIT binary patch literal 83397 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 V@pkzoKL9HMC95ivD`oih{{S5w61V^W literal 0 HcmV?d00001 diff --git a/images/icon1.png b/images/icon1.png new file mode 100644 index 0000000000000000000000000000000000000000..05c58af2adacafde173bd08c006a0afb9a1154fd GIT binary patch literal 26486 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 M)>0}~cpCV>0GrvI6#xJL literal 0 HcmV?d00001 diff --git a/images/icon1.svg b/images/icon1.svg new file mode 100644 index 0000000..77ecb53 --- /dev/null +++ b/images/icon1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/icon2.svg b/images/icon2.svg new file mode 100644 index 0000000..a08760d --- /dev/null +++ b/images/icon2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/icon3.svg b/images/icon3.svg new file mode 100644 index 0000000..2dcb65b --- /dev/null +++ b/images/icon3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/ict.png b/images/ict.png new file mode 100644 index 0000000000000000000000000000000000000000..fde19dba20f817725820dcb62a90f39fa2426db9 GIT binary patch literal 8505 zcmch7Ra9Kdwl={Dngn+V?%p^AhsJ^imu~3Bp&OSVAwaMYf(9o*aDuxx?j*Pb4^GhF zx3kaL=laQmUU)*9cGn)TJJRco$DZB1qT$CQszP*CtyRTN&Lpge*g``*}? z$aX~ma*h0>fGZlobzN-XURLg46giNKHJD!2$;uA=5^M$XaT@?jqM)F$K=q8^MjAkI z8y6=Yt3MbXZzorzGzyBOjJK~~0bT(CZX|*m=Hm>v z^5%AiG5xJU0SvQohq}U{F3$9SG+J4^c)+C?k)Hlz2u`m5QtJ%+XPA%ylw$ z`!l4!ff^eBf2fnwztAxFOYndD`)?J)^n6^wyf48p7Y}zE0aO!nWm zkPQ0M{TFqS7ylwZ*cr)qcOBe9vC^SW?3UYeh^ZOY%-lmAeBdsMrzoY3kb#su7 zjY)414WB%a=*M&H;rrA#sSLa=ebz7Nad_o11y08|Zftu8L$0rLqr}DHZf_B$rO(fR zPJ}K;v`zas12u#m`zZw3grKMW-OvZKV2AvpQOU;n8}RQ@e*yk?sI@7%JYCu6R-5{p zZRK@5$y0mL5#DNN7V1NrTcA42@$>duA{zoWj>qz5tpu>wXwh?5rKP3A6fsItX$3e_ zLRcIe9K)-LxD1w4EJ3vnk7y+b#yu^kB0}q-hQYaP*_Hw7G#ECN^(eZRHzdb|oB6Dt zgm4^I9MbrBTT8G5-EccRNKkOmZs=d{8AJr$?~Oa0b?i=td8RgpCq5XHbZDug+;6RW zLhPR$PsaGTii*etEK6fgH(9BA;`G~^Jq+UXpWw_k_|i)1O`vuXb$kdSC@SyCnrprz z9Uk)Po)AZ)%oWED3$8pK0(^M=cB@jiAm(-op2DB94eQ>$Wt^qmeWUp$L?$t5QePca z!xVe%w*NwzwD#u#I0-y*qSQ*aaieSAchDMo)%$CKM|b3c7j?U6P5b<&czaFM&2N9F zFzc<9-vzq8gM+$!&bUQ(|L&_-uRie~F%=EL?QxJZniA4im#CFQ0}+w9SB|6g?^rXi zSBXhKrhsNN1V{)4M6H)loxO7jor6*Ft)e3y7*cY47w>b3kG8h9IK{=qGarX{C+ErH z))Yr&dap&gSer+TO3J;LeWsh*A3O`1gHDtmKbAMzsroVy}e#|JA}15U|Vx%P&TKHQui=hw#1=LQ3mCY(r2ra zGznk{02@!QP9OzVryc@jRn3&4F8Ku*FCF+!(2i{tSgSCclZ0B+_KicTi-6cxpY$WD z)2k#bZYW)b#~;oXgi1(5>n2@rD}=It(LMg!rF0dSK(}d2>_)_TI^mvKxjfu_7?KIG z)>2WxccWhs`eV2|Vx+X8rr?=Ndgz+3G3M=v%QtQUADS?#y0kJx)VAJg9pH`)T@F

      &&HLX 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

      MVWw$7a0dj%Q&OHut?s=r4PkVKP7>pkWqq* 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�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 literal 0 HcmV?d00001 diff --git a/images/kds.png b/images/kds.png new file mode 100644 index 0000000000000000000000000000000000000000..8b17f18b92b631752f52574289ae8640709f0e90 GIT binary patch literal 140051 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

      MgNQ#hE56BY^^o&gU zRmz%c`?wSFb~iR9(i;5N(PCG^LgCwzYEJ0ssO`+EXlU`+nNZ8119p`yWQaqDG%a(}C&eT!Oc5#)mCX-aF zQQQ7fxmy<>{}>@D&9b{^&+Rnz4kx5EWk=K&P&pOYlg)Z@efim^pWoap2Ls&d2t^L! zBvMSWU&|(eZLe@o{V0mYV;m{R^>o?iRv0&%1QayFTKK3$rb~5uB>Q2%mxyHIj8!{W zh~D*{w6V$KtRRZ={`mBP2(_vrO3P3p66V~FN0UJ~L|z((!#LjNS^Dhm1_k7U2M=t= zE0P!wXBV&VT(9o#KKu09Iw?xCtQDNVFbBSurNwf+)_Yb?#ZgA2tHReymx(iJwm@tu zJPyZGjt4o^B0=f(#dWfY7jR}pG4jJ{5RE3I0KQsEO%!R!+fYASjwXOkg zPu49M8xCBo_zmFBJjX5al%#!SmBibsD3I{Wk|Fyed^^48GNj2#>ln8RzRC*_Vq76l zHEcYm=|rko_EAYBDMrV~;qW57%Fhha@(*THq!pbia%4jbM{tSYxnmEmJkp1|^yHq(BHXkc+_peroJ+Aqd45yApi~ zB^$0~ZWfuN;IIPwR-zz!k6sXo0P0By$F3reV0}meV57*n{z(>kQmnnE=HaR@P7LZ2 z183yHdIn1{Jor6~#N6ra4ahWPXGPJenMo?B;g}HRSVY%B(1nGp_Cz6^YTP z-i0iZqdFV$+eOrQ_UyU#xBkXH!SB>0pf3`nrG!5Q$P}n1Y2rj{1(N!1IN*?d*X*bS zT6ZsAU4M3Qfdlg9gGbGjqb7RgruAJilXl!qAsV(JG*GW`lGqEcG7-Vl1@WemgCxx> zZl>qRr^*}^S|iIIIq8PPNyyq2o1m(3R8V;VNn>X1cC*8o>$_E5B2gOPynCK07;lfc zF`d6DVijsDLUm$-Xb8K+o!Ns)xa4tjw?JA`wpKx6d`jgYhs<{=VKW>yY0+f<=)3P~ zdGh?*OV=j}5Ylp34%xuT@aiCbwru;kR!-{cAT*Wo1Y5d9FJ!8(4nwsC;iT`IdAJN) zU>GIg4{8;JvT8PYR7Gc^D6-uy@(tWr?!FgQG>lr4gH2g>lZ8?e)^vuV2@&FoPVL)p z9K^YFRqt?Ws&d!Vg$N%CMItLhLuHGaps&lkBiSW~x{4=+Hdt3lm2K_LHf*o0M7dFi93#)jqQ+S~|r^ z1a?R8A=0*rq0$aKv$b%{7t2k&O(NuDr5^Z-8KVd4`i{N0zu#=O)5%!HZzaB~DM|=g z`$6?Pn#~FUQ?;g&3#G9Vy-n4T=E3Pn7H3z>jb|7KPoEB_lP=FS*N08M``3R+FxTB8 z<1ka3z3~)J&8iH4OFtmSzOBgm5-TPW70@z9Xo*9!u; zB4K_dGooPBoBQ<+XL>T7yt=$TdHPr{D`Vi~G25QuWJr}&%X;{o_in!W3I>39AC5

      k>undga<4T)97*;2tVC5(`&Zbme|YO5~*HQ5RiP-4wCLXgCZ< z;{xG>Vk(IxN)J{vC`fO~oGRXwM6fHV@T`D~L|&HcR`zJlIf^R2H9_wSCPwy{8l|k* zwkgWYvQF?5x1A=d39l@TjBLNkM{zB_th=IhbRSuznn%=~mgn1SdyQ&Gw|dprY`03b z%ZjK>(zo;c3mH|XD0~{#jkEf?ldmiZAB$U<5XZGCr|l)FFxr-TOd|L!P}U+}-QA@L zWsHK*bL5H2DlN->jjD2i9vU8H5i_CuOHszuJ4&}Iy)o`M;7%zJjG7hltW{*%;0TDm z4Vf5@-YE2?6K#+~PP&3h0~B>;im)c%NV)T-9So=PoI0K`N-5F#Ar~f}yd-`Cq0mOt zNnLuYCGnoC6;g#7(KhgdgSm}Z)HS=R=mi*T-_4TvezBZRCTb(NuL<`Fsv;yqC@6N7 z;LyE+L6u961f>_M35@;dVEXj*@N&IDY1#(%;iD6~>D;E9y!EC#j)tr4i;q4=?RWCm zzHeC0{PCOL{`e!M6L?LMz>SMhuAd}nrWh~o~sA{dz2zEjD1w7UO@ zlZLRHvGhbZvWeQ4f`^;H>H~9ClJu`^lW*e~2}6};-i-dSNRnVoWi|4_`rcqZ9Uuy| zHG5Qf23um*V;JLu{0H>iMD=rKma_XlnM_JSZkeQSixDUt&SpE6V2iY?bU*e~ zf?dB6qg1hLCEu;#m%1bX&Q!9=h5$_s;fO^j&}=E1RiC4R0c*<&r_8B@52Y%yZPy^n z^E`YVm#rOLwlmA3=V??U3W2J$;?;EpZn5CxVL7Yi9TDrO6R0Y}sBP;WJVTWixYI}i zkg(xjLKcJU$@8%hOv5~zib%Q{4916#&JY-~&F1#vRlHj2Lg(c8!FW6+TMWWvKY}-L zSzJ26ixYpPWpNvCH|`)Jauq4J2)@^<-zd{+ogso}G3mHw>bTb3?Ips!@b;1F-4j|a ze8@b@;Z|UciaoAlnL&v1-Oc)oFJ3-)bb@oXisQ*_bapZshr#Vlyh-!YF{h(}-WFSw zg|EBJ;s{mOnjV1(jz}gY2|fZ2TyEqXCo1Ux?qzmC=)-}1_t7bC|K-iqXYum%@BHEH z(Sz}1f&k>1mOr08{%hYu$!Y|sJ#7Ez=*jQ=cGlFx!@2G8<8Tyxetz+bPaeGgPIP#L zw3h&=&F1F$v*C0+JbBn5=)^Fiy#qiSGZ?3>05PwIy!#i@vE=D#vKv}C28|IC=>EJ8qh4^D{z)bOP3%sY@(1X0fw|K!@&^A^Ybr0)2a$5FWzhs+db<3*@NLY zZtE;dyS!R1>cdA5i>mfK*Q{$bJ3t&#GiZVL8ft4q@7cN+NDg)2O(i%4ZTU+*)D7XeIv@4@B6HQUcw57$x(GlnMj@gh;waU5#MLqmNwkwR* z6zFo__*3MCrb9Yct;n+5n`;gphLdP|0Q+bZJgjfg!l&nI+qF|#hU}{woHx0?69~15 zq?d3@VHnPiPE60+-rbeE1i1mF%nc^j2FLoHYL+4yQEVG6fk@ddj`6)iUC-jg;SxGk zDG4YoTcy{BS~CbDc4+e4VM~y@&8x*K-fm~pG2VSR9OA$+RT&PrjVfYuqLF4~S@G)p z;@fBEB0A>dVU$(7UMJ(RA9(u7(O{4@NN)m1Puk|{>Qd8wwUzCS9$}~b74{s99?qn? zRnu}zDN|j!Q7A+#D| zJJ;gfyGJK)(7Q|;*?7cpq&7>}`b45RxV8cbf@~zpWRa3JutiF~cO7Y~O*8Aa&s&5h zO$23wz_-bBVO=g4!|iH(aFpEKYQkQG1C?)9lf%B%+Uy!OGGjl!C||NXNLzwXt`br!*=XA%PudLxWoq!9&pdb_m>%~l3LET#RsutAdVHX+ zyDN$M-iUTvZEaD-M%NkYZG@XNA%u?G2T*L?6bxhYo#YHqd zs>2-KX>q?;X^j~=1J!fZMSq*M5KV`}UIW?%~7Du`sx(`9aT%uST96))j_O zv&&N?3lp)PvgKsTRJurW914%HL(Ppw2$(f$-rY7yGuRlF`Yc=Zg@u5f=|Gw!>*azQ z808J)iFuZh=XSM5B3B`jI1aNWU7t?p zRgr)D?XxFuJUu!*xVX5yy(5#=(eY`kOJC74in7|q+ISShiJ&a1w3b zlRs#C%pLPh%k-lV&c$tcZH2H2>LOynp0%x;D8vw}heP|t_1N)NtN7}tA5WsF3;e+# zAe^w#_Iwg7B-!%f za{26qR(GKrJsk}mo*s|q<679qB%rYki>D`Q7HuP1i_D*qjBt67^ORsT42A<~l?g;% z(_xt?t?!l#FSPTjWGleb7gyIP0aw?zlcPtQUBWea_Pe_x*?PV^fAmn-s?}|nRPPqQ?V)}4@3HdI9B0;HGc#b&*UaBBuu5aGZ$qA8fg+x1n`3=s28 zqMqT`1~-Gc%wD~?iNf&o>USHV<_WQrq7G?=?GYr9HqoZ?@;6UUND)AaWlyGQs!>P4XH7z6q}eqT#Dj1CJco%R2H77^kvE3g%ULIeVjLZ zEBq+uD~5S>cMG3~I)Uh?u0w94>02)h^0H)qzixcjU9D0Sbe3dm5l%tKR?e&Qk0{kUw&=l}ZY8ynaqCZ?R0Yk;^jY9Z4(c*0tnFq@oGEP^B z#73*(Zr~cvzy9j`fAeoY|Kf}9{K{`>rklhuX;5s-Kw`OGhX>R9i|5H^Ylzy=Zo3`h zfwCLojt-Bu@v6uP!*e`OkRcR!fL)-B^@9L)$zpL2&ln9y%=1TsyvlLIH}{LGDrQJg zOd|-x!DN=M7SpkIbA5SubfA;x(;^2!ZF>0JYt>GrV(mUcTpvqgq z{WI>g@_tmLKNNtaS|}7eU_UgYTqcQcR1ZZIFi0(o8i_bqe!Gk?@-}l?z0wLHB`4RD z;f1g!98JOYxa~3&IxeIjEA_c zytEgacfa$5LZo%|lb?R_`@i=ae+5XlZ_+6CdzHP&?u9iTj}w%L(*G8f2m+i)_wSmA zPaf7N8m?~aja9+xEw;b-NB?B>=;Zjl?|l66r;k5)|Mbl_H8jU8EM zp$QZ6R-x)Gb5po&5Cm&tfZOq8X4{@{@>NnFu*r>ra2uz(EJ=r9aB+2cv-t8?|D(S< zKRU|e)%^JM(;xqf_q^{7rik%_#jEqf=@2IL;-gR8&>MvQjv3hf>Dgn_F(Xy3Tlh|9 zn}cD&f#(os)bX6v>UO)idHC=Q1qce^qr-YSp9hGECmura%5)o1&ZVwWt4(IJ#m)72 zG{T47F4qWfD3W2%t!|W?0wp3&>3X#?+|UgNxcX?~bt3r2g_4rO3RR9wO;$R&xQC!m zo@@<@h;vaoQJV-(58-T?=#&uNCl+mZYQD(BoeOg!~Fbk-~=Hu4NJs27*IuW)Zo%K-k?geoS@+VUtq19S)GJBIybOE{4ty4uAg9NATTnRj8CH z{>8Re$IW=I69ulNx90lepMUn-Kl}lwdfI;by5G0&6t1Te&>;&>a^d;(>)h_s)M~%z zc}P4MP>L`p3o1Y@R$Ox`%gwWw+m}~Xr(a$D=*9o@FNY5f4?g?>QcR18Hl6`Qx?;P# z{^q&${&z+5-LZV9-X<4+`X}+-HLAsYxmiAcWl=?{#oh3x;~G}y;hng9-e{GCQcIzo z5CR-^_b9H=AsB60MIVUvMw2BwJlrUZh^~|!kxse*O;fG6NI45P;y?;{(AQr-$I1Qa zAOF#>|K9Ijy*hv6gI~p4B%5_Krh*^dZ?{_eqanV2d4E@A!DKWnvJCgu5_a1l9Bl9I z$8+u+)#Pa5T4f@l#oOiex6eL*_~g5e>D}Mn;Cwlrk0Uji9^moDn`N0MVPAoh768fG z^l*wR-CW-wK|uA(ITeS@#b}7j4UrjnQB=a%h{;yfU?b$Q3K>J`1@Wh3zwQjBYoYXN z*$E}TO(*CVR*x(@l|b7bL8FN{pTK$zk{=Sw-DbG&z8Bg4kcum|q)~*Vn7blLimc#r zHM@5?iD0DRBO5ey={2_mXoRq^(QH0AesKKOTZ=EBt&s-gm2OvN-*Q0d;-O443D*jd z`q-}TxBa%5U4n!$}|IJY9T;&h6=vn-`TFhtPGG!-OW;nNBFu%m;iHWvty z9coIRvYY0;6mEv0U0a&U0O-3vuyAaM}J1LwHm zkX^5;CK^&(FWw?H=Bvv)y!-X5^W%q)AHMxgzFw4wt2R{}>)kFGM@LT{y?S{*8IQBF zMCOS|I~b1P=?3G;_4!3D3!J##G)*ScsTU4#w|!@Pef7$;FHTM$XK8kEetvXvYPx<= z#Dmcg_hfN-MGUY@#m)KraB+26q{U!*U^*_mI2AgoDiGv1yf&(;Qa}v0XN#sxC+ylH zzR7J@k;E2)Q>|)DtFc^?A-B?|5Y~%5^QaW(DEl~1HH6Tu;m}`>kQ!bHC|he&>RZ+* z>&I@`x_-?)SfPE=&0O!cb)J(2U!b8}gy;$(s$@^D?d2wLiQEFlXGYwriOJNEWOgD_ zOllgP;6^wVM#3;qfe~@j;uHe~qGkE6APoA|W3`3kguzhP)5S7R$T{l?flEgOMnx(+ z9Dgn(<#;xMH^AvY4VIR*;u_8Hu_$ezEu?6q%}i%E`r?#5;MC{b)_^fV6|CWCgqkU z_`1EWNa3WP#K2Q4qAjj687OR>s7yDT%{O188cwr~XN7gag-*(yG_zC4e~H#amUzQROF9uz$Q_@-$MeDnX-T|5>Jxes)R%+75U&iAKygMK zJyIhC-03tN4GpH6Avab;v&AYaN_LtCVkyodO4B6Sq1;X54Jwwyx86QHd-&N;Kl=Gk zKMAA38*jZcnIFTO?Cx)_E-txeY}t<=KmPKwk6nlC6*yIn$JKHN@c}6%915HDsE|;^ z8*$qG_|Jdw;k$2nwrj|dRm+*Cs1XXYM5FCB8I4|_LY6F~Kh+Cr33Uu7PB0rwb4Stq z>~y!Lqi&10I0#vu2cd&RDhmD8 zYU8^4Ni@8?{HFM`_;3EF{~4?ZmpVQ=Dz>ZEEV2quFb+l`YKODOkH7im*?2ri*4x>v z!uQUO55v*)@tbcVpTb+((yfKvdV|q)Hci*t(+7{2tJ}{%{q$&lNWxdG^G9>IDVQpf zvf*&(haqY?J}-7wkxOMxFm7u7ZCR^I_{OTX znC{AGu_|#Jkpm*68X}M={DmUIqW1J#jTDn?+;*1g(K2~RcE9-3AAkP&XXDA_;nOF< z5Rrr}EP*Lj`i-~g0vueHDl{F6E zaCUqECr4h!Rv>JYy3KL9WbG-+Nz+hSnqVHQ5tw_PmxHDDxaH zvMF^$;$0*-t3%UIHib^qphg;M-(li$(@J^W8 zi5s*neK-nUKEHs=`}j}))%Sn%uNS)=F1I67XIWtlD|%`q`ocM5QRAS*;eJ zQenwYkwbD5+d?JAJX4|jWdoSI?#Lu+(a05ap~2v*vuH77UDFW8ZsoSQeWGNP+J2@h z%^{^4M1BCcG6JTMf8szisM4d?Tffu8L!>yew1FGL%_-8kWI1J1DvHLqwux(nYxNwP zc`$dS>OcBtKPqbL@0|R7q;R(5CGlc9pWCK^r-ny@dqwi4woUV_5lSH#L=XiB$EQdy z=~bI%wOmc7le_C{-}OhM$#^>5?Y7gvP1c*+t84T29v3+zH>52$fPL(&s>pF{I-}Xq z5C7)hPEx*j(iy{}6U2FxI=<(p=`IXMWROEVNmrpjM`f`)D{CCQ0wsKimF1dN+SuwRmpI#Mu|9XbuxTC;a)#rVE_TTU zZm3S;aN98*OZsHBq{w(62!rIx&ya$_2%B2%wvkyrh&;#B>l)4}$+DGhid;IiSrADm z^Cy&RK7NFIfk$CTw+kO+_igoarM9bAOGLG|J{E6qEo2M!s5EgZ8|D+*w(Qm-53%+Syt~rb8yWIM6u1B4$=IS@6mI zjt_v0hWve$eAkwX^*{Z;{@M3`@c!A8r^0>b;k?3-UOxL~esbDr)MkUbq(B&fwOrW2 zO+aaPzgToc6owZsUpjUZgrm)3;kw?@!_(@#y}o=kJ9uz}oB!hZ<%<{7`SI-NK|{PH zz5HgqLU48*x0MB!;o-z|9XgjHizWx@dNHz%<>Hnrqi}bQo@8q)aN%zYO1JLPa$RX# z%_+H6iCU_55D7|=t(IC!Q*;lilxFv>-c!zWYLlBF8dLAJjD+4!WRxi?P2~$b>au~k ze3|7*5DZB3mEFb35?AQE!GNYu=5vIsU6SBTis~zkupoM(v+`u?2-_F#6teuYr%#tx zSMXq-Z0Ky(F&>Ojl7KN15+}IkXlTOs?AGhSXsA&dHWzv_O|j)LXRWJvvqqX;5gA?u zMtE}i_|5PA*2C|9*Bpd|Wq7VJ2#}ArqN~b0JQzA>(eU9JF7x)QFV4UIbai)G-`%il zf|%?I>!wZu&uqKl{3`HK1B8>&^~E`EhGRRKUbeP<^5m>_ES%(5cT_F%5LzLE2&~K#n7b9i}*$+FE8NE4po42QKrh{c)Q)kszwr4 zMZP;1kZmhVa|A}qutF5%dHFy6kN@+3`Ct9RH{N*)D?;cwd~o(}|HVIlYjclt=5dX< znoY+dSyia@DDKfm5o%yfI#T!7*AJh1EuHyde0Xs3@YJ@O348q4x-Y=@+{^t7l z>`7ioQQbBq|5fy=B@)y{ba-HK2hpVzo+e|DIyK@gwG1pN-dcURyzPX1EHC4{*tS}s znHBZ1rJJQ5P*)o&p&+u9`>T7jD4eg>=bkko&y|oubc+6g`jH*&hgOtR%TyP7zFo4` zndpoR5@e<1kJgMqIJdO06OWAVHLcAq%}Ey`y#>ZCc#U|u^oIl3A-*J-PNok}i#$b= z$+j;6zv(8uM`e@WT(^ zIXOG?hhyh(-oloYcoJ>^HD_cq&gdCs1ikKfqv-5c=cn&||Er(;n`eLaFK@1Irfus8 zKR??-UXW}ytkXQ#9fnBlH>(9wmshvfc(HeW<@-3rE+J9L^6nNl=E3pNcC(>iZdL_B zNEzv}^nFB8dpsGz?MJSsjqD`JO=b)29!7|awEkB=`gdpl;1A6fWsE5RGW|7*M*pi( zksTEB-t|y#MH8g-0_34}uP6V?*~#Ehtq)48yHztPwYepAolKG>{A!Y=s9o<)V!5HR zBxQ|~@wR)R8d(n16bqOp6+3UQO^JEbXmvCmiUuIxJqRKpvm%`gVr9xwFuA?GPt)wd zgOl^~m$KHN31ec1*Jbf=3P0fL42ma*vVU}#Yyfl>txaT5J?UGdk zOR0;d%c?qSwWhys6rR_Fx7~&tY#Y_QRN+JEp-EkWO1{=wMVp`3u1VTv(^SMGY?WKK zZZ!tyVkgW;I_mOkj^Aa(K~80IZSVj4|k&{*bMX%gd)5ki`9 z03p9G*30d31^4FIUL+JotMxi5GT~77v@E~7zsFSvVSqaluUVpqoMSC1c#G5zCi&JI zZ@=;QJM-f=-1*cw7#qGvnkvLnrdo~i_aeb%Ydx}E@hK>KG%U}5>w^!yZ1e1!uX1>p zo4cu~EXnEy1D6?4XEKfBVzcY2GK>bu*p7~ld7JAR&#%n#UA)1$*>1K3{<`k{{Q^E1 zFHb=W+l<1H`sU^~aH*(MP|cXYb^3iQJyS)&q|EP^syIDJxNCZv zb-gDD>iU_DYW{0IGE{$U#M-_ApjNw-MO6a-H;&={MoD&8$3Zm)kuqm5(8zVWPCZ3S+ zGqooMg1m-hQQh6$4~wwI<4aLVb;71;&!_Y8XpCw*37y!JFP25T+ubim)2Tz~TvRnROc0MJO;c2N z%lnP%M;1AS*aJkioorXcJK>}GE=rWyY>I5>`szkH?|u~d|Nehyx!vBBbjA58E<<#wNZe8r2ygDKO9`OvD+*1; zG-bVFnyRO!*2+YpQ01V8Wbu`4i5gGW<5#2?Bw#9~jM#Pi=8r6;>HVgF`2Sx@EcBkj z(785Ul!$n*w**BnlSU}x?~VwPx}=72RdMiO8pGj$;=aNvMhdoonfo^0QHQ*yOx<8G z$O?jw@3*@@{-ZyB@Ze}NKXfhU^x^SWpWfkLw%bG_3F`gv@oApruJ5Cw!*`9wV@@b2 zCV~Vjz~5}PyRs^;E-o7`URd~yX;Zkv=qU2)-Bvk7TyarU1fA+^LE-rhN72UjzWC&4 z2M-U!+1z~;R3ta19q585uDXU{BS-0#!5efs#j)!)Z(xmDrFaQ-MWH7Yx2oT!?qsjY zEISU;!|V!Snsb`Y?>f6RC>|q22Gb&Uo+fOFNJ{sVOll0&^ylx)8Z zYircubte{1AdZ#9+eXyI@V4-0NC?Bx6qPyheg$$NuL0vaa?FDAT9$7cep9u96&*~D z2L~Y%8`tto*R`0z$^tKPkIBRykIczPj{M4C#?U8LZyZ~{ zTP!@uKCiB?GUQ}MIT#SCKAujbsnr@S?RC;F%0bNBcHsi}@udeRz9-Yhy zP9Z&zscfp1BMwKQmUM)}zBe`sJsK)b${K|HMu@-2P)?>V(VX)gpJEsVJ8MENrc*jX z#GmV$&FY@&PL^)8u4hTs_X%*PNKlL(D1HY;IS1li+sJ_z%X2x+-9MaE6GWt=^>?B(n@Qi(8nQngKv#8^)LS9 z@BO{MTY4>g{cti&i(&uIG@bpJLrlz(=RsAkH*lkZtE`+Y6xuBnADldeT zKCGOKrF+RHQzM5kn^TsdbPh#CotlK)mag#=C$MciKZqRLEx7W&lVMWFWqnDXOjsW> zH^snLa91iUE=7wugn$g-$R#th{j7O92fB!e${?2!&<8hr9Im1-U z1M9n5=(e8Mg^?bH+GMOp13d^d)C~JDExSM*lyv0xK>5wA*`^MZrV3=W{j9f2jbM|- zF)^ZC#?bM<#qAAMYq-$qG4JI8LMmEVq>O_%$}9HHtTNecm&-Cs)|)MA(Z^4oY?teJ z6XWP8nzPY(ggb)V+poLnbc)Z7TBVcO9o&-ah;SHy^7YR@`TDIN{p=t9gFmo3k2Z3nAPHmw_g6k2&V-b7O zdyPEpH9>dxI^1cB`I%QtdJ!c%P%8kk-f@O%UI5_H`;@+{X>Ec54FC zxy)E2jI&e_B4B4UnI?Cm+v_XcwtwY!{^0nX@8NrpdY(RbeDd%C3?J#sZn=`ev_O`? z1!3Q{0|dwrHwpd|MLh+lq_4C;HQWs(^Bh+saZYl4egXcOomx#0YAMz#ly^Xp;KBq`d%(Tv9c-T z|32smr-a_`q6z0B&aLmba7rRB%u<}Q4Dz+Q8~}<7%hOCaE^;my1sDAeK1&r1Y{OvA5-h{XR_S+Z7#|Nn1aW_y6au?q0Bw=wIt*4TP`*2+^ zGp*4uI%Lajse+Gct%x>`D&1kLR@Eu>=1xIDIl8cvCWFdFRkV|(dx5k`mqJ$xuua#` z4`mLdS+-7EA@a(w#AZ6+YQAv12!#{@oF+H0JK-)P<#ZuTM3gJiTD!>n(ypo;5oJeE zU`Z6Ybk@knLHgv$^!Vu$yzO?eGMlukbS{ru20YNg@k#3&2XDUhga60%w3yCw!IYJds8Pd%0E9G4vV(#l}8oR8+>`S_D9nqO>eI*ZLPu8g;Ds% zn{QpdJWt}J%*xqxhKEgB%i$QMrNI9k+gi@%2mks<|E?BJPPRpe({17A#8b8B7ndJ> z{ORBR?H~3tTxAPtA}^2AlCoBSnwC1~5`l1DnS&`*4Rac!Q?;CF8pa-Csy3wh#Uf!S zSECHrBrir&MBBQt@2U366+J{%6P77mi2ZulDsenQXi5DuRx_<5X{d;bkYY3B2Wydk=x@ zbx2U)1zx;(_5BatMKr#y%Ja+fciwy7GHl#Z*K_ISsCgKB4i$7<7scR_kiaNKLEe-~ zYtfRCp37Fy46uemc5@NU7|`mQD{;t z4Q5{FZCUU+TR7diaORQw!Lv=T)!Ksec`aw80)>GQ8Uzm&ak9l5a+RuRBw9m#**1l*y0ZiW5Bl#d^C<^NL+K@dc(xWXJ+ufwENVKL7INuYdUAco@)sRV|SmLP*5G z(l#p2^~fa2Na=JqVV6aUMprX|{e(hwP}EkUIy?dn-a~M>8X_OlWV6SX1^`=QFaT?R z9#l@+_DtsLsVL-bzlJJg(!xC@@u4g$)sHPiw2&@C6Q$mkt34Ij4|ec-^ZATyG`6Go zvS1jp9nuNdgYUz1qpa5V_isIU^WvZ}+=B3&c5KRIvwD568CD%h@o2b*Cu+HhRK;RMbk%RXu>NrFyQ(4z8@%QnaAu4%1$lNQJvb6k-&mvpgEh zY`sRvoaI@(UMEHEXOvZ!Wp$1WlNmkfm67lnuAt^QpO8Y!w#drVb;vgJf+$twsg%;) zmTK+~v&0{9u4;l#TV1q!Ei)Q$fE<};@4mZu_FOuxii?UpH`L~)6X=!@tG!OaRJsKt zMB-tYjcvA$-MUWe_^s=;fv4lh<4IElZr^HA{k&GOTh;RL%dRSP&yi6xMPCv0d1vaf z-Y$yGeO+V{b#;=bk~)qBK$#Wzo9TQmf=#F?93}^jw>-ZI2BR$5z|M-@wluUfONR%? zC?{}+N0Sk3c(aZV4(6ljY&1Ve7n?M194`t-ql?Qc1piuyVi_DLT}IPEO5^$DY&^fb z{^*m>e)yZ;m)jtTfKHlFHo8!P)}`=t36-P#&^T46{2=upkfkB75<(pz=MfrAL&pCi zC898HBCx^b72I?r+exx(1*lC|&rKwf=S%%*Qom9y#~6Irx{w4a$UxtfQId|0^jaM! z%X8Fw-1n7pXPF9N$K@FO1<^EFA}SG{ORZu)__0ThA7rZWCUK}_*qMSjwKaRS*%tY3 zaeMxs{NeB2y?BKKvRJL~e%BY*e&DS(@jv?C{{#+tIGoL=b6DratNYW#qcC(D3XErr z60A;xR->xK%jcJPtjIa3pO)sRHE-|kVKkdK{oaS)`}EV#0^c(ppP>XL&wybP^h;$` z*okI3zU73DABbuqOA=W1FdP!1RdRz*$?ULqKoED;XCnKVpkfliGqG$_QC$c1w0Kcs0`5BDaU^nlLo<@Ya5vNACd|L;m1?^>Y+)q0&GP1Q4blHMRwc}68S}Kz&SFP)S7>f+hAzxtcM`}2}@{dT>+zP`)yQ1hanefrI}H@imb9v+_tKE9lMI$;5H$+dhWA$+2%?OpvNBzXpc%{> z_=HG$sHru2Wm5ZiV`_cys1?pgqT{`+8w>Wtsc3qL;TkF*)|57ue9|z+C zMf+5mh)*d#R~TWhl8!}F$+>rR=VA+n9F>OJ-I(XMACRxK8uizI0Ukk<>x$WQK! z)a`b?y}G^4vOEer-d5X+hOj8Il~zTzDsx0v6gIe)!EgZkyt}=_CEnjJhoiyqF-$i+ zIy>8LHi!tL@kF>lx}17biEJ3Qqv7EEHtpvm9pMcqDe|WI(O>)puICT`)?bJ1lU9f0 z2G-q@NfOhji!@TFDm_i#_c3)T;u;wr?a|+z5G;r=j@~K@Y^9xGxZEBm$FwcV2U6*o z+J1E3i7>qySLnaQ`)hl|hoUMJUR&<2q6pNoBt1h1^yWd6aO~D+|^=k#J1)G2L=m8(%V7OXugCMxPx`8Wj zkC^8lA0OY`-u~>PpR*Iro&qUkY@$X*ii0gWLzw*<63F>J$}FU~M7PRkUoG#}>&v1_ zQ10NtrpS)-QYtS#49j7iWSIN2Oop!7(nX6}W)w9UPHMI0*GUYip>m+YO=g*cR+w?wm9mV)UFt4;vIBGg!m)1v?noJMO|Ok+*6i##*rCOA7mGP-XY zD{!MZDy40CpXy!hxQ5G>B{lDQ-5%HWNvVW5g94{L;6+tRdf$K2_F?=le^(FS@Aha+ z^>_Ww0lDg{G)CQ`oRO~N<2ihj{vo}41%tV~yn6TOppr>9(mo_VXOF+Ly1z`4HF9k{ zGg3|ubV~ZVGiKvOlD14<0@=kger8yeZsMW-#oJ zCo_1PyQ}N@(b4VQ`sRN3^~=lEE{n@9tF>&oMp^mt_V&Z?9)9q_d*cy`!_IZ>c(e9= zS1OO@{NftX38HQ==H_N~bUbgwq9fgcT3QH`J) zL{XMxC>roV!r`Em;fGKdljaLq?cLqQYIU8m5kP(=?!__KF0j;_^_VhJFe>36mTJ(fWS<|NiLD4v!C}(_yJs)GucD z!<5E=kZ*UtOxOGJ-{`TOGOyoD!K#H8ejsvD>!Lc`!`SG_1X8MNY#K^sZg8H*NmxaA z0~ZJ-S2gwtlPve{Cm{rRm%XQpw@CNa_zm|xyZ>lAEiC&YruE{-W%>DW;e;8U1L z5d1OeKa$;WG7aYkS(;Ga5NEbC1HmfkWAniE@f1*>hkg+HZZwRRNtG69jf<^Q*z$KC zzx9Lfy+0feVKvz?`DLFIZc&o2gp!Toae_8W&)k$m&b z`SO01C*|e&-TNQD_3-R*G@dH*3DfncqA3E&IF#@mIbvOwRFXf<28Un2{POzdMVxG5 zeyBD}4h&?$n#rqSD~enf38e6BNVt>5d)kOJBQ-%J@ub(%Txq3*^E{Kh^HRX83dy8| zi4LPd;kR9to||c+geSwbk}YLR@e!(&w$mizBolSb!6S^&6-6vdsnxViuGg95uuX&e z2(RB3xR1!`2>rE{2VnWKuWkOa0d}geX`~KTQ@ggWQvb@=zQ#NEnH8~fgc^|ztEp_M z5%Cr5;8tbNt)zN=e<^b6nqZOB91m%?OBKrmhZ*S(Pgex!?Vi*b;@N~UbMTRF+t>#|gt-Eb6f-?=KaUqZt=wIa*rTM)pE|LEWR=^y^BzoGe_ zs3Rf?(NPvkf4o(xAnOF_e8~90P^2#A9?+udOqngqtLuiK#??ZiAshWe|-6LR=d2oMq)X2T_t#1m8qeX zvxzsG`l#nlA07`!6U%W`MZ=^NR)H(0rjX;9&Tg}ku6dzo;#Q0Mc(cp!xk!vg$1a#Y zDvWu)<@xO95dUesUVqu2wVuF4$-(Z6C&7+(NI!`trlqy(%T~DTqQ5+jCP36MO#PG<#^Wr z&(@nZTXJRBVR>@SywjU%E}$?qfF{{ZbT=uIGHr@-(6(&rgToFvLLq^LVel&&hj>;nzTQq3XSR^Jbnsuf3M( z)Y^Jy$FSrOn8^$CBeXnpW~-5@H17wP?Hfm1cW-v!c*xEPRON$Dz6Di2oiMiQR)7%9 zr{st(1@BpCs2VIUPEU_+9YXq|E>Di1#j)SCC4#ljB8aWNJikzWw6`}pnN8BT*Y6Jx zDRCVPE>BMi3J@SWjhBlB<=d1$1kC>A2Og$q#_-qzIUv#zbwfW)lj9fXfBoYR=nwzN z@BTKc!e~0dIlOMogfbp)dm03{VWHMSC8ELb-(qPA4-r5Z43s1Eitv+E|1{FVVq7D- z>DaUI9r~f#EzzTrm0wNYDVPD<#Fma303WPBg?SpiP?lwyyR{fa0Q3YSBv%5yAF9d< zCbC$rfM|>2Fo;_2DN%62>A!mO&}qwG{pN$;`ptLuh6AOV7thcC=C8hgbTs&-ci-S~4thoOun!JK#iTqv zn}y-#o!4*fAB;x5_#1cA+edpz=)HRDV2*{e>|5Xa_V<4MH;4OsF2hkkz8=vd!|p!_ z{*zw0-dvrY9o@MJ#sJS-&Zn#OVv`l3;>39$onfjR-QFOGA&w5Lh^$=JRo8wIkO*=v z*_mgLrW=t>7Ct^~4+0`Xc`5oS^s<3~6fs1_ZXxIaJwg03DjI<|>G`4W_IrWHQ@Sjx zrxT!bu|b4%M@blTz+yx{z^LWwW=oe(q%Y_+EUqAY;l>AEV&IkDJS zRU&(a`EQ8Y!ZXYrFO`zYE}yg8W?)du=$#gl5#-F66-(q(jTth+NQ5OQ4e-)9-Yh{d z!=Nn%YL9%~ONJgxqGHNNuE4G7ZcoPJSKfH@?%g|^71qXIx&I2}0juiEFTPA;N(U5` z6Z`u|s0MkA6UWKfdB*I3(!XHvpi3n|bag$6;~`z{Y@Pq@fB5+~UVrV)S0E<}oo5uQ zP87#*DHW{IWnMPl39%oF`FNH1EMU+Y9b&X7nM_iFyM*g~XdXI3&4htF)Z4&%#E$?y zb6r3N*zF`$SH#U1>+xCsRk@~l%5A6sQYkZ86!>^7@gWRWe|BGLP$OY zJr%(I=+FekW&_r(USC#Q>9#mrBO{KjH_33|1~G%BDXVLK?K{8p)w7fL-~W7c6utKP zt@pnDdM}OXD4m|Xc=qJv)~&-=UcJNS3P#zI$?0By{odz~f7*+}G;(h5rSJXfyP@w? zs~O#(>&q*;vV5Hi2q-Fd>GfDOO&Buxwd-hR$c`Auk0{UcFh@%Xzt( zQ&@#XQ`U~~?Sqw>RqR|AiE;%yxic$dKL8j42sN`+=BZ@8PcA)=Hf{(LZVm7LjuE0` zZ|AFRt!(_n7!AwsIe1#z)@=OX^Ecf{+JG-zHP{=ChQlXcKE8G9sD&sFSPz|sQqGhv ze!VO=1qG*yLSN&krpPG_+u*B-Q0eSUm=uz$FBw7;%$ zI?rL;dvS4!mjo|)L#a4+F+GT_Q?wfmBi7>7XIIPr`S<_tfA&v*@7KTmj?=Cfw&Rhh z1yO|C)Hb2Z&;=jMrW7UVPU2aX6_c2QGX@{W2f?Fa25TUH!QiSr1KQT`x>((CStSlS zBs^ILg*kFj(cflPubQ`m6-xXB#4r#NM{^YFeTx~Lt~gDgvmL6Kjy#2`A|qQ`FBj|8 z%8!Dyk5L;c9uNkD4xD`1dbJ)N9jYX%=WDLRV|uSxIa$+CA)spA8}+>;ro((SzMf5I z|KgwhlmF}=fA{&*uN9TwzB{{`EXYe%&Ha0~7pwKN7sph<-ae$XrC7{YAAkDj?(47p z!+-D=g^h#Z=-qF8V}G=FdGUhYc{ZhQUy;Xs^PBI!^S$5Fe%!cT%N!zg0cO|h>#L?H zs6wJTb2gvSM;r`>7ni4S_&TQamg)nPQQ#;C)-)Xj!~Jx$KaBc)7mx!e*XNr#KnpI) za<&}9EF&E@4kZYEJVn%!Kx$qPZ8(REF_xx7;W8}{+G&)IYNj(JH!09X9@HYAiX*=_ z=z)@gp+7;qSS>gC2Fj82n3LEa^cYx=!eFz>=d&8j)-~3j7+qrMg0P(}b2{6N+X-r% zUUK)Ph7<^PjG-8ee^{%`MF&8djXQN@D_|YrM3R(%d&8`_(R5uKVd1gu2Vot6`@eB? zM77=Qno2v=f%JD&(vXAf_0oW4Yyu>KDouMWPq)jezPPx2?Ty#d-r(%yDkttglQz2>)oC>V@AdSgYwYNY7=I~SA1U;f=sZX6xl zzj1(28A0pN0q7cWk33BxXi11=M$mL!ub3NwyD2`;CwS4F@+*gd$&zYfJE>{%B1a|* z=uAy^2?g{l1My+q(5pGXUSpJ7fyPU-s09EY^mfczx(0U+cWddMQT+FKLP5nAbdjib zC3jL48@e9t^pZYhJ19CppXc$^(WTs#E|iQD9on)Ak@zL#h7`z^RvyTEmaWnwP-9^^ z^rMeIoy}+Oy!+a-cYX-bCysX^`~7Ac1~6K0ZPoP`(9Y{WxBUM5=^A^f0pxxGAye z$1C(`=gN0N$Wn!^$chQZ$q~UO8LsiKJP_xVd3pt8RAjW^ET;1ovdSz7Mwe<;cp&xd z_fm={VVL?9!}8g@oQyR~v;_$|LDGz|lv1skCH((2I%P7!nl)LOWqy{2N#SN$5JHv9 zKyA!y+OWm(_5mZ0Srb48`bcHbR%&^{nX76pceL!8a8|7$O_I=c({HDf36@q_+r$fk zxGUuK94VUYaC?GU>bmA_K&BnSu5WUl;WnEYk%`@FH*uAOdi+RzkDX95gK>=)) ztsPc2!z@2gpp1@yzYuB+!L7O4YPQuHkOzV0cPAITlA+ne;DMnO zhpiWAs9NyLF|Rqyr~vOi)?-R|G&n>$47kJO(y%=XV-03BuzJ<&UCyuR^xwI2O9Ww-v*mm?BX3G| z7sRyS2-yPb`re(JQ54N*ipR!dnI+{9-dmC~y z8CWVD))CO`=0vd^lfWpd097kDbjl!yl*BPKMSx-lI8N|(=+Kf6xOs4gEL=kk*8#(w zGGraHT2Z4N)q^yqQqP}1ySTi3`|Vdekmjh@U+*dS(2C7t@%Zuc<72w1x#!>VL-+V< z{nhcTH%uB`1H?*ibQdaa6u(!(}@h@80>h%fdgT@s^Z=q`PY-<7kw;kH}D{9 zDghe$0N3N|@p#@F2E$QGfpfOLrk{|pG=`~6rK!!x+G?bs&&m5r!d$-7tl(}Mm39V| z)(HKB?O_VASE*1Mi%f#(0+A|XeJzg#J?e`2qp%sOz-Y+p)S4rOFG>egi5F$TxxeV= zCO(ADDcjksaY;U33F{{+87C=`D^;yb{kRv?iba`GF|+v_vSY&`z->TEO1U@Vdm=%u z1xg_6;akewkjaiv$>73ypP4sJ8-4?$mjmP^FOt)1Q3=-@_1^uJcW3kK^F`F+bb^6&)e;TFn zI?v~ef=*Hl_GU1~&|T}N?$L;9t@!FXN9Dz1NqAY#AhW9c!TX<#`oG#6fLyGf<$fH~ zVsbCK>dX%LUyodRv#5o=(or=-JYpOVd<##ZeZr@#7{W@#ye? zVja>X=#v9u=<@ZT#|P=`9v&)rQThP5FfAN^>>sG?a=4L$V|j8q{onrJFTBt{*iR4l zpi%bbgWL3cj$b@otQME&le>2h-|62P_JX`^|DPXx;<(Y>TZi9x_x77_zcn27C>^i- z;KuEHp#Tf1go0qOUW1(x)93Yi^YG#4&z@bp|FcghaZaL;!r*jr`kh~W*a`fG!nmy3Ap@$>WGoBHn?O)g41D&mEt?#Ovav6g zrx``;hWR8EQd=L>J?3PhP#jD(sE{pP+t3^GU7n1B!5?{I@E^5U|YvE2{nmV)x z@K1o|f&sxA<5kjCg=n73C`F|3IF3>U@*=r_ybK7(WvLa>%yrf1V2`C$t9&_kz^7kj zVCX=%u|h7ds5ENmBSLw{!#)X;G%~T=WlJu~lJ0U&F@X~{`ewS;I0Ggam|CVi_m$os zresiQ?2GQthU!n3vLs5eodRoW3{q>I&tF{pZt3(K=rEz@#yvyfrwDi-;_C8}UWi@= zB%BN@s{#A=s-|*<4vK?okvFD&3TD9?>ruXBvXH(2;T?43D=@?W1%f%J0yi!SZ=*hAX;x=-z#yy*Y_mv>Aj5vZx zp#fYvLP%raDz22=a9z;bbl^#W*T*eX4P-a9K+YAzsU`5aSkQE%gj}?X_PRmZZ3l(g z;;P#YhAoAd7$R&CYX(>YBlCA#A02iyvh8@&kyJq<;vGZjKw$UX#<;7I<>j)E=K zl~+MOirn{dI?k@gRgtfFf^>Lrh_#`nisKkPYoMqxdS1-ujHq^(vpL=2*>r~W^SWMd zV12!QFG+kdNi|=QT*xk>2)e;bDdsXFefjC(G)so=%nz zAD@0Nd3`^m?^j%XsPWb1^!n=7t=r&e84SQ4&3Syu5Dc#Zrw3JuNGDqmT5?Wd013eI zqcB@x=8m2l5QSKSBzH+QGrKwp6sU914TruJ#Slt3v9VMXVHiy(*BM4?5!AFia!I+| z%_1W|;<5fJN&e)2lMF+y*_d@ ztSccjC~k;snY>6rrn6C>Jw6S!d$1RdhKzty!PB$F2cKT8>u@uholnOPAL%4)-+1u! zd*AuxS6;b$KW~8$;LLe^JzK6e&tIH=@%YKtPmkw|Wt{XfkS2l?AjGIHaO3dH~mjpKR!@Z=}g*VDA`4@U0(p?`2h$seC1POQk?B0tx*Fp@P?-tUotu=FXEYZwy* zNl$Sv0i&V|@)gQM=xtMvJ9BtaWuaKBqoKr=^`wQLUJGJ{ULcA*Mnge;xfNP;CS}HQ z4SD3&S*?n?o`$g>q?jN}BeHSKx~MRm;+-j%!yZ3GK|S5A%E&6W1j1JK=p3fj5QCJ~ z1)nM2E;alD2A?L;vgHnH8Ttx9*Q#JRj$<(;%GjalIS7Xpr_-*`=PEjm%js;rT9!rb zfM63_KlHz%(3D*D2gpn5tkSjOOhbbupn`2Yp00Tpkxp%Y&|hz;Qi|6UO1Vu&;gsrR zRIyi7Zp{dF~Cg2e~zQBU5ONMWVW(XAvU>`0h$hGjD zE%;Ols^&3qF0-mAkr;0_(0Bn?L4JC6KDip-xqVZRq>x*11q%zg@V$crvZ8=jJy`|A z<)jB4^SUZ1Xu~*}>xBM3Vogs5vO-@L+OH5Z4@7W=esHzUfbpwanF?dX8+zK0XOyYa z#n#a_OII4-;QtIf#gMJV{ zswA&n_x${l9zJC_h)B4}z*~DfO=9dJo)n!Xve+D0@RH$VN>*&O%*&Pj;_U3LC(o!N zq6gRS^~xZaPv=yICuzD~t>_A=u%UoPr67|^)RXD-#?b+VbAbGpYx;DeS`}bcfh~LR zx`TKO6r-CgOJYiu6}P&o)n)}7@YH-hr;o9i&HMen%elaOI?c1qV!61!x&|hpZlDv& zi5W922faRYJP(d;kr6WTKV-#Rc}@_Htc&{2y;psz)6ne!i)0YRIAx6R^B|ScG60n; z8}f&BL*~K@BJ^mKU@zzc&e!=DCx!2~-mwb(XhnA*ubdE$yk%XKRu1k_L=L9#nlCQml=3L*M(m>mg#EW^adB2=w13APq7i*DbBt%=;^X4SZnLPxX} z6YExE9~Y~ zocFT;lX5@#`o(+ScymB+--Bu!Rs<+PBp*;-(~DC)xp8zvubgGjZDl^SGNU>*%gEkR zGR|S2OK~S-C1X~6Xt*_sabQ(pcSL|4BGu$@`HVV3X>yoXS68dmvZ=`>Rdi?$j}9DW zF%CItaIPqLGn{%PMR0{$yEzkApO*OT>uUl#X=I5SLNQ}ffi0j#=B6SFWNvN zgF)9)w`#e`jnGk2_CD3wYq{G9yog<|@NA z>Bh^-v+xM;_9idK@#KJ>xLcC7hNJy`XkF$R*V}06(FIUyb#h)@k2fdJvu}Op@a7#* zHOWX`%beN~oLbA{4C#zAu3b5Cji%X1XBF8dI;h}VLcDM_>jm-d z3znpmNf0Gk@vsW5N+#ShxD~~#!}6wRoYVy(Aqssw314zXUgP#b=Eh;r;V@|Ti?<^R zy9QwjMP*pvEE&72x-ZwZWn@5zds?Fii~=}g`(Uv)ODq zolKaN#RnHdm_B-bx?ZgxJb2~x*IrG+0D3@$zbIc*!nh>Yv|7^XgmwiQHrO9W&O^^j z7D-2=o(Nep=veIU9|EDWT8+n(UN5B(Lq<+EldU$`PpMmuIyg|g=7YyY(Jus(9zrb} zNlVuZggzd8jVzjyMjvnChjEsdlx8o3Dv9jCf z8r2}zZY?_!!*~zblPQ6AjJA>H4x9l(v18WEUo3$@S!A`4qqW-@W&}?t6{N>f(*fGw zA0>Ibf!+q15_ludz3MVPIc~4VlQ-TT-F?+Pyn(Z9exBWiP`t=G0dJMT??=5Tr5q*= zdE@}MgV4k&XjAIV8VoUHezn05Vt5$vnj$niS^AU7khuP=(QMhQt1Lr5$c@aJ3`Z%Z zJJqJ*@CBCA>hAPAyn9V{7+~J%V~8Xpd10V-?Zk!6O89bwImL67YpY7T&2@RTf;R1eP1&adgfroFUQ-t*6%QD#R4 zTlVGS8#iyJNv}5?ssLh?1+Y7KwBzeZ2^xRA`2POE9_6Kgw!}Q+E>Y}p#YJuvPapu; z+6SSXw<=(Dtmdj@{(=#VFiM!xRTZ`K@X7Hz@4V5|LR3S!UoT?ClFcSRJ3l|zKcGKd zwo4x^nPNk34>>Sm0+o#D_yNWl(X-lYR%Da=djZhZJTWcMe?dc){5_qOUawC#jqH#- z^msC%ySK@6a!h5hraxiqnU^Ffw1Bx6(5LSY!UV)k18j%7%)QU20kp+veFYk7(pb+! z_(h$S)1v`5f@zCZ0!Gg(h%2xW;+f7DkYnFM5|x11J-#WmMKW7G=*=EE_v97NJeljYtKWdf0Hp{hAy2$TTOQ-3)=(#5J};}KLewGp!WPOx z-yMMV*z$x4%C41pAGd+bju8``XpFAhuF^FI#JiBnF)@uUE#G7(Up+m2^fYv8W$5{} z>LTFQfw~6lZCYGN;ZXC;XP1{$yI-DNTzg&+Z8qmumsAMdzjx=sgZp$~oj`DFkZSP46bowQy07b1 z-Wv>EHdD`g*4xA*%4G|iBjX(sV2C)51w zGCRA@SDS{a`-baM6p#&5|8UdLwNZo|A34{eYF5i?z2webq;B5JjSpcufFn^RI`?aR3lQlTrJLW+Iqst5puEWAa#^%JO3EiQI!T>DH z#@7!&_~87}!?#|)#|wSA!&5*l;UY%t};4Rj4)gk?nu7v*(}`C>esQ;eg;o!r)q zn}>8cgF$-x_N{ESrepuNKmLf4())LAVA|dv?E3*YVai&TZby3~I^S1U*A?ghy(nx;=d79+Ba9_{zb0wg#b0R82BNk4UXcyMxdN^XU6X@+{i8K0h<0Zkr($h=%E z(==I}o%7mpJe$w+g0k!Ii!Z*!DbvvPxqtW0XgH))Iz^ruV%>>_N6EY?s(U<^NcugW z2bdC_YUck1u(mE&ixp&*?%p9IBsZ~Mu0Tx?f>gYgJ~m^}dHtt?YC0!Nl!Jcx^>Jyo z>x7NUV+^|0hXeJPrwuj(JqkL|Auo$Kd|2(NQOc_8i09>_=L)L%r6!>LGIfeD7doy) zNGem(G$zMGcfbeE9+*z@tp&)GnL(!U##jDd{n_}J-b?O3pi0~jzjBmCI8Kv3xhzq+ zW0j7E(xTaT_2O)Oa+QxM)nEZTSRl(~f=|!x&Z2GGXaP0R6P_=t*{oWwDl*Z-o3RJs z&@_zEx^q+!Mvz)kU=nGH3_~biK3}8d6>VqJ+!dGQ^;}~V+7R~3?td$S;4Dh4xhaGG zGtyzk0?4gXoZ$;n8$2=1_4)Z%kH0LbMp|Zv^L3-bA-GlGQ7lkZcbQCwonyw>f;XyH zYp%qh&=iF?Zynyfd(Q*&8)}Cj>7AX-e)93t7gy_dUY(2v$v579eb|rbK$0PdXY~TC z4(uNutd^S=p$7C=w{9L)b(2Bxn5?yOib^(~>2D*~TVfDENoi@&3H&;){A-*NeP;J$ zy!!mf$*=wLoBXIeo>f7n6PtueA5w{*<(n|;rTzJAjtOeuJ$>@E%PJPL#eBWq+`M@s zTj$H=5?LVDN%YNIH_y+{v3!V1Gp7$fnM~S{`KV*UC#LWV$h?qkD_eI_7BxF zjA8oV4Itwc{HLTPa$^k+&g6br9PJNAi>I~P>a^pCmT!1WuUQpD@v2^VRPC;|&F16qTr71TJI#~`(A^>LGwAmw*HjfTzV~hrqI)iXV|a8<~4=L^+sGz7xu5V<+hxslYggF!o{7*xjoY*$@^pczq{ zNQya@te;}CA7M7f?brY+^DSoUy);E$U019TKzV8~AG@Etzg{oBZ@qU!Yqkd&L zypyDd^pjyg=}?;_qcHMfh%JG>%ok0(8o`wDA$+1tH%i+q)OKy8k<u|sA7woy0{8CTA?u|RJ)4gADb}a)XfOaT88>`c z*TPME14`7v3>}1N+6PZGrwU4T0F)#c0P4}>g6!F7h;+ZM7qi9w-k!^v7F-Fmlt1-( zt;ylVeADFA&JTY0!EBL9PVRCG2S^HbQPOS^w(?HcomFV45NbD@4LJqZ_V6%M;P}~@ zlPBU`IBu=8lc~zAyx&wA90`e(}0K_LZD1}yzkcf*W zd;IFN>hkQx_kR7YZ~n?FQOt5RC`~tD)uN(qm93Wyk-!{C76=%(;)*_-;=Y|`)R!a6 zp&mBmJ&GxTuL?jpRFe3IhxhmP9}N08<8}@H2@F|_n#Gwb>>x5E zrxj)*#kla@FEe2QFo0~Y0vSwG<+{$5LlF%fOps1<5>u5~RfQf_*ieXKeu;XMin^7n z^P|JWQBjl*Fc+?XwIhpJj4x2P29RkXPaHFDgW;4A&;y_l1ngN^Rsy7;dvUNgqCA$a zY&u{3)ek;;ela5>LobetnaO-LU96Y0MeM1skFP)c;;UEg?!WQi6))8588W&gO_E+% zYh<`(tlF+D^q#$d8kdtJ=LEKA$j=^vc8#IEz-9|r2s_2n05Bgv@plhX%LH7j2 z1%p9r(;jll09E^7{-vZY>ZMdz0*_v|zxeDiFPh^8K~gLhp@a{W$x%6n>gqj{28S3* zQId-h2zOk$jcz$ z9v}utH8DG-bA+4dRP+QF^X9Mr>Qj0M-~079qKH{(YL`y;YMEv0LWoXKE4hu#D_vLC zGw|f8XbwPl;ii3`DsD!WV#}lvaxX~wv;ny=a+Ap@i1)*Qs)HDxcH|!(y|KS{t1gNf zjHx&k;3wv;u7Fr={MTkvLJN*e@hHb(h-ghQumGsPs+_tc<3*m|G8tz>e?=vfR~JEr zRu5y4Lu~68n?*Lgbh1h6RRQ_JSTU`3L)qZ@`NdbCeM0t2+1hY4I6OQ|G3E*)ZZkAs z2ck4~wOFm@l$hmIA2v}z$@hj5ZYmzW|NduR9$zazBHIhVhQM2x?D@v?42jrkLofC8 za{l3$=llIM21g}5?giB+oDW~IZtcPP4Lj>AvCVV(%vd{+hw1qPRZw?8F6 zG6?r)XP0MJ^Zwo_O}h0F_#6}}*zb(9^@_#Cd05p`f}a=R7bW!GWDkJaxs-lmVM57X z1>7yKin9I)nO79>BA6F|x*SEL7kDteIPuYb1CuBwOtw+YKBP6rnnP2zT#MCtFhU>* zhr^)*#0XaP<@86Ct$A*lL&2h-_UM$gu6lladVD=?>>SBa-9ir#r5IJ49Ux`Jy-j_A z*$(!h0vXh|EOIJA(oFmr5F!#BK*?({YIkSgA!TQ4{@ZoY1Z60etXeVzzQs;ig%@vE zya>h-8(0I!33*+%Z3B@BpB3osA;Ca1JEU>RNT#I;4+Y}!gS zc~Bsa%&N@i-LSk`Tvw}!%I7{EUj$`(vs9JMW^#7^?D3PQ&yKHVbZ~AT9Xz;qYcw1t zagwG9)jagP^37&Com?;GSIgC$YS}_(witFEYi9y$(0%fIe*+Um0*Xx2S|Mz_!mVW`IvpE9ZcpK4WvGJ!lelnCE1j zfAaOogV$c;0gW%=llLo-$aw%sqTf?80DwyYtYJel*@r3vYIDdl`9+ya-sQ2zz5F<~ zWx1~h)iScT0{}2^p5KzLek=mtb zHe%>3c#f7HgVcwRh6(~ougUBE zRV)RMFH_ffmR`VwK}RGaJQ+l9X%<)$PRb)GJmpbIQHrjp2NPE)BAN)qu}u^QT`NsA zKR7(%UJK~!>SFyTfBeI5efyO+-aO1Pk8k8{$Q4EbCk2*%lmEv$o7#y&b?f%v)z|J1 zhx;DL%jZ!%qqLyS8@HzTM&{?_C=e^7UdZzy`t$>G(u3Cm_scSyf+D>e(+g<=*SNe8 zp&QqX48W1cy)34@!PYzFF?n4V=*OV6aCijSLRiBgvvk|a%d-XLQ-GYTXV4pTTGu1% zEtKZ6hjKmq_>A%{x1QeI58i(LRvd;W8!7(t0H}Nm4W5lk3)oXv(6zdRXJS_X{IjB2VNnW0d*(c$fjY*D-_K7mXaVnQ;yPzvfgsA^onlT+Esi<%%IpYs&d-dW~Tf+I1Qzb0XXj_LjdQVkdkJ*wl`ln z+_tFsMtaIV4rLA7I!2GV8sUFE&NW&dnU!371@KXfL*%YCD{Om|f%B?@hb^#NfB3Vr z^{TpcTjkJv7eppDV-C28vV+Y$jE*VA9}J3O zMRAeNq~2ufEMIdwS13)HDFXruhfcdkg;Cs7zGx(2;ODW9wp4{^l>#v33c7$DW6K=B z^z=}r=0JQy$#k5A;0S4gpo%8 z9|wPGUV5ytrrZNd1=B9`B0rGp&SzhI{plB9iYd8_u;;kLxb|*LudTWV^Z(0jS2ln- zTSSyeHXz=n0A?(xpkSSD$4o4AXS!fR7yKFzB%og>CTOVm%;ugv%UZCe!2Myi4gfAJ zh^c0L;||F39SfjCZ1ix?AANp(dfeW;%epVH02Vd|%^6&F%LGt7`PND3?j0oihetTu zQ4i>hfKu^%KD}o8SS}(Q!I^+_()tTgqpUzeR<^4pq==zh2OE?vMyx6DdOTKaYb88r z=*VK~%4>%JRF(x<;JVH?Rk3z-#YKel9%Khs;U-{5sjjnCwb{6J6(yku@(Q!{>j^rJ zCBz_GL8mSlCW)W+!`laYclKt-7qjbWPUZ0g`%2iJtQkG56u_LCHKqYE5tuNy&cwd9 z?$$A`n6r7!8$0mJd;-n6(DoFtcDSkEc0-@jnr4O(B0zb_bk3m4ZAAlC(st9f;eqM0 zsDJwLqksCJ|EE;aJD^(^SJryWT!5Mb34EZ;QkahE<$Y!-Qo84)QthX^`jcFhe${z%#YvK`|y9XqLHH8h-S7sNk6#y1t#OEj>3 zraq7-*LeqeZ7SNE%NKbva9iw+7~X4E&Sv}PwR(CqgI+Wk_6H-%=aUfZj~@4BdUTli zoy`qTlOClf+@`2G%|O3@ovjutu%z;Aj2Caw9Ytaa%|zA=W+P;bHIhaQq<#2PP{@=m zq<*3MR2Lgv0w2V9UTwmlGIJ=D!QkD?@=adkIaOVKRfQ-WjgA!ai`w)A8+=~eOZJr$ zhe47A2m8@%v79Y8*NbK{$(PG=v1)VPI06p{!XG%qjgc_kmpy=D9yk7zR-ksGW??{# zik}2G#663hH;0prZI>2~(ZgJT%Q(wG{s3@CVuqDyo*K)G7?a>0C{@=_k1wvL(_VC# zXcimcBv7_#0=o}|MObW01YC-9?orUur}`b5uK^mHo~6*zJN|H|3J&5T49o}D0^qW zgQ1+ZC^n}9ZYlHsHYweiIh-Z!s3mFk_6>7T;bJh zCR7lWtM%;k^yzGN$!sPHTtnO<5F#eg^x^qOkHLf)O-*IGf*@l zLd)7NPjIZbtVX!6H=As=%8IfWuh+w6+D}97>SC~?m|%}(5FJ*7fJ>x%F1B`-Wau9fthf`SXrML^T-F` z4}Fw&tf7asjli>HzOaKDia=DhfuGmqMAu=S1x7Zqli=Mo9Aei@C%g{OFN8{;)LCD!`Xe4n3rw66P~Vq^K%3_p8}oq< z;?@)ER89x2H*HP^TL((!1nD{0Y5wiZW9#H8!+r<>nhKTmPA|e^>OCs ziVF<5B#DEdU+Lg-I@w%Ty-AcNDoula+S|j3FZ7^_Zqk9a@#WblkgE9!>(-Hb9t@kZ zZkGG$(P43GmQB~yi_7JU>s8J5iIC86XRKy3^1J9NxN<2hn~Pg2*_W^2tcRspBWjc1nE z)j z7r{=mi~($ej*_=Hf)=OE9%N8XF5LOsAAYa^m76Eo1+yY)kx4|jLj}bnNRAl|^EfuP z2<*IrR1FL?a~%r~b{wP4DEbLdDMe-q7`^9;l)9`tDee_JaU5wZ`{g$L^5;Z#%JRwh zZOgX@7cWq9l=O{20&t-7g0&vd403rY!tsOYXK>FougTVamCb{srWjG^B|FI8hi*E$>)kBD4X06rG1tnHB641Xn*3CLr&N#MF&wA)I$wl+2@JLxjHF82mZ zqrUlBDG&333E!uV-Ym0AZmtBoU3b zu1LlN$5B7|;Nb_KeWknzt+fC%5z}!I&t*mMOcl+jV{jtxj4b3?Y!UzByNugH<4Y#1 z4sYm&+__@Cx0()$>j~Obz8N3HX13eyQ+X>7hUSSwG5t01N7B{gc+~P93{q|8Rpiz$ zk_;A5Yk^H2;I*j@}`|MpL0> z?!YtQyxvej0I)f?%`l?SrkUsnUsJ=2q$N4SEOS8J>$bcJg>DfQf@JB-#cDa*td``h z&DJBY3h*!3js@L|_9&rNejAdP_54}hTrMj=tCPr!u`QV=ldPXm!WjHna5T#t6{86lAvfF3)NfMfus|XaC7>ej5!9aQPbQSb2Yu+eO9S z@>Ud=p!5g8Sy4vLdvCHaDtzAoTf7M z7G_i*I&Y5b2hovakqqDAxa4rli*6q|?LYX_zc{%XGmc3!r?uCJ(kuHNlNc(Q+_#c3 z+W8l!h$b90mTtUr8MaBnD}K`4lMOowuo~!-N;OJ4c-)TiAb!N@Rx87Ln|0f2h;vtE zxE>fQF3SiGXRU^X#dUZO3l9{a;y_Eq4Jw0>BQUJAj)6$=N>`!%!Cp;8p*QSDy<~)x zAxsRDJ(DqGU5P&kWwv1q;_|XtR@J&~`}F5j5N73~YL{?#U^Qrfm|>b-hgI4P>Vd;s zlT&Hw=XC!ozre4Y8*G?h7L@Gh*8<$dRQQLc~HOK81WU59< zK}j=QE8P({aLSD{-Ka+1R50tU7A|=4&|LNi4wKnWkb_`mTd+KrTsb9QAY5u|uUtnx zF#G7*sl{2-rymVss0@NeB}5MBdvP!bygui*UXsGahaonEn8$Qof$G7n+cL|iv)TCy zqDI)9YdI3`@ZD=W7DV1sxmey&mCFTT+h%0}?QeK%s+@IGVJ}k|jYUpMd7ukwHi*as zjvJ?Y!K?3t;c)N4i_zq?9J>lzgh) zu|r3iK)xq`}18(d(z20zdIGT>fr>CbEmzUEyC2K`qK$mpAq43yxrllb@zr+1n z2(AI!-!O^*Q9|vHR1aG81NU^*-Er9^k|4y7tu=X!+Kv!9*K1Fw>9V|(Ny@o!%tCjU zsya3!^>|*aS-W$$<*1B3*;li#Tr|zsPoKYi{}w0Mfy|lQ7fCm75|`wvQzruro3azulc%NDaKVB5u_Bs6kGo1|LV^ zHxPs#*2RpDWZ^dJC8V_*@NI*J4;oKpLv>P`#)mg!%^GP%(NNamtDr8yYC0v!?tfR+A|3Xu_4Vs{qgCV}g_Ci3U=LLf( z83ak{_^~`jKXB7te>5EBo9xXu-WX4&r)Ov5$>eG>UM?4l)qJ-~~VX^6`K455F_4y}GQlA@uRhUSBKI zHG_-q)_&x&yMoF_SG0?j#bMeO2xr>T?-e2dxp-G;L-5}6uv=nb%WRf`?VO;SpqRhM zSAOSHFmzVRR&02QvUUFSuYU0CY^Cf!nS&mu=acoy=y})4jvo^{IeYlp~hlnyP!f@cx5= z3;M=pHZ9O{L}FRzt0i4Pk!R&*QEZlI%!Ul^r4wmA4gRS)8gjJ}c%n{7wL!q^Xu9z* zPOgMW(Z&YxTgJDb{qILX*bkx}^y?J%$2clticAqY9Z*CZ>>b^>dFRf0y}Y_2Gn_ns z@#1u1M5djA(K&mrV2gL;&&NJ?Lsxy$`G8P$I*V>?;y1*zQSHT@)>jFe|Rp~>i#B$F_!SC!mYt9iI%R$KHzbpB_ zSSmIrIZpsRhk~4&st{zkXm=S0&ZB&uV&-|>Pmjv7zMfq^`f5Jf|1=2FJFmV)kEW{i zVlmyU$7#>)yCdZUt*(=J69yp4tUQ&Oah6YhXZoN0_YHJ$_} z#Djj4_B@swRwypTF}2Ewg*J{6OK`vSS4){GfKM%g{EG%Mca~Xk(ccCeqoD zDMaO(_@W@|YCKD;?52fzHS@C)M?D+yxgF~%|MbpQM>|N3G!t2OxW6;Goe zt>IWwAT;e=34#Xi&Q4D7)UNBEMab?VOTp(yEzz`Coo%Hv$@(%ftw86* z^&`n+-KIPAt}wx(-2zEkmpgalcvKiAQIhT*93CFtxOwB&)#c^s+4-~M=d1O)W)!RR zjT}2h%Zu`IJg*y%+bwp8&>csc=yZQ75zqXWIk2|I+xkw`9c5FlaJ0cuWBKz6iW;tw zt6^_s=pT*c+VVpv`%Qq5zf+Z?Kl}R0Y`Glulg1+EJWrd0z>8_pAymq+HERQmvT@u7 zTW!H8CfC~?!*`u}?ik3Awqj{gHksuh&LlbCafK(=j&rmrY8kmE=xhE=Uq5;N!7n~) z93j)em&cH9xw*SxN-nR188N;OccV2Wm~dl?Pf@n}U`d2fD}i z`omHGU_aU$#aMb6Q2OWxu?L=?7+O-wlj$cT>4en55$ZKlTig4Hc*!XS5-^qoKr^6G zcJGtVJ9oiBP7+1Es_yrO!{Lbj-P=DnI6Sz%zMjwNddCzbYc%iS0_lFIakSTqmRY;3 zbZfV;Y#k?wr2$midaE_?Lbd(cu3YT6XA?+Vx66x|2)pJAUPn`NWzSb&tBJFk`HSwunR%>Z37N+vjJ>2j`4@y|M9Q>@UzFydB4jn zPbxm3jiocxT?2+6N5@I1Jj(;~ z=T8mMq^H!HK9lV3X(LsrO(6lI-m=QpU8_|Y zDH&lWlTMg8D0I3VrXBF{JH|;+j?wG&4)+hv&(E=jo2@EP)1rltM9~}fZoG2y;OW_X z@_bTry1G4*wl}Ri)3S|?m#h2jM5{ZRHoQ2y1xao2K$>S_4qt=J30!55zP5#>BRc~o zpg7`~#J;o_{P^b&f9JP<6Y_7`^pYCm%hBWEe7Z3n#e@pa1ZTh|qe)PdFDv1YNdq|2dabxF2jl2X5 z$>x*%Ss27*GZUK&%TJh`lYeCADe#Aq=O_!DU8ddITPovzgO4-lPq%c?f5fI}5Q+Pe zJ(At$E^TW$4+gg+rYE1z=J#6I&L9HKe_FSJCzPtVX0+&(u%dZYmBi6e5c}DNyhELP zRlcfL%MIci7F_G~GSAl)JS(~z1Vw&J3Nt~hxgcOtuVRggL zrG%#5wJ1-iV(q!Nl&o?-_>Ws)P8~PL{xJYPeuF(=W~9_i!i-TbTn^yrxVzA)#iTz7 z6RJ{qGrSikkoEK2#cFWdQ?0rmm$M%m;dl_Ruz0RAP9HQM8$yTnzre`^D#9KRLd7 z>&{Wd^fL0ZjR>zf=#g75E?4PN!Y=DPTnoC}1r=orCR5MI+Pn>DUFzi+7@j>@TMOiu zxAy0l+vb4%C187Zp-e7jrrdx1$A3DRFSQpswn=OAY;<@S-J+yxw)+;Ij6)@%;La>N zCW+dX#Y3AO!%O{M4BNKdQHhFD5We&=^tKc?7Xx8dx~pxLW%TV)6myclGdN-6Hr~Jj z2DAy{dYcbeSdTpk$lS4c;~0pq&;J4m;OH!?$ZnoIntc0vx5s*^SWrf zfS$gyS(Vtfah$S&E(L}bOvKj0CUG)YP83}4K&ZG-mG#BJY&%$rJGdr!=n4#FD+tGW zVBN8RXtTD5f~sPMSuk?4E61_%92t`F#uOf)^n=m5!paSPN=j=N*tDOrXo|hg_I5mCXNP*HVPl8vrqwP(;m(-N7(v@C z(z+lSX}2#m=EaVrJ7V6VXq|ue=l}2j^gsM}SkYuHK5ck0cKRD_=P{HONOoD5nP1d3 za|_4d#_axSSmgL^rbcebCw9Cf+%oZxy5^v)WIqPQvckuge``4ts+h(+8D1hEt*1$XN) zl*sq{N$<70_sH}P_V;hxI2i5q<0$^izx~O4)0h)sW_zYGG59jxhTfgC*~93FIhn^{ zY*BYLhPY?PP^&iLGEv%X4c&%Ud4!^IyOU>`Xog_Venu)Fa`0~O;}1UhuYdPHe(Tj6 zOB6S=s!{|ML&Oe0r?iP;XuC7LsDQr?-Y7H{9h;Y;_%S?rK_&mcl^3 z+-)z;4$yhLFKNEg_6R9yOJi8g&~LW^&Q0?McXyEF$LZRJ!{H!}5B5j&Pm~1Nru_7) zC$-_)GV&qYfM(FTJ6=JalaS;YA7O0DV1K*x%yg%fiAs`Z^Qw@{Zj^1snDeN+Pj8z( zra^=ib?k3j?PZCcvsL!PpMUhmTmOYBa%GRCX&9Obxw$XK0=FYb)2J|;OlED*{EfEB zm9nXoaLQ=gQI;rVYF&9y{Ej@rHu1-`zC{Zf)OEjpar`HL{{319t;x2#uBUQ@c3h@> z)`YfBjpu&C<77PtU!)Dg%EDi4I`MKo!n1gJaYrUV&KB?1`SIN^!!qJX|IZPb@uJAW zNVY5a$~fVd!in#kmbwYUL(`DKEl4WtGB=%Gbp-%^#{9ak;3c> zaTN9XJt!qb5v9u~C(p0Olg8vWe0X%T^}E_Yhs9SnmTlYaeQ%#$hZi;Hz^0&DoUl}b zJf)EGP@8;Dp5aSz23@Z1#M#N1$tpR$qSp_|l3nlbe*E)a`_6ms-a9NI(iUme{gC-} zTQ31t!}*X|i;z~j84Gl8t#_O^uM(P?XZz7?rfOOaJGHTE6qNXHq@^xy##NKq?0^54 z|LS@?ZI$s;lKC^SycyZIwl}>sEp2X|7l=~3?TEJ9OhW#cv+-@J?AqPV-6vvxmRW8U zW3qR@0nZC9W`|)+7A?R(#dUPJuB*jj(eDpbH(WJEp_aI(q=GiV(B$vC>F!RJiWd+> z0R!tXJ7XRL*)D2}c9kZ*@gi$f_Rgz;8yO3S?UpU*D|s_oGXR^nC2%WUQ97#Hd{y~L z92aRq1)@jUKmLMA4JmA9S<7&n0D>wF7>51OaSR~BfajU0LAgF9vuJJOnYnf2mo+zq zTeH<-&b3V0w8dzd-)ZYY9Xa?~Aiu(c!rZ4|#jC3Vx(NES$6rytp_o-c7_7Dy$U`=1 z=ywx6IfmOHV7;kKhs?R>5MwT>ZM$FDySN4gw>4q|itBzJL+{OHd^Bu!LV3GVShTSp9St~DY)K%M+ZSK)L$FB z*DPmV8JGu#I28-Q`cVSqkdk>89EOU42oias4=>O2nG;bsK%;r)}Wv z4*O21l-E?+mOv(-Gm8!#j7Gi*xBUA*{15-@@Biy{sR0ZW$72tzD*&;VElLm$TA8OH z&2*7x+3^>04K_A9+xxk-BIl*7Pyh`42KWz;IfZrC)KRuuxV8M@Fp8V1W>P_2m4zR8QP4X*&(fa0 zcZdWHqRv@c7HEL`fpBOzQd6)_8qN?RUJdasH)JV{(8uIl%0iF*69CJ=zIZ?+;kZ}Q zY;cYKnSo;P)srdutp{~=?M6nd$L_sKyWd2Z&d5Xss5#Zs){LM;LAUkf^6HZ>AAR>*Z#P8=qEd1T{Y5VuSoPt|hI}W!3!t|Mf>3fFnF@^J#0yO#LUI zb#0uJDb=>92|<==M|vT)O=}Z8+kSMM&UJdiou^+4YmV)E8K~sWG`PD_%HHN(&*|7I zR2p4j7?wp5MgayYoKzVbmBQ6hBFGQ!4i(LcCbzy?wOtcw7%fFtT)Q3^?1lRS^lJ^e zkG>a%>GAR8R)5g6n<{VXysawe7`nbPy#rU8UrdrLxe0Vg=^K(X>Zg=;#tCblQZ5xI zQQG&T(D#`$oVRy43vEEW%{=G)C}fk}JZxm?KI+46*T>|9tsT3G1&a7n-G~;HY!jO? zlEFrq6C{rfi~$s$i}Gqb&8gIM!qz~YyVKDD#gr`0$#29CoUWj^uj%gWo0@0ZT1GCp zZo9SK)Dpf8CAU56hUJpe5?nB|If>YVYoDS)$vKkviIA%Ak>B{^KmYgNd+(dDJsuKP zd>T{-_}ZqHPFdC0*Vi|1+Y+)-pV^_EzFsMROA%E%tsiIUlLZs-$(w9NNK z$e~NcOpVmGs&kC|#Yi2;CU0^swAnr2&Vi&lCh0O;*rttPxa1tkf4baBLa5vV)p=pL z%QCHQOW7^Z%;_tN3x4COM_)g`xV*lzzXy)2hPP(uSJU`r?15)y*(ipK((GgKhmkOd z4`|qQItmWC9^<<#ddrvq=Z7+30tvSuz@w|4rSp{FY z1%29t(p`RtplMbriH4WcF+Kjfd%oh-OlezUaB}T39F_m2#{oT0A1m;l^2zL?#AE52 zAdWz@#%#r|^j@?!i=S+!SUu#Pq*hLs{jpujTd-*=88pC>Sc_Z==4SiA9Fx*GyA~(_ zaX^m0K8X(?v&3_wpI@tSnoU+%LRbdg*&pi?uNDMEL02PgkCC&TWs8Zswu6er=(Z7@ z4d^Ot&sKRI!LzdM0vl-zYDk-;$Wh%hWco@;hg$P1r<9GrpEezJ4-Wtfbegbw@L24XJa zV7_?e#agKwWityWwlRTJnNAokUWgf37{eqH z_LB&0xiNb*W~~ir!NN&XfHRhLmQ`To3T3Mn^l)B8Y2<9arbxKoa|2&@XbbVt?553; zfuI_QFQY*Xo~Sl(Ye-~z!k8BD?wQ{K0ofEixAw74sjAMg8CNF@e%OlgtU+iAQ>{%4 z?fvgkS+U~nmzbXxeTLdVx}cw(W96s5J}F1#w+@6oO~ukt6xba&ESF*D8iWKADO>z_aTYPG5M zdx2>oSuBp0T1)1oc2MTnIiF3w`BLokMVUO)?b`Zs|2dL(Rg-0KR5sb?gA06&-4CD} zeQ`PF_L5bPaBQ}Nff(bqggQxHgW(ok>~c5_z=`2*6ZW!OTQPQb*!o;4aJt{@mIl)1 zvG$;i%lms-41am1uPvn}h>`LvH^!}Gb4N;U7c`~NgY};xwIC)#YlHMgZ6-k&u&SCIg)e>=T-t zSl9LY2e&u#$znNKFXm}~&>M_Ahu7&tUIJvi0`n_S4nh&LQ8kz?SQEQDUG(Z9Hy@Z_ zMsuWUbtmcFa55=F18oGyBz3T+$-xio9b$nM@B#n?MoAk4rCXFNPqI1%=3 znB`)le5WBK>+~QeBsBU@;<93gHLFBXZR$%v7SEvz_RQ4R0;b-7z-n&1^Pn{i#J1a!hkrvVzU8sWdha)`kz+;a+^TY!W>~J__hh&+uOod2>9U?`O5J-Ro zNRbeT1_YwnX!gJReeQerch0F(RhiDc*4|llA9VZS;l6v%sZ*7i`@i z7>cq?w|$;;>+hnH^|u=C7qkytPo7sIwr>S9Gv*SNc}rptt=X0H8uq9&+nv7^!?(!~n{?>xSBtkfTz2q{K4p)B!%y(jWi; zQ0_}=V39Xv926GEE z(KZ*m{qtRTr8R}1F15*{- zMqvjZ>~MPpsHv9%7>l*gB_nGo65}n}v}10bF}y68a>aY)>xvn4u4KiNI!;zrQ=c<3 zRp6~vxJV}NEg6N0o7qDT(qX|>jqYE(`Q{(L``!n^ z|EM8@%p|A70Fpjx1Wk{|wxG~wV+8)LnEMrz2m<2#mh%^v|J&dDKc1dHM^6*sdZHPG zSyU!@N=mK<<3q`*On^1~$ve0Jm16#rEuml^rO=plS?@G_nBs$!QmMJ43N;erP@G0M z;gkEyUdB=w9Ebc_tz;`kci447W(73amUNv^V(NByXAN`2t5}tPRuGa&-E5nZ(VyBo z=7qeYUdT{F2Nq_D9QV7Wo=aXu`U?x!!NLLw27;7WT1AH*r67SN%5sx!fI{tk&5@J(HkZvNeJ< zrN+}mLYH=*7TN3z^jw3rR4mdYekza}9%#@#wdOMSCE19YIfrpzFwL=b?dC|BZjzcH zQLa_c=x-7LT9N5${&sz0{ylXBMXDGSzJ*B9G=DwszZhN%HT?`A21QW9E{jW9#4ndZ z9XUVPvlka%|K_(p|GC!z!4SV++X6IiQkWpLD}iXrWH;sKG-HLHpFqRlY*G#*&&2gp9b11OGix=b`A#~5mrD$0LF-8 zUrIZ+FGeZifV@hski<~>i_Iy{svteQ)=S34}0LAOFd2yS=_R-(O$&aj!mIUyt44=Hjy7A9jnYq1&C_ zySqNU*DM#!`q(!s-9*lB%2yuh{MK}kh-739e)dIsnAGo}p9JJvqIW^#D8(g=a+HZW zBT?k=UYe|z+NNq3+N{khWUGioB%G^gbrOiNw`82{N!fdKc4#oHVM1k$hZ(02Gg6$L zb(K$^2_tDJ-s@D#rg?(y9ZQ8HY3@q?Nm^pr@3!r_-LHS?%m2w=|CttDHaKd@ESw}K ztgF`pyAO_9z>?GmSwoArh%u=WQLZHP3P+|%qMnr!dNJhmq|5x5-+t?V{@?%49v=@( ziMCL3>qffL-e)arxI(qnTzn2fBNR11NH6@(fzA*j3r)8`q0F+i!B9#rmF78=*K2sZ zR>J@$o1INX=}XgH(+F{HFLqA`8)L4~2>b`y#w%kQaV&}%&xUSdn5pIjPGJn`DN;Nc zVUKioXzSL~HjZcql%u=b?r|yUFl=O;k*HUpx!sS)Cr4ek-*#QT&n&ecU5v-))#qL- zmcd)HR0@VU@TzyuKiF?~-Obg|cOKB5#@DdP%WUIiw%eh5u-%4+s}M+Y6J$rX{f{9be!YQaVGY zIeB;c%fI}Cq8BVj$|0_NcVPS>#059ozyA;Z;nlW76DX*YlUpuVNx_DwP>)HW3sHOc z9N=lpf6MMW?w~B4M6fhLWVm+9ea2AV5sacigpC`prZeC?IpvDQz$teh(btzEkM&Yk1^vRbsM+c(|* zAY=^nqG=YPZG=z}h1bJjxHx}NFOIAA#w|8&Z8cR%y#jK^5HA&MT2!doXy5ReQk**0 z5zHh@Ov{8wsR+uJAF_A97Y`rf`(*S)%Sn2PuAQ;jl)l&^Z;YfYZb9NFm2@cmpW>-b zSxv+=Jlasb+UGvAkxA2u&J~YHRe{s$f-})^#0JdZ;8Z3Pt|pU4yuM|o5C=i^;9`A9T5&M8$P3$_^-3IFGMy}n(bbtqJfn7uPv1w4Yb z8idoxxd)p|vEHon8IXLK@S$4W70Fc|ar#q5S~Twp)aYn}4Yx?vZs7Zc31|YSVV?|ex2wX;9be#-g>&1c3 zd!HR4iBEheISZ$NPw=)|JD*9E9+6b0lmWxpH&8RMf@wnm?WtFLkW+3ni z&N&-oZx+~sNoRhSFO7nJ3T}L9j+TK0k|?j2NB{hr-~QSkedEV|_s5Bht$E4VBPCQUryYnUO;2eg{CO%aJ!>^-YY&IK~ z{Qx%+w=kPD=Zk_QZe)r0drz5D}qx=!&WsR;+^Q8G>4{578EV< z;zQX@wNf)(t=~<6Rd3!AG+@>SY}=)O3x*_0Ek_QkTc5BFae!w;axQEKs7Ivibl4v9 z6J%T0)=l4~_dndf`oLGK2oeC@tTaR!Ay~Hy@peS41+9_Y=Io7Rap=eV#+}R!l$ve6 z-|^<^IS~BFsM?{g4`YxnUeRKq$XCl?HTU9xGzkNhxhhboxCY@s-ko8;FAk>$7wF>4_EQ)iv`ECeF!;7+dFg?$u4+AmNyuZe zr;~q`4*-2phYs58fJ2|6ZQOWD9n0~v?ojq*%918$t-X9q!IxV|$=n<@U`iU7Sq7%; z4f9*fG9c@y6)?{bC(#v<*f}bFH$eIIbP;(&Ilhf`)H${e5V^^2VF_SpN8*`+R<$Ow3=OQR&s7Az&S4v%!)^w3z(DsY8Ac+C0k`)Q8EWiv_bY;25B#Y3hOYm%!aLA5`yEmo<#!Gq` zW4IWyU5R6jF(B86;lpSBozulhRMi+zudf$p51Tf}#0vZ3E7b41Po@})HF+l=iqK+7ZzEfF`YgK4NrE5-}wDMy1L%|m4ElAWSYn7Zqv5v zdudE%RlZ+DI2~s)v}p6xJJ@LRO;nm+2JF37qNG z(btfRuTVWCcDahh7J-x}80(Q>bjDZ|nkzW~t@|l?L9`ezSfkj~6l+O^xqY)0hkpyd zBHglnikNp!N3S?@_yh(iw?A?OLNOZJ0Su%s&%!Nhsrey!Ry?81rp8nGYu|k7+kbL# zef3xWou5eV&pdkdQM+v6JS*mft?_;u|E4lpLKKY!lWa7{)T&6{5thY(u=8AHotnJ4H3%je}gQF7#2523Th#gq()qqb3q2r$&1NpIYS z*MLI9iZV&Y;zc_lvF$l>dfmdwUtZ9rGUdyJDWY8kTLpk|Sv3NBV;;T_8yYMm6C&wGwhWkp!nQ>JJw z!38_?-f|?d9Q|nRMpF_faW!vCqCB;NB)Q@qgI*2(=)I05F{IpN5v;?>cr>&Qq~4LX zCYm;uIuZ!g^ZkoohwOrIn@bI1_3dX*_h0(*cHjSns(I!02bGW_)K1eXNM5Q%aTNYY zI1XLV8Vxzjg>rBRvceo?DP}?N9{u|tzxW^j*T4I%kKP|adCm}Ev5?w#Nr6x+5tI!H zaAwK~6##Z$)KKDTF9f$anqs89g;El>?4>qgGhF~aj6~3^PGy2$?XA#4tC=06USP;l ziWgEqFtBJiQIeuK1jR`a76>KBN+^X_MX)KHMbb=iN{bqOZ)aUsydMzgC0~w^WlhzK z%?H%t6fv_70SE>jiZRTKo)jv`R2_&*>4OMI z;`aKw-|wWAK8Jm7s05qa_^QQ}$$ZeO97|(TH-l%h1%K=azS6$g%pHI@w$AAFfs$%^%i`PCaPalV`f(?J=I@@V}@d z?bUln2@koGm{{XZI#$ib)M4pI#q4D7EUcD`q*Ep2gM!!7#KYsHt+)I>>BFaN51LQvqJ+R11y(@1ha^s01}?)N(Q3uyYA}6)y1>j?lN0KFR~8U6N$7SU!x3&8wpc#GiGQ- zI%#GC(W*%%4|6K+ilcuOv?<&|4I;7`AQOz*9rnNX`@bJ))S?D$bVM}2G1|n<;`+M6 zY#*J~hTLqQw3f}4mgQ-%ZQAz~=Od6zu!-SzvjhW0DlpezDIfkSnIwOY>UB;5=vCW7 zYec)EtFo>CaNGT(FZ@>a0RFCP^!(~~e*bHK_ZR;0)2nUI?j?Xu)|<6M%L~gAJfbXw0cj~)P}gurqq&K3Ry603 zrh<-u2wGpJoD&MC0oF?8z@c;;7w|=CooKvh*JU1yLrawipunt!$`??zD)^!gdDaOH z(NRtO3ZC2_gW%5TG9=TA>NEl#?5$47n-3*ro-~W^{q2Cl&GHVmmGB!$hf&ZP=q7=r zYUUPs92q^G?|%s4s!JDF&E`bE8%PTN;VL)M6C=F(}b@E*KKky4&yKU(=TL`_49x0uYLBjuY;jkBX(yL z`trpQ*+T0hZi=ZfpEPU>SxrBC_Tn3FeB;-@_?54H`^_#n%q7oC?U23O)q0iR-eble zyM!#1(@k*#%WfT3Rh1t0*x6P(^bpELx{ePOZ9|i}BO=V|(&64fp6#WbymnKRE)OTJ z9r8Ma9C@2<=rLp#ZAWUAD7s4c2R*E#m+f?6{bglXRiX-DfRD4Mv(T(Ih|>+1>$b>w z5**I-tuur-xum?QX+E(Uf3<{(UJTWI$dOq^g3!>6Y53sD&DovB@j}QIvMBCjHioH_ z?scim4>y;WH_sklK7KFVT+~tc^>KncBWyBOWKliryWMt2eMsn!AR*ALt6e0~7%mjA zrj`)W;3C_L z3!#%BGZdbb+-&%SNu3!kKl@?u29++qD&DLyM@+9SUh(%TRQ(7Bz;>4mSRjzyh)gQU!#KYC&U;_|>L0xI)(3CD z``)w57uz8nk^@9lcB2)$(oiWJI;juEf=p+`?No-?!X?ee02?Jky-=|tAY3@&%cxU= z5kyhgv^n1JQIHmJL|8IQs1(K`hqg3g7$p*f!@^$SLT1B#iLu~9Zv}W7=6OZK$!AC9 z|1EF94bOvyWKoe*Wn;&RqFj!X_Kx8Ss8mNd0<(mWIb3XHBd!3mk1HXXM+~1IXTOgh zJ?kER5|$71bB(ol*-@k~zaa0&e!IUoe|q)ouhKS&R9w-+K2 zxJRs^k5-|NdQeg{94UTIk|Jy(h0U7wQqd>0q~6>FCwa*HY5hkZeRw$Z&7vvagERkitOYqj`dV4Ql5*P+Rp1l!F_XR~NIjU!92V;fO_Y_N7 zE*`CG&g*SVElYF9m9A#?!#=pY{0IN!|NHpqi=X&6f8@{q=)bW-9x_6M534R`Z&4*$kVB(5HLBEB~Y(YVcR!D{Lz|~Mhe_+oE$5coYiu@FZi|j z_9ZQGc#{q1W~EX-Ye@lO{ic);+sh~8_NsDaT!BNpG(ZLqUVINX z_81>WtP)r%QFT$Uc3?7iGKRXecCRyEpg4XQ*2d?p6mul_^cR;ezWesuj)q94xV1w+ zlxyWnSE7%EEg%ZgqP{IWDuk7SqHS<2SARytR#;EUlF$FC2U9}}dzPwFv1I-okgJ)+ zlVC`3n=>KQb7pDSa_m(2Ets9xVh@`qWi)ZzWn!p>6f~3?4&+b29An4+jrg3(FOuDu&o6E!CAUWi}ZFs^aJ%= zr(%elVLlgt^&Z5ztuRQ7qlkTp2_f^sZ`l zkg3T9NBtZ9%(-Roj7K2W%Jq`W^QbNalUa=^uplD?L0|e)oessaKvCqDDh#|Q&KaAQ z?zPQSOlYdEAmkC;dHH5qP)^Ap3WeD;-4LH%4VO3J>{t>rNWJylq1#;JXYAtDI#bw3S{Zub|g%dE4pMe)8Z+RVAMp zsBC)SiKV#y*~LW;2m$38+Gc5169o0B(xnJCNM$#%tR}S(*gYAb+&XPuOAAR^Dkdh( za$g39R%7Ok@eF1tl(fzyMUnPh{WwEE(IE@Yl=p78YmtzU!vPSWDt#S3PKAvwFC@T_ ziE$rZ@BYsJ{mWnZ+SmWfzx^NoYoGbPb=4rHU6al*x-pFYdVBbL|JSd4;kSS1#o>^z zDqN8sq5PQk`&|}0NyA_)9T6%Z6QL!sz^ptk9CW9K%V~xa{edOqb_fU)$hbr#5zjj1 z7c!4AOxZ2u7Dp_d&#Aanh|xHUs2WhlJ+d9C`eib2!S?U z*#0IrbwwwI{+YbZm{U})xRcBapxJU{d5Ig(V*zuoSLBvP28AK)58$2y1H>RC&N4Xg z<}ltI+`U$~*>4V=M0eZk>&G8{@X0&xUOs*5Q@?1U5Z6fNM;wjap$lPXm)o%Debf62 zIc*^bK(^yHxY>jbH^}9V$xQZ?z@!3k@R54Kj?1|aGw5sD1BpHl{qv{i+pd?Y$)T@h z5V3s0IT=aCkcG1nDuxOzmxIIDXRJqz?2(TGMs`|XP7GZNSB0CIyM!=lIyI(TH3e<2 zWdCQ`uz-9yqe``AJkYacDc)w@gBF`S!X9C?h>O}S%a{z(NXUjpDbl>%`SgwNzWv|+ zcmMrg{;7Za=l`R>b^qamw#~mD639Z{fB)Gp{?f00>G%I|$l^!H3(ioMwEcdcW$EbT zWZ<-^9N|eWbVQ$uA-U{}2Wyb&GRTcqpxbdtWsiqZY(5~)GBFdr5UjpFBaZWk-c;vj zQxsJW4Y9%8rqPP3C~8(+?!OYRrLid_W0P6l+Yl6fQXf%$S8wxSoW<<8 z6yK}tHD$k&+VhfGjV7P+Ta5`?_G`L|42+V37e?_U4x zs=j)D-tG6-SC<#hFaGqc?|%HwySwYFWm}z`aBNW3OT)CxH_WkR*B$(>8>>a#)Waa1 z|4>aKYR|Sh2F_Mf#n8GbH2GGPlwR zXn5%u2eVe4z2yq+sRb%x7&q2GW74{)#*l8N59b1-R?g{eT74_M^r9ld`cUd>vOqG$ zc;zjua10o)1qY<}M$iU3<3`#fGB)ZRf9;=s@y)m28-r21da*Oo4>m>_XvNW%m;xxBN-?otp8Hjf505n}c%B3|SX-WM zXPqhfqyZ&D#}r&tU$MlDM35Dv`^@oHnl=AD>ywNYfP^E&OBGv35mkJd9VC99BKz#d zT%qJKt*TO7K1fqIe2Y|Q(zNNtMJs}xtR2zMoutW<<)XQ>J9^NEexr~BX$+TchC`~m z7!FM%|NZUd{@Wqb)*qZ^LNcQP){^5^Q9dqMoaJO0;;%DqZO;GABRh9 zx7&P1*UKfCMDt(Gb$9sS$)Vm}US2&rfA`Hl`PO&desX@z%(w8(%ZQ75I7ly9{@Cn$ zhJ5tvWmq0UI|!m*Dq4uSHOpD@d!;<62j5x$skNb&MBO0m6F7y%v9?)7O2m}!`|{>` zk{#j31Ds8wK;j$aHv&|T6^D)rz@jeccJ7a2B4)Lr`9fPngs&-0=V;Tkhdo%n0UpfU zK~>0)SGA~R+{rdhwOyYkZLQ#veCo5J$vSAYTB4mE5N+nT$$_8*fa=*9IS|90DhDXn zGOz)XfTo`OwU?g898IjKm)LC0**kGy=AVzL_@H9#gI4O;tnE;obc!Q2b5x#Uxmb8j z>`V6%7n76}fQu;OsM^~Jzvl7n!0QBWqv=>hU@xl-9v?1x3O8c#+Y za8EatinZv1nTA#Wr34rhD{o)rY*=QM7M<~w{vJ9a&B;{D^U{&`I&DPDn-2KoU6#YD zURI5?dNg&{xsN~U>g$`EXXnrVeCdKOKH9XE(%>+7%n^o*(QWj@@l$K@*Bec91lb3z2I-Ni3=Q3D^7w`k+=Kp&29^D zkX%usP@f}1@!tkNlnxa#A=hm~ii8{i)@>DUC8=$l=Ki6smO%mOolaGFGhZ{M9u4To zXGGRSzBt#kY_p@AXRgspPAU53YBQvA#Njt)Ib3^^QjeM>sX+Z0R0G+u0Us5JL%q%3 z(U?uxpzC_MTA~Ax{bJIj*B>zO&WEu`OKAbo4H6mT!9@@+*A!sq(2oE>FyAKW0bC(_ zBa)%z2?dl2sZpkX%ViUfgF+O5Yf@Mrz67*f5Mem4^fmI6p{t{GAz~LQB`GE3&CP77 z3MU}7Md}jxMLD=vPy}%jzY;-c+1H-mDPELM!A{+vBm;?tG}s|ZI*lGzvNJ>PHevH7Us>@qs?_yZ<248%NkW;AZ9`Gqnbl4q3YL}Yo?W1NuFfqlU)%7EaE%^eNXNM#^%{d z9J+y{Ijn1ric2_^vNq|JqL;?7NogA!d^x^s&3w`doB{_EU@5*2Bog>dP`=s zQJbyIj8B$XchD>OPmv}aYcESHm${*bir+FQY@+_)T-A<=_p*vTyqcO%3#1gEPR8`aAV%IE_ z06!>5SHR=)*or7O0MW@8BQYjuST!&P}YXs-a3$k=*p*`8TVzj1O`Oo%gzg8dL{M&qbYi zM_|7VCh?5dgDc9;8A}*Ji*?(&B64=S$r2&XoC|OBddnB(kWOjIxaN-qZ-gI_!ziWi zB3{w5NnU9ut#igHEsrH&&_;Z_&#(}dx{}$_&nWg!&Ru`6cZO*tx+G+)-n70X7$!qE|CsV0iK=_^eEp$*K@ z8>6?yeDD15vrwV)b!Nfge2dLx(Ss0dGEKof75CcDeWa;Ysc9Iegx2LCX`0a+N;&^6 zv;&8fy}UJu_UaFxymrl&Rl5kF?hOJD zs_48Z!KB@sIyi>srUW{J^94;3My5PH>QUlJdVt>m@Xwy{;c&RPy5e#tSDFCrxCj_l z=(;7bDwPIBu_}q#Nj?3hZI{GLn!CjIG`*z#HXl_ zq{zFhL&u&-2^nw-u%Zc$N}5`L$uC!%!P|>AaI_U@Tb!M44$o0?wAFIWqI%zFPdE#9 z{@f9WrVt0#lW3`sZn>@Dits5>L!ADTmXM~tjUaR8cEsori<@7c} z`-RG9lS*^L|mR@L3p(^u}_J3ihlmog;7 zu_qzGBM35KnTNslG(nvYq>`}~%;M=4%}OmSiw}B;#Oj$0Wy_DE4EJROgV>Gim7(r2R(_hXZjqQi(=9LIU-dPqYQ0kn%<++%^&{5tV7@xzggHY#p|9Q#!;ri&$xr4_*Flu+V!5REII^ZPYV&6~c6ui&nyyJ^y_Cxc}>aTwNyD|Y+4XtY2)5wbhxvhs)xn^=C4YU)= zJb2wa)RR()`HPI%=Z-T9eM2Ho&W3>t%xqZSAdf#aTMq&L{UP4TD-UJ`Jr?@hdP?mGlvw zG%}8$!GdU%Ar}LAhnPE7=K@}u)Ct5C>pnqypk6=f&PE`EidPegn3q85fRs;!GaQUVKFr7VsvNX0?r0_If@L8ikpBywhHqb+yf zZFx;pQYuh-p|zZq`zoY%MqR)M<*X8l=PQ# z>Z=C@+bKnN;)29zxhB=80V8n>7_$h2=H1D^%5_e&Y$dag%-bwiE3|BDH-~6InY&2o zik{`LMVr0<#qrUyZ8&2~@&SAtG?RKTDj=)rP2HJG37$2!R_eHogdAz#cP!A$pecrR ztTK%pcPtGy*$?Fm>j6g%sU0LLD=tl{O-C>~Pa>1j4-#ddePDA$TW5!=XS1ffQqbl} zrOs^GtsvS>>&V0FtAZV+&^pd-i8}EQORu|a-EL{Ztd+A(bFVrR1CC2%m9EgYTA zmSodcJ~#PGN?8Ni-g%@zbWbrec>{4FoCO7`TJ}N{n9R3HJ5GL?@T?uJ*Mdln>VwK1 zhKcKS9v#r0C#yhGSVxXPqqoTutWW@AD~p7niz3{5YTJ5Oa82}YJO|ETvN=)>AzK#Y z4wLb~T$_aa&Y(dka>Q4!*X_1@;??HD|xRyky4&o$= ztBACl9EggdJE7Ikso|JrbxE7VguS;?zeprdhRAgi3rTJ;FvA{g_Q;4BGGWJ^gs`>Z zDmBrqz$gYh5>3HNRIGz^!~`}_$s|-C>rnUlPj23f4UzWS`*d5ynz2&F>`_?P0(4MB zl1ALvdW5^y=QBGl1vFVU*t{BZ*-d4tZ;7mW00v#fUh2*+Fgc@@Vj@CRr{bUEXz6%X z1ygxUu8d_&z2WSbCoCUb7Np!#nT*Y1$w

      F&3{?cno}Hb6}KnQIOX7s4-c|UJg+O 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 literal 0 HcmV?d00001 diff --git a/images/logo.svg b/images/logo.svg new file mode 100644 index 0000000..e9195ce --- /dev/null +++ b/images/logo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/my1.png b/images/my1.png new file mode 100644 index 0000000000000000000000000000000000000000..d2466522ff68b3c4510a2dbe9cd0afe2c05e0471 GIT binary patch literal 121014 zcmYIvWl)_<(=G1qt{ZoP`^McRxCeK4cXvW?cMHLSJ0xhZ;O@S0{q{NMy>+LGqTtul zGd49e!$VcqJ}WB#Emq65qB> z8#4^g$lTF>7IPI1rRlhDd_MIg=&aZ7{CJ&PYvFGB?&#tz$T&dwkKqqHue*9fyEnhO zASFs@@Cy6A+aJZsiou3Xy4+j$aFl{ScaaF>J6pb4zVz$}Xn!>{4wUV>jdcJ0GxgZ?;O=Dnmq~z8%0D+oR=vFBQ+<66eykGTlAl_D4XZoVhih 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%0D5Kj^S2Tu@*@foPlB-ajD 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 ZpZ%xTWL~Ap89@v{;OXk;vd$@?2>@m5*nj{4 literal 0 HcmV?d00001 diff --git a/images/mycelium.png b/images/mycelium.png new file mode 100644 index 0000000000000000000000000000000000000000..125ecd7b6626010708aa6ddd220fc5df134a17bb GIT binary patch literal 275993 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

      8#G=4{;j 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%0AwtY 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

      n+5lLCW(Af?oodsr?5Sp30BLKSujRt6ksFDi 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 literal 0 HcmV?d00001 diff --git a/images/node.png b/images/node.png new file mode 100644 index 0000000000000000000000000000000000000000..395f3b490fc360af97d9cc44e95bb2bf0ae8f2e5 GIT binary patch literal 242232 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½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 literal 0 HcmV?d00001 diff --git a/images/node1.png b/images/node1.png new file mode 100644 index 0000000000000000000000000000000000000000..773cb6d7c52beaa0ff854533482aee4a06f5d345 GIT binary patch literal 14654 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 JE0Hk|{vT-gS+D>A literal 0 HcmV?d00001 diff --git a/images/node2.png b/images/node2.png new file mode 100644 index 0000000000000000000000000000000000000000..45f1500fe4e65f93496a9badd699c0c154561615 GIT binary patch literal 11692 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 Iy3K?C0iWZR`2YX_ literal 0 HcmV?d00001 diff --git a/images/node3.png b/images/node3.png new file mode 100644 index 0000000000000000000000000000000000000000..23f945da300c49b3d460334bcff105051e879b8c GIT binary patch literal 10465 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 literal 0 HcmV?d00001 diff --git a/images/ourworld.png b/images/ourworld.png new file mode 100644 index 0000000000000000000000000000000000000000..ef1aa66a350bae1dbee0a51bac1ad98c0a7bdffc GIT binary patch literal 33762 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 literal 0 HcmV?d00001 diff --git a/images/plug.png b/images/plug.png new file mode 100644 index 0000000000000000000000000000000000000000..2fec072645298dd6bc9731323c59dc5a848e32f6 GIT binary patch literal 77546 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 Kf~yt&3;7>9q_e^R literal 0 HcmV?d00001 diff --git a/images/sikana.png b/images/sikana.png new file mode 100644 index 0000000000000000000000000000000000000000..216e66b950abbd3afdea36a2e4856ce7f7f14ef2 GIT binary patch literal 16456 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�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

      5HMtCNhfkMf&NX2HPp zsQ7|%YYdFiE`PGNbstrVyNeVD-A6X0ci4ih2_fZ~e~pb_IcS;OfIHGjPSe}%u1vM> zYL0aG2{@;PYL~D3KCZe&Ne`Th7MSx&)z^j+Oo1U)L`9NfNj&0P11}T;N|duLe#K;Q z9=4_}6=zWuC1 ztV8Bnl-B5JQ(n(%1^padFg|avb6$;CecJ=SZiYX8*OV;fFH=*~NH%Q#e5np}iLA#X z7Vh&h(wX^^1q|JqkdHNg#{89O0HPa$Ytd)Kp9zbCEWZ31{QtbmDA+Xc@4bNk$9emI zZV>!E!~ge!!QUGM|Howh{{!-$s|f$tHTdtGGAeieZ_!|m;8n1Y;we)9+Cl \ No newline at end of file diff --git a/images/stat2.svg b/images/stat2.svg new file mode 100644 index 0000000..5b2ab9e --- /dev/null +++ b/images/stat2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/stat3.svg b/images/stat3.svg new file mode 100644 index 0000000..65f84be --- /dev/null +++ b/images/stat3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/stat4.svg b/images/stat4.svg new file mode 100644 index 0000000..b3ff4eb --- /dev/null +++ b/images/stat4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/vverse.png b/images/vverse.png new file mode 100644 index 0000000000000000000000000000000000000000..ff9d23c1304c897a6a3d328a7b21de71fdcb91cc GIT binary patch literal 15626 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 V@MQo1 literal 0 HcmV?d00001 diff --git a/images/xp1.svg b/images/xp1.svg new file mode 100644 index 0000000..ac8716e --- /dev/null +++ b/images/xp1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/xp2.svg b/images/xp2.svg new file mode 100644 index 0000000..ee7ee37 --- /dev/null +++ b/images/xp2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/xp3.svg b/images/xp3.svg new file mode 100644 index 0000000..c10dc05 --- /dev/null +++ b/images/xp3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/images/xp4.svg b/images/xp4.svg new file mode 100644 index 0000000..760044b --- /dev/null +++ b/images/xp4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 0000000..35c879a --- /dev/null +++ b/index.html @@ -0,0 +1,540 @@ + + + + + + + + Hero by Mycelium Project + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

      + +
      + + + +
      +
      +
      +

      Become the Hero of
      your own digital world.

      +

      Start owning your data and digital life.
      With Hero, we can build a conscious collective intelligence together.

      + +
      + +
      +
      + + + + +
      + +
      + + + + + + + +
      +
      + +
      + +
      +

      Everyone can be a Hero

      +

      Hero is your own personal intelligent digital identity that fosters a collective intelligence and empower everyone to enhance our digital existence with unfettered access to essential tools for learning, participating, and thriving within the Mycelium Network.

      + +
        +
      • + + + Unified Digital Identity +
      • +
      • + + + Enhanced Privacy and Security +
      • +
      • + + + Seamless Integration and Accessibility +
      • +
      • + + + Customizable and Extensible Experiences +
      • +
      + +
      +
      +
      +
      + + + + + + + +
      +
      +
      + +

      Our Alter Ego within the Mycelium Network

      + + Mycelium Network + +

      Discover how Mycelium Network is revolutionizing internet access with a decentralized, community-powered approach. We aim to empower individuals worldwide by enabling them to own and manage internet resources collectively.

      +
      +
      + Explore Mycelium +
      +
      + + + + + +
      +
      +
      +
      +

      Powered by Mycelium Nodes.

      +

      Mycelium Network and Heroes exist thanks to a vast network of cloud capacity deployed by ‘Farmers’- who deploy Mycelium Nodes in supporting locations worldwide.

      + +
        +
      • + + + Decentralized and globally distributed. +
      • +
      • + + + Fully Autonomous Operations +
      • +
      • + + + Peer-to-Peer Technologies +
      • +
      +

      Together, we can create a globally distributed AI and internet infrastructure and earn an income.

      + +
      + +
      +
      + +
      + + + + + + + +
      +
      +
      +

      Join The Movement

      +

      Hero invites you to your new sovereign digital life with 3 easy steps.

      +
      +
      + +
      + Icon representing Node & Earn +

      Get A Node & Earn

      +

      Get a Mycelium Node and add capacity to the Mycelium Network.

      + Get started +
      + +
      + Icon representing Node & Earn +

      Get Your Hero

      +

      Register and reserve your own Hero - your sovereign digital identity.

      + Get started +
      + +
      + Icon representing Node & Earn +

      Acquire INCA Token

      +

      Purchase INCA - The digital currency of the Mycelium Network.

      + Get started +
      +
      +
      +
      + + + + + + + +
      +
      + +
      + +
      +

      Hero Xperiences

      +

      Dive into a world of fully decentralized and completely secure applications on the Mycelium Network, built to empower and enable our Heroes with innovative digital Xperiences.

      +
      +
      +
      + +

      Drive

      +
      +
      + +

      Chat

      + +
      +
      + +

      Browse

      +
      +
      + +

      Wallet

      +
      +
      + +
      +
      +
      +
      +
      + + + + + +
      +
      +
      +
      +

      Frequently asked questions

      +
      +
      +

      + +

      +
      +
      +

      Hero is your personalized digital identity within the Mycelium network. It serves as your unique avatar, enabling you to securely interact with various applications and services while maintaining control over your data. The Mycelium network provides the decentralized infrastructure that powers Hero, ensuring a secure and private digital experience.

      +

      Check out this guide to learn how to get started and start using Hero on Mycelium Network.

      +
      +
      +

      + +

      + +

      + +

      + +

      + +

      + +
      +
      +
      +
      + + + + +
      +
      +
      +

      Be a Hero Today

      +

      Become the center of your digital life.

      + Get Started +
      +
      + Free Trial Image +
      +
      +
      + + + + + + + + \ No newline at end of file diff --git a/input.css b/input.css new file mode 100644 index 0000000..bd6213e --- /dev/null +++ b/input.css @@ -0,0 +1,3 @@ +@tailwind base; +@tailwind components; +@tailwind utilities; \ No newline at end of file diff --git a/mstile-150x150.png b/mstile-150x150.png new file mode 100644 index 0000000000000000000000000000000000000000..cec3184d52eab6f68e2ed3ea312db1686d8cdc4e GIT binary patch literal 8630 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 Jsgh;*{{WpppThtE literal 0 HcmV?d00001 diff --git a/mycelium.html b/mycelium.html new file mode 100644 index 0000000..0f03162 --- /dev/null +++ b/mycelium.html @@ -0,0 +1,468 @@ + + + + + + + + Hero by Mycelium Project + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + +
      + + +
      +
      +
      +

      Welcome to Mycelium Network

      + + Mycelium Network +

      Discover how Mycelium Network is revolutionizing internet access with a decentralized, community-powered approach.
      We aim to empower individuals worldwide by enabling them to own and manage internet resources collectively.

      +
      + Learn More +
      +
      +
      + + + + + +
      +
      +
      +

      Our Planet Needs a
      Cloud & AI Infrastructure Upgrade.

      +

      This free and open-source landing page template was built using the utility classes from Tailwind CSS and based on the components from the Flowbite Library and the Blocks System.

      +
      +
      +

      Sovereign

      +

      Local infrastructure ensures data locality and security +

      +
      +
      +

      Private

      +

      Complete control over your own data at your proximity

      +
      +
      +

      Decentralized

      +

      Dispersed workloads System, instead of centralizing data

      +
      +
      +

      Secure

      +

      Multi-layered security architecture for data and compute safe

      +
      +
      +
      + +
      +
      + + + + + + +
      +
      +
      +

      Mycelium by the Numbers

      +

      Explore key metrics that showcase the scope and scale of the Mycelium Network's global impact. Our widespread global presence is not owned by one single entity, but maintained through the collective effort of a global community.

      +
      +
      + +
      + Icon representing Node & Earn +

      32.74 PB
      Capacity

      +

      Total data storage capacity available within the Mycelium Network.

      +
      + +
      + Icon representing Get Your Hero +

      2569
      Nodes

      +

      The number of active nodes within the network’s infrastructure.

      +
      + +
      + Icon representing Acquire INCA Token +

      61M
      Countries

      +

      The number of countries where the Mycelium Network has a presence

      +
      + +
      + Icon representing Explore Services +

      63.986
      Cores

      +

      The total number of processing cores that power the network.

      +
      +
      +
      +
      + + + + + + + + + +
      +
      + +
      + +
      +

      Mycelium Technologies

      +

      Learn the basics of how our decentralized network distributes computing and storage resources globally.

      + +
        +
      • + + +

        Decentralized

        + Nodes distributed globally ensure no single point of failure and enhance network resilience. +
      • +
      • + + +

        Autonomous

        + Network self-manages resource allocation and maintenance without human intervention. +
      • +
      • + + +

        P2P

        + Direct node interactions eliminate central servers, enhancing privacy, reducing latency. +
      • +
      + +
      +
      +
      +
      +
      +
      + +
      +
      +

      From Farmers to Everyone

      +

      Mycelium Network and Heroes exist thanks to a vast network of cloud capacity deployed by ‘Farmers’- who deploy Mycelium Nodes in supporting locations worldwide.

      + +
        +
      • + + + Promising Financial Incentives +
      • +
      • + + + Plug & Play +
      • +
      • + + + Minimal Tech skills required +
      • +
      + +
      + +
      +
      +
      + + + + + + + + + +
      +
      +
      +
      +

      Frequently asked questions

      +
      +
      +

      + +

      +
      +
      +

      Hero is your personalized digital identity within the Mycelium network. It serves as your unique avatar, enabling you to securely interact with various applications and services while maintaining control over your data. The Mycelium network provides the decentralized infrastructure that powers Hero, ensuring a secure and private digital experience.

      +

      Check out this guide to learn how to get started and start using Hero on Mycelium Network.

      +
      +
      +

      + +

      + +

      + +

      + +

      + +

      + +
      +
      +
      +
      + + + + + +
      +
      +
      +

      Be a Hero Today

      +

      Become the center of your digital life.

      + Get Started +
      +
      + Free Trial Image +
      +
      +
      + + + + + + + + \ No newline at end of file diff --git a/node_modules/.DS_Store b/node_modules/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..0984a1624f88f251d795cbc299bee5994a8849b9 GIT binary patch literal 18436 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 X=ObmBPK=So`d{oZ@EHCtuK)i72lBWL literal 0 HcmV?d00001 diff --git a/node_modules/.bin/acorn b/node_modules/.bin/acorn new file mode 120000 index 0000000..cf76760 --- /dev/null +++ b/node_modules/.bin/acorn @@ -0,0 +1 @@ +../acorn/bin/acorn \ No newline at end of file diff --git a/node_modules/.bin/cssesc b/node_modules/.bin/cssesc new file mode 120000 index 0000000..487b689 --- /dev/null +++ b/node_modules/.bin/cssesc @@ -0,0 +1 @@ +../cssesc/bin/cssesc \ No newline at end of file diff --git a/node_modules/.bin/detective b/node_modules/.bin/detective new file mode 120000 index 0000000..8c3093a --- /dev/null +++ b/node_modules/.bin/detective @@ -0,0 +1 @@ +../detective/bin/detective.js \ No newline at end of file diff --git a/node_modules/.bin/mini-svg-data-uri b/node_modules/.bin/mini-svg-data-uri new file mode 120000 index 0000000..20b061f --- /dev/null +++ b/node_modules/.bin/mini-svg-data-uri @@ -0,0 +1 @@ +../mini-svg-data-uri/cli.js \ No newline at end of file diff --git a/node_modules/.bin/nanoid b/node_modules/.bin/nanoid new file mode 120000 index 0000000..e2be547 --- /dev/null +++ b/node_modules/.bin/nanoid @@ -0,0 +1 @@ +../nanoid/bin/nanoid.cjs \ No newline at end of file diff --git a/node_modules/.bin/resolve b/node_modules/.bin/resolve new file mode 120000 index 0000000..b6afda6 --- /dev/null +++ b/node_modules/.bin/resolve @@ -0,0 +1 @@ +../resolve/bin/resolve \ No newline at end of file diff --git a/node_modules/.bin/tailwind b/node_modules/.bin/tailwind new file mode 120000 index 0000000..d497797 --- /dev/null +++ b/node_modules/.bin/tailwind @@ -0,0 +1 @@ +../tailwindcss/lib/cli.js \ No newline at end of file diff --git a/node_modules/.bin/tailwindcss b/node_modules/.bin/tailwindcss new file mode 120000 index 0000000..d497797 --- /dev/null +++ b/node_modules/.bin/tailwindcss @@ -0,0 +1 @@ +../tailwindcss/lib/cli.js \ No newline at end of file diff --git a/node_modules/.package-lock.json b/node_modules/.package-lock.json new file mode 100644 index 0000000..d183f0a --- /dev/null +++ b/node_modules/.package-lock.json @@ -0,0 +1,826 @@ +{ + "name": "landwind", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@popperjs/core": { + "version": "2.11.5", + "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.5.tgz", + "integrity": "sha512-9X2obfABZuDVLCgPK9aX0a/x4jaOEweTTWE2+9sr0Qqqevj2Uv5XorvusThmc9XGYpS9yI+fhh8RTafBtGposw==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/popperjs" + } + }, + "node_modules/acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-node": { + "version": "1.8.2", + "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.8.2.tgz", + "integrity": "sha512-8mt+fslDufLYntIoPAaIMUe/lrbrehIiwmR3t2k9LljIzoigEPF27eLk2hy8zSGzmR/ogr7zbRKINMo1u0yh5A==", + "dev": true, + "dependencies": { + "acorn": "^7.0.0", + "acorn-walk": "^7.0.0", + "xtend": "^4.0.2" + } + }, + "node_modules/acorn-walk": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", + "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/anymatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", + "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", + "dev": true, + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/arg": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", + "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==", + "dev": true + }, + "node_modules/binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", + "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/camelcase-css": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", + "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/chokidar": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", + "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ], + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/chokidar/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "dev": true, + "bin": { + "cssesc": "bin/cssesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/defined": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", + "integrity": "sha512-Y2caI5+ZwS5c3RiNDJ6u53VhQHv+hHKwhkI1iHvceKUHw9Df6EK2zRLfjejRgMuCuxK7PfSWIMwWecceVvThjQ==", + "dev": true + }, + "node_modules/detective": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/detective/-/detective-5.2.1.tgz", + "integrity": "sha512-v9XE1zRnz1wRtgurGu0Bs8uHKFSTdteYZNbIPFVhUZ39L/S79ppMpdmVOZAnoz1jfEFodc48n6MX483Xo3t1yw==", + "dev": true, + "dependencies": { + "acorn-node": "^1.8.2", + "defined": "^1.0.0", + "minimist": "^1.2.6" + }, + "bin": { + "detective": "bin/detective.js" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/didyoumean": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", + "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==", + "dev": true + }, + "node_modules/dlv": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", + "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", + "dev": true + }, + "node_modules/fast-glob": { + "version": "3.2.11", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.11.tgz", + "integrity": "sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + }, + "engines": { + "node": ">=8.6.0" + } + }, + "node_modules/fast-glob/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fastq": { + "version": "1.13.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", + "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", + "dev": true, + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/flowbite": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/flowbite/-/flowbite-1.8.1.tgz", + "integrity": "sha512-lXTcO8a6dRTPFpINyOLcATCN/pK1Of/jY4PryklPllAiqH64tSDUsOdQpar3TO59ZXWwugm2e92oaqwH6X90Xg==", + "dependencies": { + "@popperjs/core": "^2.9.3", + "mini-svg-data-uri": "^1.4.3" + } + }, + "node_modules/fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.1" + }, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-core-module": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", + "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", + "dev": true, + "dependencies": { + "has": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/lilconfig": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.5.tgz", + "integrity": "sha512-xaYmXZtTHPAw5m+xLN8ab9C+3a8YmV3asNSPOATITbtwrfbwaLJj8h66H1WMIpALCkqsIzK3h7oQ+PdX+LQ9Eg==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/micromatch": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", + "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "dev": true, + "dependencies": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/mini-svg-data-uri": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/mini-svg-data-uri/-/mini-svg-data-uri-1.4.4.tgz", + "integrity": "sha512-r9deDe9p5FJUPZAk3A59wGH7Ii9YrjjWw0jmw/liSbHl2CHiyXj6FcDXDu2K3TjVAXqiJdaw3xxwlZZr9E6nHg==", + "bin": { + "mini-svg-data-uri": "cli.js" + } + }, + "node_modules/minimist": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", + "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", + "dev": true + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-hash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", + "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/postcss": { + "version": "8.4.38", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", + "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/postcss-import": { + "version": "14.1.0", + "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-14.1.0.tgz", + "integrity": "sha512-flwI+Vgm4SElObFVPpTIT7SU7R3qk2L7PyduMcokiaVKuWv9d/U+Gm/QAd8NDLuykTWTkcrjOeD2Pp1rMeBTGw==", + "dev": true, + "dependencies": { + "postcss-value-parser": "^4.0.0", + "read-cache": "^1.0.0", + "resolve": "^1.1.7" + }, + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "postcss": "^8.0.0" + } + }, + "node_modules/postcss-js": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.0.tgz", + "integrity": "sha512-77QESFBwgX4irogGVPgQ5s07vLvFqWr228qZY+w6lW599cRlK/HmnlivnnVUxkjHnCu4J16PDMHcH+e+2HbvTQ==", + "dev": true, + "dependencies": { + "camelcase-css": "^2.0.1" + }, + "engines": { + "node": "^12 || ^14 || >= 16" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.3.3" + } + }, + "node_modules/postcss-load-config": { + "version": "3.1.4", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-3.1.4.tgz", + "integrity": "sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg==", + "dev": true, + "dependencies": { + "lilconfig": "^2.0.5", + "yaml": "^1.10.2" + }, + "engines": { + "node": ">= 10" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": ">=8.0.9", + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "postcss": { + "optional": true + }, + "ts-node": { + "optional": true + } + } + }, + "node_modules/postcss-nested": { + "version": "5.0.6", + "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-5.0.6.tgz", + "integrity": "sha512-rKqm2Fk0KbA8Vt3AdGN0FB9OBOMDVajMG6ZCf/GoHgdxUJ4sBFp0A/uMIRm+MJUdo33YXEtjqIz8u7DAp8B7DA==", + "dev": true, + "dependencies": { + "postcss-selector-parser": "^6.0.6" + }, + "engines": { + "node": ">=12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.2.14" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.0.10", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.10.tgz", + "integrity": "sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w==", + "dev": true, + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", + "dev": true + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/quick-lru": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", + "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/read-cache": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", + "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", + "dev": true, + "dependencies": { + "pify": "^2.3.0" + } + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/resolve": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", + "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.9.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true, + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/source-map-js": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", + "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/tailwindcss": { + "version": "3.1.4", + "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.1.4.tgz", + "integrity": "sha512-NrxbFV4tYsga/hpWbRyUfIaBrNMXDxx5BsHgBS4v5tlyjf+sDsgBg5m9OxjrXIqAS/uR9kicxLKP+bEHI7BSeQ==", + "dev": true, + "dependencies": { + "arg": "^5.0.2", + "chokidar": "^3.5.3", + "color-name": "^1.1.4", + "detective": "^5.2.1", + "didyoumean": "^1.2.2", + "dlv": "^1.1.3", + "fast-glob": "^3.2.11", + "glob-parent": "^6.0.2", + "is-glob": "^4.0.3", + "lilconfig": "^2.0.5", + "normalize-path": "^3.0.0", + "object-hash": "^3.0.0", + "picocolors": "^1.0.0", + "postcss": "^8.4.14", + "postcss-import": "^14.1.0", + "postcss-js": "^4.0.0", + "postcss-load-config": "^3.1.4", + "postcss-nested": "5.0.6", + "postcss-selector-parser": "^6.0.10", + "postcss-value-parser": "^4.2.0", + "quick-lru": "^5.1.1", + "resolve": "^1.22.0" + }, + "bin": { + "tailwind": "lib/cli.js", + "tailwindcss": "lib/cli.js" + }, + "engines": { + "node": ">=12.13.0" + }, + "peerDependencies": { + "postcss": "^8.0.9" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "dev": true + }, + "node_modules/xtend": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", + "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", + "dev": true, + "engines": { + "node": ">=0.4" + } + }, + "node_modules/yaml": { + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", + "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", + "dev": true, + "engines": { + "node": ">= 6" + } + } + } +} diff --git a/node_modules/@nodelib/.DS_Store b/node_modules/@nodelib/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..5b8f72826ae8fe63ceebaec976b4fc3e2d2a2f85 GIT binary patch literal 6148 zcmeHKK~BR!475unO5xBO9P@%o{XwY03o3DjG@>9HQb7^d9JuibUcfK-4nn+u@!F&b zAyQ8WAzSj!X4l@GOww#kL_EFECPX758o&j6duVfHFS;`VKwyx6enj%x6s_d1^kuvyY|lg~naOYC5qMA8b3bRVW;G$NEtSCyo`p zbp>33rUE;9Ig;}q)l*mf-%Ro=SHKncR|;@HnI%))lAW!so0GFPf}g>~B(7AfQqT!U gF=FK?K7t3scqAQQY*;E{1m=GPf(+ic0>7%jC*3V`Hvj+t literal 0 HcmV?d00001 diff --git a/node_modules/@nodelib/fs.scandir/LICENSE b/node_modules/@nodelib/fs.scandir/LICENSE new file mode 100644 index 0000000..65a9994 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Denis Malinochkin + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/@nodelib/fs.scandir/README.md b/node_modules/@nodelib/fs.scandir/README.md new file mode 100644 index 0000000..e0b218b --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/README.md @@ -0,0 +1,171 @@ +# @nodelib/fs.scandir + +> List files and directories inside the specified directory. + +## :bulb: Highlights + +The package is aimed at obtaining information about entries in the directory. + +* :moneybag: Returns useful information: `name`, `path`, `dirent` and `stats` (optional). +* :gear: On Node.js 10.10+ uses the mechanism without additional calls to determine the entry type. See [`old` and `modern` mode](#old-and-modern-mode). +* :link: Can safely work with broken symbolic links. + +## Install + +```console +npm install @nodelib/fs.scandir +``` + +## Usage + +```ts +import * as fsScandir from '@nodelib/fs.scandir'; + +fsScandir.scandir('path', (error, stats) => { /* … */ }); +``` + +## API + +### .scandir(path, [optionsOrSettings], callback) + +Returns an array of plain objects ([`Entry`](#entry)) with information about entry for provided path with standard callback-style. + +```ts +fsScandir.scandir('path', (error, entries) => { /* … */ }); +fsScandir.scandir('path', {}, (error, entries) => { /* … */ }); +fsScandir.scandir('path', new fsScandir.Settings(), (error, entries) => { /* … */ }); +``` + +### .scandirSync(path, [optionsOrSettings]) + +Returns an array of plain objects ([`Entry`](#entry)) with information about entry for provided path. + +```ts +const entries = fsScandir.scandirSync('path'); +const entries = fsScandir.scandirSync('path', {}); +const entries = fsScandir.scandirSync(('path', new fsScandir.Settings()); +``` + +#### path + +* Required: `true` +* Type: `string | Buffer | URL` + +A path to a file. If a URL is provided, it must use the `file:` protocol. + +#### optionsOrSettings + +* Required: `false` +* Type: `Options | Settings` +* Default: An instance of `Settings` class + +An [`Options`](#options) object or an instance of [`Settings`](#settingsoptions) class. + +> :book: When you pass a plain object, an instance of the `Settings` class will be created automatically. If you plan to call the method frequently, use a pre-created instance of the `Settings` class. + +### Settings([options]) + +A class of full settings of the package. + +```ts +const settings = new fsScandir.Settings({ followSymbolicLinks: false }); + +const entries = fsScandir.scandirSync('path', settings); +``` + +## Entry + +* `name` — The name of the entry (`unknown.txt`). +* `path` — The path of the entry relative to call directory (`root/unknown.txt`). +* `dirent` — An instance of [`fs.Dirent`](./src/types/index.ts) class. On Node.js below 10.10 will be emulated by [`DirentFromStats`](./src/utils/fs.ts) class. +* `stats` (optional) — An instance of `fs.Stats` class. + +For example, the `scandir` call for `tools` directory with one directory inside: + +```ts +{ + dirent: Dirent { name: 'typedoc', /* … */ }, + name: 'typedoc', + path: 'tools/typedoc' +} +``` + +## Options + +### stats + +* Type: `boolean` +* Default: `false` + +Adds an instance of `fs.Stats` class to the [`Entry`](#entry). + +> :book: Always use `fs.readdir` without the `withFileTypes` option. ??TODO?? + +### followSymbolicLinks + +* Type: `boolean` +* Default: `false` + +Follow symbolic links or not. Call `fs.stat` on symbolic link if `true`. + +### `throwErrorOnBrokenSymbolicLink` + +* Type: `boolean` +* Default: `true` + +Throw an error when symbolic link is broken if `true` or safely use `lstat` call if `false`. + +### `pathSegmentSeparator` + +* Type: `string` +* Default: `path.sep` + +By default, this package uses the correct path separator for your OS (`\` on Windows, `/` on Unix-like systems). But you can set this option to any separator character(s) that you want to use instead. + +### `fs` + +* Type: [`FileSystemAdapter`](./src/adapters/fs.ts) +* Default: A default FS methods + +By default, the built-in Node.js module (`fs`) is used to work with the file system. You can replace any method with your own. + +```ts +interface FileSystemAdapter { + lstat?: typeof fs.lstat; + stat?: typeof fs.stat; + lstatSync?: typeof fs.lstatSync; + statSync?: typeof fs.statSync; + readdir?: typeof fs.readdir; + readdirSync?: typeof fs.readdirSync; +} + +const settings = new fsScandir.Settings({ + fs: { lstat: fakeLstat } +}); +``` + +## `old` and `modern` mode + +This package has two modes that are used depending on the environment and parameters of use. + +### old + +* Node.js below `10.10` or when the `stats` option is enabled + +When working in the old mode, the directory is read first (`fs.readdir`), then the type of entries is determined (`fs.lstat` and/or `fs.stat` for symbolic links). + +### modern + +* Node.js 10.10+ and the `stats` option is disabled + +In the modern mode, reading the directory (`fs.readdir` with the `withFileTypes` option) is combined with obtaining information about its entries. An additional call for symbolic links (`fs.stat`) is still present. + +This mode makes fewer calls to the file system. It's faster. + +## Changelog + +See the [Releases section of our GitHub project](https://github.com/nodelib/nodelib/releases) for changelog for each release version. + +## License + +This software is released under the terms of the MIT license. diff --git a/node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts b/node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts new file mode 100644 index 0000000..827f1db --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts @@ -0,0 +1,20 @@ +import type * as fsStat from '@nodelib/fs.stat'; +import type { Dirent, ErrnoException } from '../types'; +export interface ReaddirAsynchronousMethod { + (filepath: string, options: { + withFileTypes: true; + }, callback: (error: ErrnoException | null, files: Dirent[]) => void): void; + (filepath: string, callback: (error: ErrnoException | null, files: string[]) => void): void; +} +export interface ReaddirSynchronousMethod { + (filepath: string, options: { + withFileTypes: true; + }): Dirent[]; + (filepath: string): string[]; +} +export declare type FileSystemAdapter = fsStat.FileSystemAdapter & { + readdir: ReaddirAsynchronousMethod; + readdirSync: ReaddirSynchronousMethod; +}; +export declare const FILE_SYSTEM_ADAPTER: FileSystemAdapter; +export declare function createFileSystemAdapter(fsMethods?: Partial): FileSystemAdapter; diff --git a/node_modules/@nodelib/fs.scandir/out/adapters/fs.js b/node_modules/@nodelib/fs.scandir/out/adapters/fs.js new file mode 100644 index 0000000..f0fe022 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/adapters/fs.js @@ -0,0 +1,19 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0; +const fs = require("fs"); +exports.FILE_SYSTEM_ADAPTER = { + lstat: fs.lstat, + stat: fs.stat, + lstatSync: fs.lstatSync, + statSync: fs.statSync, + readdir: fs.readdir, + readdirSync: fs.readdirSync +}; +function createFileSystemAdapter(fsMethods) { + if (fsMethods === undefined) { + return exports.FILE_SYSTEM_ADAPTER; + } + return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods); +} +exports.createFileSystemAdapter = createFileSystemAdapter; diff --git a/node_modules/@nodelib/fs.scandir/out/constants.d.ts b/node_modules/@nodelib/fs.scandir/out/constants.d.ts new file mode 100644 index 0000000..33f1749 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/constants.d.ts @@ -0,0 +1,4 @@ +/** + * IS `true` for Node.js 10.10 and greater. + */ +export declare const IS_SUPPORT_READDIR_WITH_FILE_TYPES: boolean; diff --git a/node_modules/@nodelib/fs.scandir/out/constants.js b/node_modules/@nodelib/fs.scandir/out/constants.js new file mode 100644 index 0000000..7e3d441 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/constants.js @@ -0,0 +1,17 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = void 0; +const NODE_PROCESS_VERSION_PARTS = process.versions.node.split('.'); +if (NODE_PROCESS_VERSION_PARTS[0] === undefined || NODE_PROCESS_VERSION_PARTS[1] === undefined) { + throw new Error(`Unexpected behavior. The 'process.versions.node' variable has invalid value: ${process.versions.node}`); +} +const MAJOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[0], 10); +const MINOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[1], 10); +const SUPPORTED_MAJOR_VERSION = 10; +const SUPPORTED_MINOR_VERSION = 10; +const IS_MATCHED_BY_MAJOR = MAJOR_VERSION > SUPPORTED_MAJOR_VERSION; +const IS_MATCHED_BY_MAJOR_AND_MINOR = MAJOR_VERSION === SUPPORTED_MAJOR_VERSION && MINOR_VERSION >= SUPPORTED_MINOR_VERSION; +/** + * IS `true` for Node.js 10.10 and greater. + */ +exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = IS_MATCHED_BY_MAJOR || IS_MATCHED_BY_MAJOR_AND_MINOR; diff --git a/node_modules/@nodelib/fs.scandir/out/index.d.ts b/node_modules/@nodelib/fs.scandir/out/index.d.ts new file mode 100644 index 0000000..b9da83e --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/index.d.ts @@ -0,0 +1,12 @@ +import type { FileSystemAdapter, ReaddirAsynchronousMethod, ReaddirSynchronousMethod } from './adapters/fs'; +import * as async from './providers/async'; +import Settings, { Options } from './settings'; +import type { Dirent, Entry } from './types'; +declare type AsyncCallback = async.AsyncCallback; +declare function scandir(path: string, callback: AsyncCallback): void; +declare function scandir(path: string, optionsOrSettings: Options | Settings, callback: AsyncCallback): void; +declare namespace scandir { + function __promisify__(path: string, optionsOrSettings?: Options | Settings): Promise; +} +declare function scandirSync(path: string, optionsOrSettings?: Options | Settings): Entry[]; +export { scandir, scandirSync, Settings, AsyncCallback, Dirent, Entry, FileSystemAdapter, ReaddirAsynchronousMethod, ReaddirSynchronousMethod, Options }; diff --git a/node_modules/@nodelib/fs.scandir/out/index.js b/node_modules/@nodelib/fs.scandir/out/index.js new file mode 100644 index 0000000..99c70d3 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/index.js @@ -0,0 +1,26 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.Settings = exports.scandirSync = exports.scandir = void 0; +const async = require("./providers/async"); +const sync = require("./providers/sync"); +const settings_1 = require("./settings"); +exports.Settings = settings_1.default; +function scandir(path, optionsOrSettingsOrCallback, callback) { + if (typeof optionsOrSettingsOrCallback === 'function') { + async.read(path, getSettings(), optionsOrSettingsOrCallback); + return; + } + async.read(path, getSettings(optionsOrSettingsOrCallback), callback); +} +exports.scandir = scandir; +function scandirSync(path, optionsOrSettings) { + const settings = getSettings(optionsOrSettings); + return sync.read(path, settings); +} +exports.scandirSync = scandirSync; +function getSettings(settingsOrOptions = {}) { + if (settingsOrOptions instanceof settings_1.default) { + return settingsOrOptions; + } + return new settings_1.default(settingsOrOptions); +} diff --git a/node_modules/@nodelib/fs.scandir/out/providers/async.d.ts b/node_modules/@nodelib/fs.scandir/out/providers/async.d.ts new file mode 100644 index 0000000..5829676 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/async.d.ts @@ -0,0 +1,7 @@ +/// +import type Settings from '../settings'; +import type { Entry } from '../types'; +export declare type AsyncCallback = (error: NodeJS.ErrnoException, entries: Entry[]) => void; +export declare function read(directory: string, settings: Settings, callback: AsyncCallback): void; +export declare function readdirWithFileTypes(directory: string, settings: Settings, callback: AsyncCallback): void; +export declare function readdir(directory: string, settings: Settings, callback: AsyncCallback): void; diff --git a/node_modules/@nodelib/fs.scandir/out/providers/async.js b/node_modules/@nodelib/fs.scandir/out/providers/async.js new file mode 100644 index 0000000..e8e2f0a --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/async.js @@ -0,0 +1,104 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.readdir = exports.readdirWithFileTypes = exports.read = void 0; +const fsStat = require("@nodelib/fs.stat"); +const rpl = require("run-parallel"); +const constants_1 = require("../constants"); +const utils = require("../utils"); +const common = require("./common"); +function read(directory, settings, callback) { + if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) { + readdirWithFileTypes(directory, settings, callback); + return; + } + readdir(directory, settings, callback); +} +exports.read = read; +function readdirWithFileTypes(directory, settings, callback) { + settings.fs.readdir(directory, { withFileTypes: true }, (readdirError, dirents) => { + if (readdirError !== null) { + callFailureCallback(callback, readdirError); + return; + } + const entries = dirents.map((dirent) => ({ + dirent, + name: dirent.name, + path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator) + })); + if (!settings.followSymbolicLinks) { + callSuccessCallback(callback, entries); + return; + } + const tasks = entries.map((entry) => makeRplTaskEntry(entry, settings)); + rpl(tasks, (rplError, rplEntries) => { + if (rplError !== null) { + callFailureCallback(callback, rplError); + return; + } + callSuccessCallback(callback, rplEntries); + }); + }); +} +exports.readdirWithFileTypes = readdirWithFileTypes; +function makeRplTaskEntry(entry, settings) { + return (done) => { + if (!entry.dirent.isSymbolicLink()) { + done(null, entry); + return; + } + settings.fs.stat(entry.path, (statError, stats) => { + if (statError !== null) { + if (settings.throwErrorOnBrokenSymbolicLink) { + done(statError); + return; + } + done(null, entry); + return; + } + entry.dirent = utils.fs.createDirentFromStats(entry.name, stats); + done(null, entry); + }); + }; +} +function readdir(directory, settings, callback) { + settings.fs.readdir(directory, (readdirError, names) => { + if (readdirError !== null) { + callFailureCallback(callback, readdirError); + return; + } + const tasks = names.map((name) => { + const path = common.joinPathSegments(directory, name, settings.pathSegmentSeparator); + return (done) => { + fsStat.stat(path, settings.fsStatSettings, (error, stats) => { + if (error !== null) { + done(error); + return; + } + const entry = { + name, + path, + dirent: utils.fs.createDirentFromStats(name, stats) + }; + if (settings.stats) { + entry.stats = stats; + } + done(null, entry); + }); + }; + }); + rpl(tasks, (rplError, entries) => { + if (rplError !== null) { + callFailureCallback(callback, rplError); + return; + } + callSuccessCallback(callback, entries); + }); + }); +} +exports.readdir = readdir; +function callFailureCallback(callback, error) { + callback(error); +} +function callSuccessCallback(callback, result) { + callback(null, result); +} diff --git a/node_modules/@nodelib/fs.scandir/out/providers/common.d.ts b/node_modules/@nodelib/fs.scandir/out/providers/common.d.ts new file mode 100644 index 0000000..2b4d08b --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/common.d.ts @@ -0,0 +1 @@ +export declare function joinPathSegments(a: string, b: string, separator: string): string; diff --git a/node_modules/@nodelib/fs.scandir/out/providers/common.js b/node_modules/@nodelib/fs.scandir/out/providers/common.js new file mode 100644 index 0000000..8724cb5 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/common.js @@ -0,0 +1,13 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.joinPathSegments = void 0; +function joinPathSegments(a, b, separator) { + /** + * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`). + */ + if (a.endsWith(separator)) { + return a + b; + } + return a + separator + b; +} +exports.joinPathSegments = joinPathSegments; diff --git a/node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts b/node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts new file mode 100644 index 0000000..e05c8f0 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts @@ -0,0 +1,5 @@ +import type Settings from '../settings'; +import type { Entry } from '../types'; +export declare function read(directory: string, settings: Settings): Entry[]; +export declare function readdirWithFileTypes(directory: string, settings: Settings): Entry[]; +export declare function readdir(directory: string, settings: Settings): Entry[]; diff --git a/node_modules/@nodelib/fs.scandir/out/providers/sync.js b/node_modules/@nodelib/fs.scandir/out/providers/sync.js new file mode 100644 index 0000000..146db34 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/providers/sync.js @@ -0,0 +1,54 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.readdir = exports.readdirWithFileTypes = exports.read = void 0; +const fsStat = require("@nodelib/fs.stat"); +const constants_1 = require("../constants"); +const utils = require("../utils"); +const common = require("./common"); +function read(directory, settings) { + if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) { + return readdirWithFileTypes(directory, settings); + } + return readdir(directory, settings); +} +exports.read = read; +function readdirWithFileTypes(directory, settings) { + const dirents = settings.fs.readdirSync(directory, { withFileTypes: true }); + return dirents.map((dirent) => { + const entry = { + dirent, + name: dirent.name, + path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator) + }; + if (entry.dirent.isSymbolicLink() && settings.followSymbolicLinks) { + try { + const stats = settings.fs.statSync(entry.path); + entry.dirent = utils.fs.createDirentFromStats(entry.name, stats); + } + catch (error) { + if (settings.throwErrorOnBrokenSymbolicLink) { + throw error; + } + } + } + return entry; + }); +} +exports.readdirWithFileTypes = readdirWithFileTypes; +function readdir(directory, settings) { + const names = settings.fs.readdirSync(directory); + return names.map((name) => { + const entryPath = common.joinPathSegments(directory, name, settings.pathSegmentSeparator); + const stats = fsStat.statSync(entryPath, settings.fsStatSettings); + const entry = { + name, + path: entryPath, + dirent: utils.fs.createDirentFromStats(name, stats) + }; + if (settings.stats) { + entry.stats = stats; + } + return entry; + }); +} +exports.readdir = readdir; diff --git a/node_modules/@nodelib/fs.scandir/out/settings.d.ts b/node_modules/@nodelib/fs.scandir/out/settings.d.ts new file mode 100644 index 0000000..a0db115 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/settings.d.ts @@ -0,0 +1,20 @@ +import * as fsStat from '@nodelib/fs.stat'; +import * as fs from './adapters/fs'; +export interface Options { + followSymbolicLinks?: boolean; + fs?: Partial; + pathSegmentSeparator?: string; + stats?: boolean; + throwErrorOnBrokenSymbolicLink?: boolean; +} +export default class Settings { + private readonly _options; + readonly followSymbolicLinks: boolean; + readonly fs: fs.FileSystemAdapter; + readonly pathSegmentSeparator: string; + readonly stats: boolean; + readonly throwErrorOnBrokenSymbolicLink: boolean; + readonly fsStatSettings: fsStat.Settings; + constructor(_options?: Options); + private _getValue; +} diff --git a/node_modules/@nodelib/fs.scandir/out/settings.js b/node_modules/@nodelib/fs.scandir/out/settings.js new file mode 100644 index 0000000..15a3e8c --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/settings.js @@ -0,0 +1,24 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const path = require("path"); +const fsStat = require("@nodelib/fs.stat"); +const fs = require("./adapters/fs"); +class Settings { + constructor(_options = {}) { + this._options = _options; + this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false); + this.fs = fs.createFileSystemAdapter(this._options.fs); + this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep); + this.stats = this._getValue(this._options.stats, false); + this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true); + this.fsStatSettings = new fsStat.Settings({ + followSymbolicLink: this.followSymbolicLinks, + fs: this.fs, + throwErrorOnBrokenSymbolicLink: this.throwErrorOnBrokenSymbolicLink + }); + } + _getValue(option, value) { + return option !== null && option !== void 0 ? option : value; + } +} +exports.default = Settings; diff --git a/node_modules/@nodelib/fs.scandir/out/types/index.d.ts b/node_modules/@nodelib/fs.scandir/out/types/index.d.ts new file mode 100644 index 0000000..f326c5e --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/types/index.d.ts @@ -0,0 +1,20 @@ +/// +import type * as fs from 'fs'; +export interface Entry { + dirent: Dirent; + name: string; + path: string; + stats?: Stats; +} +export declare type Stats = fs.Stats; +export declare type ErrnoException = NodeJS.ErrnoException; +export interface Dirent { + isBlockDevice: () => boolean; + isCharacterDevice: () => boolean; + isDirectory: () => boolean; + isFIFO: () => boolean; + isFile: () => boolean; + isSocket: () => boolean; + isSymbolicLink: () => boolean; + name: string; +} diff --git a/node_modules/@nodelib/fs.scandir/out/types/index.js b/node_modules/@nodelib/fs.scandir/out/types/index.js new file mode 100644 index 0000000..c8ad2e5 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/types/index.js @@ -0,0 +1,2 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); diff --git a/node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts b/node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts new file mode 100644 index 0000000..bb863f1 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts @@ -0,0 +1,2 @@ +import type { Dirent, Stats } from '../types'; +export declare function createDirentFromStats(name: string, stats: Stats): Dirent; diff --git a/node_modules/@nodelib/fs.scandir/out/utils/fs.js b/node_modules/@nodelib/fs.scandir/out/utils/fs.js new file mode 100644 index 0000000..ace7c74 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/utils/fs.js @@ -0,0 +1,19 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.createDirentFromStats = void 0; +class DirentFromStats { + constructor(name, stats) { + this.name = name; + this.isBlockDevice = stats.isBlockDevice.bind(stats); + this.isCharacterDevice = stats.isCharacterDevice.bind(stats); + this.isDirectory = stats.isDirectory.bind(stats); + this.isFIFO = stats.isFIFO.bind(stats); + this.isFile = stats.isFile.bind(stats); + this.isSocket = stats.isSocket.bind(stats); + this.isSymbolicLink = stats.isSymbolicLink.bind(stats); + } +} +function createDirentFromStats(name, stats) { + return new DirentFromStats(name, stats); +} +exports.createDirentFromStats = createDirentFromStats; diff --git a/node_modules/@nodelib/fs.scandir/out/utils/index.d.ts b/node_modules/@nodelib/fs.scandir/out/utils/index.d.ts new file mode 100644 index 0000000..1b41954 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/utils/index.d.ts @@ -0,0 +1,2 @@ +import * as fs from './fs'; +export { fs }; diff --git a/node_modules/@nodelib/fs.scandir/out/utils/index.js b/node_modules/@nodelib/fs.scandir/out/utils/index.js new file mode 100644 index 0000000..f5de129 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/out/utils/index.js @@ -0,0 +1,5 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.fs = void 0; +const fs = require("./fs"); +exports.fs = fs; diff --git a/node_modules/@nodelib/fs.scandir/package.json b/node_modules/@nodelib/fs.scandir/package.json new file mode 100644 index 0000000..d3a8924 --- /dev/null +++ b/node_modules/@nodelib/fs.scandir/package.json @@ -0,0 +1,44 @@ +{ + "name": "@nodelib/fs.scandir", + "version": "2.1.5", + "description": "List files and directories inside the specified directory", + "license": "MIT", + "repository": "https://github.com/nodelib/nodelib/tree/master/packages/fs/fs.scandir", + "keywords": [ + "NodeLib", + "fs", + "FileSystem", + "file system", + "scandir", + "readdir", + "dirent" + ], + "engines": { + "node": ">= 8" + }, + "files": [ + "out/**", + "!out/**/*.map", + "!out/**/*.spec.*" + ], + "main": "out/index.js", + "typings": "out/index.d.ts", + "scripts": { + "clean": "rimraf {tsconfig.tsbuildinfo,out}", + "lint": "eslint \"src/**/*.ts\" --cache", + "compile": "tsc -b .", + "compile:watch": "tsc -p . --watch --sourceMap", + "test": "mocha \"out/**/*.spec.js\" -s 0", + "build": "npm run clean && npm run compile && npm run lint && npm test", + "watch": "npm run clean && npm run compile:watch" + }, + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "devDependencies": { + "@nodelib/fs.macchiato": "1.0.4", + "@types/run-parallel": "^1.1.0" + }, + "gitHead": "d6a7960d5281d3dd5f8e2efba49bb552d090f562" +} diff --git a/node_modules/@nodelib/fs.stat/LICENSE b/node_modules/@nodelib/fs.stat/LICENSE new file mode 100644 index 0000000..65a9994 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Denis Malinochkin + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/@nodelib/fs.stat/README.md b/node_modules/@nodelib/fs.stat/README.md new file mode 100644 index 0000000..686f047 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/README.md @@ -0,0 +1,126 @@ +# @nodelib/fs.stat + +> Get the status of a file with some features. + +## :bulb: Highlights + +Wrapper around standard method `fs.lstat` and `fs.stat` with some features. + +* :beginner: Normally follows symbolic link. +* :gear: Can safely work with broken symbolic link. + +## Install + +```console +npm install @nodelib/fs.stat +``` + +## Usage + +```ts +import * as fsStat from '@nodelib/fs.stat'; + +fsStat.stat('path', (error, stats) => { /* … */ }); +``` + +## API + +### .stat(path, [optionsOrSettings], callback) + +Returns an instance of `fs.Stats` class for provided path with standard callback-style. + +```ts +fsStat.stat('path', (error, stats) => { /* … */ }); +fsStat.stat('path', {}, (error, stats) => { /* … */ }); +fsStat.stat('path', new fsStat.Settings(), (error, stats) => { /* … */ }); +``` + +### .statSync(path, [optionsOrSettings]) + +Returns an instance of `fs.Stats` class for provided path. + +```ts +const stats = fsStat.stat('path'); +const stats = fsStat.stat('path', {}); +const stats = fsStat.stat('path', new fsStat.Settings()); +``` + +#### path + +* Required: `true` +* Type: `string | Buffer | URL` + +A path to a file. If a URL is provided, it must use the `file:` protocol. + +#### optionsOrSettings + +* Required: `false` +* Type: `Options | Settings` +* Default: An instance of `Settings` class + +An [`Options`](#options) object or an instance of [`Settings`](#settings) class. + +> :book: When you pass a plain object, an instance of the `Settings` class will be created automatically. If you plan to call the method frequently, use a pre-created instance of the `Settings` class. + +### Settings([options]) + +A class of full settings of the package. + +```ts +const settings = new fsStat.Settings({ followSymbolicLink: false }); + +const stats = fsStat.stat('path', settings); +``` + +## Options + +### `followSymbolicLink` + +* Type: `boolean` +* Default: `true` + +Follow symbolic link or not. Call `fs.stat` on symbolic link if `true`. + +### `markSymbolicLink` + +* Type: `boolean` +* Default: `false` + +Mark symbolic link by setting the return value of `isSymbolicLink` function to always `true` (even after `fs.stat`). + +> :book: Can be used if you want to know what is hidden behind a symbolic link, but still continue to know that it is a symbolic link. + +### `throwErrorOnBrokenSymbolicLink` + +* Type: `boolean` +* Default: `true` + +Throw an error when symbolic link is broken if `true` or safely return `lstat` call if `false`. + +### `fs` + +* Type: [`FileSystemAdapter`](./src/adapters/fs.ts) +* Default: A default FS methods + +By default, the built-in Node.js module (`fs`) is used to work with the file system. You can replace any method with your own. + +```ts +interface FileSystemAdapter { + lstat?: typeof fs.lstat; + stat?: typeof fs.stat; + lstatSync?: typeof fs.lstatSync; + statSync?: typeof fs.statSync; +} + +const settings = new fsStat.Settings({ + fs: { lstat: fakeLstat } +}); +``` + +## Changelog + +See the [Releases section of our GitHub project](https://github.com/nodelib/nodelib/releases) for changelog for each release version. + +## License + +This software is released under the terms of the MIT license. diff --git a/node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts b/node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts new file mode 100644 index 0000000..3af759c --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts @@ -0,0 +1,13 @@ +/// +import * as fs from 'fs'; +import type { ErrnoException } from '../types'; +export declare type StatAsynchronousMethod = (path: string, callback: (error: ErrnoException | null, stats: fs.Stats) => void) => void; +export declare type StatSynchronousMethod = (path: string) => fs.Stats; +export interface FileSystemAdapter { + lstat: StatAsynchronousMethod; + stat: StatAsynchronousMethod; + lstatSync: StatSynchronousMethod; + statSync: StatSynchronousMethod; +} +export declare const FILE_SYSTEM_ADAPTER: FileSystemAdapter; +export declare function createFileSystemAdapter(fsMethods?: Partial): FileSystemAdapter; diff --git a/node_modules/@nodelib/fs.stat/out/adapters/fs.js b/node_modules/@nodelib/fs.stat/out/adapters/fs.js new file mode 100644 index 0000000..8dc08c8 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/adapters/fs.js @@ -0,0 +1,17 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0; +const fs = require("fs"); +exports.FILE_SYSTEM_ADAPTER = { + lstat: fs.lstat, + stat: fs.stat, + lstatSync: fs.lstatSync, + statSync: fs.statSync +}; +function createFileSystemAdapter(fsMethods) { + if (fsMethods === undefined) { + return exports.FILE_SYSTEM_ADAPTER; + } + return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods); +} +exports.createFileSystemAdapter = createFileSystemAdapter; diff --git a/node_modules/@nodelib/fs.stat/out/index.d.ts b/node_modules/@nodelib/fs.stat/out/index.d.ts new file mode 100644 index 0000000..f95db99 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/index.d.ts @@ -0,0 +1,12 @@ +import type { FileSystemAdapter, StatAsynchronousMethod, StatSynchronousMethod } from './adapters/fs'; +import * as async from './providers/async'; +import Settings, { Options } from './settings'; +import type { Stats } from './types'; +declare type AsyncCallback = async.AsyncCallback; +declare function stat(path: string, callback: AsyncCallback): void; +declare function stat(path: string, optionsOrSettings: Options | Settings, callback: AsyncCallback): void; +declare namespace stat { + function __promisify__(path: string, optionsOrSettings?: Options | Settings): Promise; +} +declare function statSync(path: string, optionsOrSettings?: Options | Settings): Stats; +export { Settings, stat, statSync, AsyncCallback, FileSystemAdapter, StatAsynchronousMethod, StatSynchronousMethod, Options, Stats }; diff --git a/node_modules/@nodelib/fs.stat/out/index.js b/node_modules/@nodelib/fs.stat/out/index.js new file mode 100644 index 0000000..b23f751 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/index.js @@ -0,0 +1,26 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.statSync = exports.stat = exports.Settings = void 0; +const async = require("./providers/async"); +const sync = require("./providers/sync"); +const settings_1 = require("./settings"); +exports.Settings = settings_1.default; +function stat(path, optionsOrSettingsOrCallback, callback) { + if (typeof optionsOrSettingsOrCallback === 'function') { + async.read(path, getSettings(), optionsOrSettingsOrCallback); + return; + } + async.read(path, getSettings(optionsOrSettingsOrCallback), callback); +} +exports.stat = stat; +function statSync(path, optionsOrSettings) { + const settings = getSettings(optionsOrSettings); + return sync.read(path, settings); +} +exports.statSync = statSync; +function getSettings(settingsOrOptions = {}) { + if (settingsOrOptions instanceof settings_1.default) { + return settingsOrOptions; + } + return new settings_1.default(settingsOrOptions); +} diff --git a/node_modules/@nodelib/fs.stat/out/providers/async.d.ts b/node_modules/@nodelib/fs.stat/out/providers/async.d.ts new file mode 100644 index 0000000..85423ce --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/providers/async.d.ts @@ -0,0 +1,4 @@ +import type Settings from '../settings'; +import type { ErrnoException, Stats } from '../types'; +export declare type AsyncCallback = (error: ErrnoException, stats: Stats) => void; +export declare function read(path: string, settings: Settings, callback: AsyncCallback): void; diff --git a/node_modules/@nodelib/fs.stat/out/providers/async.js b/node_modules/@nodelib/fs.stat/out/providers/async.js new file mode 100644 index 0000000..983ff0e --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/providers/async.js @@ -0,0 +1,36 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.read = void 0; +function read(path, settings, callback) { + settings.fs.lstat(path, (lstatError, lstat) => { + if (lstatError !== null) { + callFailureCallback(callback, lstatError); + return; + } + if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) { + callSuccessCallback(callback, lstat); + return; + } + settings.fs.stat(path, (statError, stat) => { + if (statError !== null) { + if (settings.throwErrorOnBrokenSymbolicLink) { + callFailureCallback(callback, statError); + return; + } + callSuccessCallback(callback, lstat); + return; + } + if (settings.markSymbolicLink) { + stat.isSymbolicLink = () => true; + } + callSuccessCallback(callback, stat); + }); + }); +} +exports.read = read; +function callFailureCallback(callback, error) { + callback(error); +} +function callSuccessCallback(callback, result) { + callback(null, result); +} diff --git a/node_modules/@nodelib/fs.stat/out/providers/sync.d.ts b/node_modules/@nodelib/fs.stat/out/providers/sync.d.ts new file mode 100644 index 0000000..428c3d7 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/providers/sync.d.ts @@ -0,0 +1,3 @@ +import type Settings from '../settings'; +import type { Stats } from '../types'; +export declare function read(path: string, settings: Settings): Stats; diff --git a/node_modules/@nodelib/fs.stat/out/providers/sync.js b/node_modules/@nodelib/fs.stat/out/providers/sync.js new file mode 100644 index 0000000..1521c36 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/providers/sync.js @@ -0,0 +1,23 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.read = void 0; +function read(path, settings) { + const lstat = settings.fs.lstatSync(path); + if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) { + return lstat; + } + try { + const stat = settings.fs.statSync(path); + if (settings.markSymbolicLink) { + stat.isSymbolicLink = () => true; + } + return stat; + } + catch (error) { + if (!settings.throwErrorOnBrokenSymbolicLink) { + return lstat; + } + throw error; + } +} +exports.read = read; diff --git a/node_modules/@nodelib/fs.stat/out/settings.d.ts b/node_modules/@nodelib/fs.stat/out/settings.d.ts new file mode 100644 index 0000000..f4b3d44 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/settings.d.ts @@ -0,0 +1,16 @@ +import * as fs from './adapters/fs'; +export interface Options { + followSymbolicLink?: boolean; + fs?: Partial; + markSymbolicLink?: boolean; + throwErrorOnBrokenSymbolicLink?: boolean; +} +export default class Settings { + private readonly _options; + readonly followSymbolicLink: boolean; + readonly fs: fs.FileSystemAdapter; + readonly markSymbolicLink: boolean; + readonly throwErrorOnBrokenSymbolicLink: boolean; + constructor(_options?: Options); + private _getValue; +} diff --git a/node_modules/@nodelib/fs.stat/out/settings.js b/node_modules/@nodelib/fs.stat/out/settings.js new file mode 100644 index 0000000..111ec09 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/settings.js @@ -0,0 +1,16 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const fs = require("./adapters/fs"); +class Settings { + constructor(_options = {}) { + this._options = _options; + this.followSymbolicLink = this._getValue(this._options.followSymbolicLink, true); + this.fs = fs.createFileSystemAdapter(this._options.fs); + this.markSymbolicLink = this._getValue(this._options.markSymbolicLink, false); + this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true); + } + _getValue(option, value) { + return option !== null && option !== void 0 ? option : value; + } +} +exports.default = Settings; diff --git a/node_modules/@nodelib/fs.stat/out/types/index.d.ts b/node_modules/@nodelib/fs.stat/out/types/index.d.ts new file mode 100644 index 0000000..74c08ed --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/types/index.d.ts @@ -0,0 +1,4 @@ +/// +import type * as fs from 'fs'; +export declare type Stats = fs.Stats; +export declare type ErrnoException = NodeJS.ErrnoException; diff --git a/node_modules/@nodelib/fs.stat/out/types/index.js b/node_modules/@nodelib/fs.stat/out/types/index.js new file mode 100644 index 0000000..c8ad2e5 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/out/types/index.js @@ -0,0 +1,2 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); diff --git a/node_modules/@nodelib/fs.stat/package.json b/node_modules/@nodelib/fs.stat/package.json new file mode 100644 index 0000000..f2540c2 --- /dev/null +++ b/node_modules/@nodelib/fs.stat/package.json @@ -0,0 +1,37 @@ +{ + "name": "@nodelib/fs.stat", + "version": "2.0.5", + "description": "Get the status of a file with some features", + "license": "MIT", + "repository": "https://github.com/nodelib/nodelib/tree/master/packages/fs/fs.stat", + "keywords": [ + "NodeLib", + "fs", + "FileSystem", + "file system", + "stat" + ], + "engines": { + "node": ">= 8" + }, + "files": [ + "out/**", + "!out/**/*.map", + "!out/**/*.spec.*" + ], + "main": "out/index.js", + "typings": "out/index.d.ts", + "scripts": { + "clean": "rimraf {tsconfig.tsbuildinfo,out}", + "lint": "eslint \"src/**/*.ts\" --cache", + "compile": "tsc -b .", + "compile:watch": "tsc -p . --watch --sourceMap", + "test": "mocha \"out/**/*.spec.js\" -s 0", + "build": "npm run clean && npm run compile && npm run lint && npm test", + "watch": "npm run clean && npm run compile:watch" + }, + "devDependencies": { + "@nodelib/fs.macchiato": "1.0.4" + }, + "gitHead": "d6a7960d5281d3dd5f8e2efba49bb552d090f562" +} diff --git a/node_modules/@nodelib/fs.walk/LICENSE b/node_modules/@nodelib/fs.walk/LICENSE new file mode 100644 index 0000000..65a9994 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Denis Malinochkin + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/@nodelib/fs.walk/README.md b/node_modules/@nodelib/fs.walk/README.md new file mode 100644 index 0000000..6ccc08d --- /dev/null +++ b/node_modules/@nodelib/fs.walk/README.md @@ -0,0 +1,215 @@ +# @nodelib/fs.walk + +> A library for efficiently walking a directory recursively. + +## :bulb: Highlights + +* :moneybag: Returns useful information: `name`, `path`, `dirent` and `stats` (optional). +* :rocket: On Node.js 10.10+ uses the mechanism without additional calls to determine the entry type for performance reasons. See [`old` and `modern` mode](https://github.com/nodelib/nodelib/blob/master/packages/fs/fs.scandir/README.md#old-and-modern-mode). +* :gear: Built-in directories/files and error filtering system. +* :link: Can safely work with broken symbolic links. + +## Install + +```console +npm install @nodelib/fs.walk +``` + +## Usage + +```ts +import * as fsWalk from '@nodelib/fs.walk'; + +fsWalk.walk('path', (error, entries) => { /* … */ }); +``` + +## API + +### .walk(path, [optionsOrSettings], callback) + +Reads the directory recursively and asynchronously. Requires a callback function. + +> :book: If you want to use the Promise API, use `util.promisify`. + +```ts +fsWalk.walk('path', (error, entries) => { /* … */ }); +fsWalk.walk('path', {}, (error, entries) => { /* … */ }); +fsWalk.walk('path', new fsWalk.Settings(), (error, entries) => { /* … */ }); +``` + +### .walkStream(path, [optionsOrSettings]) + +Reads the directory recursively and asynchronously. [Readable Stream](https://nodejs.org/dist/latest-v12.x/docs/api/stream.html#stream_readable_streams) is used as a provider. + +```ts +const stream = fsWalk.walkStream('path'); +const stream = fsWalk.walkStream('path', {}); +const stream = fsWalk.walkStream('path', new fsWalk.Settings()); +``` + +### .walkSync(path, [optionsOrSettings]) + +Reads the directory recursively and synchronously. Returns an array of entries. + +```ts +const entries = fsWalk.walkSync('path'); +const entries = fsWalk.walkSync('path', {}); +const entries = fsWalk.walkSync('path', new fsWalk.Settings()); +``` + +#### path + +* Required: `true` +* Type: `string | Buffer | URL` + +A path to a file. If a URL is provided, it must use the `file:` protocol. + +#### optionsOrSettings + +* Required: `false` +* Type: `Options | Settings` +* Default: An instance of `Settings` class + +An [`Options`](#options) object or an instance of [`Settings`](#settings) class. + +> :book: When you pass a plain object, an instance of the `Settings` class will be created automatically. If you plan to call the method frequently, use a pre-created instance of the `Settings` class. + +### Settings([options]) + +A class of full settings of the package. + +```ts +const settings = new fsWalk.Settings({ followSymbolicLinks: true }); + +const entries = fsWalk.walkSync('path', settings); +``` + +## Entry + +* `name` — The name of the entry (`unknown.txt`). +* `path` — The path of the entry relative to call directory (`root/unknown.txt`). +* `dirent` — An instance of [`fs.Dirent`](./src/types/index.ts) class. +* [`stats`] — An instance of `fs.Stats` class. + +## Options + +### basePath + +* Type: `string` +* Default: `undefined` + +By default, all paths are built relative to the root path. You can use this option to set custom root path. + +In the example below we read the files from the `root` directory, but in the results the root path will be `custom`. + +```ts +fsWalk.walkSync('root'); // → ['root/file.txt'] +fsWalk.walkSync('root', { basePath: 'custom' }); // → ['custom/file.txt'] +``` + +### concurrency + +* Type: `number` +* Default: `Infinity` + +The maximum number of concurrent calls to `fs.readdir`. + +> :book: The higher the number, the higher performance and the load on the File System. If you want to read in quiet mode, set the value to `4 * os.cpus().length` (4 is default size of [thread pool work scheduling](http://docs.libuv.org/en/v1.x/threadpool.html#thread-pool-work-scheduling)). + +### deepFilter + +* Type: [`DeepFilterFunction`](./src/settings.ts) +* Default: `undefined` + +A function that indicates whether the directory will be read deep or not. + +```ts +// Skip all directories that starts with `node_modules` +const filter: DeepFilterFunction = (entry) => !entry.path.startsWith('node_modules'); +``` + +### entryFilter + +* Type: [`EntryFilterFunction`](./src/settings.ts) +* Default: `undefined` + +A function that indicates whether the entry will be included to results or not. + +```ts +// Exclude all `.js` files from results +const filter: EntryFilterFunction = (entry) => !entry.name.endsWith('.js'); +``` + +### errorFilter + +* Type: [`ErrorFilterFunction`](./src/settings.ts) +* Default: `undefined` + +A function that allows you to skip errors that occur when reading directories. + +For example, you can skip `ENOENT` errors if required: + +```ts +// Skip all ENOENT errors +const filter: ErrorFilterFunction = (error) => error.code == 'ENOENT'; +``` + +### stats + +* Type: `boolean` +* Default: `false` + +Adds an instance of `fs.Stats` class to the [`Entry`](#entry). + +> :book: Always use `fs.readdir` with additional `fs.lstat/fs.stat` calls to determine the entry type. + +### followSymbolicLinks + +* Type: `boolean` +* Default: `false` + +Follow symbolic links or not. Call `fs.stat` on symbolic link if `true`. + +### `throwErrorOnBrokenSymbolicLink` + +* Type: `boolean` +* Default: `true` + +Throw an error when symbolic link is broken if `true` or safely return `lstat` call if `false`. + +### `pathSegmentSeparator` + +* Type: `string` +* Default: `path.sep` + +By default, this package uses the correct path separator for your OS (`\` on Windows, `/` on Unix-like systems). But you can set this option to any separator character(s) that you want to use instead. + +### `fs` + +* Type: `FileSystemAdapter` +* Default: A default FS methods + +By default, the built-in Node.js module (`fs`) is used to work with the file system. You can replace any method with your own. + +```ts +interface FileSystemAdapter { + lstat: typeof fs.lstat; + stat: typeof fs.stat; + lstatSync: typeof fs.lstatSync; + statSync: typeof fs.statSync; + readdir: typeof fs.readdir; + readdirSync: typeof fs.readdirSync; +} + +const settings = new fsWalk.Settings({ + fs: { lstat: fakeLstat } +}); +``` + +## Changelog + +See the [Releases section of our GitHub project](https://github.com/nodelib/nodelib/releases) for changelog for each release version. + +## License + +This software is released under the terms of the MIT license. diff --git a/node_modules/@nodelib/fs.walk/out/index.d.ts b/node_modules/@nodelib/fs.walk/out/index.d.ts new file mode 100644 index 0000000..8864c7b --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/index.d.ts @@ -0,0 +1,14 @@ +/// +import type { Readable } from 'stream'; +import type { Dirent, FileSystemAdapter } from '@nodelib/fs.scandir'; +import { AsyncCallback } from './providers/async'; +import Settings, { DeepFilterFunction, EntryFilterFunction, ErrorFilterFunction, Options } from './settings'; +import type { Entry } from './types'; +declare function walk(directory: string, callback: AsyncCallback): void; +declare function walk(directory: string, optionsOrSettings: Options | Settings, callback: AsyncCallback): void; +declare namespace walk { + function __promisify__(directory: string, optionsOrSettings?: Options | Settings): Promise; +} +declare function walkSync(directory: string, optionsOrSettings?: Options | Settings): Entry[]; +declare function walkStream(directory: string, optionsOrSettings?: Options | Settings): Readable; +export { walk, walkSync, walkStream, Settings, AsyncCallback, Dirent, Entry, FileSystemAdapter, Options, DeepFilterFunction, EntryFilterFunction, ErrorFilterFunction }; diff --git a/node_modules/@nodelib/fs.walk/out/index.js b/node_modules/@nodelib/fs.walk/out/index.js new file mode 100644 index 0000000..1520787 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/index.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.Settings = exports.walkStream = exports.walkSync = exports.walk = void 0; +const async_1 = require("./providers/async"); +const stream_1 = require("./providers/stream"); +const sync_1 = require("./providers/sync"); +const settings_1 = require("./settings"); +exports.Settings = settings_1.default; +function walk(directory, optionsOrSettingsOrCallback, callback) { + if (typeof optionsOrSettingsOrCallback === 'function') { + new async_1.default(directory, getSettings()).read(optionsOrSettingsOrCallback); + return; + } + new async_1.default(directory, getSettings(optionsOrSettingsOrCallback)).read(callback); +} +exports.walk = walk; +function walkSync(directory, optionsOrSettings) { + const settings = getSettings(optionsOrSettings); + const provider = new sync_1.default(directory, settings); + return provider.read(); +} +exports.walkSync = walkSync; +function walkStream(directory, optionsOrSettings) { + const settings = getSettings(optionsOrSettings); + const provider = new stream_1.default(directory, settings); + return provider.read(); +} +exports.walkStream = walkStream; +function getSettings(settingsOrOptions = {}) { + if (settingsOrOptions instanceof settings_1.default) { + return settingsOrOptions; + } + return new settings_1.default(settingsOrOptions); +} diff --git a/node_modules/@nodelib/fs.walk/out/providers/async.d.ts b/node_modules/@nodelib/fs.walk/out/providers/async.d.ts new file mode 100644 index 0000000..0f6717d --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/async.d.ts @@ -0,0 +1,12 @@ +import AsyncReader from '../readers/async'; +import type Settings from '../settings'; +import type { Entry, Errno } from '../types'; +export declare type AsyncCallback = (error: Errno, entries: Entry[]) => void; +export default class AsyncProvider { + private readonly _root; + private readonly _settings; + protected readonly _reader: AsyncReader; + private readonly _storage; + constructor(_root: string, _settings: Settings); + read(callback: AsyncCallback): void; +} diff --git a/node_modules/@nodelib/fs.walk/out/providers/async.js b/node_modules/@nodelib/fs.walk/out/providers/async.js new file mode 100644 index 0000000..51d3be5 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/async.js @@ -0,0 +1,30 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const async_1 = require("../readers/async"); +class AsyncProvider { + constructor(_root, _settings) { + this._root = _root; + this._settings = _settings; + this._reader = new async_1.default(this._root, this._settings); + this._storage = []; + } + read(callback) { + this._reader.onError((error) => { + callFailureCallback(callback, error); + }); + this._reader.onEntry((entry) => { + this._storage.push(entry); + }); + this._reader.onEnd(() => { + callSuccessCallback(callback, this._storage); + }); + this._reader.read(); + } +} +exports.default = AsyncProvider; +function callFailureCallback(callback, error) { + callback(error); +} +function callSuccessCallback(callback, entries) { + callback(null, entries); +} diff --git a/node_modules/@nodelib/fs.walk/out/providers/index.d.ts b/node_modules/@nodelib/fs.walk/out/providers/index.d.ts new file mode 100644 index 0000000..874f60c --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/index.d.ts @@ -0,0 +1,4 @@ +import AsyncProvider from './async'; +import StreamProvider from './stream'; +import SyncProvider from './sync'; +export { AsyncProvider, StreamProvider, SyncProvider }; diff --git a/node_modules/@nodelib/fs.walk/out/providers/index.js b/node_modules/@nodelib/fs.walk/out/providers/index.js new file mode 100644 index 0000000..4c2529c --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/index.js @@ -0,0 +1,9 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.SyncProvider = exports.StreamProvider = exports.AsyncProvider = void 0; +const async_1 = require("./async"); +exports.AsyncProvider = async_1.default; +const stream_1 = require("./stream"); +exports.StreamProvider = stream_1.default; +const sync_1 = require("./sync"); +exports.SyncProvider = sync_1.default; diff --git a/node_modules/@nodelib/fs.walk/out/providers/stream.d.ts b/node_modules/@nodelib/fs.walk/out/providers/stream.d.ts new file mode 100644 index 0000000..294185f --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/stream.d.ts @@ -0,0 +1,12 @@ +/// +import { Readable } from 'stream'; +import AsyncReader from '../readers/async'; +import type Settings from '../settings'; +export default class StreamProvider { + private readonly _root; + private readonly _settings; + protected readonly _reader: AsyncReader; + protected readonly _stream: Readable; + constructor(_root: string, _settings: Settings); + read(): Readable; +} diff --git a/node_modules/@nodelib/fs.walk/out/providers/stream.js b/node_modules/@nodelib/fs.walk/out/providers/stream.js new file mode 100644 index 0000000..51298b0 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/stream.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const stream_1 = require("stream"); +const async_1 = require("../readers/async"); +class StreamProvider { + constructor(_root, _settings) { + this._root = _root; + this._settings = _settings; + this._reader = new async_1.default(this._root, this._settings); + this._stream = new stream_1.Readable({ + objectMode: true, + read: () => { }, + destroy: () => { + if (!this._reader.isDestroyed) { + this._reader.destroy(); + } + } + }); + } + read() { + this._reader.onError((error) => { + this._stream.emit('error', error); + }); + this._reader.onEntry((entry) => { + this._stream.push(entry); + }); + this._reader.onEnd(() => { + this._stream.push(null); + }); + this._reader.read(); + return this._stream; + } +} +exports.default = StreamProvider; diff --git a/node_modules/@nodelib/fs.walk/out/providers/sync.d.ts b/node_modules/@nodelib/fs.walk/out/providers/sync.d.ts new file mode 100644 index 0000000..551c42e --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/sync.d.ts @@ -0,0 +1,10 @@ +import SyncReader from '../readers/sync'; +import type Settings from '../settings'; +import type { Entry } from '../types'; +export default class SyncProvider { + private readonly _root; + private readonly _settings; + protected readonly _reader: SyncReader; + constructor(_root: string, _settings: Settings); + read(): Entry[]; +} diff --git a/node_modules/@nodelib/fs.walk/out/providers/sync.js b/node_modules/@nodelib/fs.walk/out/providers/sync.js new file mode 100644 index 0000000..faab6ca --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/providers/sync.js @@ -0,0 +1,14 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const sync_1 = require("../readers/sync"); +class SyncProvider { + constructor(_root, _settings) { + this._root = _root; + this._settings = _settings; + this._reader = new sync_1.default(this._root, this._settings); + } + read() { + return this._reader.read(); + } +} +exports.default = SyncProvider; diff --git a/node_modules/@nodelib/fs.walk/out/readers/async.d.ts b/node_modules/@nodelib/fs.walk/out/readers/async.d.ts new file mode 100644 index 0000000..9acf4e6 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/async.d.ts @@ -0,0 +1,30 @@ +/// +import { EventEmitter } from 'events'; +import * as fsScandir from '@nodelib/fs.scandir'; +import type Settings from '../settings'; +import type { Entry, Errno } from '../types'; +import Reader from './reader'; +declare type EntryEventCallback = (entry: Entry) => void; +declare type ErrorEventCallback = (error: Errno) => void; +declare type EndEventCallback = () => void; +export default class AsyncReader extends Reader { + protected readonly _settings: Settings; + protected readonly _scandir: typeof fsScandir.scandir; + protected readonly _emitter: EventEmitter; + private readonly _queue; + private _isFatalError; + private _isDestroyed; + constructor(_root: string, _settings: Settings); + read(): EventEmitter; + get isDestroyed(): boolean; + destroy(): void; + onEntry(callback: EntryEventCallback): void; + onError(callback: ErrorEventCallback): void; + onEnd(callback: EndEventCallback): void; + private _pushToQueue; + private _worker; + private _handleError; + private _handleEntry; + private _emitEntry; +} +export {}; diff --git a/node_modules/@nodelib/fs.walk/out/readers/async.js b/node_modules/@nodelib/fs.walk/out/readers/async.js new file mode 100644 index 0000000..ebe8dd5 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/async.js @@ -0,0 +1,97 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const events_1 = require("events"); +const fsScandir = require("@nodelib/fs.scandir"); +const fastq = require("fastq"); +const common = require("./common"); +const reader_1 = require("./reader"); +class AsyncReader extends reader_1.default { + constructor(_root, _settings) { + super(_root, _settings); + this._settings = _settings; + this._scandir = fsScandir.scandir; + this._emitter = new events_1.EventEmitter(); + this._queue = fastq(this._worker.bind(this), this._settings.concurrency); + this._isFatalError = false; + this._isDestroyed = false; + this._queue.drain = () => { + if (!this._isFatalError) { + this._emitter.emit('end'); + } + }; + } + read() { + this._isFatalError = false; + this._isDestroyed = false; + setImmediate(() => { + this._pushToQueue(this._root, this._settings.basePath); + }); + return this._emitter; + } + get isDestroyed() { + return this._isDestroyed; + } + destroy() { + if (this._isDestroyed) { + throw new Error('The reader is already destroyed'); + } + this._isDestroyed = true; + this._queue.killAndDrain(); + } + onEntry(callback) { + this._emitter.on('entry', callback); + } + onError(callback) { + this._emitter.once('error', callback); + } + onEnd(callback) { + this._emitter.once('end', callback); + } + _pushToQueue(directory, base) { + const queueItem = { directory, base }; + this._queue.push(queueItem, (error) => { + if (error !== null) { + this._handleError(error); + } + }); + } + _worker(item, done) { + this._scandir(item.directory, this._settings.fsScandirSettings, (error, entries) => { + if (error !== null) { + done(error, undefined); + return; + } + for (const entry of entries) { + this._handleEntry(entry, item.base); + } + done(null, undefined); + }); + } + _handleError(error) { + if (this._isDestroyed || !common.isFatalError(this._settings, error)) { + return; + } + this._isFatalError = true; + this._isDestroyed = true; + this._emitter.emit('error', error); + } + _handleEntry(entry, base) { + if (this._isDestroyed || this._isFatalError) { + return; + } + const fullpath = entry.path; + if (base !== undefined) { + entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator); + } + if (common.isAppliedFilter(this._settings.entryFilter, entry)) { + this._emitEntry(entry); + } + if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) { + this._pushToQueue(fullpath, base === undefined ? undefined : entry.path); + } + } + _emitEntry(entry) { + this._emitter.emit('entry', entry); + } +} +exports.default = AsyncReader; diff --git a/node_modules/@nodelib/fs.walk/out/readers/common.d.ts b/node_modules/@nodelib/fs.walk/out/readers/common.d.ts new file mode 100644 index 0000000..5985f97 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/common.d.ts @@ -0,0 +1,7 @@ +import type { FilterFunction } from '../settings'; +import type Settings from '../settings'; +import type { Errno } from '../types'; +export declare function isFatalError(settings: Settings, error: Errno): boolean; +export declare function isAppliedFilter(filter: FilterFunction | null, value: T): boolean; +export declare function replacePathSegmentSeparator(filepath: string, separator: string): string; +export declare function joinPathSegments(a: string, b: string, separator: string): string; diff --git a/node_modules/@nodelib/fs.walk/out/readers/common.js b/node_modules/@nodelib/fs.walk/out/readers/common.js new file mode 100644 index 0000000..a93572f --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/common.js @@ -0,0 +1,31 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.joinPathSegments = exports.replacePathSegmentSeparator = exports.isAppliedFilter = exports.isFatalError = void 0; +function isFatalError(settings, error) { + if (settings.errorFilter === null) { + return true; + } + return !settings.errorFilter(error); +} +exports.isFatalError = isFatalError; +function isAppliedFilter(filter, value) { + return filter === null || filter(value); +} +exports.isAppliedFilter = isAppliedFilter; +function replacePathSegmentSeparator(filepath, separator) { + return filepath.split(/[/\\]/).join(separator); +} +exports.replacePathSegmentSeparator = replacePathSegmentSeparator; +function joinPathSegments(a, b, separator) { + if (a === '') { + return b; + } + /** + * The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`). + */ + if (a.endsWith(separator)) { + return a + b; + } + return a + separator + b; +} +exports.joinPathSegments = joinPathSegments; diff --git a/node_modules/@nodelib/fs.walk/out/readers/reader.d.ts b/node_modules/@nodelib/fs.walk/out/readers/reader.d.ts new file mode 100644 index 0000000..e1f383b --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/reader.d.ts @@ -0,0 +1,6 @@ +import type Settings from '../settings'; +export default class Reader { + protected readonly _root: string; + protected readonly _settings: Settings; + constructor(_root: string, _settings: Settings); +} diff --git a/node_modules/@nodelib/fs.walk/out/readers/reader.js b/node_modules/@nodelib/fs.walk/out/readers/reader.js new file mode 100644 index 0000000..782f07c --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/reader.js @@ -0,0 +1,11 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const common = require("./common"); +class Reader { + constructor(_root, _settings) { + this._root = _root; + this._settings = _settings; + this._root = common.replacePathSegmentSeparator(_root, _settings.pathSegmentSeparator); + } +} +exports.default = Reader; diff --git a/node_modules/@nodelib/fs.walk/out/readers/sync.d.ts b/node_modules/@nodelib/fs.walk/out/readers/sync.d.ts new file mode 100644 index 0000000..af41033 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/sync.d.ts @@ -0,0 +1,15 @@ +import * as fsScandir from '@nodelib/fs.scandir'; +import type { Entry } from '../types'; +import Reader from './reader'; +export default class SyncReader extends Reader { + protected readonly _scandir: typeof fsScandir.scandirSync; + private readonly _storage; + private readonly _queue; + read(): Entry[]; + private _pushToQueue; + private _handleQueue; + private _handleDirectory; + private _handleError; + private _handleEntry; + private _pushToStorage; +} diff --git a/node_modules/@nodelib/fs.walk/out/readers/sync.js b/node_modules/@nodelib/fs.walk/out/readers/sync.js new file mode 100644 index 0000000..9a8d5a6 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/readers/sync.js @@ -0,0 +1,59 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const fsScandir = require("@nodelib/fs.scandir"); +const common = require("./common"); +const reader_1 = require("./reader"); +class SyncReader extends reader_1.default { + constructor() { + super(...arguments); + this._scandir = fsScandir.scandirSync; + this._storage = []; + this._queue = new Set(); + } + read() { + this._pushToQueue(this._root, this._settings.basePath); + this._handleQueue(); + return this._storage; + } + _pushToQueue(directory, base) { + this._queue.add({ directory, base }); + } + _handleQueue() { + for (const item of this._queue.values()) { + this._handleDirectory(item.directory, item.base); + } + } + _handleDirectory(directory, base) { + try { + const entries = this._scandir(directory, this._settings.fsScandirSettings); + for (const entry of entries) { + this._handleEntry(entry, base); + } + } + catch (error) { + this._handleError(error); + } + } + _handleError(error) { + if (!common.isFatalError(this._settings, error)) { + return; + } + throw error; + } + _handleEntry(entry, base) { + const fullpath = entry.path; + if (base !== undefined) { + entry.path = common.joinPathSegments(base, entry.name, this._settings.pathSegmentSeparator); + } + if (common.isAppliedFilter(this._settings.entryFilter, entry)) { + this._pushToStorage(entry); + } + if (entry.dirent.isDirectory() && common.isAppliedFilter(this._settings.deepFilter, entry)) { + this._pushToQueue(fullpath, base === undefined ? undefined : entry.path); + } + } + _pushToStorage(entry) { + this._storage.push(entry); + } +} +exports.default = SyncReader; diff --git a/node_modules/@nodelib/fs.walk/out/settings.d.ts b/node_modules/@nodelib/fs.walk/out/settings.d.ts new file mode 100644 index 0000000..d1c4b45 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/settings.d.ts @@ -0,0 +1,30 @@ +import * as fsScandir from '@nodelib/fs.scandir'; +import type { Entry, Errno } from './types'; +export declare type FilterFunction = (value: T) => boolean; +export declare type DeepFilterFunction = FilterFunction; +export declare type EntryFilterFunction = FilterFunction; +export declare type ErrorFilterFunction = FilterFunction; +export interface Options { + basePath?: string; + concurrency?: number; + deepFilter?: DeepFilterFunction; + entryFilter?: EntryFilterFunction; + errorFilter?: ErrorFilterFunction; + followSymbolicLinks?: boolean; + fs?: Partial; + pathSegmentSeparator?: string; + stats?: boolean; + throwErrorOnBrokenSymbolicLink?: boolean; +} +export default class Settings { + private readonly _options; + readonly basePath?: string; + readonly concurrency: number; + readonly deepFilter: DeepFilterFunction | null; + readonly entryFilter: EntryFilterFunction | null; + readonly errorFilter: ErrorFilterFunction | null; + readonly pathSegmentSeparator: string; + readonly fsScandirSettings: fsScandir.Settings; + constructor(_options?: Options); + private _getValue; +} diff --git a/node_modules/@nodelib/fs.walk/out/settings.js b/node_modules/@nodelib/fs.walk/out/settings.js new file mode 100644 index 0000000..d7a85c8 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/settings.js @@ -0,0 +1,26 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const path = require("path"); +const fsScandir = require("@nodelib/fs.scandir"); +class Settings { + constructor(_options = {}) { + this._options = _options; + this.basePath = this._getValue(this._options.basePath, undefined); + this.concurrency = this._getValue(this._options.concurrency, Number.POSITIVE_INFINITY); + this.deepFilter = this._getValue(this._options.deepFilter, null); + this.entryFilter = this._getValue(this._options.entryFilter, null); + this.errorFilter = this._getValue(this._options.errorFilter, null); + this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep); + this.fsScandirSettings = new fsScandir.Settings({ + followSymbolicLinks: this._options.followSymbolicLinks, + fs: this._options.fs, + pathSegmentSeparator: this._options.pathSegmentSeparator, + stats: this._options.stats, + throwErrorOnBrokenSymbolicLink: this._options.throwErrorOnBrokenSymbolicLink + }); + } + _getValue(option, value) { + return option !== null && option !== void 0 ? option : value; + } +} +exports.default = Settings; diff --git a/node_modules/@nodelib/fs.walk/out/types/index.d.ts b/node_modules/@nodelib/fs.walk/out/types/index.d.ts new file mode 100644 index 0000000..6ee9bd3 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/types/index.d.ts @@ -0,0 +1,8 @@ +/// +import type * as scandir from '@nodelib/fs.scandir'; +export declare type Entry = scandir.Entry; +export declare type Errno = NodeJS.ErrnoException; +export interface QueueItem { + directory: string; + base?: string; +} diff --git a/node_modules/@nodelib/fs.walk/out/types/index.js b/node_modules/@nodelib/fs.walk/out/types/index.js new file mode 100644 index 0000000..c8ad2e5 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/out/types/index.js @@ -0,0 +1,2 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); diff --git a/node_modules/@nodelib/fs.walk/package.json b/node_modules/@nodelib/fs.walk/package.json new file mode 100644 index 0000000..86bfce4 --- /dev/null +++ b/node_modules/@nodelib/fs.walk/package.json @@ -0,0 +1,44 @@ +{ + "name": "@nodelib/fs.walk", + "version": "1.2.8", + "description": "A library for efficiently walking a directory recursively", + "license": "MIT", + "repository": "https://github.com/nodelib/nodelib/tree/master/packages/fs/fs.walk", + "keywords": [ + "NodeLib", + "fs", + "FileSystem", + "file system", + "walk", + "scanner", + "crawler" + ], + "engines": { + "node": ">= 8" + }, + "files": [ + "out/**", + "!out/**/*.map", + "!out/**/*.spec.*", + "!out/**/tests/**" + ], + "main": "out/index.js", + "typings": "out/index.d.ts", + "scripts": { + "clean": "rimraf {tsconfig.tsbuildinfo,out}", + "lint": "eslint \"src/**/*.ts\" --cache", + "compile": "tsc -b .", + "compile:watch": "tsc -p . --watch --sourceMap", + "test": "mocha \"out/**/*.spec.js\" -s 0", + "build": "npm run clean && npm run compile && npm run lint && npm test", + "watch": "npm run clean && npm run compile:watch" + }, + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "devDependencies": { + "@nodelib/fs.macchiato": "1.0.4" + }, + "gitHead": "1e5bad48565da2b06b8600e744324ea240bf49d8" +} diff --git a/node_modules/@popperjs/core/LICENSE.md b/node_modules/@popperjs/core/LICENSE.md new file mode 100644 index 0000000..0370c45 --- /dev/null +++ b/node_modules/@popperjs/core/LICENSE.md @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2019 Federico Zivolo + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/@popperjs/core/README.md b/node_modules/@popperjs/core/README.md new file mode 100644 index 0000000..53be7b9 --- /dev/null +++ b/node_modules/@popperjs/core/README.md @@ -0,0 +1,376 @@ + +

      + Popper +

      + +
      +

      Tooltip & Popover Positioning Engine

      +
      + +

      + + npm version + + + npm downloads per month (popper.js + @popperjs/core) + + + Rolling Versions + +

      + +
      + + +**Positioning tooltips and popovers is difficult. Popper is here to help!** + +Given an element, such as a button, and a tooltip element describing it, Popper +will automatically put the tooltip in the right place near the button. + +It will position _any_ UI element that "pops out" from the flow of your document +and floats near a target element. The most common example is a tooltip, but it +also includes popovers, drop-downs, and more. All of these can be generically +described as a "popper" element. + +## Demo + +[![Popper visualized](https://i.imgur.com/F7qWsmV.jpg)](https://popper.js.org) + +## Docs + +- [v2.x (latest)](https://popper.js.org/docs/v2/) +- [v1.x](https://popper.js.org/docs/v1/) + +We've created a +[Migration Guide](https://popper.js.org/docs/v2/migration-guide/) to help you +migrate from Popper 1 to Popper 2. + +To contribute to the Popper website and documentation, please visit the +[dedicated repository](https://github.com/popperjs/website). + +## Why not use pure CSS? + +- **Clipping and overflow issues**: Pure CSS poppers will not be prevented from + overflowing clipping boundaries, such as the viewport. It will get partially + cut off or overflows if it's near the edge since there is no dynamic + positioning logic. When using Popper, your popper will always be positioned in + the right place without needing manual adjustments. +- **No flipping**: CSS poppers will not flip to a different placement to fit + better in view if necessary. While you can manually adjust for the main axis + overflow, this feature cannot be achieved via CSS alone. Popper automatically + flips the tooltip to make it fit in view as best as possible for the user. +- **No virtual positioning**: CSS poppers cannot follow the mouse cursor or be + used as a context menu. Popper allows you to position your tooltip relative to + any coordinates you desire. +- **Slower development cycle**: When pure CSS is used to position popper + elements, the lack of dynamic positioning means they must be carefully placed + to consider overflow on all screen sizes. In reusable component libraries, + this means a developer can't just add the component anywhere on the page, + because these issues need to be considered and adjusted for every time. With + Popper, you can place your elements anywhere and they will be positioned + correctly, without needing to consider different screen sizes, layouts, etc. + This massively speeds up development time because this work is automatically + offloaded to Popper. +- **Lack of extensibility**: CSS poppers cannot be easily extended to fit any + arbitrary use case you may need to adjust for. Popper is built with + extensibility in mind. + +## Why Popper? + +With the CSS drawbacks out of the way, we now move on to Popper in the +JavaScript space itself. + +Naive JavaScript tooltip implementations usually have the following problems: + +- **Scrolling containers**: They don't ensure the tooltip stays with the + reference element while scrolling when inside any number of scrolling + containers. +- **DOM context**: They often require the tooltip move outside of its original + DOM context because they don't handle `offsetParent` contexts. +- **Compatibility**: Popper handles an incredible number of edge cases regarding + different browsers and environments (mobile viewports, RTL, scrollbars enabled + or disabled, etc.). Popper is a popular and well-maintained library, so you + can be confident positioning will work for your users on any device. +- **Configurability**: They often lack advanced configurability to suit any + possible use case. +- **Size**: They are usually relatively large in size, or require an ancient + jQuery dependency. +- **Performance**: They often have runtime performance issues and update the + tooltip position too slowly. + +**Popper solves all of these key problems in an elegant, performant manner.** It +is a lightweight ~3 kB library that aims to provide a reliable and extensible +positioning engine you can use to ensure all your popper elements are positioned +in the right place. + +When you start writing your own popper implementation, you'll quickly run into +all of the problems mentioned above. These widgets are incredibly common in our +UIs; we've done the hard work figuring this out so you don't need to spend hours +fixing and handling numerous edge cases that we already ran into while building +the library! + +Popper is used in popular libraries like Bootstrap, Foundation, Material UI, and +more. It's likely you've already used popper elements on the web positioned by +Popper at some point in the past few years. + +Since we write UIs using powerful abstraction libraries such as React or Angular +nowadays, you'll also be glad to know Popper can fully integrate with them and +be a good citizen together with your other components. Check out `react-popper` +for the official Popper wrapper for React. + +## Installation + +### 1. Package Manager + +```bash +# With npm +npm i @popperjs/core + +# With Yarn +yarn add @popperjs/core +``` + +### 2. CDN + +```html + + + + + +``` + +### 3. Direct Download? + +Managing dependencies by "directly downloading" them and placing them into your +source code is not recommended for a variety of reasons, including missing out +on feat/fix updates easily. Please use a versioning management system like a CDN +or npm/Yarn. + +## Usage + +The most straightforward way to get started is to import Popper from the `unpkg` +CDN, which includes all of its features. You can call the `Popper.createPopper` +constructor to create new popper instances. + +Here is a complete example: + +```html + +Popper example + + + + + + + + +``` + +Visit the [tutorial](https://popper.js.org/docs/v2/tutorial/) for an example of +how to build your own tooltip from scratch using Popper. + +### Module bundlers + +You can import the `createPopper` constructor from the fully-featured file: + +```js +import { createPopper } from '@popperjs/core'; + +const button = document.querySelector('#button'); +const tooltip = document.querySelector('#tooltip'); + +// Pass the button, the tooltip, and some options, and Popper will do the +// magic positioning for you: +createPopper(button, tooltip, { + placement: 'right', +}); +``` + +All the modifiers listed in the docs menu will be enabled and "just work", so +you don't need to think about setting Popper up. The size of Popper including +all of its features is about 5 kB minzipped, but it may grow a bit in the +future. + +#### Popper Lite (tree-shaking) + +If bundle size is important, you'll want to take advantage of tree-shaking. The +library is built in a modular way to allow to import only the parts you really +need. + +```js +import { createPopperLite as createPopper } from '@popperjs/core'; +``` + +The Lite version includes the most necessary modifiers that will compute the +offsets of the popper, compute and add the positioning styles, and add event +listeners. This is close in bundle size to pure CSS tooltip libraries, and +behaves somewhat similarly. + +However, this does not include the features that makes Popper truly useful. + +The two most useful modifiers not included in Lite are `preventOverflow` and +`flip`: + +```js +import { + createPopperLite as createPopper, + preventOverflow, + flip, +} from '@popperjs/core'; + +const button = document.querySelector('#button'); +const tooltip = document.querySelector('#tooltip'); + +createPopper(button, tooltip, { + modifiers: [preventOverflow, flip], +}); +``` + +As you make more poppers, you may be finding yourself needing other modifiers +provided by the library. + +See [tree-shaking](https://popper.js.org/docs/v2/performance/#tree-shaking) for more +information. + +## Distribution targets + +Popper is distributed in 3 different versions, in 3 different file formats. + +The 3 file formats are: + +- `esm` (works with `import` syntax — **recommended**) +- `umd` (works with ` + + +``` + +The `initFlowbite` function sets up all of the init functions for dropdowns, modals, navbars, tooltips and so on to hook onto the data attributes. Alternatively, you can also initialise each component category class separately with `initDropdowns` or `initModals`. + +You can view more examples by browsing the [components from Flowbite](#components). + +### ESM and CJS + +Flowbite also offers an API for using the components programmatically and it supports both CJS and ESM for JavaScript which can be helpful if you need to expand the default capabilities of the data attributes interface and get access to function callbacks. + +Here's an example how you can import and create a new Modal component inside JavaScript: + +```javascript +import { Modal } from 'flowbite' + +const $modalElement = document.querySelector('#modalEl'); + +const modalOptions = { + placement: 'bottom-right', + backdrop: 'dynamic', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + onHide: () => { + console.log('modal is hidden'); + }, + onShow: () => { + console.log('modal is shown'); + }, + onToggle: () => { + console.log('modal has been toggled'); + } +} + +const modal = new Modal($modalElement, modalOptions); + +modal.show(); +``` + +Check out the JavaScript behaviour section of each component's page to learn how you can use this. + +### TypeScript + +Flowbite supports type declarations for the interactive UI components including object interfaces and parameter types. Check out the following examples to learn how you can use types with Flowbite. + +Additionally to our code above, we will now import some relevant types from the Flowbite package, namely the `ModalOptions` and `ModalInterface`: + +```javascript +import { Modal } from 'flowbite' +import type { ModalOptions, ModalInterface } from 'flowbite' + +// other code +``` + +Generally speaking, all of the components have an interface definition that you can use whenever you create a new object to make sure that you're using the correct types of parameters and methods. + +When creating a new modal you can set the `ModalInterface` as the main type: + +```javascript +const modal: ModalInterface = new Modal($modalElement, modalOptions); +``` + +Flowbite also supports type definitions for the options object so if you want to set the placement of the modal based on types, here's how you would do that: + +```javascript +const modalOptions: ModalOptions = { + placement: 'top-right' +} + +const modal: ModalInterface = new Modal($modalElement, modalOptions); +``` + +Learn more about Flowbite and TypeScript in the [quickstart guide](https://flowbite.com/docs/getting-started/typescript/). + +### JavaScript Frameworks + +The awesome open-source community also built and currently maintains the following standalone libraries for React, Vue, Svelte, and Angular: + +- [🌀 Flowbite React Library](https://github.com/themesberg/flowbite-react) +- [🍀 Flowbite Vue Library](https://github.com/themesberg/flowbite-vue) +- [🎸 Flowbite Svelte Library](https://github.com/themesberg/flowbite-svelte) +- [📕 Flowbite Angular Library](https://github.com/themesberg/flowbite-angular) + +We also wrote integration guides for the following front-end frameworks and libraries: + +- [📝 Flowbite with React guide](https://flowbite.com/docs/getting-started/react/) +- [📝 Flowbite with Next.js guide](https://flowbite.com/docs/getting-started/next-js/) +- [📝 Flowbite with Remix guide](https://flowbite.com/docs/getting-started/remix/) +- [📝 Flowbite with Vue guide](https://flowbite.com/docs/getting-started/vue/) +- [📝 Flowbite with Nuxt guide](https://flowbite.com/docs/getting-started/nuxt-js/) +- [📝 Flowbite with Svelte guide](https://flowbite.com/docs/getting-started/svelte/) +- [📝 Flowbite with Astro guide](https://flowbite.com/docs/getting-started/astro/) +- [📝 Flowbite with Gatsby guide](https://flowbite.com/docs/getting-started/gatsby/) +- [📝 Flowbite with SolidJS guide](https://flowbite.com/docs/getting-started/solid-js/) + +### Back-end Frameworks + +Flowbite has a great integration with most of the back-end frameworks because it relies on vanilla JavaScript: + +- [📚 Using Flowbite with Laravel](https://flowbite.com/docs/getting-started/laravel/) +- [🎼 Using Flowbite with Symfony](https://flowbite.com/docs/getting-started/symfony/) +- [🚊 Using Flowbite with Ruby on Rails 7](https://flowbite.com/docs/getting-started/rails/) +- [🐉 Using Flowbite with Phoenix (Elixir)](https://flowbite.com/docs/getting-started/phoenix/) +- [🐸 Using Flowbite with Django](https://flowbite.com/docs/getting-started/django/) +- [🌶 Using Flowbite with Flask](https://flowbite.com/docs/getting-started/flask/) + +## Components + +Flowbite is an open source collection of UI components built with the utility classes from Tailwind CSS that you can use as a starting point when coding user interfaces and websites. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      AlertsBadgeBreadcrumbs
      + + Tailwind CSS Alerts + + + + Tailwind CSS Badge + + + + Tailwind CSS Breadcrumbs + +
      ButtonsButton groupCards
      + + Tailwind CSS Buttons + + + + Tailwind CSS Button Group + + + + Tailwind CSS Cards + +
      DropdownFormsList group
      + + Tailwind CSS Dropdown + + + + Tailwind CSS Forms + + + + Tailwind CSS List group + +
      TypographyModalTabs
      + + Tailwind CSS Typography + + + + Tailwind CSS Modal + + + + Tailwind CSS Tabs + +
      NavbarPaginationTimeline
      + + Tailwind CSS Navbar + + + + Tailwind CSS Pagination + + + + Tailwind CSS Timeline + +
      Progress barTablesToast
      + + Tailwind CSS Progress Bar + + + + Tailwind CSS Tables + + + + Tailwind CSS Toast + +
      TooltipsDatepickerSpinner
      + + Tailwind CSS Tooltips + + + + Tailwind CSS Datepicker + + + + Tailwind CSS Spinner + +
      FooterAccordionSidebar
      + + Tailwind CSS Footer + + + + Tailwind CSS Accordion + + + + Tailwind CSS Sidebar + +
      CarouselAvatarRating
      + + Tailwind CSS Carousel + + + + Tailwind CSS Avatar + + + + Tailwind CSS Rating + +
      Input FieldFile InputSearch Input
      + + Tailwind CSS Input Field + + + + Tailwind CSS File Input + + + + Tailwind CSS Search Input + +
      SelectTextareaCheckbox
      + + Tailwind CSS Select + + + + Tailwind CSS Textarea + + + + Tailwind CSS Checkbox + +
      RadioToggleRange Slider
      + + Tailwind CSS Radio + + + + Tailwind CSS Toggle + + + + Tailwind CSS Range Slider + +
      Floating LabelMega MenuSkeleton
      + + Tailwind CSS Floating Label + + + + Tailwind CSS Mega Menu + + + + Tailwind CSS Skeleton + +
      KBD (keyboard)Drawer (offcanvas)Popover
      + + Tailwind CSS KBD (Keyboard) + + + + Tailwind CSS Drawer (offcanvas) + + + + Tailwind CSS Popover + +
      VideoHeadingParagraph
      + + Tailwind CSS Video + + + + Tailwind CSS Heading + + + + Tailwind CSS Paragraph + +
      BlockquoteImageList
      + + Tailwind CSS Blockquote + + + + Tailwind CSS Image + + + + Tailwind CSS List + +
      LinkTextHorizontal line (HR)
      + + Tailwind CSS Link + + + + Tailwind CSS Text + + + + Tailwind CSS HR + +
      Speed DialStepperIndicators
      + + Tailwind CSS Speed Dial + + + + Tailwind CSS Stepper + + + + Tailwind CSS Indicators + +
      Bottom NavigationSticky BannerGallery (Masonry)
      + + Tailwind CSS Bottom Navigation Bar + + + + Tailwind CSS Bottom Sticky Banner + + + + Tailwind CSS Image Gallery (Masonry) + +
      JumbotronDevice mockupsCharts
      + + Tailwind CSS Jumbotron + + + + Tailwind CSS Device Mockups + + + + Tailwind CSS Charts + +
      + +## Figma Design System + +If you need the Figma files for the components you can check out our website for more information: + +🎨 [Get access to the Figma design files](https://flowbite.com/figma/) + +## Flowbite Blocks + +Check out Flowbite Blocks to get access to over 330+ website sections coded in Tailwind CSS and Flowbite: + +📦 [Check out Flowbite Blocks](https://flowbite.com/blocks/) + +## Flowbite Icons + +Start using over 430+ free and open-source collection of solid and outline SVG icons built for Tailwind CSS and with support for Figma and JSX (React): + +🔍 [Check out the icons](https://flowbite.com/icons/) + +## Pro version + +Get access to all premium features including the Figma design system, access to all Flowbite Block sections and a dashboard UI interface: + +💎 [Check out Flowbite Pro](https://flowbite.com/pro/) + +## Learn Design Concepts + +If you want to create even better Flowbite pages, learn design fundamentals from Teach Me Design - Enhance UI, a book that covers color theory, typography, UI and UX so you can make the most to implement the Flowbite Ecosystem! + +📖 [Learn with Enhance UI](https://www.enhanceui.com/?ref=flowbite-github) + +## Community + +If you need help or just want to discuss about the library join the community on Github: + +⌨️ [Discuss about Flowbite on GitHub](https://github.com/themesberg/flowbite/discussions) + +For casual chatting with others using the library: + +💬 [Join the Flowbite Discord Server](https://discord.gg/4eeurUVvTy) + +Video tutorials and presentations using Flowbite: + +🎥 [Subscribe to our YouTube channel](https://www.youtube.com/channel/UC_Ms4V2kYDsh7F_CSsHyQ6A) + +## Copyright and license + +The Flowbite name and logos are trademarks of Bergside Inc. + +- 📝 [Read about the licensing terms](https://flowbite.com/docs/getting-started/license/) +- 📀 [Brand guideline and trademark usage agreement](https://flowbite.com/brand/) diff --git a/node_modules/flowbite/dist/datepicker.js b/node_modules/flowbite/dist/datepicker.js new file mode 100644 index 0000000..6df2667 --- /dev/null +++ b/node_modules/flowbite/dist/datepicker.js @@ -0,0 +1,3119 @@ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define("Flowbite", [], factory); + else if(typeof exports === 'object') + exports["Flowbite"] = factory(); + else + root["Flowbite"] = factory(); +})(self, function() { +return /******/ (function() { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ 482: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Z": function() { return /* binding */ DateRangePicker; } +/* harmony export */ }); +/* harmony import */ var _lib_event_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(698); +/* harmony import */ var _lib_date_format_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(963); +/* harmony import */ var _Datepicker_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(770); + + + + +// filter out the config options inapproprite to pass to Datepicker +function filterOptions(options) { + const newOpts = Object.assign({}, options); + + delete newOpts.inputs; + delete newOpts.allowOneSidedRange; + delete newOpts.maxNumberOfDates; // to ensure each datepicker handles a single date + + return newOpts; +} + +function setupDatepicker(rangepicker, changeDateListener, el, options) { + (0,_lib_event_js__WEBPACK_IMPORTED_MODULE_0__/* .registerListeners */ .cF)(rangepicker, [ + [el, 'changeDate', changeDateListener], + ]); + new _Datepicker_js__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(el, options, rangepicker); +} + +function onChangeDate(rangepicker, ev) { + // to prevent both datepickers trigger the other side's update each other + if (rangepicker._updating) { + return; + } + rangepicker._updating = true; + + const target = ev.target; + if (target.datepicker === undefined) { + return; + } + + const datepickers = rangepicker.datepickers; + const setDateOptions = {render: false}; + const changedSide = rangepicker.inputs.indexOf(target); + const otherSide = changedSide === 0 ? 1 : 0; + const changedDate = datepickers[changedSide].dates[0]; + const otherDate = datepickers[otherSide].dates[0]; + + if (changedDate !== undefined && otherDate !== undefined) { + // if the start of the range > the end, swap them + if (changedSide === 0 && changedDate > otherDate) { + datepickers[0].setDate(otherDate, setDateOptions); + datepickers[1].setDate(changedDate, setDateOptions); + } else if (changedSide === 1 && changedDate < otherDate) { + datepickers[0].setDate(changedDate, setDateOptions); + datepickers[1].setDate(otherDate, setDateOptions); + } + } else if (!rangepicker.allowOneSidedRange) { + // to prevent the range from becoming one-sided, copy changed side's + // selection (no matter if it's empty) to the other side + if (changedDate !== undefined || otherDate !== undefined) { + setDateOptions.clear = true; + datepickers[otherSide].setDate(datepickers[changedSide].dates, setDateOptions); + } + } + datepickers[0].picker.update().render(); + datepickers[1].picker.update().render(); + delete rangepicker._updating; +} + +/** + * Class representing a date range picker + */ +class DateRangePicker { + /** + * Create a date range picker + * @param {Element} element - element to bind a date range picker + * @param {Object} [options] - config options + */ + constructor(element, options = {}) { + const inputs = Array.isArray(options.inputs) + ? options.inputs + : Array.from(element.querySelectorAll('input')); + if (inputs.length < 2) { + return; + } + + element.rangepicker = this; + this.element = element; + this.inputs = inputs.slice(0, 2); + this.allowOneSidedRange = !!options.allowOneSidedRange; + + const changeDateListener = onChangeDate.bind(null, this); + const cleanOptions = filterOptions(options); + // in order for initial date setup to work right when pcicLvel > 0, + // let Datepicker constructor add the instance to the rangepicker + const datepickers = []; + Object.defineProperty(this, 'datepickers', { + get() { + return datepickers; + }, + }); + setupDatepicker(this, changeDateListener, this.inputs[0], cleanOptions); + setupDatepicker(this, changeDateListener, this.inputs[1], cleanOptions); + Object.freeze(datepickers); + // normalize the range if inital dates are given + if (datepickers[0].dates.length > 0) { + onChangeDate(this, {target: this.inputs[0]}); + } else if (datepickers[1].dates.length > 0) { + onChangeDate(this, {target: this.inputs[1]}); + } + } + + /** + * @type {Array} - selected date of the linked date pickers + */ + get dates() { + return this.datepickers.length === 2 + ? [ + this.datepickers[0].dates[0], + this.datepickers[1].dates[0], + ] + : undefined; + } + + /** + * Set new values to the config options + * @param {Object} options - config options to update + */ + setOptions(options) { + this.allowOneSidedRange = !!options.allowOneSidedRange; + + const cleanOptions = filterOptions(options); + this.datepickers[0].setOptions(cleanOptions); + this.datepickers[1].setOptions(cleanOptions); + } + + /** + * Destroy the DateRangePicker instance + * @return {DateRangePicker} - the instance destroyed + */ + destroy() { + this.datepickers[0].destroy(); + this.datepickers[1].destroy(); + (0,_lib_event_js__WEBPACK_IMPORTED_MODULE_0__/* .unregisterListeners */ .uV)(this); + delete this.element.rangepicker; + } + + /** + * Get the start and end dates of the date range + * + * The method returns Date objects by default. If format string is passed, + * it returns date strings formatted in given format. + * The result array always contains 2 items (start date/end date) and + * undefined is used for unselected side. (e.g. If none is selected, + * the result will be [undefined, undefined]. If only the end date is set + * when allowOneSidedRange config option is true, [undefined, endDate] will + * be returned.) + * + * @param {String} [format] - Format string to stringify the dates + * @return {Array} - Start and end dates + */ + getDates(format = undefined) { + const callback = format + ? date => (0,_lib_date_format_js__WEBPACK_IMPORTED_MODULE_1__/* .formatDate */ .p6)(date, format, this.datepickers[0].config.locale) + : date => new Date(date); + + return this.dates.map(date => date === undefined ? date : callback(date)); + } + + /** + * Set the start and end dates of the date range + * + * The method calls datepicker.setDate() internally using each of the + * arguments in start→end order. + * + * When a clear: true option object is passed instead of a date, the method + * clears the date. + * + * If an invalid date, the same date as the current one or an option object + * without clear: true is passed, the method considers that argument as an + * "ineffective" argument because calling datepicker.setDate() with those + * values makes no changes to the date selection. + * + * When the allowOneSidedRange config option is false, passing {clear: true} + * to clear the range works only when it is done to the last effective + * argument (in other words, passed to rangeEnd or to rangeStart along with + * ineffective rangeEnd). This is because when the date range is changed, + * it gets normalized based on the last change at the end of the changing + * process. + * + * @param {Date|Number|String|Object} rangeStart - Start date of the range + * or {clear: true} to clear the date + * @param {Date|Number|String|Object} rangeEnd - End date of the range + * or {clear: true} to clear the date + */ + setDates(rangeStart, rangeEnd) { + const [datepicker0, datepicker1] = this.datepickers; + const origDates = this.dates; + + // If range normalization runs on every change, we can't set a new range + // that starts after the end of the current range correctly because the + // normalization process swaps start↔︎end right after setting the new start + // date. To prevent this, the normalization process needs to run once after + // both of the new dates are set. + this._updating = true; + datepicker0.setDate(rangeStart); + datepicker1.setDate(rangeEnd); + delete this._updating; + + if (datepicker1.dates[0] !== origDates[1]) { + onChangeDate(this, {target: this.inputs[1]}); + } else if (datepicker0.dates[0] !== origDates[0]) { + onChangeDate(this, {target: this.inputs[0]}); + } + } +} + + +/***/ }), + +/***/ 770: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "Z": function() { return /* binding */ Datepicker; } +}); + +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/utils.js +var utils = __webpack_require__(105); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/date.js +var lib_date = __webpack_require__(560); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/date-format.js +var date_format = __webpack_require__(963); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/event.js +var lib_event = __webpack_require__(698); +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/i18n/base-locales.js +// default locales +const locales = { + en: { + days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], + daysShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], + daysMin: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], + months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], + monthsShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], + today: "Today", + clear: "Clear", + titleFormat: "MM y" + } +}; + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/options/defaultOptions.js +// config options updatable by setOptions() and their default values +const defaultOptions = { + autohide: false, + beforeShowDay: null, + beforeShowDecade: null, + beforeShowMonth: null, + beforeShowYear: null, + calendarWeeks: false, + clearBtn: false, + dateDelimiter: ',', + datesDisabled: [], + daysOfWeekDisabled: [], + daysOfWeekHighlighted: [], + defaultViewDate: undefined, // placeholder, defaults to today() by the program + disableTouchKeyboard: false, + format: 'mm/dd/yyyy', + language: 'en', + maxDate: null, + maxNumberOfDates: 1, + maxView: 3, + minDate: null, + nextArrow: '', + orientation: 'auto', + pickLevel: 0, + prevArrow: '', + showDaysOfWeek: true, + showOnClick: true, + showOnFocus: true, + startView: 0, + title: '', + todayBtn: false, + todayBtnMode: 0, + todayHighlight: false, + updateOnBlur: true, + weekStart: 0, +}; + +/* harmony default export */ var options_defaultOptions = (defaultOptions); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/lib/dom.js +const range = document.createRange(); + +function parseHTML(html) { + return range.createContextualFragment(html); +} + +// equivalent to jQuery's :visble +function isVisible(el) { + return !!(el.offsetWidth || el.offsetHeight || el.getClientRects().length); +} + +function hideElement(el) { + if (el.style.display === 'none') { + return; + } + // back up the existing display setting in data-style-display + if (el.style.display) { + el.dataset.styleDisplay = el.style.display; + } + el.style.display = 'none'; +} + +function showElement(el) { + if (el.style.display !== 'none') { + return; + } + if (el.dataset.styleDisplay) { + // restore backed-up dispay property + el.style.display = el.dataset.styleDisplay; + delete el.dataset.styleDisplay; + } else { + el.style.display = ''; + } +} + +function emptyChildNodes(el) { + if (el.firstChild) { + el.removeChild(el.firstChild); + emptyChildNodes(el); + } +} + +function replaceChildNodes(el, newChildNodes) { + emptyChildNodes(el); + if (newChildNodes instanceof DocumentFragment) { + el.appendChild(newChildNodes); + } else if (typeof newChildNodes === 'string') { + el.appendChild(parseHTML(newChildNodes)); + } else if (typeof newChildNodes.forEach === 'function') { + newChildNodes.forEach((node) => { + el.appendChild(node); + }); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/options/processOptions.js + + + + + + +const { + language: defaultLang, + format: defaultFormat, + weekStart: defaultWeekStart, +} = options_defaultOptions; + +// Reducer function to filter out invalid day-of-week from the input +function sanitizeDOW(dow, day) { + return dow.length < 6 && day >= 0 && day < 7 + ? (0,utils/* pushUnique */.$C)(dow, day) + : dow; +} + +function calcEndOfWeek(startOfWeek) { + return (startOfWeek + 6) % 7; +} + +// validate input date. if invalid, fallback to the original value +function validateDate(value, format, locale, origValue) { + const date = (0,date_format/* parseDate */.sG)(value, format, locale); + return date !== undefined ? date : origValue; +} + +// Validate viewId. if invalid, fallback to the original value +function validateViewId(value, origValue, max = 3) { + const viewId = parseInt(value, 10); + return viewId >= 0 && viewId <= max ? viewId : origValue; +} + +// Create Datepicker configuration to set +function processOptions(options, datepicker) { + const inOpts = Object.assign({}, options); + const config = {}; + const locales = datepicker.constructor.locales; + let { + format, + language, + locale, + maxDate, + maxView, + minDate, + pickLevel, + startView, + weekStart, + } = datepicker.config || {}; + + if (inOpts.language) { + let lang; + if (inOpts.language !== language) { + if (locales[inOpts.language]) { + lang = inOpts.language; + } else { + // Check if langauge + region tag can fallback to the one without + // region (e.g. fr-CA → fr) + lang = inOpts.language.split('-')[0]; + if (locales[lang] === undefined) { + lang = false; + } + } + } + delete inOpts.language; + if (lang) { + language = config.language = lang; + + // update locale as well when updating language + const origLocale = locale || locales[defaultLang]; + // use default language's properties for the fallback + locale = Object.assign({ + format: defaultFormat, + weekStart: defaultWeekStart + }, locales[defaultLang]); + if (language !== defaultLang) { + Object.assign(locale, locales[language]); + } + config.locale = locale; + // if format and/or weekStart are the same as old locale's defaults, + // update them to new locale's defaults + if (format === origLocale.format) { + format = config.format = locale.format; + } + if (weekStart === origLocale.weekStart) { + weekStart = config.weekStart = locale.weekStart; + config.weekEnd = calcEndOfWeek(locale.weekStart); + } + } + } + + if (inOpts.format) { + const hasToDisplay = typeof inOpts.format.toDisplay === 'function'; + const hasToValue = typeof inOpts.format.toValue === 'function'; + const validFormatString = date_format/* reFormatTokens.test */.CL.test(inOpts.format); + if ((hasToDisplay && hasToValue) || validFormatString) { + format = config.format = inOpts.format; + } + delete inOpts.format; + } + + //*** dates ***// + // while min and maxDate for "no limit" in the options are better to be null + // (especially when updating), the ones in the config have to be undefined + // because null is treated as 0 (= unix epoch) when comparing with time value + let minDt = minDate; + let maxDt = maxDate; + if (inOpts.minDate !== undefined) { + minDt = inOpts.minDate === null + ? (0,lib_date/* dateValue */.by)(0, 0, 1) // set 0000-01-01 to prevent negative values for year + : validateDate(inOpts.minDate, format, locale, minDt); + delete inOpts.minDate; + } + if (inOpts.maxDate !== undefined) { + maxDt = inOpts.maxDate === null + ? undefined + : validateDate(inOpts.maxDate, format, locale, maxDt); + delete inOpts.maxDate; + } + if (maxDt < minDt) { + minDate = config.minDate = maxDt; + maxDate = config.maxDate = minDt; + } else { + if (minDate !== minDt) { + minDate = config.minDate = minDt; + } + if (maxDate !== maxDt) { + maxDate = config.maxDate = maxDt; + } + } + + if (inOpts.datesDisabled) { + config.datesDisabled = inOpts.datesDisabled.reduce((dates, dt) => { + const date = (0,date_format/* parseDate */.sG)(dt, format, locale); + return date !== undefined ? (0,utils/* pushUnique */.$C)(dates, date) : dates; + }, []); + delete inOpts.datesDisabled; + } + if (inOpts.defaultViewDate !== undefined) { + const viewDate = (0,date_format/* parseDate */.sG)(inOpts.defaultViewDate, format, locale); + if (viewDate !== undefined) { + config.defaultViewDate = viewDate; + } + delete inOpts.defaultViewDate; + } + + //*** days of week ***// + if (inOpts.weekStart !== undefined) { + const wkStart = Number(inOpts.weekStart) % 7; + if (!isNaN(wkStart)) { + weekStart = config.weekStart = wkStart; + config.weekEnd = calcEndOfWeek(wkStart); + } + delete inOpts.weekStart; + } + if (inOpts.daysOfWeekDisabled) { + config.daysOfWeekDisabled = inOpts.daysOfWeekDisabled.reduce(sanitizeDOW, []); + delete inOpts.daysOfWeekDisabled; + } + if (inOpts.daysOfWeekHighlighted) { + config.daysOfWeekHighlighted = inOpts.daysOfWeekHighlighted.reduce(sanitizeDOW, []); + delete inOpts.daysOfWeekHighlighted; + } + + //*** multi date ***// + if (inOpts.maxNumberOfDates !== undefined) { + const maxNumberOfDates = parseInt(inOpts.maxNumberOfDates, 10); + if (maxNumberOfDates >= 0) { + config.maxNumberOfDates = maxNumberOfDates; + config.multidate = maxNumberOfDates !== 1; + } + delete inOpts.maxNumberOfDates; + } + if (inOpts.dateDelimiter) { + config.dateDelimiter = String(inOpts.dateDelimiter); + delete inOpts.dateDelimiter; + } + + //*** pick level & view ***// + let newPickLevel = pickLevel; + if (inOpts.pickLevel !== undefined) { + newPickLevel = validateViewId(inOpts.pickLevel, 2); + delete inOpts.pickLevel; + } + if (newPickLevel !== pickLevel) { + pickLevel = config.pickLevel = newPickLevel; + } + + let newMaxView = maxView; + if (inOpts.maxView !== undefined) { + newMaxView = validateViewId(inOpts.maxView, maxView); + delete inOpts.maxView; + } + // ensure max view >= pick level + newMaxView = pickLevel > newMaxView ? pickLevel : newMaxView; + if (newMaxView !== maxView) { + maxView = config.maxView = newMaxView; + } + + let newStartView = startView; + if (inOpts.startView !== undefined) { + newStartView = validateViewId(inOpts.startView, newStartView); + delete inOpts.startView; + } + // ensure pick level <= start view <= max view + if (newStartView < pickLevel) { + newStartView = pickLevel; + } else if (newStartView > maxView) { + newStartView = maxView; + } + if (newStartView !== startView) { + config.startView = newStartView; + } + + //*** template ***// + if (inOpts.prevArrow) { + const prevArrow = parseHTML(inOpts.prevArrow); + if (prevArrow.childNodes.length > 0) { + config.prevArrow = prevArrow.childNodes; + } + delete inOpts.prevArrow; + } + if (inOpts.nextArrow) { + const nextArrow = parseHTML(inOpts.nextArrow); + if (nextArrow.childNodes.length > 0) { + config.nextArrow = nextArrow.childNodes; + } + delete inOpts.nextArrow; + } + + //*** misc ***// + if (inOpts.disableTouchKeyboard !== undefined) { + config.disableTouchKeyboard = 'ontouchstart' in document && !!inOpts.disableTouchKeyboard; + delete inOpts.disableTouchKeyboard; + } + if (inOpts.orientation) { + const orientation = inOpts.orientation.toLowerCase().split(/\s+/g); + config.orientation = { + x: orientation.find(x => (x === 'left' || x === 'right')) || 'auto', + y: orientation.find(y => (y === 'top' || y === 'bottom')) || 'auto', + }; + delete inOpts.orientation; + } + if (inOpts.todayBtnMode !== undefined) { + switch(inOpts.todayBtnMode) { + case 0: + case 1: + config.todayBtnMode = inOpts.todayBtnMode; + } + delete inOpts.todayBtnMode; + } + + //*** copy the rest ***// + Object.keys(inOpts).forEach((key) => { + if (inOpts[key] !== undefined && (0,utils/* hasProperty */.l$)(options_defaultOptions, key)) { + config[key] = inOpts[key]; + } + }); + + return config; +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/pickerTemplate.js + + +const pickerTemplate = (0,utils/* optimizeTemplateHTML */.zh)(``); + +/* harmony default export */ var templates_pickerTemplate = (pickerTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/daysTemplate.js + + +const daysTemplate = (0,utils/* optimizeTemplateHTML */.zh)(`
      +
      ${(0,utils/* createTagRepeat */.em)('span', 7, {class: 'dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      +
      ${(0,utils/* createTagRepeat */.em)('span', 42 , {class: 'block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'})}
      +
      `); + +/* harmony default export */ var templates_daysTemplate = (daysTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/calendarWeeksTemplate.js + + +const calendarWeeksTemplate = (0,utils/* optimizeTemplateHTML */.zh)(`
      +
      +
      ${(0,utils/* createTagRepeat */.em)('span', 6, {class: 'week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      +
      `); + +/* harmony default export */ var templates_calendarWeeksTemplate = (calendarWeeksTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/View.js + + + +// Base class of the view classes +class View { + constructor(picker, config) { + Object.assign(this, config, { + picker, + element: parseHTML(`
      `).firstChild, + selected: [], + }); + this.init(this.picker.datepicker.config); + } + + init(options) { + if (options.pickLevel !== undefined) { + this.isMinView = this.id === options.pickLevel; + } + this.setOptions(options); + this.updateFocus(); + this.updateSelection(); + } + + // Execute beforeShow() callback and apply the result to the element + // args: + // - current - current value on the iteration on view rendering + // - timeValue - time value of the date to pass to beforeShow() + performBeforeHook(el, current, timeValue) { + let result = this.beforeShow(new Date(timeValue)); + switch (typeof result) { + case 'boolean': + result = {enabled: result}; + break; + case 'string': + result = {classes: result}; + } + + if (result) { + if (result.enabled === false) { + el.classList.add('disabled'); + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + if (result.classes) { + const extraClasses = result.classes.split(/\s+/); + el.classList.add(...extraClasses); + if (extraClasses.includes('disabled')) { + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + } + if (result.content) { + replaceChildNodes(el, result.content); + } + } + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/DaysView.js + + + + + + + + +class DaysView extends View { + constructor(picker) { + super(picker, { + id: 0, + name: 'days', + cellClass: 'day', + }); + } + + init(options, onConstruction = true) { + if (onConstruction) { + const inner = parseHTML(templates_daysTemplate).firstChild; + this.dow = inner.firstChild; + this.grid = inner.lastChild; + this.element.appendChild(inner); + } + super.init(options); + } + + setOptions(options) { + let updateDOW; + + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + this.minDate = options.minDate; + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + this.maxDate = options.maxDate; + } + if (options.datesDisabled) { + this.datesDisabled = options.datesDisabled; + } + if (options.daysOfWeekDisabled) { + this.daysOfWeekDisabled = options.daysOfWeekDisabled; + updateDOW = true; + } + if (options.daysOfWeekHighlighted) { + this.daysOfWeekHighlighted = options.daysOfWeekHighlighted; + } + if (options.todayHighlight !== undefined) { + this.todayHighlight = options.todayHighlight; + } + if (options.weekStart !== undefined) { + this.weekStart = options.weekStart; + this.weekEnd = options.weekEnd; + updateDOW = true; + } + if (options.locale) { + const locale = this.locale = options.locale; + this.dayNames = locale.daysMin; + this.switchLabelFormat = locale.titleFormat; + updateDOW = true; + } + if (options.beforeShowDay !== undefined) { + this.beforeShow = typeof options.beforeShowDay === 'function' + ? options.beforeShowDay + : undefined; + } + + if (options.calendarWeeks !== undefined) { + if (options.calendarWeeks && !this.calendarWeeks) { + const weeksElem = parseHTML(templates_calendarWeeksTemplate).firstChild; + this.calendarWeeks = { + element: weeksElem, + dow: weeksElem.firstChild, + weeks: weeksElem.lastChild, + }; + this.element.insertBefore(weeksElem, this.element.firstChild); + } else if (this.calendarWeeks && !options.calendarWeeks) { + this.element.removeChild(this.calendarWeeks.element); + this.calendarWeeks = null; + } + } + if (options.showDaysOfWeek !== undefined) { + if (options.showDaysOfWeek) { + showElement(this.dow); + if (this.calendarWeeks) { + showElement(this.calendarWeeks.dow); + } + } else { + hideElement(this.dow); + if (this.calendarWeeks) { + hideElement(this.calendarWeeks.dow); + } + } + } + + // update days-of-week when locale, daysOfweekDisabled or weekStart is changed + if (updateDOW) { + Array.from(this.dow.children).forEach((el, index) => { + const dow = (this.weekStart + index) % 7; + el.textContent = this.dayNames[dow]; + el.className = this.daysOfWeekDisabled.includes(dow) ? 'dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed' : 'dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'; + }); + } + } + + // Apply update on the focused date to view's settings + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + const viewYear = viewDate.getFullYear(); + const viewMonth = viewDate.getMonth(); + const firstOfMonth = (0,lib_date/* dateValue */.by)(viewYear, viewMonth, 1); + const start = (0,lib_date/* dayOfTheWeekOf */.fr)(firstOfMonth, this.weekStart, this.weekStart); + + this.first = firstOfMonth; + this.last = (0,lib_date/* dateValue */.by)(viewYear, viewMonth + 1, 0); + this.start = start; + this.focused = this.picker.viewDate; + } + + // Apply update on the selected dates to view's settings + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates; + if (rangepicker) { + this.range = rangepicker.dates; + } + } + + // Update the entire view UI + render() { + // update today marker on ever render + this.today = this.todayHighlight ? (0,lib_date/* today */.Lg)() : undefined; + // refresh disabled dates on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = [...this.datesDisabled]; + + const switchLabel = (0,date_format/* formatDate */.p6)(this.focused, this.switchLabelFormat, this.locale); + this.picker.setViewSwitchLabel(switchLabel); + this.picker.setPrevBtnDisabled(this.first <= this.minDate); + this.picker.setNextBtnDisabled(this.last >= this.maxDate); + + if (this.calendarWeeks) { + // start of the UTC week (Monday) of the 1st of the month + const startOfWeek = (0,lib_date/* dayOfTheWeekOf */.fr)(this.first, 1, 1); + Array.from(this.calendarWeeks.weeks.children).forEach((el, index) => { + el.textContent = (0,lib_date/* getWeek */.Qk)((0,lib_date/* addWeeks */.jh)(startOfWeek, index)); + }); + } + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const current = (0,lib_date/* addDays */.E4)(this.start, index); + const date = new Date(current); + const day = date.getDay(); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + el.dataset.date = current; + el.textContent = date.getDate(); + + if (current < this.first) { + classList.add('prev', 'text-gray-500', 'dark:text-white'); + } else if (current > this.last) { + classList.add('next', 'text-gray-500', 'dark:text-white'); + } + if (this.today === current) { + classList.add('today', 'bg-gray-100', 'dark:bg-gray-600'); + } + if (current < this.minDate || current > this.maxDate || this.disabled.includes(current)) { + classList.add('disabled', 'cursor-not-allowed'); + } + if (this.daysOfWeekDisabled.includes(day)) { + classList.add('disabled', 'cursor-not-allowed'); + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + if (this.daysOfWeekHighlighted.includes(day)) { + classList.add('highlighted'); + } + if (this.range) { + const [rangeStart, rangeEnd] = this.range; + if (current > rangeStart && current < rangeEnd) { + classList.add('range', 'bg-gray-200', 'dark:bg-gray-600'); + classList.remove('rounded-lg', 'rounded-l-lg', 'rounded-r-lg') + } + if (current === rangeStart) { + classList.add('range-start', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-l-lg'); + classList.remove('rounded-lg', 'rounded-r-lg'); + } + if (current === rangeEnd) { + classList.add('range-end', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-r-lg'); + classList.remove('rounded-lg', 'rounded-l-lg'); + } + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'text-gray-500', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'dark:bg-gray-600', 'bg-gray-100', 'bg-gray-200'); + } + if (current === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, current, current); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const [rangeStart, rangeEnd] = this.range || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused'); + el.classList.add('text-gray-900', 'rounded-lg', 'dark:text-white'); + }); + Array.from(this.grid.children).forEach((el) => { + const current = Number(el.dataset.date); + const classList = el.classList; + classList.remove('bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg', 'rounded-r-lg') + if (current > rangeStart && current < rangeEnd) { + classList.add('range', 'bg-gray-200', 'dark:bg-gray-600'); + classList.remove('rounded-lg'); + } + if (current === rangeStart) { + classList.add('range-start', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg'); + classList.remove('rounded-lg', 'rounded-r-lg'); + } + if (current === rangeEnd) { + classList.add('range-end', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-r-lg'); + classList.remove('rounded-lg', 'rounded-l-lg'); + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'bg-gray-100', 'bg-gray-200', 'dark:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + const index = Math.round((this.focused - this.start) / 86400000); + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[index].classList.add('focused'); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/MonthsView.js + + + + + +function computeMonthRange(range, thisYear) { + if (!range || !range[0] || !range[1]) { + return; + } + + const [[startY, startM], [endY, endM]] = range; + if (startY > thisYear || endY < thisYear) { + return; + } + return [ + startY === thisYear ? startM : -1, + endY === thisYear ? endM : 12, + ]; +} + +class MonthsView extends View { + constructor(picker) { + super(picker, { + id: 1, + name: 'months', + cellClass: 'month', + }); + } + + init(options, onConstruction = true) { + if (onConstruction) { + this.grid = this.element; + this.element.classList.add('months', 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4'); + this.grid.appendChild(parseHTML((0,utils/* createTagRepeat */.em)('span', 12, {'data-month': ix => ix}))); + } + super.init(options); + } + + setOptions(options) { + if (options.locale) { + this.monthNames = options.locale.monthsShort; + } + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + if (options.minDate === undefined) { + this.minYear = this.minMonth = this.minDate = undefined; + } else { + const minDateObj = new Date(options.minDate); + this.minYear = minDateObj.getFullYear(); + this.minMonth = minDateObj.getMonth(); + this.minDate = minDateObj.setDate(1); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + if (options.maxDate === undefined) { + this.maxYear = this.maxMonth = this.maxDate = undefined; + } else { + const maxDateObj = new Date(options.maxDate); + this.maxYear = maxDateObj.getFullYear(); + this.maxMonth = maxDateObj.getMonth(); + this.maxDate = (0,lib_date/* dateValue */.by)(this.maxYear, this.maxMonth + 1, 0); + } + } + if (options.beforeShowMonth !== undefined) { + this.beforeShow = typeof options.beforeShowMonth === 'function' + ? options.beforeShowMonth + : undefined; + } + } + + // Update view's settings to reflect the viewDate set on the picker + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + this.year = viewDate.getFullYear(); + this.focused = viewDate.getMonth(); + } + + // Update view's settings to reflect the selected dates + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates.reduce((selected, timeValue) => { + const date = new Date(timeValue); + const year = date.getFullYear(); + const month = date.getMonth(); + if (selected[year] === undefined) { + selected[year] = [month]; + } else { + (0,utils/* pushUnique */.$C)(selected[year], month); + } + return selected; + }, {}); + if (rangepicker && rangepicker.dates) { + this.range = rangepicker.dates.map(timeValue => { + const date = new Date(timeValue); + return isNaN(date) ? undefined : [date.getFullYear(), date.getMonth()]; + }); + } + } + + // Update the entire view UI + render() { + // refresh disabled months on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = []; + + this.picker.setViewSwitchLabel(this.year); + this.picker.setPrevBtnDisabled(this.year <= this.minYear); + this.picker.setNextBtnDisabled(this.year >= this.maxYear); + + const selected = this.selected[this.year] || []; + const yrOutOfRange = this.year < this.minYear || this.year > this.maxYear; + const isMinYear = this.year === this.minYear; + const isMaxYear = this.year === this.maxYear; + const range = computeMonthRange(this.range, this.year); + + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const date = (0,lib_date/* dateValue */.by)(this.year, index, 1); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + if (this.isMinView) { + el.dataset.date = date; + } + // reset text on every render to clear the custom content set + // by beforeShow hook at previous render + el.textContent = this.monthNames[index]; + + if ( + yrOutOfRange + || isMinYear && index < this.minMonth + || isMaxYear && index > this.maxMonth + ) { + classList.add('disabled'); + } + if (range) { + const [rangeStart, rangeEnd] = range; + if (index > rangeStart && index < rangeEnd) { + classList.add('range'); + } + if (index === rangeStart) { + classList.add('range-start'); + } + if (index === rangeEnd) { + classList.add('range-end'); + } + } + if (selected.includes(index)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (index === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, index, date); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const selected = this.selected[this.year] || []; + const [rangeStart, rangeEnd] = computeMonthRange(this.range, this.year) || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'dark:bg-blue-600', 'dark:text-white', 'text-white', 'focused'); + el.classList.add('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + }); + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + if (index > rangeStart && index < rangeEnd) { + classList.add('range'); + } + if (index === rangeStart) { + classList.add('range-start'); + } + if (index === rangeEnd) { + classList.add('range-end'); + } + if (selected.includes(index)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (index === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[this.focused].classList.add('focused'); + } +} +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/YearsView.js + + + + + +function toTitleCase(word) { + return [...word].reduce((str, ch, ix) => str += ix ? ch : ch.toUpperCase(), ''); +} + +// Class representing the years and decades view elements +class YearsView extends View { + constructor(picker, config) { + super(picker, config); + } + + init(options, onConstruction = true) { + if (onConstruction) { + this.navStep = this.step * 10; + this.beforeShowOption = `beforeShow${toTitleCase(this.cellClass)}`; + this.grid = this.element; + this.element.classList.add(this.name, 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4'); + this.grid.appendChild(parseHTML((0,utils/* createTagRepeat */.em)('span', 12))); + } + super.init(options); + } + + setOptions(options) { + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + if (options.minDate === undefined) { + this.minYear = this.minDate = undefined; + } else { + this.minYear = (0,lib_date/* startOfYearPeriod */.ak)(options.minDate, this.step); + this.minDate = (0,lib_date/* dateValue */.by)(this.minYear, 0, 1); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + if (options.maxDate === undefined) { + this.maxYear = this.maxDate = undefined; + } else { + this.maxYear = (0,lib_date/* startOfYearPeriod */.ak)(options.maxDate, this.step); + this.maxDate = (0,lib_date/* dateValue */.by)(this.maxYear, 11, 31); + } + } + if (options[this.beforeShowOption] !== undefined) { + const beforeShow = options[this.beforeShowOption]; + this.beforeShow = typeof beforeShow === 'function' ? beforeShow : undefined; + } + } + + // Update view's settings to reflect the viewDate set on the picker + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + const first = (0,lib_date/* startOfYearPeriod */.ak)(viewDate, this.navStep); + const last = first + 9 * this.step; + + this.first = first; + this.last = last; + this.start = first - this.step; + this.focused = (0,lib_date/* startOfYearPeriod */.ak)(viewDate, this.step); + } + + // Update view's settings to reflect the selected dates + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates.reduce((years, timeValue) => { + return (0,utils/* pushUnique */.$C)(years, (0,lib_date/* startOfYearPeriod */.ak)(timeValue, this.step)); + }, []); + if (rangepicker && rangepicker.dates) { + this.range = rangepicker.dates.map(timeValue => { + if (timeValue !== undefined) { + return (0,lib_date/* startOfYearPeriod */.ak)(timeValue, this.step); + } + }); + } + } + + // Update the entire view UI + render() { + // refresh disabled years on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = []; + + this.picker.setViewSwitchLabel(`${this.first}-${this.last}`); + this.picker.setPrevBtnDisabled(this.first <= this.minYear); + this.picker.setNextBtnDisabled(this.last >= this.maxYear); + + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const current = this.start + (index * this.step); + const date = (0,lib_date/* dateValue */.by)(current, 0, 1); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + if (this.isMinView) { + el.dataset.date = date; + } + el.textContent = el.dataset.year = current; + + if (index === 0) { + classList.add('prev'); + } else if (index === 11) { + classList.add('next'); + } + if (current < this.minYear || current > this.maxYear) { + classList.add('disabled'); + } + if (this.range) { + const [rangeStart, rangeEnd] = this.range; + if (current > rangeStart && current < rangeEnd) { + classList.add('range'); + } + if (current === rangeStart) { + classList.add('range-start'); + } + if (current === rangeEnd) { + classList.add('range-end'); + } + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, current, date); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const [rangeStart, rangeEnd] = this.range || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused'); + }); + Array.from(this.grid.children).forEach((el) => { + const current = Number(el.textContent); + const classList = el.classList; + if (current > rangeStart && current < rangeEnd) { + classList.add('range'); + } + if (current === rangeStart) { + classList.add('range-start'); + } + if (current === rangeEnd) { + classList.add('range-end'); + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + const index = Math.round((this.focused - this.start) / this.step); + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[index].classList.add('focused'); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/functions.js + + + +function triggerDatepickerEvent(datepicker, type) { + const detail = { + date: datepicker.getDate(), + viewDate: new Date(datepicker.picker.viewDate), + viewId: datepicker.picker.currentView.id, + datepicker, + }; + datepicker.element.dispatchEvent(new CustomEvent(type, {detail})); +} + +// direction: -1 (to previous), 1 (to next) +function goToPrevOrNext(datepicker, direction) { + const {minDate, maxDate} = datepicker.config; + const {currentView, viewDate} = datepicker.picker; + let newViewDate; + switch (currentView.id) { + case 0: + newViewDate = (0,lib_date/* addMonths */.zI)(viewDate, direction); + break; + case 1: + newViewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction); + break; + default: + newViewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction * currentView.navStep); + } + newViewDate = (0,utils/* limitToRange */.jG)(newViewDate, minDate, maxDate); + datepicker.picker.changeFocus(newViewDate).render(); +} + +function switchView(datepicker) { + const viewId = datepicker.picker.currentView.id; + if (viewId === datepicker.config.maxView) { + return; + } + datepicker.picker.changeView(viewId + 1).render(); +} + +function unfocus(datepicker) { + if (datepicker.config.updateOnBlur) { + datepicker.update({autohide: true}); + } else { + datepicker.refresh('input'); + datepicker.hide(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/pickerListeners.js + + + + +function goToSelectedMonthOrYear(datepicker, selection) { + const picker = datepicker.picker; + const viewDate = new Date(picker.viewDate); + const viewId = picker.currentView.id; + const newDate = viewId === 1 + ? (0,lib_date/* addMonths */.zI)(viewDate, selection - viewDate.getMonth()) + : (0,lib_date/* addYears */.Bc)(viewDate, selection - viewDate.getFullYear()); + + picker.changeFocus(newDate).changeView(viewId - 1).render(); +} + +function onClickTodayBtn(datepicker) { + const picker = datepicker.picker; + const currentDate = (0,lib_date/* today */.Lg)(); + if (datepicker.config.todayBtnMode === 1) { + if (datepicker.config.autohide) { + datepicker.setDate(currentDate); + return; + } + datepicker.setDate(currentDate, {render: false}); + picker.update(); + } + if (picker.viewDate !== currentDate) { + picker.changeFocus(currentDate); + } + picker.changeView(0).render(); +} + +function onClickClearBtn(datepicker) { + datepicker.setDate({clear: true}); +} + +function onClickViewSwitch(datepicker) { + switchView(datepicker); +} + +function onClickPrevBtn(datepicker) { + goToPrevOrNext(datepicker, -1); +} + +function onClickNextBtn(datepicker) { + goToPrevOrNext(datepicker, 1); +} + +// For the picker's main block to delegete the events from `datepicker-cell`s +function onClickView(datepicker, ev) { + const target = (0,lib_event/* findElementInEventPath */.He)(ev, '.datepicker-cell'); + if (!target || target.classList.contains('disabled')) { + return; + } + + const {id, isMinView} = datepicker.picker.currentView; + if (isMinView) { + datepicker.setDate(Number(target.dataset.date)); + } else if (id === 1) { + goToSelectedMonthOrYear(datepicker, Number(target.dataset.month)); + } else { + goToSelectedMonthOrYear(datepicker, Number(target.dataset.year)); + } +} + +function onClickPicker(datepicker) { + if (!datepicker.inline && !datepicker.config.disableTouchKeyboard) { + datepicker.inputField.focus(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/Picker.js + + + + + + + + + + + +function processPickerOptions(picker, options) { + if (options.title !== undefined) { + if (options.title) { + picker.controls.title.textContent = options.title; + showElement(picker.controls.title); + } else { + picker.controls.title.textContent = ''; + hideElement(picker.controls.title); + } + } + if (options.prevArrow) { + const prevBtn = picker.controls.prevBtn; + emptyChildNodes(prevBtn); + options.prevArrow.forEach((node) => { + prevBtn.appendChild(node.cloneNode(true)); + }); + } + if (options.nextArrow) { + const nextBtn = picker.controls.nextBtn; + emptyChildNodes(nextBtn); + options.nextArrow.forEach((node) => { + nextBtn.appendChild(node.cloneNode(true)); + }); + } + if (options.locale) { + picker.controls.todayBtn.textContent = options.locale.today; + picker.controls.clearBtn.textContent = options.locale.clear; + } + if (options.todayBtn !== undefined) { + if (options.todayBtn) { + showElement(picker.controls.todayBtn); + } else { + hideElement(picker.controls.todayBtn); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'minDate') || (0,utils/* hasProperty */.l$)(options, 'maxDate')) { + const {minDate, maxDate} = picker.datepicker.config; + picker.controls.todayBtn.disabled = !(0,utils/* isInRange */.mh)((0,lib_date/* today */.Lg)(), minDate, maxDate); + } + if (options.clearBtn !== undefined) { + if (options.clearBtn) { + showElement(picker.controls.clearBtn); + } else { + hideElement(picker.controls.clearBtn); + } + } +} + +// Compute view date to reset, which will be... +// - the last item of the selected dates or defaultViewDate if no selection +// - limitted to minDate or maxDate if it exceeds the range +function computeResetViewDate(datepicker) { + const {dates, config} = datepicker; + const viewDate = dates.length > 0 ? (0,utils/* lastItemOf */.Jm)(dates) : config.defaultViewDate; + return (0,utils/* limitToRange */.jG)(viewDate, config.minDate, config.maxDate); +} + +// Change current view's view date +function setViewDate(picker, newDate) { + const oldViewDate = new Date(picker.viewDate); + const newViewDate = new Date(newDate); + const {id, year, first, last} = picker.currentView; + const viewYear = newViewDate.getFullYear(); + + picker.viewDate = newDate; + if (viewYear !== oldViewDate.getFullYear()) { + triggerDatepickerEvent(picker.datepicker, 'changeYear'); + } + if (newViewDate.getMonth() !== oldViewDate.getMonth()) { + triggerDatepickerEvent(picker.datepicker, 'changeMonth'); + } + + // return whether the new date is in different period on time from the one + // displayed in the current view + // when true, the view needs to be re-rendered on the next UI refresh. + switch (id) { + case 0: + return newDate < first || newDate > last; + case 1: + return viewYear !== year; + default: + return viewYear < first || viewYear > last; + } +} + +function getTextDirection(el) { + return window.getComputedStyle(el).direction; +} + +// Class representing the picker UI +class Picker { + constructor(datepicker) { + this.datepicker = datepicker; + + const template = templates_pickerTemplate.replace(/%buttonClass%/g, datepicker.config.buttonClass); + const element = this.element = parseHTML(template).firstChild; + const [header, main, footer] = element.firstChild.children; + const title = header.firstElementChild; + const [prevBtn, viewSwitch, nextBtn] = header.lastElementChild.children; + const [todayBtn, clearBtn] = footer.firstChild.children; + const controls = { + title, + prevBtn, + viewSwitch, + nextBtn, + todayBtn, + clearBtn, + }; + this.main = main; + this.controls = controls; + + const elementClass = datepicker.inline ? 'inline' : 'dropdown'; + element.classList.add(`datepicker-${elementClass}`); + elementClass === 'dropdown' ? element.classList.add('dropdown', 'absolute', 'top-0', 'left-0', 'z-50', 'pt-2') : null; + + processPickerOptions(this, datepicker.config); + this.viewDate = computeResetViewDate(datepicker); + + // set up event listeners + (0,lib_event/* registerListeners */.cF)(datepicker, [ + [element, 'click', onClickPicker.bind(null, datepicker), {capture: true}], + [main, 'click', onClickView.bind(null, datepicker)], + [controls.viewSwitch, 'click', onClickViewSwitch.bind(null, datepicker)], + [controls.prevBtn, 'click', onClickPrevBtn.bind(null, datepicker)], + [controls.nextBtn, 'click', onClickNextBtn.bind(null, datepicker)], + [controls.todayBtn, 'click', onClickTodayBtn.bind(null, datepicker)], + [controls.clearBtn, 'click', onClickClearBtn.bind(null, datepicker)], + ]); + + // set up views + this.views = [ + new DaysView(this), + new MonthsView(this), + new YearsView(this, {id: 2, name: 'years', cellClass: 'year', step: 1}), + new YearsView(this, {id: 3, name: 'decades', cellClass: 'decade', step: 10}), + ]; + this.currentView = this.views[datepicker.config.startView]; + + this.currentView.render(); + this.main.appendChild(this.currentView.element); + datepicker.config.container.appendChild(this.element); + } + + setOptions(options) { + processPickerOptions(this, options); + this.views.forEach((view) => { + view.init(options, false); + }); + this.currentView.render(); + } + + detach() { + this.datepicker.config.container.removeChild(this.element); + } + + show() { + if (this.active) { + return; + } + this.element.classList.add('active', 'block'); + this.element.classList.remove('hidden'); + this.active = true; + + const datepicker = this.datepicker; + if (!datepicker.inline) { + // ensure picker's direction matches input's + const inputDirection = getTextDirection(datepicker.inputField); + if (inputDirection !== getTextDirection(datepicker.config.container)) { + this.element.dir = inputDirection; + } else if (this.element.dir) { + this.element.removeAttribute('dir'); + } + + this.place(); + if (datepicker.config.disableTouchKeyboard) { + datepicker.inputField.blur(); + } + } + triggerDatepickerEvent(datepicker, 'show'); + } + + hide() { + if (!this.active) { + return; + } + this.datepicker.exitEditMode(); + this.element.classList.remove('active', 'block'); + this.element.classList.add('active', 'block', 'hidden'); + this.active = false; + triggerDatepickerEvent(this.datepicker, 'hide'); + } + + place() { + const {classList, style} = this.element; + const {config, inputField} = this.datepicker; + const container = config.container; + const { + width: calendarWidth, + height: calendarHeight, + } = this.element.getBoundingClientRect(); + const { + left: containerLeft, + top: containerTop, + width: containerWidth, + } = container.getBoundingClientRect(); + const { + left: inputLeft, + top: inputTop, + width: inputWidth, + height: inputHeight + } = inputField.getBoundingClientRect(); + let {x: orientX, y: orientY} = config.orientation; + let scrollTop; + let left; + let top; + + if (container === document.body) { + scrollTop = window.scrollY; + left = inputLeft + window.scrollX; + top = inputTop + scrollTop; + } else { + scrollTop = container.scrollTop; + left = inputLeft - containerLeft; + top = inputTop - containerTop + scrollTop; + } + + if (orientX === 'auto') { + if (left < 0) { + // align to the left and move into visible area if input's left edge < window's + orientX = 'left'; + left = 10; + } else if (left + calendarWidth > containerWidth) { + // align to the right if canlendar's right edge > container's + orientX = 'right'; + } else { + orientX = getTextDirection(inputField) === 'rtl' ? 'right' : 'left'; + } + } + if (orientX === 'right') { + left -= calendarWidth - inputWidth; + } + + if (orientY === 'auto') { + orientY = top - calendarHeight < scrollTop ? 'bottom' : 'top'; + } + if (orientY === 'top') { + top -= calendarHeight; + } else { + top += inputHeight; + } + + classList.remove( + 'datepicker-orient-top', + 'datepicker-orient-bottom', + 'datepicker-orient-right', + 'datepicker-orient-left' + ); + classList.add(`datepicker-orient-${orientY}`, `datepicker-orient-${orientX}`); + + style.top = top ? `${top}px` : top; + style.left = left ? `${left}px` : left; + } + + setViewSwitchLabel(labelText) { + this.controls.viewSwitch.textContent = labelText; + } + + setPrevBtnDisabled(disabled) { + this.controls.prevBtn.disabled = disabled; + } + + setNextBtnDisabled(disabled) { + this.controls.nextBtn.disabled = disabled; + } + + changeView(viewId) { + const oldView = this.currentView; + const newView = this.views[viewId]; + if (newView.id !== oldView.id) { + this.currentView = newView; + this._renderMethod = 'render'; + triggerDatepickerEvent(this.datepicker, 'changeView'); + this.main.replaceChild(newView.element, oldView.element); + } + return this; + } + + // Change the focused date (view date) + changeFocus(newViewDate) { + this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refreshFocus'; + this.views.forEach((view) => { + view.updateFocus(); + }); + return this; + } + + // Apply the change of the selected dates + update() { + const newViewDate = computeResetViewDate(this.datepicker); + this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refresh'; + this.views.forEach((view) => { + view.updateFocus(); + view.updateSelection(); + }); + return this; + } + + // Refresh the picker UI + render(quickRender = true) { + const renderMethod = (quickRender && this._renderMethod) || 'render'; + delete this._renderMethod; + + this.currentView[renderMethod](); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/inputFieldListeners.js + + + + +// Find the closest date that doesn't meet the condition for unavailable date +// Returns undefined if no available date is found +// addFn: function to calculate the next date +// - args: time value, amount +// increase: amount to pass to addFn +// testFn: function to test the unavailablity of the date +// - args: time value; retun: true if unavailable +function findNextAvailableOne(date, addFn, increase, testFn, min, max) { + if (!(0,utils/* isInRange */.mh)(date, min, max)) { + return; + } + if (testFn(date)) { + const newDate = addFn(date, increase); + return findNextAvailableOne(newDate, addFn, increase, testFn, min, max); + } + return date; +} + +// direction: -1 (left/up), 1 (right/down) +// vertical: true for up/down, false for left/right +function moveByArrowKey(datepicker, ev, direction, vertical) { + const picker = datepicker.picker; + const currentView = picker.currentView; + const step = currentView.step || 1; + let viewDate = picker.viewDate; + let addFn; + let testFn; + switch (currentView.id) { + case 0: + if (vertical) { + viewDate = (0,lib_date/* addDays */.E4)(viewDate, direction * 7); + } else if (ev.ctrlKey || ev.metaKey) { + viewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction); + } else { + viewDate = (0,lib_date/* addDays */.E4)(viewDate, direction); + } + addFn = lib_date/* addDays */.E4; + testFn = (date) => currentView.disabled.includes(date); + break; + case 1: + viewDate = (0,lib_date/* addMonths */.zI)(viewDate, vertical ? direction * 4 : direction); + addFn = lib_date/* addMonths */.zI; + testFn = (date) => { + const dt = new Date(date); + const {year, disabled} = currentView; + return dt.getFullYear() === year && disabled.includes(dt.getMonth()); + }; + break; + default: + viewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction * (vertical ? 4 : 1) * step); + addFn = lib_date/* addYears */.Bc; + testFn = date => currentView.disabled.includes((0,lib_date/* startOfYearPeriod */.ak)(date, step)); + } + viewDate = findNextAvailableOne( + viewDate, + addFn, + direction < 0 ? -step : step, + testFn, + currentView.minDate, + currentView.maxDate + ); + if (viewDate !== undefined) { + picker.changeFocus(viewDate).render(); + } +} + +function onKeydown(datepicker, ev) { + if (ev.key === 'Tab') { + unfocus(datepicker); + return; + } + + const picker = datepicker.picker; + const {id, isMinView} = picker.currentView; + if (!picker.active) { + switch (ev.key) { + case 'ArrowDown': + case 'Escape': + picker.show(); + break; + case 'Enter': + datepicker.update(); + break; + default: + return; + } + } else if (datepicker.editMode) { + switch (ev.key) { + case 'Escape': + picker.hide(); + break; + case 'Enter': + datepicker.exitEditMode({update: true, autohide: datepicker.config.autohide}); + break; + default: + return; + } + } else { + switch (ev.key) { + case 'Escape': + picker.hide(); + break; + case 'ArrowLeft': + if (ev.ctrlKey || ev.metaKey) { + goToPrevOrNext(datepicker, -1); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, -1, false); + } + break; + case 'ArrowRight': + if (ev.ctrlKey || ev.metaKey) { + goToPrevOrNext(datepicker, 1); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, 1, false); + } + break; + case 'ArrowUp': + if (ev.ctrlKey || ev.metaKey) { + switchView(datepicker); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, -1, true); + } + break; + case 'ArrowDown': + if (ev.shiftKey && !ev.ctrlKey && !ev.metaKey) { + datepicker.enterEditMode(); + return; + } + moveByArrowKey(datepicker, ev, 1, true); + break; + case 'Enter': + if (isMinView) { + datepicker.setDate(picker.viewDate); + } else { + picker.changeView(id - 1).render(); + } + break; + case 'Backspace': + case 'Delete': + datepicker.enterEditMode(); + return; + default: + if (ev.key.length === 1 && !ev.ctrlKey && !ev.metaKey) { + datepicker.enterEditMode(); + } + return; + } + } + ev.preventDefault(); + ev.stopPropagation(); +} + +function onFocus(datepicker) { + if (datepicker.config.showOnFocus && !datepicker._showing) { + datepicker.show(); + } +} + +// for the prevention for entering edit mode while getting focus on click +function onMousedown(datepicker, ev) { + const el = ev.target; + if (datepicker.picker.active || datepicker.config.showOnClick) { + el._active = el === document.activeElement; + el._clicking = setTimeout(() => { + delete el._active; + delete el._clicking; + }, 2000); + } +} + +function onClickInput(datepicker, ev) { + const el = ev.target; + if (!el._clicking) { + return; + } + clearTimeout(el._clicking); + delete el._clicking; + + if (el._active) { + datepicker.enterEditMode(); + } + delete el._active; + + if (datepicker.config.showOnClick) { + datepicker.show(); + } +} + +function onPaste(datepicker, ev) { + if (ev.clipboardData.types.includes('text/plain')) { + datepicker.enterEditMode(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/otherListeners.js + + + +// for the `document` to delegate the events from outside the picker/input field +function onClickOutside(datepicker, ev) { + const element = datepicker.element; + if (element !== document.activeElement) { + return; + } + const pickerElem = datepicker.picker.element; + if ((0,lib_event/* findElementInEventPath */.He)(ev, el => el === element || el === pickerElem)) { + return; + } + unfocus(datepicker); +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/Datepicker.js + + + + + + + + + + + + +function stringifyDates(dates, config) { + return dates + .map(dt => (0,date_format/* formatDate */.p6)(dt, config.format, config.locale)) + .join(config.dateDelimiter); +} + +// parse input dates and create an array of time values for selection +// returns undefined if there are no valid dates in inputDates +// when origDates (current selection) is passed, the function works to mix +// the input dates into the current selection +function processInputDates(datepicker, inputDates, clear = false) { + const {config, dates: origDates, rangepicker} = datepicker; + if (inputDates.length === 0) { + // empty input is considered valid unless origiDates is passed + return clear ? [] : undefined; + } + + const rangeEnd = rangepicker && datepicker === rangepicker.datepickers[1]; + let newDates = inputDates.reduce((dates, dt) => { + let date = (0,date_format/* parseDate */.sG)(dt, config.format, config.locale); + if (date === undefined) { + return dates; + } + if (config.pickLevel > 0) { + // adjust to 1st of the month/Jan 1st of the year + // or to the last day of the monh/Dec 31st of the year if the datepicker + // is the range-end picker of a rangepicker + const dt = new Date(date); + if (config.pickLevel === 1) { + date = rangeEnd + ? dt.setMonth(dt.getMonth() + 1, 0) + : dt.setDate(1); + } else { + date = rangeEnd + ? dt.setFullYear(dt.getFullYear() + 1, 0, 0) + : dt.setMonth(0, 1); + } + } + if ( + (0,utils/* isInRange */.mh)(date, config.minDate, config.maxDate) + && !dates.includes(date) + && !config.datesDisabled.includes(date) + && !config.daysOfWeekDisabled.includes(new Date(date).getDay()) + ) { + dates.push(date); + } + return dates; + }, []); + if (newDates.length === 0) { + return; + } + if (config.multidate && !clear) { + // get the synmetric difference between origDates and newDates + newDates = newDates.reduce((dates, date) => { + if (!origDates.includes(date)) { + dates.push(date); + } + return dates; + }, origDates.filter(date => !newDates.includes(date))); + } + // do length check always because user can input multiple dates regardless of the mode + return config.maxNumberOfDates && newDates.length > config.maxNumberOfDates + ? newDates.slice(config.maxNumberOfDates * -1) + : newDates; +} + +// refresh the UI elements +// modes: 1: input only, 2, picker only, 3 both +function refreshUI(datepicker, mode = 3, quickRender = true) { + const {config, picker, inputField} = datepicker; + if (mode & 2) { + const newView = picker.active ? config.pickLevel : config.startView; + picker.update().changeView(newView).render(quickRender); + } + if (mode & 1 && inputField) { + inputField.value = stringifyDates(datepicker.dates, config); + } +} + +function setDate(datepicker, inputDates, options) { + let {clear, render, autohide} = options; + if (render === undefined) { + render = true; + } + if (!render) { + autohide = false; + } else if (autohide === undefined) { + autohide = datepicker.config.autohide; + } + + const newDates = processInputDates(datepicker, inputDates, clear); + if (!newDates) { + return; + } + if (newDates.toString() !== datepicker.dates.toString()) { + datepicker.dates = newDates; + refreshUI(datepicker, render ? 3 : 1); + triggerDatepickerEvent(datepicker, 'changeDate'); + } else { + refreshUI(datepicker, 1); + } + if (autohide) { + datepicker.hide(); + } +} + +/** + * Class representing a date picker + */ +class Datepicker { + /** + * Create a date picker + * @param {Element} element - element to bind a date picker + * @param {Object} [options] - config options + * @param {DateRangePicker} [rangepicker] - DateRangePicker instance the + * date picker belongs to. Use this only when creating date picker as a part + * of date range picker + */ + constructor(element, options = {}, rangepicker = undefined) { + element.datepicker = this; + this.element = element; + + // set up config + const config = this.config = Object.assign({ + buttonClass: (options.buttonClass && String(options.buttonClass)) || 'button', + container: document.body, + defaultViewDate: (0,lib_date/* today */.Lg)(), + maxDate: undefined, + minDate: undefined, + }, processOptions(options_defaultOptions, this)); + this._options = options; + Object.assign(config, processOptions(options, this)); + + // configure by type + const inline = this.inline = element.tagName !== 'INPUT'; + let inputField; + let initialDates; + + if (inline) { + config.container = element; + initialDates = (0,utils/* stringToArray */.W7)(element.dataset.date, config.dateDelimiter); + delete element.dataset.date; + } else { + const container = options.container ? document.querySelector(options.container) : null; + if (container) { + config.container = container; + } + inputField = this.inputField = element; + inputField.classList.add('datepicker-input'); + initialDates = (0,utils/* stringToArray */.W7)(inputField.value, config.dateDelimiter); + } + if (rangepicker) { + // check validiry + const index = rangepicker.inputs.indexOf(inputField); + const datepickers = rangepicker.datepickers; + if (index < 0 || index > 1 || !Array.isArray(datepickers)) { + throw Error('Invalid rangepicker object.'); + } + // attach itaelf to the rangepicker here so that processInputDates() can + // determine if this is the range-end picker of the rangepicker while + // setting inital values when pickLevel > 0 + datepickers[index] = this; + // add getter for rangepicker + Object.defineProperty(this, 'rangepicker', { + get() { + return rangepicker; + }, + }); + } + + // set initial dates + this.dates = []; + // process initial value + const inputDateValues = processInputDates(this, initialDates); + if (inputDateValues && inputDateValues.length > 0) { + this.dates = inputDateValues; + } + if (inputField) { + inputField.value = stringifyDates(this.dates, config); + } + + const picker = this.picker = new Picker(this); + + if (inline) { + this.show(); + } else { + // set up event listeners in other modes + const onMousedownDocument = onClickOutside.bind(null, this); + const listeners = [ + [inputField, 'keydown', onKeydown.bind(null, this)], + [inputField, 'focus', onFocus.bind(null, this)], + [inputField, 'mousedown', onMousedown.bind(null, this)], + [inputField, 'click', onClickInput.bind(null, this)], + [inputField, 'paste', onPaste.bind(null, this)], + [document, 'mousedown', onMousedownDocument], + [document, 'touchstart', onMousedownDocument], + [window, 'resize', picker.place.bind(picker)] + ]; + (0,lib_event/* registerListeners */.cF)(this, listeners); + } + } + + /** + * Format Date object or time value in given format and language + * @param {Date|Number} date - date or time value to format + * @param {String|Object} format - format string or object that contains + * toDisplay() custom formatter, whose signature is + * - args: + * - date: {Date} - Date instance of the date passed to the method + * - format: {Object} - the format object passed to the method + * - locale: {Object} - locale for the language specified by `lang` + * - return: + * {String} formatted date + * @param {String} [lang=en] - language code for the locale to use + * @return {String} formatted date + */ + static formatDate(date, format, lang) { + return (0,date_format/* formatDate */.p6)(date, format, lang && locales[lang] || locales.en); + } + + /** + * Parse date string + * @param {String|Date|Number} dateStr - date string, Date object or time + * value to parse + * @param {String|Object} format - format string or object that contains + * toValue() custom parser, whose signature is + * - args: + * - dateStr: {String|Date|Number} - the dateStr passed to the method + * - format: {Object} - the format object passed to the method + * - locale: {Object} - locale for the language specified by `lang` + * - return: + * {Date|Number} parsed date or its time value + * @param {String} [lang=en] - language code for the locale to use + * @return {Number} time value of parsed date + */ + static parseDate(dateStr, format, lang) { + return (0,date_format/* parseDate */.sG)(dateStr, format, lang && locales[lang] || locales.en); + } + + /** + * @type {Object} - Installed locales in `[languageCode]: localeObject` format + * en`:_English (US)_ is pre-installed. + */ + static get locales() { + return locales; + } + + /** + * @type {Boolean} - Whether the picker element is shown. `true` whne shown + */ + get active() { + return !!(this.picker && this.picker.active); + } + + /** + * @type {HTMLDivElement} - DOM object of picker element + */ + get pickerElement() { + return this.picker ? this.picker.element : undefined; + } + + /** + * Set new values to the config options + * @param {Object} options - config options to update + */ + setOptions(options) { + const picker = this.picker; + const newOptions = processOptions(options, this); + Object.assign(this._options, options); + Object.assign(this.config, newOptions); + picker.setOptions(newOptions); + + refreshUI(this, 3); + } + + /** + * Show the picker element + */ + show() { + if (this.inputField) { + if (this.inputField.disabled) { + return; + } + if (this.inputField !== document.activeElement) { + this._showing = true; + this.inputField.focus(); + delete this._showing; + } + } + this.picker.show(); + } + + /** + * Hide the picker element + * Not available on inline picker + */ + hide() { + if (this.inline) { + return; + } + this.picker.hide(); + this.picker.update().changeView(this.config.startView).render(); + } + + /** + * Destroy the Datepicker instance + * @return {Detepicker} - the instance destroyed + */ + destroy() { + this.hide(); + (0,lib_event/* unregisterListeners */.uV)(this); + this.picker.detach(); + if (!this.inline) { + this.inputField.classList.remove('datepicker-input'); + } + delete this.element.datepicker; + return this; + } + + /** + * Get the selected date(s) + * + * The method returns a Date object of selected date by default, and returns + * an array of selected dates in multidate mode. If format string is passed, + * it returns date string(s) formatted in given format. + * + * @param {String} [format] - Format string to stringify the date(s) + * @return {Date|String|Date[]|String[]} - selected date(s), or if none is + * selected, empty array in multidate mode and untitled in sigledate mode + */ + getDate(format = undefined) { + const callback = format + ? date => (0,date_format/* formatDate */.p6)(date, format, this.config.locale) + : date => new Date(date); + + if (this.config.multidate) { + return this.dates.map(callback); + } + if (this.dates.length > 0) { + return callback(this.dates[0]); + } + } + + /** + * Set selected date(s) + * + * In multidate mode, you can pass multiple dates as a series of arguments + * or an array. (Since each date is parsed individually, the type of the + * dates doesn't have to be the same.) + * The given dates are used to toggle the select status of each date. The + * number of selected dates is kept from exceeding the length set to + * maxNumberOfDates. + * + * With clear: true option, the method can be used to clear the selection + * and to replace the selection instead of toggling in multidate mode. + * If the option is passed with no date arguments or an empty dates array, + * it works as "clear" (clear the selection then set nothing), and if the + * option is passed with new dates to select, it works as "replace" (clear + * the selection then set the given dates) + * + * When render: false option is used, the method omits re-rendering the + * picker element. In this case, you need to call refresh() method later in + * order for the picker element to reflect the changes. The input field is + * refreshed always regardless of this option. + * + * When invalid (unparsable, repeated, disabled or out-of-range) dates are + * passed, the method ignores them and applies only valid ones. In the case + * that all the given dates are invalid, which is distinguished from passing + * no dates, the method considers it as an error and leaves the selection + * untouched. + * + * @param {...(Date|Number|String)|Array} [dates] - Date strings, Date + * objects, time values or mix of those for new selection + * @param {Object} [options] - function options + * - clear: {boolean} - Whether to clear the existing selection + * defualt: false + * - render: {boolean} - Whether to re-render the picker element + * default: true + * - autohide: {boolean} - Whether to hide the picker element after re-render + * Ignored when used with render: false + * default: config.autohide + */ + setDate(...args) { + const dates = [...args]; + const opts = {}; + const lastArg = (0,utils/* lastItemOf */.Jm)(args); + if ( + typeof lastArg === 'object' + && !Array.isArray(lastArg) + && !(lastArg instanceof Date) + && lastArg + ) { + Object.assign(opts, dates.pop()); + } + + const inputDates = Array.isArray(dates[0]) ? dates[0] : dates; + setDate(this, inputDates, opts); + } + + /** + * Update the selected date(s) with input field's value + * Not available on inline picker + * + * The input field will be refreshed with properly formatted date string. + * + * @param {Object} [options] - function options + * - autohide: {boolean} - whether to hide the picker element after refresh + * default: false + */ + update(options = undefined) { + if (this.inline) { + return; + } + + const opts = {clear: true, autohide: !!(options && options.autohide)}; + const inputDates = (0,utils/* stringToArray */.W7)(this.inputField.value, this.config.dateDelimiter); + setDate(this, inputDates, opts); + } + + /** + * Refresh the picker element and the associated input field + * @param {String} [target] - target item when refreshing one item only + * 'picker' or 'input' + * @param {Boolean} [forceRender] - whether to re-render the picker element + * regardless of its state instead of optimized refresh + */ + refresh(target = undefined, forceRender = false) { + if (target && typeof target !== 'string') { + forceRender = target; + target = undefined; + } + + let mode; + if (target === 'picker') { + mode = 2; + } else if (target === 'input') { + mode = 1; + } else { + mode = 3; + } + refreshUI(this, mode, !forceRender); + } + + /** + * Enter edit mode + * Not available on inline picker or when the picker element is hidden + */ + enterEditMode() { + if (this.inline || !this.picker.active || this.editMode) { + return; + } + this.editMode = true; + this.inputField.classList.add('in-edit', 'border-blue-700'); + } + + /** + * Exit from edit mode + * Not available on inline picker + * @param {Object} [options] - function options + * - update: {boolean} - whether to call update() after exiting + * If false, input field is revert to the existing selection + * default: false + */ + exitEditMode(options = undefined) { + if (this.inline || !this.editMode) { + return; + } + const opts = Object.assign({update: false}, options); + delete this.editMode; + this.inputField.classList.remove('in-edit', 'border-blue-700'); + if (opts.update) { + this.update(opts); + } + } +} + + +/***/ }), + +/***/ 963: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "CL": function() { return /* binding */ reFormatTokens; }, +/* harmony export */ "p6": function() { return /* binding */ formatDate; }, +/* harmony export */ "sG": function() { return /* binding */ parseDate; } +/* harmony export */ }); +/* unused harmony export reNonDateParts */ +/* harmony import */ var _date_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(560); +/* harmony import */ var _utils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(105); + + + +// pattern for format parts +const reFormatTokens = /dd?|DD?|mm?|MM?|yy?(?:yy)?/; +// pattern for non date parts +const reNonDateParts = /[\s!-/:-@[-`{-~年月日]+/; +// cache for persed formats +let knownFormats = {}; +// parse funtions for date parts +const parseFns = { + y(date, year) { + return new Date(date).setFullYear(parseInt(year, 10)); + }, + m(date, month, locale) { + const newDate = new Date(date); + let monthIndex = parseInt(month, 10) - 1; + + if (isNaN(monthIndex)) { + if (!month) { + return NaN; + } + + const monthName = month.toLowerCase(); + const compareNames = name => name.toLowerCase().startsWith(monthName); + // compare with both short and full names because some locales have periods + // in the short names (not equal to the first X letters of the full names) + monthIndex = locale.monthsShort.findIndex(compareNames); + if (monthIndex < 0) { + monthIndex = locale.months.findIndex(compareNames); + } + if (monthIndex < 0) { + return NaN; + } + } + + newDate.setMonth(monthIndex); + return newDate.getMonth() !== normalizeMonth(monthIndex) + ? newDate.setDate(0) + : newDate.getTime(); + }, + d(date, day) { + return new Date(date).setDate(parseInt(day, 10)); + }, +}; +// format functions for date parts +const formatFns = { + d(date) { + return date.getDate(); + }, + dd(date) { + return padZero(date.getDate(), 2); + }, + D(date, locale) { + return locale.daysShort[date.getDay()]; + }, + DD(date, locale) { + return locale.days[date.getDay()]; + }, + m(date) { + return date.getMonth() + 1; + }, + mm(date) { + return padZero(date.getMonth() + 1, 2); + }, + M(date, locale) { + return locale.monthsShort[date.getMonth()]; + }, + MM(date, locale) { + return locale.months[date.getMonth()]; + }, + y(date) { + return date.getFullYear(); + }, + yy(date) { + return padZero(date.getFullYear(), 2).slice(-2); + }, + yyyy(date) { + return padZero(date.getFullYear(), 4); + }, +}; + +// get month index in normal range (0 - 11) from any number +function normalizeMonth(monthIndex) { + return monthIndex > -1 ? monthIndex % 12 : normalizeMonth(monthIndex + 12); +} + +function padZero(num, length) { + return num.toString().padStart(length, '0'); +} + +function parseFormatString(format) { + if (typeof format !== 'string') { + throw new Error("Invalid date format."); + } + if (format in knownFormats) { + return knownFormats[format]; + } + + // sprit the format string into parts and seprators + const separators = format.split(reFormatTokens); + const parts = format.match(new RegExp(reFormatTokens, 'g')); + if (separators.length === 0 || !parts) { + throw new Error("Invalid date format."); + } + + // collect format functions used in the format + const partFormatters = parts.map(token => formatFns[token]); + + // collect parse function keys used in the format + // iterate over parseFns' keys in order to keep the order of the keys. + const partParserKeys = Object.keys(parseFns).reduce((keys, key) => { + const token = parts.find(part => part[0] !== 'D' && part[0].toLowerCase() === key); + if (token) { + keys.push(key); + } + return keys; + }, []); + + return knownFormats[format] = { + parser(dateStr, locale) { + const dateParts = dateStr.split(reNonDateParts).reduce((dtParts, part, index) => { + if (part.length > 0 && parts[index]) { + const token = parts[index][0]; + if (token === 'M') { + dtParts.m = part; + } else if (token !== 'D') { + dtParts[token] = part; + } + } + return dtParts; + }, {}); + + // iterate over partParserkeys so that the parsing is made in the oder + // of year, month and day to prevent the day parser from correcting last + // day of month wrongly + return partParserKeys.reduce((origDate, key) => { + const newDate = parseFns[key](origDate, dateParts[key], locale); + // ingnore the part failed to parse + return isNaN(newDate) ? origDate : newDate; + }, (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .today */ .Lg)()); + }, + formatter(date, locale) { + let dateStr = partFormatters.reduce((str, fn, index) => { + return str += `${separators[index]}${fn(date, locale)}`; + }, ''); + // separators' length is always parts' length + 1, + return dateStr += (0,_utils_js__WEBPACK_IMPORTED_MODULE_1__/* .lastItemOf */ .Jm)(separators); + }, + }; +} + +function parseDate(dateStr, format, locale) { + if (dateStr instanceof Date || typeof dateStr === 'number') { + const date = (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .stripTime */ .xR)(dateStr); + return isNaN(date) ? undefined : date; + } + if (!dateStr) { + return undefined; + } + if (dateStr === 'today') { + return (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .today */ .Lg)(); + } + + if (format && format.toValue) { + const date = format.toValue(dateStr, format, locale); + return isNaN(date) ? undefined : (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .stripTime */ .xR)(date); + } + + return parseFormatString(format).parser(dateStr, locale); +} + +function formatDate(date, format, locale) { + if (isNaN(date) || (!date && date !== 0)) { + return ''; + } + + const dateObj = typeof date === 'number' ? new Date(date) : date; + + if (format.toDisplay) { + return format.toDisplay(dateObj, format, locale); + } + + return parseFormatString(format).formatter(dateObj, locale); +} + + +/***/ }), + +/***/ 560: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Bc": function() { return /* binding */ addYears; }, +/* harmony export */ "E4": function() { return /* binding */ addDays; }, +/* harmony export */ "Lg": function() { return /* binding */ today; }, +/* harmony export */ "Qk": function() { return /* binding */ getWeek; }, +/* harmony export */ "ak": function() { return /* binding */ startOfYearPeriod; }, +/* harmony export */ "by": function() { return /* binding */ dateValue; }, +/* harmony export */ "fr": function() { return /* binding */ dayOfTheWeekOf; }, +/* harmony export */ "jh": function() { return /* binding */ addWeeks; }, +/* harmony export */ "xR": function() { return /* binding */ stripTime; }, +/* harmony export */ "zI": function() { return /* binding */ addMonths; } +/* harmony export */ }); +function stripTime(timeValue) { + return new Date(timeValue).setHours(0, 0, 0, 0); +} + +function today() { + return new Date().setHours(0, 0, 0, 0); +} + +// Get the time value of the start of given date or year, month and day +function dateValue(...args) { + switch (args.length) { + case 0: + return today(); + case 1: + return stripTime(args[0]); + } + + // use setFullYear() to keep 2-digit year from being mapped to 1900-1999 + const newDate = new Date(0); + newDate.setFullYear(...args); + return newDate.setHours(0, 0, 0, 0); +} + +function addDays(date, amount) { + const newDate = new Date(date); + return newDate.setDate(newDate.getDate() + amount); +} + +function addWeeks(date, amount) { + return addDays(date, amount * 7); +} + +function addMonths(date, amount) { + // If the day of the date is not in the new month, the last day of the new + // month will be returned. e.g. Jan 31 + 1 month → Feb 28 (not Mar 03) + const newDate = new Date(date); + const monthsToSet = newDate.getMonth() + amount; + let expectedMonth = monthsToSet % 12; + if (expectedMonth < 0) { + expectedMonth += 12; + } + + const time = newDate.setMonth(monthsToSet); + return newDate.getMonth() !== expectedMonth ? newDate.setDate(0) : time; +} + +function addYears(date, amount) { + // If the date is Feb 29 and the new year is not a leap year, Feb 28 of the + // new year will be returned. + const newDate = new Date(date); + const expectedMonth = newDate.getMonth(); + const time = newDate.setFullYear(newDate.getFullYear() + amount); + return expectedMonth === 1 && newDate.getMonth() === 2 ? newDate.setDate(0) : time; +} + +// Calculate the distance bettwen 2 days of the week +function dayDiff(day, from) { + return (day - from + 7) % 7; +} + +// Get the date of the specified day of the week of given base date +function dayOfTheWeekOf(baseDate, dayOfWeek, weekStart = 0) { + const baseDay = new Date(baseDate).getDay(); + return addDays(baseDate, dayDiff(dayOfWeek, weekStart) - dayDiff(baseDay, weekStart)); +} + +// Get the ISO week of a date +function getWeek(date) { + // start of ISO week is Monday + const thuOfTheWeek = dayOfTheWeekOf(date, 4, 1); + // 1st week == the week where the 4th of January is in + const firstThu = dayOfTheWeekOf(new Date(thuOfTheWeek).setMonth(0, 4), 4, 1); + return Math.round((thuOfTheWeek - firstThu) / 604800000) + 1; +} + +// Get the start year of the period of years that includes given date +// years: length of the year period +function startOfYearPeriod(date, years) { + /* @see https://en.wikipedia.org/wiki/Year_zero#ISO_8601 */ + const year = new Date(date).getFullYear(); + return Math.floor(year / years) * years; +} + + +/***/ }), + +/***/ 698: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "He": function() { return /* binding */ findElementInEventPath; }, +/* harmony export */ "cF": function() { return /* binding */ registerListeners; }, +/* harmony export */ "uV": function() { return /* binding */ unregisterListeners; } +/* harmony export */ }); +const listenerRegistry = new WeakMap(); +const {addEventListener, removeEventListener} = EventTarget.prototype; + +// Register event listeners to a key object +// listeners: array of listener definitions; +// - each definition must be a flat array of event target and the arguments +// used to call addEventListener() on the target +function registerListeners(keyObj, listeners) { + let registered = listenerRegistry.get(keyObj); + if (!registered) { + registered = []; + listenerRegistry.set(keyObj, registered); + } + listeners.forEach((listener) => { + addEventListener.call(...listener); + registered.push(listener); + }); +} + +function unregisterListeners(keyObj) { + let listeners = listenerRegistry.get(keyObj); + if (!listeners) { + return; + } + listeners.forEach((listener) => { + removeEventListener.call(...listener); + }); + listenerRegistry.delete(keyObj); +} + +// Event.composedPath() polyfill for Edge +// based on https://gist.github.com/kleinfreund/e9787d73776c0e3750dcfcdc89f100ec +if (!Event.prototype.composedPath) { + const getComposedPath = (node, path = []) => { + path.push(node); + + let parent; + if (node.parentNode) { + parent = node.parentNode; + } else if (node.host) { // ShadowRoot + parent = node.host; + } else if (node.defaultView) { // Document + parent = node.defaultView; + } + return parent ? getComposedPath(parent, path) : path; + }; + + Event.prototype.composedPath = function () { + return getComposedPath(this.target); + }; +} + +function findFromPath(path, criteria, currentTarget, index = 0) { + const el = path[index]; + if (criteria(el)) { + return el; + } else if (el === currentTarget || !el.parentElement) { + // stop when reaching currentTarget or + return; + } + return findFromPath(path, criteria, currentTarget, index + 1); +} + +// Search for the actual target of a delegated event +function findElementInEventPath(ev, selector) { + const criteria = typeof selector === 'function' ? selector : el => el.matches(selector); + return findFromPath(ev.composedPath(), criteria, ev.currentTarget); +} + + +/***/ }), + +/***/ 105: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "$C": function() { return /* binding */ pushUnique; }, +/* harmony export */ "Jm": function() { return /* binding */ lastItemOf; }, +/* harmony export */ "W7": function() { return /* binding */ stringToArray; }, +/* harmony export */ "em": function() { return /* binding */ createTagRepeat; }, +/* harmony export */ "jG": function() { return /* binding */ limitToRange; }, +/* harmony export */ "l$": function() { return /* binding */ hasProperty; }, +/* harmony export */ "mh": function() { return /* binding */ isInRange; }, +/* harmony export */ "zh": function() { return /* binding */ optimizeTemplateHTML; } +/* harmony export */ }); +function hasProperty(obj, prop) { + return Object.prototype.hasOwnProperty.call(obj, prop); +} + +function lastItemOf(arr) { + return arr[arr.length - 1]; +} + +// push only the items not included in the array +function pushUnique(arr, ...items) { + items.forEach((item) => { + if (arr.includes(item)) { + return; + } + arr.push(item); + }); + return arr; +} + +function stringToArray(str, separator) { + // convert empty string to an empty array + return str ? str.split(separator) : []; +} + +function isInRange(testVal, min, max) { + const minOK = min === undefined || testVal >= min; + const maxOK = max === undefined || testVal <= max; + return minOK && maxOK; +} + +function limitToRange(val, min, max) { + if (val < min) { + return min; + } + if (val > max) { + return max; + } + return val; +} + +function createTagRepeat(tagName, repeat, attributes = {}, index = 0, html = '') { + const openTagSrc = Object.keys(attributes).reduce((src, attr) => { + let val = attributes[attr]; + if (typeof val === 'function') { + val = val(index); + } + return `${src} ${attr}="${val}"`; + }, tagName); + html += `<${openTagSrc}>`; + + const next = index + 1; + return next < repeat + ? createTagRepeat(tagName, repeat, attributes, next, html) + : html; +} + +// Remove the spacing surrounding tags for HTML parser not to create text nodes +// before/after elements +function optimizeTemplateHTML(html) { + return html.replace(/>\s+/g, '>').replace(/\s+ the end, swap them\n if (changedSide === 0 && changedDate > otherDate) {\n datepickers[0].setDate(otherDate, setDateOptions);\n datepickers[1].setDate(changedDate, setDateOptions);\n } else if (changedSide === 1 && changedDate < otherDate) {\n datepickers[0].setDate(changedDate, setDateOptions);\n datepickers[1].setDate(otherDate, setDateOptions);\n }\n } else if (!rangepicker.allowOneSidedRange) {\n // to prevent the range from becoming one-sided, copy changed side's\n // selection (no matter if it's empty) to the other side\n if (changedDate !== undefined || otherDate !== undefined) {\n setDateOptions.clear = true;\n datepickers[otherSide].setDate(datepickers[changedSide].dates, setDateOptions);\n }\n }\n datepickers[0].picker.update().render();\n datepickers[1].picker.update().render();\n delete rangepicker._updating;\n}\n\n/**\n * Class representing a date range picker\n */\nexport default class DateRangePicker {\n /**\n * Create a date range picker\n * @param {Element} element - element to bind a date range picker\n * @param {Object} [options] - config options\n */\n constructor(element, options = {}) {\n const inputs = Array.isArray(options.inputs)\n ? options.inputs\n : Array.from(element.querySelectorAll('input'));\n if (inputs.length < 2) {\n return;\n }\n\n element.rangepicker = this;\n this.element = element;\n this.inputs = inputs.slice(0, 2);\n this.allowOneSidedRange = !!options.allowOneSidedRange;\n\n const changeDateListener = onChangeDate.bind(null, this);\n const cleanOptions = filterOptions(options);\n // in order for initial date setup to work right when pcicLvel > 0,\n // let Datepicker constructor add the instance to the rangepicker\n const datepickers = [];\n Object.defineProperty(this, 'datepickers', {\n get() {\n return datepickers;\n },\n });\n setupDatepicker(this, changeDateListener, this.inputs[0], cleanOptions);\n setupDatepicker(this, changeDateListener, this.inputs[1], cleanOptions);\n Object.freeze(datepickers);\n // normalize the range if inital dates are given\n if (datepickers[0].dates.length > 0) {\n onChangeDate(this, {target: this.inputs[0]});\n } else if (datepickers[1].dates.length > 0) {\n onChangeDate(this, {target: this.inputs[1]});\n }\n }\n\n /**\n * @type {Array} - selected date of the linked date pickers\n */\n get dates() {\n return this.datepickers.length === 2\n ? [\n this.datepickers[0].dates[0],\n this.datepickers[1].dates[0],\n ]\n : undefined;\n }\n\n /**\n * Set new values to the config options\n * @param {Object} options - config options to update\n */\n setOptions(options) {\n this.allowOneSidedRange = !!options.allowOneSidedRange;\n\n const cleanOptions = filterOptions(options);\n this.datepickers[0].setOptions(cleanOptions);\n this.datepickers[1].setOptions(cleanOptions);\n }\n\n /**\n * Destroy the DateRangePicker instance\n * @return {DateRangePicker} - the instance destroyed\n */\n destroy() {\n this.datepickers[0].destroy();\n this.datepickers[1].destroy();\n unregisterListeners(this);\n delete this.element.rangepicker;\n }\n\n /**\n * Get the start and end dates of the date range\n *\n * The method returns Date objects by default. If format string is passed,\n * it returns date strings formatted in given format.\n * The result array always contains 2 items (start date/end date) and\n * undefined is used for unselected side. (e.g. If none is selected,\n * the result will be [undefined, undefined]. If only the end date is set\n * when allowOneSidedRange config option is true, [undefined, endDate] will\n * be returned.)\n *\n * @param {String} [format] - Format string to stringify the dates\n * @return {Array} - Start and end dates\n */\n getDates(format = undefined) {\n const callback = format\n ? date => formatDate(date, format, this.datepickers[0].config.locale)\n : date => new Date(date);\n\n return this.dates.map(date => date === undefined ? date : callback(date));\n }\n\n /**\n * Set the start and end dates of the date range\n *\n * The method calls datepicker.setDate() internally using each of the\n * arguments in start→end order.\n *\n * When a clear: true option object is passed instead of a date, the method\n * clears the date.\n *\n * If an invalid date, the same date as the current one or an option object\n * without clear: true is passed, the method considers that argument as an\n * \"ineffective\" argument because calling datepicker.setDate() with those\n * values makes no changes to the date selection.\n *\n * When the allowOneSidedRange config option is false, passing {clear: true}\n * to clear the range works only when it is done to the last effective\n * argument (in other words, passed to rangeEnd or to rangeStart along with\n * ineffective rangeEnd). This is because when the date range is changed,\n * it gets normalized based on the last change at the end of the changing\n * process.\n *\n * @param {Date|Number|String|Object} rangeStart - Start date of the range\n * or {clear: true} to clear the date\n * @param {Date|Number|String|Object} rangeEnd - End date of the range\n * or {clear: true} to clear the date\n */\n setDates(rangeStart, rangeEnd) {\n const [datepicker0, datepicker1] = this.datepickers;\n const origDates = this.dates;\n\n // If range normalization runs on every change, we can't set a new range\n // that starts after the end of the current range correctly because the\n // normalization process swaps start↔︎end right after setting the new start\n // date. To prevent this, the normalization process needs to run once after\n // both of the new dates are set.\n this._updating = true;\n datepicker0.setDate(rangeStart);\n datepicker1.setDate(rangeEnd);\n delete this._updating;\n\n if (datepicker1.dates[0] !== origDates[1]) {\n onChangeDate(this, {target: this.inputs[1]});\n } else if (datepicker0.dates[0] !== origDates[0]) {\n onChangeDate(this, {target: this.inputs[0]});\n }\n }\n}\n","// default locales\nexport const locales = {\n en: {\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n daysShort: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n daysMin: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n monthsShort: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"],\n today: \"Today\",\n clear: \"Clear\",\n titleFormat: \"MM y\"\n }\n};\n","// config options updatable by setOptions() and their default values\nconst defaultOptions = {\n autohide: false,\n beforeShowDay: null,\n beforeShowDecade: null,\n beforeShowMonth: null,\n beforeShowYear: null,\n calendarWeeks: false,\n clearBtn: false,\n dateDelimiter: ',',\n datesDisabled: [],\n daysOfWeekDisabled: [],\n daysOfWeekHighlighted: [],\n defaultViewDate: undefined, // placeholder, defaults to today() by the program\n disableTouchKeyboard: false,\n format: 'mm/dd/yyyy',\n language: 'en',\n maxDate: null,\n maxNumberOfDates: 1,\n maxView: 3,\n minDate: null,\n nextArrow: '',\n orientation: 'auto',\n pickLevel: 0,\n prevArrow: '',\n showDaysOfWeek: true,\n showOnClick: true,\n showOnFocus: true,\n startView: 0,\n title: '',\n todayBtn: false,\n todayBtnMode: 0,\n todayHighlight: false,\n updateOnBlur: true,\n weekStart: 0,\n};\n\nexport default defaultOptions;\n","const range = document.createRange();\n\nexport function parseHTML(html) {\n return range.createContextualFragment(html);\n}\n\n// equivalent to jQuery's :visble\nexport function isVisible(el) {\n return !!(el.offsetWidth || el.offsetHeight || el.getClientRects().length);\n}\n\nexport function hideElement(el) {\n if (el.style.display === 'none') {\n return;\n }\n // back up the existing display setting in data-style-display\n if (el.style.display) {\n el.dataset.styleDisplay = el.style.display;\n }\n el.style.display = 'none';\n}\n\nexport function showElement(el) {\n if (el.style.display !== 'none') {\n return;\n }\n if (el.dataset.styleDisplay) {\n // restore backed-up dispay property\n el.style.display = el.dataset.styleDisplay;\n delete el.dataset.styleDisplay;\n } else {\n el.style.display = '';\n }\n}\n\nexport function emptyChildNodes(el) {\n if (el.firstChild) {\n el.removeChild(el.firstChild);\n emptyChildNodes(el);\n }\n}\n\nexport function replaceChildNodes(el, newChildNodes) {\n emptyChildNodes(el);\n if (newChildNodes instanceof DocumentFragment) {\n el.appendChild(newChildNodes);\n } else if (typeof newChildNodes === 'string') {\n el.appendChild(parseHTML(newChildNodes));\n } else if (typeof newChildNodes.forEach === 'function') {\n newChildNodes.forEach((node) => {\n el.appendChild(node);\n });\n }\n}\n","import {hasProperty, pushUnique} from '../lib/utils.js';\nimport {dateValue} from '../lib/date.js';\nimport {reFormatTokens, parseDate} from '../lib/date-format.js';\nimport {parseHTML} from '../lib/dom.js';\nimport defaultOptions from './defaultOptions.js';\n\nconst {\n language: defaultLang,\n format: defaultFormat,\n weekStart: defaultWeekStart,\n} = defaultOptions;\n\n// Reducer function to filter out invalid day-of-week from the input\nfunction sanitizeDOW(dow, day) {\n return dow.length < 6 && day >= 0 && day < 7\n ? pushUnique(dow, day)\n : dow;\n}\n\nfunction calcEndOfWeek(startOfWeek) {\n return (startOfWeek + 6) % 7;\n}\n\n// validate input date. if invalid, fallback to the original value\nfunction validateDate(value, format, locale, origValue) {\n const date = parseDate(value, format, locale);\n return date !== undefined ? date : origValue;\n}\n\n// Validate viewId. if invalid, fallback to the original value\nfunction validateViewId(value, origValue, max = 3) {\n const viewId = parseInt(value, 10);\n return viewId >= 0 && viewId <= max ? viewId : origValue;\n}\n\n// Create Datepicker configuration to set\nexport default function processOptions(options, datepicker) {\n const inOpts = Object.assign({}, options);\n const config = {};\n const locales = datepicker.constructor.locales;\n let {\n format,\n language,\n locale,\n maxDate,\n maxView,\n minDate,\n pickLevel,\n startView,\n weekStart,\n } = datepicker.config || {};\n\n if (inOpts.language) {\n let lang;\n if (inOpts.language !== language) {\n if (locales[inOpts.language]) {\n lang = inOpts.language;\n } else {\n // Check if langauge + region tag can fallback to the one without\n // region (e.g. fr-CA → fr)\n lang = inOpts.language.split('-')[0];\n if (locales[lang] === undefined) {\n lang = false;\n }\n }\n }\n delete inOpts.language;\n if (lang) {\n language = config.language = lang;\n\n // update locale as well when updating language\n const origLocale = locale || locales[defaultLang];\n // use default language's properties for the fallback\n locale = Object.assign({\n format: defaultFormat,\n weekStart: defaultWeekStart\n }, locales[defaultLang]);\n if (language !== defaultLang) {\n Object.assign(locale, locales[language]);\n }\n config.locale = locale;\n // if format and/or weekStart are the same as old locale's defaults,\n // update them to new locale's defaults\n if (format === origLocale.format) {\n format = config.format = locale.format;\n }\n if (weekStart === origLocale.weekStart) {\n weekStart = config.weekStart = locale.weekStart;\n config.weekEnd = calcEndOfWeek(locale.weekStart);\n }\n }\n }\n\n if (inOpts.format) {\n const hasToDisplay = typeof inOpts.format.toDisplay === 'function';\n const hasToValue = typeof inOpts.format.toValue === 'function';\n const validFormatString = reFormatTokens.test(inOpts.format);\n if ((hasToDisplay && hasToValue) || validFormatString) {\n format = config.format = inOpts.format;\n }\n delete inOpts.format;\n }\n\n //*** dates ***//\n // while min and maxDate for \"no limit\" in the options are better to be null\n // (especially when updating), the ones in the config have to be undefined\n // because null is treated as 0 (= unix epoch) when comparing with time value\n let minDt = minDate;\n let maxDt = maxDate;\n if (inOpts.minDate !== undefined) {\n minDt = inOpts.minDate === null\n ? dateValue(0, 0, 1) // set 0000-01-01 to prevent negative values for year\n : validateDate(inOpts.minDate, format, locale, minDt);\n delete inOpts.minDate;\n }\n if (inOpts.maxDate !== undefined) {\n maxDt = inOpts.maxDate === null\n ? undefined\n : validateDate(inOpts.maxDate, format, locale, maxDt);\n delete inOpts.maxDate;\n }\n if (maxDt < minDt) {\n minDate = config.minDate = maxDt;\n maxDate = config.maxDate = minDt;\n } else {\n if (minDate !== minDt) {\n minDate = config.minDate = minDt;\n }\n if (maxDate !== maxDt) {\n maxDate = config.maxDate = maxDt;\n }\n }\n\n if (inOpts.datesDisabled) {\n config.datesDisabled = inOpts.datesDisabled.reduce((dates, dt) => {\n const date = parseDate(dt, format, locale);\n return date !== undefined ? pushUnique(dates, date) : dates;\n }, []);\n delete inOpts.datesDisabled;\n }\n if (inOpts.defaultViewDate !== undefined) {\n const viewDate = parseDate(inOpts.defaultViewDate, format, locale);\n if (viewDate !== undefined) {\n config.defaultViewDate = viewDate;\n }\n delete inOpts.defaultViewDate;\n }\n\n //*** days of week ***//\n if (inOpts.weekStart !== undefined) {\n const wkStart = Number(inOpts.weekStart) % 7;\n if (!isNaN(wkStart)) {\n weekStart = config.weekStart = wkStart;\n config.weekEnd = calcEndOfWeek(wkStart);\n }\n delete inOpts.weekStart;\n }\n if (inOpts.daysOfWeekDisabled) {\n config.daysOfWeekDisabled = inOpts.daysOfWeekDisabled.reduce(sanitizeDOW, []);\n delete inOpts.daysOfWeekDisabled;\n }\n if (inOpts.daysOfWeekHighlighted) {\n config.daysOfWeekHighlighted = inOpts.daysOfWeekHighlighted.reduce(sanitizeDOW, []);\n delete inOpts.daysOfWeekHighlighted;\n }\n\n //*** multi date ***//\n if (inOpts.maxNumberOfDates !== undefined) {\n const maxNumberOfDates = parseInt(inOpts.maxNumberOfDates, 10);\n if (maxNumberOfDates >= 0) {\n config.maxNumberOfDates = maxNumberOfDates;\n config.multidate = maxNumberOfDates !== 1;\n }\n delete inOpts.maxNumberOfDates;\n }\n if (inOpts.dateDelimiter) {\n config.dateDelimiter = String(inOpts.dateDelimiter);\n delete inOpts.dateDelimiter;\n }\n\n //*** pick level & view ***//\n let newPickLevel = pickLevel;\n if (inOpts.pickLevel !== undefined) {\n newPickLevel = validateViewId(inOpts.pickLevel, 2);\n delete inOpts.pickLevel;\n }\n if (newPickLevel !== pickLevel) {\n pickLevel = config.pickLevel = newPickLevel;\n }\n\n let newMaxView = maxView;\n if (inOpts.maxView !== undefined) {\n newMaxView = validateViewId(inOpts.maxView, maxView);\n delete inOpts.maxView;\n }\n // ensure max view >= pick level\n newMaxView = pickLevel > newMaxView ? pickLevel : newMaxView;\n if (newMaxView !== maxView) {\n maxView = config.maxView = newMaxView;\n }\n\n let newStartView = startView;\n if (inOpts.startView !== undefined) {\n newStartView = validateViewId(inOpts.startView, newStartView);\n delete inOpts.startView;\n }\n // ensure pick level <= start view <= max view\n if (newStartView < pickLevel) {\n newStartView = pickLevel;\n } else if (newStartView > maxView) {\n newStartView = maxView;\n }\n if (newStartView !== startView) {\n config.startView = newStartView;\n }\n\n //*** template ***//\n if (inOpts.prevArrow) {\n const prevArrow = parseHTML(inOpts.prevArrow);\n if (prevArrow.childNodes.length > 0) {\n config.prevArrow = prevArrow.childNodes;\n }\n delete inOpts.prevArrow;\n }\n if (inOpts.nextArrow) {\n const nextArrow = parseHTML(inOpts.nextArrow);\n if (nextArrow.childNodes.length > 0) {\n config.nextArrow = nextArrow.childNodes;\n }\n delete inOpts.nextArrow;\n }\n\n //*** misc ***//\n if (inOpts.disableTouchKeyboard !== undefined) {\n config.disableTouchKeyboard = 'ontouchstart' in document && !!inOpts.disableTouchKeyboard;\n delete inOpts.disableTouchKeyboard;\n }\n if (inOpts.orientation) {\n const orientation = inOpts.orientation.toLowerCase().split(/\\s+/g);\n config.orientation = {\n x: orientation.find(x => (x === 'left' || x === 'right')) || 'auto',\n y: orientation.find(y => (y === 'top' || y === 'bottom')) || 'auto',\n };\n delete inOpts.orientation;\n }\n if (inOpts.todayBtnMode !== undefined) {\n switch(inOpts.todayBtnMode) {\n case 0:\n case 1:\n config.todayBtnMode = inOpts.todayBtnMode;\n }\n delete inOpts.todayBtnMode;\n }\n\n //*** copy the rest ***//\n Object.keys(inOpts).forEach((key) => {\n if (inOpts[key] !== undefined && hasProperty(defaultOptions, key)) {\n config[key] = inOpts[key];\n }\n });\n\n return config;\n}\n","import {optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst pickerTemplate = optimizeTemplateHTML(`
      \n
      \n
      \n
      \n
      \n \n \n \n
      \n
      \n
      \n
      \n
      \n \n \n
      \n
      \n
      \n
      `);\n\nexport default pickerTemplate;\n","import {createTagRepeat, optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst daysTemplate = optimizeTemplateHTML(`
      \n
      ${createTagRepeat('span', 7, {class: 'dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      \n
      ${createTagRepeat('span', 42 , {class: 'block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'})}
      \n
      `);\n\nexport default daysTemplate;\n","import {createTagRepeat, optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst calendarWeeksTemplate = optimizeTemplateHTML(`
      \n
      \n
      ${createTagRepeat('span', 6, {class: 'week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      \n
      `);\n\nexport default calendarWeeksTemplate;\n","import {pushUnique} from '../../lib/utils.js';\nimport {parseHTML, replaceChildNodes} from '../../lib/dom.js';\n\n// Base class of the view classes\nexport default class View {\n constructor(picker, config) {\n Object.assign(this, config, {\n picker,\n element: parseHTML(`
      `).firstChild,\n selected: [],\n });\n this.init(this.picker.datepicker.config);\n }\n\n init(options) {\n if (options.pickLevel !== undefined) {\n this.isMinView = this.id === options.pickLevel;\n }\n this.setOptions(options);\n this.updateFocus();\n this.updateSelection();\n }\n\n // Execute beforeShow() callback and apply the result to the element\n // args:\n // - current - current value on the iteration on view rendering\n // - timeValue - time value of the date to pass to beforeShow()\n performBeforeHook(el, current, timeValue) {\n let result = this.beforeShow(new Date(timeValue));\n switch (typeof result) {\n case 'boolean':\n result = {enabled: result};\n break;\n case 'string':\n result = {classes: result};\n }\n\n if (result) {\n if (result.enabled === false) {\n el.classList.add('disabled');\n pushUnique(this.disabled, current);\n }\n if (result.classes) {\n const extraClasses = result.classes.split(/\\s+/);\n el.classList.add(...extraClasses);\n if (extraClasses.includes('disabled')) {\n pushUnique(this.disabled, current);\n }\n }\n if (result.content) {\n replaceChildNodes(el, result.content);\n }\n }\n }\n}\n","import {hasProperty, pushUnique} from '../../lib/utils.js';\nimport {today, dateValue, addDays, addWeeks, dayOfTheWeekOf, getWeek} from '../../lib/date.js';\nimport {formatDate} from '../../lib/date-format.js';\nimport {parseHTML, showElement, hideElement} from '../../lib/dom.js';\nimport daysTemplate from '../templates/daysTemplate.js';\nimport calendarWeeksTemplate from '../templates/calendarWeeksTemplate.js';\nimport View from './View.js';\n\nexport default class DaysView extends View {\n constructor(picker) {\n super(picker, {\n id: 0,\n name: 'days',\n cellClass: 'day',\n });\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n const inner = parseHTML(daysTemplate).firstChild;\n this.dow = inner.firstChild;\n this.grid = inner.lastChild;\n this.element.appendChild(inner);\n }\n super.init(options);\n }\n\n setOptions(options) {\n let updateDOW;\n\n if (hasProperty(options, 'minDate')) {\n this.minDate = options.minDate;\n }\n if (hasProperty(options, 'maxDate')) {\n this.maxDate = options.maxDate;\n }\n if (options.datesDisabled) {\n this.datesDisabled = options.datesDisabled;\n }\n if (options.daysOfWeekDisabled) {\n this.daysOfWeekDisabled = options.daysOfWeekDisabled;\n updateDOW = true;\n }\n if (options.daysOfWeekHighlighted) {\n this.daysOfWeekHighlighted = options.daysOfWeekHighlighted;\n }\n if (options.todayHighlight !== undefined) {\n this.todayHighlight = options.todayHighlight;\n }\n if (options.weekStart !== undefined) {\n this.weekStart = options.weekStart;\n this.weekEnd = options.weekEnd;\n updateDOW = true;\n }\n if (options.locale) {\n const locale = this.locale = options.locale;\n this.dayNames = locale.daysMin;\n this.switchLabelFormat = locale.titleFormat;\n updateDOW = true;\n }\n if (options.beforeShowDay !== undefined) {\n this.beforeShow = typeof options.beforeShowDay === 'function'\n ? options.beforeShowDay\n : undefined;\n }\n\n if (options.calendarWeeks !== undefined) {\n if (options.calendarWeeks && !this.calendarWeeks) {\n const weeksElem = parseHTML(calendarWeeksTemplate).firstChild;\n this.calendarWeeks = {\n element: weeksElem,\n dow: weeksElem.firstChild,\n weeks: weeksElem.lastChild,\n };\n this.element.insertBefore(weeksElem, this.element.firstChild);\n } else if (this.calendarWeeks && !options.calendarWeeks) {\n this.element.removeChild(this.calendarWeeks.element);\n this.calendarWeeks = null;\n }\n }\n if (options.showDaysOfWeek !== undefined) {\n if (options.showDaysOfWeek) {\n showElement(this.dow);\n if (this.calendarWeeks) {\n showElement(this.calendarWeeks.dow);\n }\n } else {\n hideElement(this.dow);\n if (this.calendarWeeks) {\n hideElement(this.calendarWeeks.dow);\n }\n }\n }\n\n // update days-of-week when locale, daysOfweekDisabled or weekStart is changed\n if (updateDOW) {\n Array.from(this.dow.children).forEach((el, index) => {\n const dow = (this.weekStart + index) % 7;\n el.textContent = this.dayNames[dow];\n el.className = this.daysOfWeekDisabled.includes(dow) ? 'dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed' : 'dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400';\n });\n }\n }\n\n // Apply update on the focused date to view's settings\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n const viewYear = viewDate.getFullYear();\n const viewMonth = viewDate.getMonth();\n const firstOfMonth = dateValue(viewYear, viewMonth, 1);\n const start = dayOfTheWeekOf(firstOfMonth, this.weekStart, this.weekStart);\n\n this.first = firstOfMonth;\n this.last = dateValue(viewYear, viewMonth + 1, 0);\n this.start = start;\n this.focused = this.picker.viewDate;\n }\n\n // Apply update on the selected dates to view's settings\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates;\n if (rangepicker) {\n this.range = rangepicker.dates;\n }\n }\n\n // Update the entire view UI\n render() {\n // update today marker on ever render\n this.today = this.todayHighlight ? today() : undefined;\n // refresh disabled dates on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [...this.datesDisabled];\n\n const switchLabel = formatDate(this.focused, this.switchLabelFormat, this.locale);\n this.picker.setViewSwitchLabel(switchLabel);\n this.picker.setPrevBtnDisabled(this.first <= this.minDate);\n this.picker.setNextBtnDisabled(this.last >= this.maxDate);\n\n if (this.calendarWeeks) {\n // start of the UTC week (Monday) of the 1st of the month\n const startOfWeek = dayOfTheWeekOf(this.first, 1, 1);\n Array.from(this.calendarWeeks.weeks.children).forEach((el, index) => {\n el.textContent = getWeek(addWeeks(startOfWeek, index));\n });\n }\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const current = addDays(this.start, index);\n const date = new Date(current);\n const day = date.getDay();\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n el.dataset.date = current;\n el.textContent = date.getDate();\n\n if (current < this.first) {\n classList.add('prev', 'text-gray-500', 'dark:text-white');\n } else if (current > this.last) {\n classList.add('next', 'text-gray-500', 'dark:text-white');\n }\n if (this.today === current) {\n classList.add('today', 'bg-gray-100', 'dark:bg-gray-600');\n }\n if (current < this.minDate || current > this.maxDate || this.disabled.includes(current)) {\n classList.add('disabled', 'cursor-not-allowed');\n }\n if (this.daysOfWeekDisabled.includes(day)) {\n classList.add('disabled', 'cursor-not-allowed');\n pushUnique(this.disabled, current);\n }\n if (this.daysOfWeekHighlighted.includes(day)) {\n classList.add('highlighted');\n }\n if (this.range) {\n const [rangeStart, rangeEnd] = this.range;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range', 'bg-gray-200', 'dark:bg-gray-600');\n classList.remove('rounded-lg', 'rounded-l-lg', 'rounded-r-lg')\n }\n if (current === rangeStart) {\n classList.add('range-start', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-l-lg');\n classList.remove('rounded-lg', 'rounded-r-lg');\n }\n if (current === rangeEnd) {\n classList.add('range-end', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-r-lg');\n classList.remove('rounded-lg', 'rounded-l-lg');\n }\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'text-gray-500', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'dark:bg-gray-600', 'bg-gray-100', 'bg-gray-200');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, current, current);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const [rangeStart, rangeEnd] = this.range || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused');\n el.classList.add('text-gray-900', 'rounded-lg', 'dark:text-white');\n });\n Array.from(this.grid.children).forEach((el) => {\n const current = Number(el.dataset.date);\n const classList = el.classList;\n classList.remove('bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg', 'rounded-r-lg')\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range', 'bg-gray-200', 'dark:bg-gray-600');\n classList.remove('rounded-lg');\n }\n if (current === rangeStart) {\n classList.add('range-start', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg');\n classList.remove('rounded-lg', 'rounded-r-lg');\n }\n if (current === rangeEnd) {\n classList.add('range-end', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-r-lg');\n classList.remove('rounded-lg', 'rounded-l-lg');\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'bg-gray-100', 'bg-gray-200', 'dark:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n const index = Math.round((this.focused - this.start) / 86400000);\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[index].classList.add('focused');\n }\n}\n","import {hasProperty, pushUnique, createTagRepeat} from '../../lib/utils.js';\nimport {dateValue} from '../../lib/date.js';\nimport {parseHTML} from '../../lib/dom.js';\nimport View from './View.js';\n\nfunction computeMonthRange(range, thisYear) {\n if (!range || !range[0] || !range[1]) {\n return;\n }\n\n const [[startY, startM], [endY, endM]] = range;\n if (startY > thisYear || endY < thisYear) {\n return;\n }\n return [\n startY === thisYear ? startM : -1,\n endY === thisYear ? endM : 12,\n ];\n}\n\nexport default class MonthsView extends View {\n constructor(picker) {\n super(picker, {\n id: 1,\n name: 'months',\n cellClass: 'month',\n });\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n this.grid = this.element;\n this.element.classList.add('months', 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4');\n this.grid.appendChild(parseHTML(createTagRepeat('span', 12, {'data-month': ix => ix})));\n }\n super.init(options);\n }\n\n setOptions(options) {\n if (options.locale) {\n this.monthNames = options.locale.monthsShort;\n }\n if (hasProperty(options, 'minDate')) {\n if (options.minDate === undefined) {\n this.minYear = this.minMonth = this.minDate = undefined;\n } else {\n const minDateObj = new Date(options.minDate);\n this.minYear = minDateObj.getFullYear();\n this.minMonth = minDateObj.getMonth();\n this.minDate = minDateObj.setDate(1);\n }\n }\n if (hasProperty(options, 'maxDate')) {\n if (options.maxDate === undefined) {\n this.maxYear = this.maxMonth = this.maxDate = undefined;\n } else {\n const maxDateObj = new Date(options.maxDate);\n this.maxYear = maxDateObj.getFullYear();\n this.maxMonth = maxDateObj.getMonth();\n this.maxDate = dateValue(this.maxYear, this.maxMonth + 1, 0);\n }\n }\n if (options.beforeShowMonth !== undefined) {\n this.beforeShow = typeof options.beforeShowMonth === 'function'\n ? options.beforeShowMonth\n : undefined;\n }\n }\n\n // Update view's settings to reflect the viewDate set on the picker\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n this.year = viewDate.getFullYear();\n this.focused = viewDate.getMonth();\n }\n\n // Update view's settings to reflect the selected dates\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates.reduce((selected, timeValue) => {\n const date = new Date(timeValue);\n const year = date.getFullYear();\n const month = date.getMonth();\n if (selected[year] === undefined) {\n selected[year] = [month];\n } else {\n pushUnique(selected[year], month);\n }\n return selected;\n }, {});\n if (rangepicker && rangepicker.dates) {\n this.range = rangepicker.dates.map(timeValue => {\n const date = new Date(timeValue);\n return isNaN(date) ? undefined : [date.getFullYear(), date.getMonth()];\n });\n }\n }\n\n // Update the entire view UI\n render() {\n // refresh disabled months on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [];\n\n this.picker.setViewSwitchLabel(this.year);\n this.picker.setPrevBtnDisabled(this.year <= this.minYear);\n this.picker.setNextBtnDisabled(this.year >= this.maxYear);\n\n const selected = this.selected[this.year] || [];\n const yrOutOfRange = this.year < this.minYear || this.year > this.maxYear;\n const isMinYear = this.year === this.minYear;\n const isMaxYear = this.year === this.maxYear;\n const range = computeMonthRange(this.range, this.year);\n\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const date = dateValue(this.year, index, 1);\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n if (this.isMinView) {\n el.dataset.date = date;\n }\n // reset text on every render to clear the custom content set\n // by beforeShow hook at previous render\n el.textContent = this.monthNames[index];\n\n if (\n yrOutOfRange\n || isMinYear && index < this.minMonth\n || isMaxYear && index > this.maxMonth\n ) {\n classList.add('disabled');\n }\n if (range) {\n const [rangeStart, rangeEnd] = range;\n if (index > rangeStart && index < rangeEnd) {\n classList.add('range');\n }\n if (index === rangeStart) {\n classList.add('range-start');\n }\n if (index === rangeEnd) {\n classList.add('range-end');\n }\n }\n if (selected.includes(index)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (index === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, index, date);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const selected = this.selected[this.year] || [];\n const [rangeStart, rangeEnd] = computeMonthRange(this.range, this.year) || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'dark:bg-blue-600', 'dark:text-white', 'text-white', 'focused');\n el.classList.add('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n });\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n if (index > rangeStart && index < rangeEnd) {\n classList.add('range');\n }\n if (index === rangeStart) {\n classList.add('range-start');\n }\n if (index === rangeEnd) {\n classList.add('range-end');\n }\n if (selected.includes(index)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (index === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[this.focused].classList.add('focused');\n }\n}","import {hasProperty, pushUnique, createTagRepeat} from '../../lib/utils.js';\nimport {dateValue, startOfYearPeriod} from '../../lib/date.js';\nimport {parseHTML} from '../../lib/dom.js';\nimport View from './View.js';\n\nfunction toTitleCase(word) {\n return [...word].reduce((str, ch, ix) => str += ix ? ch : ch.toUpperCase(), '');\n}\n\n// Class representing the years and decades view elements\nexport default class YearsView extends View {\n constructor(picker, config) {\n super(picker, config);\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n this.navStep = this.step * 10;\n this.beforeShowOption = `beforeShow${toTitleCase(this.cellClass)}`;\n this.grid = this.element;\n this.element.classList.add(this.name, 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4');\n this.grid.appendChild(parseHTML(createTagRepeat('span', 12)));\n }\n super.init(options);\n }\n\n setOptions(options) {\n if (hasProperty(options, 'minDate')) {\n if (options.minDate === undefined) {\n this.minYear = this.minDate = undefined;\n } else {\n this.minYear = startOfYearPeriod(options.minDate, this.step);\n this.minDate = dateValue(this.minYear, 0, 1);\n }\n }\n if (hasProperty(options, 'maxDate')) {\n if (options.maxDate === undefined) {\n this.maxYear = this.maxDate = undefined;\n } else {\n this.maxYear = startOfYearPeriod(options.maxDate, this.step);\n this.maxDate = dateValue(this.maxYear, 11, 31);\n }\n }\n if (options[this.beforeShowOption] !== undefined) {\n const beforeShow = options[this.beforeShowOption];\n this.beforeShow = typeof beforeShow === 'function' ? beforeShow : undefined;\n }\n }\n\n // Update view's settings to reflect the viewDate set on the picker\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n const first = startOfYearPeriod(viewDate, this.navStep);\n const last = first + 9 * this.step;\n\n this.first = first;\n this.last = last;\n this.start = first - this.step;\n this.focused = startOfYearPeriod(viewDate, this.step);\n }\n\n // Update view's settings to reflect the selected dates\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates.reduce((years, timeValue) => {\n return pushUnique(years, startOfYearPeriod(timeValue, this.step));\n }, []);\n if (rangepicker && rangepicker.dates) {\n this.range = rangepicker.dates.map(timeValue => {\n if (timeValue !== undefined) {\n return startOfYearPeriod(timeValue, this.step);\n }\n });\n }\n }\n\n // Update the entire view UI\n render() {\n // refresh disabled years on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [];\n\n this.picker.setViewSwitchLabel(`${this.first}-${this.last}`);\n this.picker.setPrevBtnDisabled(this.first <= this.minYear);\n this.picker.setNextBtnDisabled(this.last >= this.maxYear);\n\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const current = this.start + (index * this.step);\n const date = dateValue(current, 0, 1);\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n if (this.isMinView) {\n el.dataset.date = date;\n }\n el.textContent = el.dataset.year = current;\n\n if (index === 0) {\n classList.add('prev');\n } else if (index === 11) {\n classList.add('next');\n }\n if (current < this.minYear || current > this.maxYear) {\n classList.add('disabled');\n }\n if (this.range) {\n const [rangeStart, rangeEnd] = this.range;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range');\n }\n if (current === rangeStart) {\n classList.add('range-start');\n }\n if (current === rangeEnd) {\n classList.add('range-end');\n }\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, current, date);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const [rangeStart, rangeEnd] = this.range || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused');\n });\n Array.from(this.grid.children).forEach((el) => {\n const current = Number(el.textContent);\n const classList = el.classList;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range');\n }\n if (current === rangeStart) {\n classList.add('range-start');\n }\n if (current === rangeEnd) {\n classList.add('range-end');\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n const index = Math.round((this.focused - this.start) / this.step);\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[index].classList.add('focused');\n }\n}\n","import {limitToRange} from '../lib/utils.js';\nimport {addMonths, addYears} from '../lib/date.js';\n\nexport function triggerDatepickerEvent(datepicker, type) {\n const detail = {\n date: datepicker.getDate(),\n viewDate: new Date(datepicker.picker.viewDate),\n viewId: datepicker.picker.currentView.id,\n datepicker,\n };\n datepicker.element.dispatchEvent(new CustomEvent(type, {detail}));\n}\n\n// direction: -1 (to previous), 1 (to next)\nexport function goToPrevOrNext(datepicker, direction) {\n const {minDate, maxDate} = datepicker.config;\n const {currentView, viewDate} = datepicker.picker;\n let newViewDate;\n switch (currentView.id) {\n case 0:\n newViewDate = addMonths(viewDate, direction);\n break;\n case 1:\n newViewDate = addYears(viewDate, direction);\n break;\n default:\n newViewDate = addYears(viewDate, direction * currentView.navStep);\n }\n newViewDate = limitToRange(newViewDate, minDate, maxDate);\n datepicker.picker.changeFocus(newViewDate).render();\n}\n\nexport function switchView(datepicker) {\n const viewId = datepicker.picker.currentView.id;\n if (viewId === datepicker.config.maxView) {\n return;\n }\n datepicker.picker.changeView(viewId + 1).render();\n}\n\nexport function unfocus(datepicker) {\n if (datepicker.config.updateOnBlur) {\n datepicker.update({autohide: true});\n } else {\n datepicker.refresh('input');\n datepicker.hide();\n }\n}\n","import {today, addMonths, addYears} from '../lib/date.js';\nimport {findElementInEventPath} from '../lib/event.js';\nimport {goToPrevOrNext, switchView} from './functions.js';\n\nfunction goToSelectedMonthOrYear(datepicker, selection) {\n const picker = datepicker.picker;\n const viewDate = new Date(picker.viewDate);\n const viewId = picker.currentView.id;\n const newDate = viewId === 1\n ? addMonths(viewDate, selection - viewDate.getMonth())\n : addYears(viewDate, selection - viewDate.getFullYear());\n\n picker.changeFocus(newDate).changeView(viewId - 1).render();\n}\n\nexport function onClickTodayBtn(datepicker) {\n const picker = datepicker.picker;\n const currentDate = today();\n if (datepicker.config.todayBtnMode === 1) {\n if (datepicker.config.autohide) {\n datepicker.setDate(currentDate);\n return;\n }\n datepicker.setDate(currentDate, {render: false});\n picker.update();\n }\n if (picker.viewDate !== currentDate) {\n picker.changeFocus(currentDate);\n }\n picker.changeView(0).render();\n}\n\nexport function onClickClearBtn(datepicker) {\n datepicker.setDate({clear: true});\n}\n\nexport function onClickViewSwitch(datepicker) {\n switchView(datepicker);\n}\n\nexport function onClickPrevBtn(datepicker) {\n goToPrevOrNext(datepicker, -1);\n}\n\nexport function onClickNextBtn(datepicker) {\n goToPrevOrNext(datepicker, 1);\n}\n\n// For the picker's main block to delegete the events from `datepicker-cell`s\nexport function onClickView(datepicker, ev) {\n const target = findElementInEventPath(ev, '.datepicker-cell');\n if (!target || target.classList.contains('disabled')) {\n return;\n }\n\n const {id, isMinView} = datepicker.picker.currentView;\n if (isMinView) {\n datepicker.setDate(Number(target.dataset.date));\n } else if (id === 1) {\n goToSelectedMonthOrYear(datepicker, Number(target.dataset.month));\n } else {\n goToSelectedMonthOrYear(datepicker, Number(target.dataset.year));\n }\n}\n\nexport function onClickPicker(datepicker) {\n if (!datepicker.inline && !datepicker.config.disableTouchKeyboard) {\n datepicker.inputField.focus();\n }\n}\n","import {hasProperty, lastItemOf, isInRange, limitToRange} from '../lib/utils.js';\nimport {today} from '../lib/date.js';\nimport {parseHTML, showElement, hideElement, emptyChildNodes} from '../lib/dom.js';\nimport {registerListeners} from '../lib/event.js';\nimport pickerTemplate from './templates/pickerTemplate.js';\nimport DaysView from './views/DaysView.js';\nimport MonthsView from './views/MonthsView.js';\nimport YearsView from './views/YearsView.js';\nimport {triggerDatepickerEvent} from '../events/functions.js';\nimport {\n onClickTodayBtn,\n onClickClearBtn,\n onClickViewSwitch,\n onClickPrevBtn,\n onClickNextBtn,\n onClickView,\n onClickPicker,\n} from '../events/pickerListeners.js';\n\nfunction processPickerOptions(picker, options) {\n if (options.title !== undefined) {\n if (options.title) {\n picker.controls.title.textContent = options.title;\n showElement(picker.controls.title);\n } else {\n picker.controls.title.textContent = '';\n hideElement(picker.controls.title);\n }\n }\n if (options.prevArrow) {\n const prevBtn = picker.controls.prevBtn;\n emptyChildNodes(prevBtn);\n options.prevArrow.forEach((node) => {\n prevBtn.appendChild(node.cloneNode(true));\n });\n }\n if (options.nextArrow) {\n const nextBtn = picker.controls.nextBtn;\n emptyChildNodes(nextBtn);\n options.nextArrow.forEach((node) => {\n nextBtn.appendChild(node.cloneNode(true));\n });\n }\n if (options.locale) {\n picker.controls.todayBtn.textContent = options.locale.today;\n picker.controls.clearBtn.textContent = options.locale.clear;\n }\n if (options.todayBtn !== undefined) {\n if (options.todayBtn) {\n showElement(picker.controls.todayBtn);\n } else {\n hideElement(picker.controls.todayBtn);\n }\n }\n if (hasProperty(options, 'minDate') || hasProperty(options, 'maxDate')) {\n const {minDate, maxDate} = picker.datepicker.config;\n picker.controls.todayBtn.disabled = !isInRange(today(), minDate, maxDate);\n }\n if (options.clearBtn !== undefined) {\n if (options.clearBtn) {\n showElement(picker.controls.clearBtn);\n } else {\n hideElement(picker.controls.clearBtn);\n }\n }\n}\n\n// Compute view date to reset, which will be...\n// - the last item of the selected dates or defaultViewDate if no selection\n// - limitted to minDate or maxDate if it exceeds the range\nfunction computeResetViewDate(datepicker) {\n const {dates, config} = datepicker;\n const viewDate = dates.length > 0 ? lastItemOf(dates) : config.defaultViewDate;\n return limitToRange(viewDate, config.minDate, config.maxDate);\n}\n\n// Change current view's view date\nfunction setViewDate(picker, newDate) {\n const oldViewDate = new Date(picker.viewDate);\n const newViewDate = new Date(newDate);\n const {id, year, first, last} = picker.currentView;\n const viewYear = newViewDate.getFullYear();\n\n picker.viewDate = newDate;\n if (viewYear !== oldViewDate.getFullYear()) {\n triggerDatepickerEvent(picker.datepicker, 'changeYear');\n }\n if (newViewDate.getMonth() !== oldViewDate.getMonth()) {\n triggerDatepickerEvent(picker.datepicker, 'changeMonth');\n }\n\n // return whether the new date is in different period on time from the one\n // displayed in the current view\n // when true, the view needs to be re-rendered on the next UI refresh.\n switch (id) {\n case 0:\n return newDate < first || newDate > last;\n case 1:\n return viewYear !== year;\n default:\n return viewYear < first || viewYear > last;\n }\n}\n\nfunction getTextDirection(el) {\n return window.getComputedStyle(el).direction;\n}\n\n// Class representing the picker UI\nexport default class Picker {\n constructor(datepicker) {\n this.datepicker = datepicker;\n\n const template = pickerTemplate.replace(/%buttonClass%/g, datepicker.config.buttonClass);\n const element = this.element = parseHTML(template).firstChild;\n const [header, main, footer] = element.firstChild.children;\n const title = header.firstElementChild;\n const [prevBtn, viewSwitch, nextBtn] = header.lastElementChild.children;\n const [todayBtn, clearBtn] = footer.firstChild.children;\n const controls = {\n title,\n prevBtn,\n viewSwitch,\n nextBtn,\n todayBtn,\n clearBtn,\n };\n this.main = main;\n this.controls = controls;\n\n const elementClass = datepicker.inline ? 'inline' : 'dropdown';\n element.classList.add(`datepicker-${elementClass}`);\n elementClass === 'dropdown' ? element.classList.add('dropdown', 'absolute', 'top-0', 'left-0', 'z-50', 'pt-2') : null;\n\n processPickerOptions(this, datepicker.config);\n this.viewDate = computeResetViewDate(datepicker);\n\n // set up event listeners\n registerListeners(datepicker, [\n [element, 'click', onClickPicker.bind(null, datepicker), {capture: true}],\n [main, 'click', onClickView.bind(null, datepicker)],\n [controls.viewSwitch, 'click', onClickViewSwitch.bind(null, datepicker)],\n [controls.prevBtn, 'click', onClickPrevBtn.bind(null, datepicker)],\n [controls.nextBtn, 'click', onClickNextBtn.bind(null, datepicker)],\n [controls.todayBtn, 'click', onClickTodayBtn.bind(null, datepicker)],\n [controls.clearBtn, 'click', onClickClearBtn.bind(null, datepicker)],\n ]);\n\n // set up views\n this.views = [\n new DaysView(this),\n new MonthsView(this),\n new YearsView(this, {id: 2, name: 'years', cellClass: 'year', step: 1}),\n new YearsView(this, {id: 3, name: 'decades', cellClass: 'decade', step: 10}),\n ];\n this.currentView = this.views[datepicker.config.startView];\n\n this.currentView.render();\n this.main.appendChild(this.currentView.element);\n datepicker.config.container.appendChild(this.element);\n }\n\n setOptions(options) {\n processPickerOptions(this, options);\n this.views.forEach((view) => {\n view.init(options, false);\n });\n this.currentView.render();\n }\n\n detach() {\n this.datepicker.config.container.removeChild(this.element);\n }\n\n show() {\n if (this.active) {\n return;\n }\n this.element.classList.add('active', 'block');\n this.element.classList.remove('hidden');\n this.active = true;\n\n const datepicker = this.datepicker;\n if (!datepicker.inline) {\n // ensure picker's direction matches input's\n const inputDirection = getTextDirection(datepicker.inputField);\n if (inputDirection !== getTextDirection(datepicker.config.container)) {\n this.element.dir = inputDirection;\n } else if (this.element.dir) {\n this.element.removeAttribute('dir');\n }\n\n this.place();\n if (datepicker.config.disableTouchKeyboard) {\n datepicker.inputField.blur();\n }\n }\n triggerDatepickerEvent(datepicker, 'show');\n }\n\n hide() {\n if (!this.active) {\n return;\n }\n this.datepicker.exitEditMode();\n this.element.classList.remove('active', 'block');\n this.element.classList.add('active', 'block', 'hidden');\n this.active = false;\n triggerDatepickerEvent(this.datepicker, 'hide');\n }\n\n place() {\n const {classList, style} = this.element;\n const {config, inputField} = this.datepicker;\n const container = config.container;\n const {\n width: calendarWidth,\n height: calendarHeight,\n } = this.element.getBoundingClientRect();\n const {\n left: containerLeft,\n top: containerTop,\n width: containerWidth,\n } = container.getBoundingClientRect();\n const {\n left: inputLeft,\n top: inputTop,\n width: inputWidth,\n height: inputHeight\n } = inputField.getBoundingClientRect();\n let {x: orientX, y: orientY} = config.orientation;\n let scrollTop;\n let left;\n let top;\n\n if (container === document.body) {\n scrollTop = window.scrollY;\n left = inputLeft + window.scrollX;\n top = inputTop + scrollTop;\n } else {\n scrollTop = container.scrollTop;\n left = inputLeft - containerLeft;\n top = inputTop - containerTop + scrollTop;\n }\n\n if (orientX === 'auto') {\n if (left < 0) {\n // align to the left and move into visible area if input's left edge < window's\n orientX = 'left';\n left = 10;\n } else if (left + calendarWidth > containerWidth) {\n // align to the right if canlendar's right edge > container's\n orientX = 'right';\n } else {\n orientX = getTextDirection(inputField) === 'rtl' ? 'right' : 'left';\n }\n }\n if (orientX === 'right') {\n left -= calendarWidth - inputWidth;\n }\n\n if (orientY === 'auto') {\n orientY = top - calendarHeight < scrollTop ? 'bottom' : 'top';\n }\n if (orientY === 'top') {\n top -= calendarHeight;\n } else {\n top += inputHeight;\n }\n\n classList.remove(\n 'datepicker-orient-top',\n 'datepicker-orient-bottom',\n 'datepicker-orient-right',\n 'datepicker-orient-left'\n );\n classList.add(`datepicker-orient-${orientY}`, `datepicker-orient-${orientX}`);\n\n style.top = top ? `${top}px` : top;\n style.left = left ? `${left}px` : left;\n }\n\n setViewSwitchLabel(labelText) {\n this.controls.viewSwitch.textContent = labelText;\n }\n\n setPrevBtnDisabled(disabled) {\n this.controls.prevBtn.disabled = disabled;\n }\n\n setNextBtnDisabled(disabled) {\n this.controls.nextBtn.disabled = disabled;\n }\n\n changeView(viewId) {\n const oldView = this.currentView;\n const newView = this.views[viewId];\n if (newView.id !== oldView.id) {\n this.currentView = newView;\n this._renderMethod = 'render';\n triggerDatepickerEvent(this.datepicker, 'changeView');\n this.main.replaceChild(newView.element, oldView.element);\n }\n return this;\n }\n\n // Change the focused date (view date)\n changeFocus(newViewDate) {\n this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refreshFocus';\n this.views.forEach((view) => {\n view.updateFocus();\n });\n return this;\n }\n\n // Apply the change of the selected dates\n update() {\n const newViewDate = computeResetViewDate(this.datepicker);\n this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refresh';\n this.views.forEach((view) => {\n view.updateFocus();\n view.updateSelection();\n });\n return this;\n }\n\n // Refresh the picker UI\n render(quickRender = true) {\n const renderMethod = (quickRender && this._renderMethod) || 'render';\n delete this._renderMethod;\n\n this.currentView[renderMethod]();\n }\n}\n","import {isInRange} from '../lib/utils.js';\nimport {addDays, addMonths, addYears, startOfYearPeriod} from '../lib/date.js';\nimport {goToPrevOrNext, switchView, unfocus} from './functions.js';\n\n// Find the closest date that doesn't meet the condition for unavailable date\n// Returns undefined if no available date is found\n// addFn: function to calculate the next date\n// - args: time value, amount\n// increase: amount to pass to addFn\n// testFn: function to test the unavailablity of the date\n// - args: time value; retun: true if unavailable\nfunction findNextAvailableOne(date, addFn, increase, testFn, min, max) {\n if (!isInRange(date, min, max)) {\n return;\n }\n if (testFn(date)) {\n const newDate = addFn(date, increase);\n return findNextAvailableOne(newDate, addFn, increase, testFn, min, max);\n }\n return date;\n}\n\n// direction: -1 (left/up), 1 (right/down)\n// vertical: true for up/down, false for left/right\nfunction moveByArrowKey(datepicker, ev, direction, vertical) {\n const picker = datepicker.picker;\n const currentView = picker.currentView;\n const step = currentView.step || 1;\n let viewDate = picker.viewDate;\n let addFn;\n let testFn;\n switch (currentView.id) {\n case 0:\n if (vertical) {\n viewDate = addDays(viewDate, direction * 7);\n } else if (ev.ctrlKey || ev.metaKey) {\n viewDate = addYears(viewDate, direction);\n } else {\n viewDate = addDays(viewDate, direction);\n }\n addFn = addDays;\n testFn = (date) => currentView.disabled.includes(date);\n break;\n case 1:\n viewDate = addMonths(viewDate, vertical ? direction * 4 : direction);\n addFn = addMonths;\n testFn = (date) => {\n const dt = new Date(date);\n const {year, disabled} = currentView;\n return dt.getFullYear() === year && disabled.includes(dt.getMonth());\n };\n break;\n default:\n viewDate = addYears(viewDate, direction * (vertical ? 4 : 1) * step);\n addFn = addYears;\n testFn = date => currentView.disabled.includes(startOfYearPeriod(date, step));\n }\n viewDate = findNextAvailableOne(\n viewDate,\n addFn,\n direction < 0 ? -step : step,\n testFn,\n currentView.minDate,\n currentView.maxDate\n );\n if (viewDate !== undefined) {\n picker.changeFocus(viewDate).render();\n }\n}\n\nexport function onKeydown(datepicker, ev) {\n if (ev.key === 'Tab') {\n unfocus(datepicker);\n return;\n }\n\n const picker = datepicker.picker;\n const {id, isMinView} = picker.currentView;\n if (!picker.active) {\n switch (ev.key) {\n case 'ArrowDown':\n case 'Escape':\n picker.show();\n break;\n case 'Enter':\n datepicker.update();\n break;\n default:\n return;\n }\n } else if (datepicker.editMode) {\n switch (ev.key) {\n case 'Escape':\n picker.hide();\n break;\n case 'Enter':\n datepicker.exitEditMode({update: true, autohide: datepicker.config.autohide});\n break;\n default:\n return;\n }\n } else {\n switch (ev.key) {\n case 'Escape':\n picker.hide();\n break;\n case 'ArrowLeft':\n if (ev.ctrlKey || ev.metaKey) {\n goToPrevOrNext(datepicker, -1);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, -1, false);\n }\n break;\n case 'ArrowRight':\n if (ev.ctrlKey || ev.metaKey) {\n goToPrevOrNext(datepicker, 1);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, 1, false);\n }\n break;\n case 'ArrowUp':\n if (ev.ctrlKey || ev.metaKey) {\n switchView(datepicker);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, -1, true);\n }\n break;\n case 'ArrowDown':\n if (ev.shiftKey && !ev.ctrlKey && !ev.metaKey) {\n datepicker.enterEditMode();\n return;\n }\n moveByArrowKey(datepicker, ev, 1, true);\n break;\n case 'Enter':\n if (isMinView) {\n datepicker.setDate(picker.viewDate);\n } else {\n picker.changeView(id - 1).render();\n }\n break;\n case 'Backspace':\n case 'Delete':\n datepicker.enterEditMode();\n return;\n default:\n if (ev.key.length === 1 && !ev.ctrlKey && !ev.metaKey) {\n datepicker.enterEditMode();\n }\n return;\n }\n }\n ev.preventDefault();\n ev.stopPropagation();\n}\n\nexport function onFocus(datepicker) {\n if (datepicker.config.showOnFocus && !datepicker._showing) {\n datepicker.show();\n }\n}\n\n// for the prevention for entering edit mode while getting focus on click\nexport function onMousedown(datepicker, ev) {\n const el = ev.target;\n if (datepicker.picker.active || datepicker.config.showOnClick) {\n el._active = el === document.activeElement;\n el._clicking = setTimeout(() => {\n delete el._active;\n delete el._clicking;\n }, 2000);\n }\n}\n\nexport function onClickInput(datepicker, ev) {\n const el = ev.target;\n if (!el._clicking) {\n return;\n }\n clearTimeout(el._clicking);\n delete el._clicking;\n\n if (el._active) {\n datepicker.enterEditMode();\n }\n delete el._active;\n\n if (datepicker.config.showOnClick) {\n datepicker.show();\n }\n}\n\nexport function onPaste(datepicker, ev) {\n if (ev.clipboardData.types.includes('text/plain')) {\n datepicker.enterEditMode();\n }\n}\n","import {findElementInEventPath} from '../lib/event.js';\nimport {unfocus} from './functions.js';\n\n// for the `document` to delegate the events from outside the picker/input field\nexport function onClickOutside(datepicker, ev) {\n const element = datepicker.element;\n if (element !== document.activeElement) {\n return;\n }\n const pickerElem = datepicker.picker.element;\n if (findElementInEventPath(ev, el => el === element || el === pickerElem)) {\n return;\n }\n unfocus(datepicker);\n}\n","import {lastItemOf, stringToArray, isInRange} from './lib/utils.js';\nimport {today} from './lib/date.js';\nimport {parseDate, formatDate} from './lib/date-format.js';\nimport {registerListeners, unregisterListeners} from './lib/event.js';\nimport {locales} from './i18n/base-locales.js';\nimport defaultOptions from './options/defaultOptions.js';\nimport processOptions from './options/processOptions.js';\nimport Picker from './picker/Picker.js';\nimport {triggerDatepickerEvent} from './events/functions.js';\nimport {onKeydown, onFocus, onMousedown, onClickInput, onPaste} from './events/inputFieldListeners.js';\nimport {onClickOutside} from './events/otherListeners.js';\n\nfunction stringifyDates(dates, config) {\n return dates\n .map(dt => formatDate(dt, config.format, config.locale))\n .join(config.dateDelimiter);\n}\n\n// parse input dates and create an array of time values for selection\n// returns undefined if there are no valid dates in inputDates\n// when origDates (current selection) is passed, the function works to mix\n// the input dates into the current selection\nfunction processInputDates(datepicker, inputDates, clear = false) {\n const {config, dates: origDates, rangepicker} = datepicker;\n if (inputDates.length === 0) {\n // empty input is considered valid unless origiDates is passed\n return clear ? [] : undefined;\n }\n\n const rangeEnd = rangepicker && datepicker === rangepicker.datepickers[1];\n let newDates = inputDates.reduce((dates, dt) => {\n let date = parseDate(dt, config.format, config.locale);\n if (date === undefined) {\n return dates;\n }\n if (config.pickLevel > 0) {\n // adjust to 1st of the month/Jan 1st of the year\n // or to the last day of the monh/Dec 31st of the year if the datepicker\n // is the range-end picker of a rangepicker\n const dt = new Date(date);\n if (config.pickLevel === 1) {\n date = rangeEnd\n ? dt.setMonth(dt.getMonth() + 1, 0)\n : dt.setDate(1);\n } else {\n date = rangeEnd\n ? dt.setFullYear(dt.getFullYear() + 1, 0, 0)\n : dt.setMonth(0, 1);\n }\n }\n if (\n isInRange(date, config.minDate, config.maxDate)\n && !dates.includes(date)\n && !config.datesDisabled.includes(date)\n && !config.daysOfWeekDisabled.includes(new Date(date).getDay())\n ) {\n dates.push(date);\n }\n return dates;\n }, []);\n if (newDates.length === 0) {\n return;\n }\n if (config.multidate && !clear) {\n // get the synmetric difference between origDates and newDates\n newDates = newDates.reduce((dates, date) => {\n if (!origDates.includes(date)) {\n dates.push(date);\n }\n return dates;\n }, origDates.filter(date => !newDates.includes(date)));\n }\n // do length check always because user can input multiple dates regardless of the mode\n return config.maxNumberOfDates && newDates.length > config.maxNumberOfDates\n ? newDates.slice(config.maxNumberOfDates * -1)\n : newDates;\n}\n\n// refresh the UI elements\n// modes: 1: input only, 2, picker only, 3 both\nfunction refreshUI(datepicker, mode = 3, quickRender = true) {\n const {config, picker, inputField} = datepicker;\n if (mode & 2) {\n const newView = picker.active ? config.pickLevel : config.startView;\n picker.update().changeView(newView).render(quickRender);\n }\n if (mode & 1 && inputField) {\n inputField.value = stringifyDates(datepicker.dates, config);\n }\n}\n\nfunction setDate(datepicker, inputDates, options) {\n let {clear, render, autohide} = options;\n if (render === undefined) {\n render = true;\n }\n if (!render) {\n autohide = false;\n } else if (autohide === undefined) {\n autohide = datepicker.config.autohide;\n }\n\n const newDates = processInputDates(datepicker, inputDates, clear);\n if (!newDates) {\n return;\n }\n if (newDates.toString() !== datepicker.dates.toString()) {\n datepicker.dates = newDates;\n refreshUI(datepicker, render ? 3 : 1);\n triggerDatepickerEvent(datepicker, 'changeDate');\n } else {\n refreshUI(datepicker, 1);\n }\n if (autohide) {\n datepicker.hide();\n }\n}\n\n/**\n * Class representing a date picker\n */\nexport default class Datepicker {\n /**\n * Create a date picker\n * @param {Element} element - element to bind a date picker\n * @param {Object} [options] - config options\n * @param {DateRangePicker} [rangepicker] - DateRangePicker instance the\n * date picker belongs to. Use this only when creating date picker as a part\n * of date range picker\n */\n constructor(element, options = {}, rangepicker = undefined) {\n element.datepicker = this;\n this.element = element;\n\n // set up config\n const config = this.config = Object.assign({\n buttonClass: (options.buttonClass && String(options.buttonClass)) || 'button',\n container: document.body,\n defaultViewDate: today(),\n maxDate: undefined,\n minDate: undefined,\n }, processOptions(defaultOptions, this));\n this._options = options;\n Object.assign(config, processOptions(options, this));\n\n // configure by type\n const inline = this.inline = element.tagName !== 'INPUT';\n let inputField;\n let initialDates;\n\n if (inline) {\n config.container = element;\n initialDates = stringToArray(element.dataset.date, config.dateDelimiter);\n delete element.dataset.date;\n } else {\n const container = options.container ? document.querySelector(options.container) : null;\n if (container) {\n config.container = container;\n }\n inputField = this.inputField = element;\n inputField.classList.add('datepicker-input');\n initialDates = stringToArray(inputField.value, config.dateDelimiter);\n }\n if (rangepicker) {\n // check validiry\n const index = rangepicker.inputs.indexOf(inputField);\n const datepickers = rangepicker.datepickers;\n if (index < 0 || index > 1 || !Array.isArray(datepickers)) {\n throw Error('Invalid rangepicker object.');\n }\n // attach itaelf to the rangepicker here so that processInputDates() can\n // determine if this is the range-end picker of the rangepicker while\n // setting inital values when pickLevel > 0\n datepickers[index] = this;\n // add getter for rangepicker\n Object.defineProperty(this, 'rangepicker', {\n get() {\n return rangepicker;\n },\n });\n }\n\n // set initial dates\n this.dates = [];\n // process initial value\n const inputDateValues = processInputDates(this, initialDates);\n if (inputDateValues && inputDateValues.length > 0) {\n this.dates = inputDateValues;\n }\n if (inputField) {\n inputField.value = stringifyDates(this.dates, config);\n }\n\n const picker = this.picker = new Picker(this);\n\n if (inline) {\n this.show();\n } else {\n // set up event listeners in other modes\n const onMousedownDocument = onClickOutside.bind(null, this);\n const listeners = [\n [inputField, 'keydown', onKeydown.bind(null, this)],\n [inputField, 'focus', onFocus.bind(null, this)],\n [inputField, 'mousedown', onMousedown.bind(null, this)],\n [inputField, 'click', onClickInput.bind(null, this)],\n [inputField, 'paste', onPaste.bind(null, this)],\n [document, 'mousedown', onMousedownDocument],\n [document, 'touchstart', onMousedownDocument],\n [window, 'resize', picker.place.bind(picker)]\n ];\n registerListeners(this, listeners);\n }\n }\n\n /**\n * Format Date object or time value in given format and language\n * @param {Date|Number} date - date or time value to format\n * @param {String|Object} format - format string or object that contains\n * toDisplay() custom formatter, whose signature is\n * - args:\n * - date: {Date} - Date instance of the date passed to the method\n * - format: {Object} - the format object passed to the method\n * - locale: {Object} - locale for the language specified by `lang`\n * - return:\n * {String} formatted date\n * @param {String} [lang=en] - language code for the locale to use\n * @return {String} formatted date\n */\n static formatDate(date, format, lang) {\n return formatDate(date, format, lang && locales[lang] || locales.en);\n }\n\n /**\n * Parse date string\n * @param {String|Date|Number} dateStr - date string, Date object or time\n * value to parse\n * @param {String|Object} format - format string or object that contains\n * toValue() custom parser, whose signature is\n * - args:\n * - dateStr: {String|Date|Number} - the dateStr passed to the method\n * - format: {Object} - the format object passed to the method\n * - locale: {Object} - locale for the language specified by `lang`\n * - return:\n * {Date|Number} parsed date or its time value\n * @param {String} [lang=en] - language code for the locale to use\n * @return {Number} time value of parsed date\n */\n static parseDate(dateStr, format, lang) {\n return parseDate(dateStr, format, lang && locales[lang] || locales.en);\n }\n\n /**\n * @type {Object} - Installed locales in `[languageCode]: localeObject` format\n * en`:_English (US)_ is pre-installed.\n */\n static get locales() {\n return locales;\n }\n\n /**\n * @type {Boolean} - Whether the picker element is shown. `true` whne shown\n */\n get active() {\n return !!(this.picker && this.picker.active);\n }\n\n /**\n * @type {HTMLDivElement} - DOM object of picker element\n */\n get pickerElement() {\n return this.picker ? this.picker.element : undefined;\n }\n\n /**\n * Set new values to the config options\n * @param {Object} options - config options to update\n */\n setOptions(options) {\n const picker = this.picker;\n const newOptions = processOptions(options, this);\n Object.assign(this._options, options);\n Object.assign(this.config, newOptions);\n picker.setOptions(newOptions);\n\n refreshUI(this, 3);\n }\n\n /**\n * Show the picker element\n */\n show() {\n if (this.inputField) {\n if (this.inputField.disabled) {\n return;\n }\n if (this.inputField !== document.activeElement) {\n this._showing = true;\n this.inputField.focus();\n delete this._showing;\n }\n }\n this.picker.show();\n }\n\n /**\n * Hide the picker element\n * Not available on inline picker\n */\n hide() {\n if (this.inline) {\n return;\n }\n this.picker.hide();\n this.picker.update().changeView(this.config.startView).render();\n }\n\n /**\n * Destroy the Datepicker instance\n * @return {Detepicker} - the instance destroyed\n */\n destroy() {\n this.hide();\n unregisterListeners(this);\n this.picker.detach();\n if (!this.inline) {\n this.inputField.classList.remove('datepicker-input');\n }\n delete this.element.datepicker;\n return this;\n }\n\n /**\n * Get the selected date(s)\n *\n * The method returns a Date object of selected date by default, and returns\n * an array of selected dates in multidate mode. If format string is passed,\n * it returns date string(s) formatted in given format.\n *\n * @param {String} [format] - Format string to stringify the date(s)\n * @return {Date|String|Date[]|String[]} - selected date(s), or if none is\n * selected, empty array in multidate mode and untitled in sigledate mode\n */\n getDate(format = undefined) {\n const callback = format\n ? date => formatDate(date, format, this.config.locale)\n : date => new Date(date);\n\n if (this.config.multidate) {\n return this.dates.map(callback);\n }\n if (this.dates.length > 0) {\n return callback(this.dates[0]);\n }\n }\n\n /**\n * Set selected date(s)\n *\n * In multidate mode, you can pass multiple dates as a series of arguments\n * or an array. (Since each date is parsed individually, the type of the\n * dates doesn't have to be the same.)\n * The given dates are used to toggle the select status of each date. The\n * number of selected dates is kept from exceeding the length set to\n * maxNumberOfDates.\n *\n * With clear: true option, the method can be used to clear the selection\n * and to replace the selection instead of toggling in multidate mode.\n * If the option is passed with no date arguments or an empty dates array,\n * it works as \"clear\" (clear the selection then set nothing), and if the\n * option is passed with new dates to select, it works as \"replace\" (clear\n * the selection then set the given dates)\n *\n * When render: false option is used, the method omits re-rendering the\n * picker element. In this case, you need to call refresh() method later in\n * order for the picker element to reflect the changes. The input field is\n * refreshed always regardless of this option.\n *\n * When invalid (unparsable, repeated, disabled or out-of-range) dates are\n * passed, the method ignores them and applies only valid ones. In the case\n * that all the given dates are invalid, which is distinguished from passing\n * no dates, the method considers it as an error and leaves the selection\n * untouched.\n *\n * @param {...(Date|Number|String)|Array} [dates] - Date strings, Date\n * objects, time values or mix of those for new selection\n * @param {Object} [options] - function options\n * - clear: {boolean} - Whether to clear the existing selection\n * defualt: false\n * - render: {boolean} - Whether to re-render the picker element\n * default: true\n * - autohide: {boolean} - Whether to hide the picker element after re-render\n * Ignored when used with render: false\n * default: config.autohide\n */\n setDate(...args) {\n const dates = [...args];\n const opts = {};\n const lastArg = lastItemOf(args);\n if (\n typeof lastArg === 'object'\n && !Array.isArray(lastArg)\n && !(lastArg instanceof Date)\n && lastArg\n ) {\n Object.assign(opts, dates.pop());\n }\n\n const inputDates = Array.isArray(dates[0]) ? dates[0] : dates;\n setDate(this, inputDates, opts);\n }\n\n /**\n * Update the selected date(s) with input field's value\n * Not available on inline picker\n *\n * The input field will be refreshed with properly formatted date string.\n *\n * @param {Object} [options] - function options\n * - autohide: {boolean} - whether to hide the picker element after refresh\n * default: false\n */\n update(options = undefined) {\n if (this.inline) {\n return;\n }\n\n const opts = {clear: true, autohide: !!(options && options.autohide)};\n const inputDates = stringToArray(this.inputField.value, this.config.dateDelimiter);\n setDate(this, inputDates, opts);\n }\n\n /**\n * Refresh the picker element and the associated input field\n * @param {String} [target] - target item when refreshing one item only\n * 'picker' or 'input'\n * @param {Boolean} [forceRender] - whether to re-render the picker element\n * regardless of its state instead of optimized refresh\n */\n refresh(target = undefined, forceRender = false) {\n if (target && typeof target !== 'string') {\n forceRender = target;\n target = undefined;\n }\n\n let mode;\n if (target === 'picker') {\n mode = 2;\n } else if (target === 'input') {\n mode = 1;\n } else {\n mode = 3;\n }\n refreshUI(this, mode, !forceRender);\n }\n\n /**\n * Enter edit mode\n * Not available on inline picker or when the picker element is hidden\n */\n enterEditMode() {\n if (this.inline || !this.picker.active || this.editMode) {\n return;\n }\n this.editMode = true;\n this.inputField.classList.add('in-edit', 'border-blue-700');\n }\n\n /**\n * Exit from edit mode\n * Not available on inline picker\n * @param {Object} [options] - function options\n * - update: {boolean} - whether to call update() after exiting\n * If false, input field is revert to the existing selection\n * default: false\n */\n exitEditMode(options = undefined) {\n if (this.inline || !this.editMode) {\n return;\n }\n const opts = Object.assign({update: false}, options);\n delete this.editMode;\n this.inputField.classList.remove('in-edit', 'border-blue-700');\n if (opts.update) {\n this.update(opts);\n }\n }\n}\n","import {stripTime, today} from './date.js';\nimport {lastItemOf} from './utils.js';\n\n// pattern for format parts\nexport const reFormatTokens = /dd?|DD?|mm?|MM?|yy?(?:yy)?/;\n// pattern for non date parts\nexport const reNonDateParts = /[\\s!-/:-@[-`{-~年月日]+/;\n// cache for persed formats\nlet knownFormats = {};\n// parse funtions for date parts\nconst parseFns = {\n y(date, year) {\n return new Date(date).setFullYear(parseInt(year, 10));\n },\n m(date, month, locale) {\n const newDate = new Date(date);\n let monthIndex = parseInt(month, 10) - 1;\n\n if (isNaN(monthIndex)) {\n if (!month) {\n return NaN;\n }\n\n const monthName = month.toLowerCase();\n const compareNames = name => name.toLowerCase().startsWith(monthName);\n // compare with both short and full names because some locales have periods\n // in the short names (not equal to the first X letters of the full names)\n monthIndex = locale.monthsShort.findIndex(compareNames);\n if (monthIndex < 0) {\n monthIndex = locale.months.findIndex(compareNames);\n }\n if (monthIndex < 0) {\n return NaN;\n }\n }\n\n newDate.setMonth(monthIndex);\n return newDate.getMonth() !== normalizeMonth(monthIndex)\n ? newDate.setDate(0)\n : newDate.getTime();\n },\n d(date, day) {\n return new Date(date).setDate(parseInt(day, 10));\n },\n};\n// format functions for date parts\nconst formatFns = {\n d(date) {\n return date.getDate();\n },\n dd(date) {\n return padZero(date.getDate(), 2);\n },\n D(date, locale) {\n return locale.daysShort[date.getDay()];\n },\n DD(date, locale) {\n return locale.days[date.getDay()];\n },\n m(date) {\n return date.getMonth() + 1;\n },\n mm(date) {\n return padZero(date.getMonth() + 1, 2);\n },\n M(date, locale) {\n return locale.monthsShort[date.getMonth()];\n },\n MM(date, locale) {\n return locale.months[date.getMonth()];\n },\n y(date) {\n return date.getFullYear();\n },\n yy(date) {\n return padZero(date.getFullYear(), 2).slice(-2);\n },\n yyyy(date) {\n return padZero(date.getFullYear(), 4);\n },\n};\n\n// get month index in normal range (0 - 11) from any number\nfunction normalizeMonth(monthIndex) {\n return monthIndex > -1 ? monthIndex % 12 : normalizeMonth(monthIndex + 12);\n}\n\nfunction padZero(num, length) {\n return num.toString().padStart(length, '0');\n}\n\nfunction parseFormatString(format) {\n if (typeof format !== 'string') {\n throw new Error(\"Invalid date format.\");\n }\n if (format in knownFormats) {\n return knownFormats[format];\n }\n\n // sprit the format string into parts and seprators\n const separators = format.split(reFormatTokens);\n const parts = format.match(new RegExp(reFormatTokens, 'g'));\n if (separators.length === 0 || !parts) {\n throw new Error(\"Invalid date format.\");\n }\n\n // collect format functions used in the format\n const partFormatters = parts.map(token => formatFns[token]);\n\n // collect parse function keys used in the format\n // iterate over parseFns' keys in order to keep the order of the keys.\n const partParserKeys = Object.keys(parseFns).reduce((keys, key) => {\n const token = parts.find(part => part[0] !== 'D' && part[0].toLowerCase() === key);\n if (token) {\n keys.push(key);\n }\n return keys;\n }, []);\n\n return knownFormats[format] = {\n parser(dateStr, locale) {\n const dateParts = dateStr.split(reNonDateParts).reduce((dtParts, part, index) => {\n if (part.length > 0 && parts[index]) {\n const token = parts[index][0];\n if (token === 'M') {\n dtParts.m = part;\n } else if (token !== 'D') {\n dtParts[token] = part;\n }\n }\n return dtParts;\n }, {});\n\n // iterate over partParserkeys so that the parsing is made in the oder\n // of year, month and day to prevent the day parser from correcting last\n // day of month wrongly\n return partParserKeys.reduce((origDate, key) => {\n const newDate = parseFns[key](origDate, dateParts[key], locale);\n // ingnore the part failed to parse\n return isNaN(newDate) ? origDate : newDate;\n }, today());\n },\n formatter(date, locale) {\n let dateStr = partFormatters.reduce((str, fn, index) => {\n return str += `${separators[index]}${fn(date, locale)}`;\n }, '');\n // separators' length is always parts' length + 1,\n return dateStr += lastItemOf(separators);\n },\n };\n}\n\nexport function parseDate(dateStr, format, locale) {\n if (dateStr instanceof Date || typeof dateStr === 'number') {\n const date = stripTime(dateStr);\n return isNaN(date) ? undefined : date;\n }\n if (!dateStr) {\n return undefined;\n }\n if (dateStr === 'today') {\n return today();\n }\n\n if (format && format.toValue) {\n const date = format.toValue(dateStr, format, locale);\n return isNaN(date) ? undefined : stripTime(date);\n }\n\n return parseFormatString(format).parser(dateStr, locale);\n}\n\nexport function formatDate(date, format, locale) {\n if (isNaN(date) || (!date && date !== 0)) {\n return '';\n }\n\n const dateObj = typeof date === 'number' ? new Date(date) : date;\n\n if (format.toDisplay) {\n return format.toDisplay(dateObj, format, locale);\n }\n\n return parseFormatString(format).formatter(dateObj, locale);\n}\n","export function stripTime(timeValue) {\n return new Date(timeValue).setHours(0, 0, 0, 0);\n}\n\nexport function today() {\n return new Date().setHours(0, 0, 0, 0);\n}\n\n// Get the time value of the start of given date or year, month and day\nexport function dateValue(...args) {\n switch (args.length) {\n case 0:\n return today();\n case 1:\n return stripTime(args[0]);\n }\n\n // use setFullYear() to keep 2-digit year from being mapped to 1900-1999\n const newDate = new Date(0);\n newDate.setFullYear(...args);\n return newDate.setHours(0, 0, 0, 0);\n}\n\nexport function addDays(date, amount) {\n const newDate = new Date(date);\n return newDate.setDate(newDate.getDate() + amount);\n}\n\nexport function addWeeks(date, amount) {\n return addDays(date, amount * 7);\n}\n\nexport function addMonths(date, amount) {\n // If the day of the date is not in the new month, the last day of the new\n // month will be returned. e.g. Jan 31 + 1 month → Feb 28 (not Mar 03)\n const newDate = new Date(date);\n const monthsToSet = newDate.getMonth() + amount;\n let expectedMonth = monthsToSet % 12;\n if (expectedMonth < 0) {\n expectedMonth += 12;\n }\n\n const time = newDate.setMonth(monthsToSet);\n return newDate.getMonth() !== expectedMonth ? newDate.setDate(0) : time;\n}\n\nexport function addYears(date, amount) {\n // If the date is Feb 29 and the new year is not a leap year, Feb 28 of the\n // new year will be returned.\n const newDate = new Date(date);\n const expectedMonth = newDate.getMonth();\n const time = newDate.setFullYear(newDate.getFullYear() + amount);\n return expectedMonth === 1 && newDate.getMonth() === 2 ? newDate.setDate(0) : time;\n}\n\n// Calculate the distance bettwen 2 days of the week\nfunction dayDiff(day, from) {\n return (day - from + 7) % 7;\n}\n\n// Get the date of the specified day of the week of given base date\nexport function dayOfTheWeekOf(baseDate, dayOfWeek, weekStart = 0) {\n const baseDay = new Date(baseDate).getDay();\n return addDays(baseDate, dayDiff(dayOfWeek, weekStart) - dayDiff(baseDay, weekStart));\n}\n\n// Get the ISO week of a date\nexport function getWeek(date) {\n // start of ISO week is Monday\n const thuOfTheWeek = dayOfTheWeekOf(date, 4, 1);\n // 1st week == the week where the 4th of January is in\n const firstThu = dayOfTheWeekOf(new Date(thuOfTheWeek).setMonth(0, 4), 4, 1);\n return Math.round((thuOfTheWeek - firstThu) / 604800000) + 1;\n}\n\n// Get the start year of the period of years that includes given date\n// years: length of the year period\nexport function startOfYearPeriod(date, years) {\n /* @see https://en.wikipedia.org/wiki/Year_zero#ISO_8601 */\n const year = new Date(date).getFullYear();\n return Math.floor(year / years) * years;\n}\n","const listenerRegistry = new WeakMap();\nconst {addEventListener, removeEventListener} = EventTarget.prototype;\n\n// Register event listeners to a key object\n// listeners: array of listener definitions;\n// - each definition must be a flat array of event target and the arguments\n// used to call addEventListener() on the target\nexport function registerListeners(keyObj, listeners) {\n let registered = listenerRegistry.get(keyObj);\n if (!registered) {\n registered = [];\n listenerRegistry.set(keyObj, registered);\n }\n listeners.forEach((listener) => {\n addEventListener.call(...listener);\n registered.push(listener);\n });\n}\n\nexport function unregisterListeners(keyObj) {\n let listeners = listenerRegistry.get(keyObj);\n if (!listeners) {\n return;\n }\n listeners.forEach((listener) => {\n removeEventListener.call(...listener);\n });\n listenerRegistry.delete(keyObj);\n}\n\n// Event.composedPath() polyfill for Edge\n// based on https://gist.github.com/kleinfreund/e9787d73776c0e3750dcfcdc89f100ec\nif (!Event.prototype.composedPath) {\n const getComposedPath = (node, path = []) => {\n path.push(node);\n\n let parent;\n if (node.parentNode) {\n parent = node.parentNode;\n } else if (node.host) { // ShadowRoot\n parent = node.host;\n } else if (node.defaultView) { // Document\n parent = node.defaultView;\n }\n return parent ? getComposedPath(parent, path) : path;\n };\n\n Event.prototype.composedPath = function () {\n return getComposedPath(this.target);\n };\n}\n\nfunction findFromPath(path, criteria, currentTarget, index = 0) {\n const el = path[index];\n if (criteria(el)) {\n return el;\n } else if (el === currentTarget || !el.parentElement) {\n // stop when reaching currentTarget or \n return;\n }\n return findFromPath(path, criteria, currentTarget, index + 1);\n}\n\n// Search for the actual target of a delegated event\nexport function findElementInEventPath(ev, selector) {\n const criteria = typeof selector === 'function' ? selector : el => el.matches(selector);\n return findFromPath(ev.composedPath(), criteria, ev.currentTarget);\n}\n","export function hasProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nexport function lastItemOf(arr) {\n return arr[arr.length - 1];\n}\n\n// push only the items not included in the array\nexport function pushUnique(arr, ...items) {\n items.forEach((item) => {\n if (arr.includes(item)) {\n return;\n }\n arr.push(item);\n });\n return arr;\n}\n\nexport function stringToArray(str, separator) {\n // convert empty string to an empty array\n return str ? str.split(separator) : [];\n}\n\nexport function isInRange(testVal, min, max) {\n const minOK = min === undefined || testVal >= min;\n const maxOK = max === undefined || testVal <= max;\n return minOK && maxOK;\n}\n\nexport function limitToRange(val, min, max) {\n if (val < min) {\n return min;\n }\n if (val > max) {\n return max;\n }\n return val;\n}\n\nexport function createTagRepeat(tagName, repeat, attributes = {}, index = 0, html = '') {\n const openTagSrc = Object.keys(attributes).reduce((src, attr) => {\n let val = attributes[attr];\n if (typeof val === 'function') {\n val = val(index);\n }\n return `${src} ${attr}=\"${val}\"`;\n }, tagName);\n html += `<${openTagSrc}>`;\n\n const next = index + 1;\n return next < repeat\n ? createTagRepeat(tagName, repeat, attributes, next, html)\n : html;\n}\n\n// Remove the spacing surrounding tags for HTML parser not to create text nodes\n// before/after elements\nexport function optimizeTemplateHTML(html) {\n return html.replace(/>\\s+/g, '>').replace(/\\s+ {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import Datepicker from 'flowbite-datepicker/Datepicker';\nimport DateRangePicker from 'flowbite-datepicker/DateRangePicker';\nimport Events from '../dom/events';\n\nconst getDatepickerOptions = (datepickerEl) => {\n const buttons = datepickerEl.hasAttribute('datepicker-buttons');\n const autohide = datepickerEl.hasAttribute('datepicker-autohide');\n const format = datepickerEl.hasAttribute('datepicker-format');\n const orientation = datepickerEl.hasAttribute('datepicker-orientation');\n const title = datepickerEl.hasAttribute('datepicker-title');\n\n const options = {};\n if (buttons) {\n options.todayBtn = true;\n options.clearBtn = true;\n }\n if (autohide) {\n options.autohide = true;\n }\n if (format) {\n options.format = datepickerEl.getAttribute('datepicker-format');\n }\n if (orientation) {\n options.orientation = datepickerEl.getAttribute(\n 'datepicker-orientation'\n );\n }\n if (title) {\n options.title = datepickerEl.getAttribute('datepicker-title');\n }\n\n return options;\n};\n\nexport function initDatepickers() {\n document.querySelectorAll('[datepicker]').forEach(function (datepickerEl) {\n new Datepicker(datepickerEl, getDatepickerOptions(datepickerEl));\n });\n\n document\n .querySelectorAll('[inline-datepicker]')\n .forEach(function (datepickerEl) {\n new Datepicker(datepickerEl, getDatepickerOptions(datepickerEl));\n });\n\n document\n .querySelectorAll('[date-rangepicker]')\n .forEach(function (datepickerEl) {\n new DateRangePicker(\n datepickerEl,\n getDatepickerOptions(datepickerEl)\n );\n });\n}\n\nconst events = new Events('DOMContentLoaded', [initDatepickers]);\nevents.init();\n"],"names":["Datepicker","DateRangePicker","Events","getDatepickerOptions","datepickerEl","buttons","hasAttribute","autohide","format","orientation","title","options","todayBtn","clearBtn","getAttribute","initDatepickers","document","querySelectorAll","forEach","events","init"],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/datepicker.min.js b/node_modules/flowbite/dist/datepicker.min.js new file mode 100644 index 0000000..f0c9007 --- /dev/null +++ b/node_modules/flowbite/dist/datepicker.min.js @@ -0,0 +1,2 @@ +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("Flowbite",[],t):"object"==typeof exports?exports.Flowbite=t():e.Flowbite=t()}(self,(function(){return function(){"use strict";var e={482:function(e,t,i){i.d(t,{Z:function(){return c}});var r=i(698),n=i(963),a=i(770);function s(e){const t=Object.assign({},e);return delete t.inputs,delete t.allowOneSidedRange,delete t.maxNumberOfDates,t}function o(e,t,i,n){(0,r.cF)(e,[[i,"changeDate",t]]),new a.Z(i,n,e)}function d(e,t){if(e._updating)return;e._updating=!0;const i=t.target;if(void 0===i.datepicker)return;const r=e.datepickers,n={render:!1},a=e.inputs.indexOf(i),s=0===a?1:0,o=r[a].dates[0],d=r[s].dates[0];void 0!==o&&void 0!==d?0===a&&o>d?(r[0].setDate(d,n),r[1].setDate(o,n)):1===a&&o0?d(this,{target:this.inputs[0]}):a[1].dates.length>0&&d(this,{target:this.inputs[1]})}get dates(){return 2===this.datepickers.length?[this.datepickers[0].dates[0],this.datepickers[1].dates[0]]:void 0}setOptions(e){this.allowOneSidedRange=!!e.allowOneSidedRange;const t=s(e);this.datepickers[0].setOptions(t),this.datepickers[1].setOptions(t)}destroy(){this.datepickers[0].destroy(),this.datepickers[1].destroy(),(0,r.uV)(this),delete this.element.rangepicker}getDates(e){const t=e?t=>(0,n.p6)(t,e,this.datepickers[0].config.locale):e=>new Date(e);return this.dates.map((e=>void 0===e?e:t(e)))}setDates(e,t){const[i,r]=this.datepickers,n=this.dates;this._updating=!0,i.setDate(e),r.setDate(t),delete this._updating,r.dates[0]!==n[1]?d(this,{target:this.inputs[1]}):i.dates[0]!==n[0]&&d(this,{target:this.inputs[0]})}}},770:function(e,t,i){i.d(t,{Z:function(){return ae}});var r=i(105),n=i(560),a=i(963),s=i(698);const o={en:{days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],daysShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],daysMin:["Su","Mo","Tu","We","Th","Fr","Sa"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],monthsShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],today:"Today",clear:"Clear",titleFormat:"MM y"}};var d={autohide:!1,beforeShowDay:null,beforeShowDecade:null,beforeShowMonth:null,beforeShowYear:null,calendarWeeks:!1,clearBtn:!1,dateDelimiter:",",datesDisabled:[],daysOfWeekDisabled:[],daysOfWeekHighlighted:[],defaultViewDate:void 0,disableTouchKeyboard:!1,format:"mm/dd/yyyy",language:"en",maxDate:null,maxNumberOfDates:1,maxView:3,minDate:null,nextArrow:'',orientation:"auto",pickLevel:0,prevArrow:'',showDaysOfWeek:!0,showOnClick:!0,showOnFocus:!0,startView:0,title:"",todayBtn:!1,todayBtnMode:0,todayHighlight:!1,updateOnBlur:!0,weekStart:0};const c=document.createRange();function l(e){return c.createContextualFragment(e)}function h(e){"none"!==e.style.display&&(e.style.display&&(e.dataset.styleDisplay=e.style.display),e.style.display="none")}function u(e){"none"===e.style.display&&(e.dataset.styleDisplay?(e.style.display=e.dataset.styleDisplay,delete e.dataset.styleDisplay):e.style.display="")}function g(e){e.firstChild&&(e.removeChild(e.firstChild),g(e))}const{language:f,format:p,weekStart:m}=d;function b(e,t){return e.length<6&&t>=0&&t<7?(0,r.$C)(e,t):e}function y(e){return(e+6)%7}function w(e,t,i,r){const n=(0,a.sG)(e,t,i);return void 0!==n?n:r}function k(e,t,i=3){const r=parseInt(e,10);return r>=0&&r<=i?r:t}function v(e,t){const i=Object.assign({},e),s={},o=t.constructor.locales;let{format:c,language:h,locale:u,maxDate:g,maxView:v,minDate:x,pickLevel:D,startView:M,weekStart:S}=t.config||{};if(i.language){let e;if(i.language!==h&&(o[i.language]?e=i.language:(e=i.language.split("-")[0],void 0===o[e]&&(e=!1))),delete i.language,e){h=s.language=e;const t=u||o[f];u=Object.assign({format:p,weekStart:m},o[f]),h!==f&&Object.assign(u,o[h]),s.locale=u,c===t.format&&(c=s.format=u.format),S===t.weekStart&&(S=s.weekStart=u.weekStart,s.weekEnd=y(u.weekStart))}}if(i.format){const e="function"==typeof i.format.toDisplay,t="function"==typeof i.format.toValue,r=a.CL.test(i.format);(e&&t||r)&&(c=s.format=i.format),delete i.format}let O=x,C=g;if(void 0!==i.minDate&&(O=null===i.minDate?(0,n.by)(0,0,1):w(i.minDate,c,u,O),delete i.minDate),void 0!==i.maxDate&&(C=null===i.maxDate?void 0:w(i.maxDate,c,u,C),delete i.maxDate),C{const i=(0,a.sG)(t,c,u);return void 0!==i?(0,r.$C)(e,i):e}),[]),delete i.datesDisabled),void 0!==i.defaultViewDate){const e=(0,a.sG)(i.defaultViewDate,c,u);void 0!==e&&(s.defaultViewDate=e),delete i.defaultViewDate}if(void 0!==i.weekStart){const e=Number(i.weekStart)%7;isNaN(e)||(S=s.weekStart=e,s.weekEnd=y(e)),delete i.weekStart}if(i.daysOfWeekDisabled&&(s.daysOfWeekDisabled=i.daysOfWeekDisabled.reduce(b,[]),delete i.daysOfWeekDisabled),i.daysOfWeekHighlighted&&(s.daysOfWeekHighlighted=i.daysOfWeekHighlighted.reduce(b,[]),delete i.daysOfWeekHighlighted),void 0!==i.maxNumberOfDates){const e=parseInt(i.maxNumberOfDates,10);e>=0&&(s.maxNumberOfDates=e,s.multidate=1!==e),delete i.maxNumberOfDates}i.dateDelimiter&&(s.dateDelimiter=String(i.dateDelimiter),delete i.dateDelimiter);let E=D;void 0!==i.pickLevel&&(E=k(i.pickLevel,2),delete i.pickLevel),E!==D&&(D=s.pickLevel=E);let F=v;void 0!==i.maxView&&(F=k(i.maxView,v),delete i.maxView),F=D>F?D:F,F!==v&&(v=s.maxView=F);let L=M;if(void 0!==i.startView&&(L=k(i.startView,L),delete i.startView),Lv&&(L=v),L!==M&&(s.startView=L),i.prevArrow){const e=l(i.prevArrow);e.childNodes.length>0&&(s.prevArrow=e.childNodes),delete i.prevArrow}if(i.nextArrow){const e=l(i.nextArrow);e.childNodes.length>0&&(s.nextArrow=e.childNodes),delete i.nextArrow}if(void 0!==i.disableTouchKeyboard&&(s.disableTouchKeyboard="ontouchstart"in document&&!!i.disableTouchKeyboard,delete i.disableTouchKeyboard),i.orientation){const e=i.orientation.toLowerCase().split(/\s+/g);s.orientation={x:e.find((e=>"left"===e||"right"===e))||"auto",y:e.find((e=>"top"===e||"bottom"===e))||"auto"},delete i.orientation}if(void 0!==i.todayBtnMode){switch(i.todayBtnMode){case 0:case 1:s.todayBtnMode=i.todayBtnMode}delete i.todayBtnMode}return Object.keys(i).forEach((e=>{void 0!==i[e]&&(0,r.l$)(d,e)&&(s[e]=i[e])})),s}var x=(0,r.zh)('');var D=(0,r.zh)(`
      \n
      ${(0,r.em)("span",7,{class:"dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm"})}
      \n
      ${(0,r.em)("span",42,{class:"block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400"})}
      \n
      `);var M=(0,r.zh)(`
      \n
      \n
      ${(0,r.em)("span",6,{class:"week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm"})}
      \n
      `);class S{constructor(e,t){Object.assign(this,t,{picker:e,element:l('
      ').firstChild,selected:[]}),this.init(this.picker.datepicker.config)}init(e){void 0!==e.pickLevel&&(this.isMinView=this.id===e.pickLevel),this.setOptions(e),this.updateFocus(),this.updateSelection()}performBeforeHook(e,t,i){let n=this.beforeShow(new Date(i));switch(typeof n){case"boolean":n={enabled:n};break;case"string":n={classes:n}}if(n){if(!1===n.enabled&&(e.classList.add("disabled"),(0,r.$C)(this.disabled,t)),n.classes){const i=n.classes.split(/\s+/);e.classList.add(...i),i.includes("disabled")&&(0,r.$C)(this.disabled,t)}n.content&&function(e,t){g(e),t instanceof DocumentFragment?e.appendChild(t):"string"==typeof t?e.appendChild(l(t)):"function"==typeof t.forEach&&t.forEach((t=>{e.appendChild(t)}))}(e,n.content)}}}class O extends S{constructor(e){super(e,{id:0,name:"days",cellClass:"day"})}init(e,t=!0){if(t){const e=l(D).firstChild;this.dow=e.firstChild,this.grid=e.lastChild,this.element.appendChild(e)}super.init(e)}setOptions(e){let t;if((0,r.l$)(e,"minDate")&&(this.minDate=e.minDate),(0,r.l$)(e,"maxDate")&&(this.maxDate=e.maxDate),e.datesDisabled&&(this.datesDisabled=e.datesDisabled),e.daysOfWeekDisabled&&(this.daysOfWeekDisabled=e.daysOfWeekDisabled,t=!0),e.daysOfWeekHighlighted&&(this.daysOfWeekHighlighted=e.daysOfWeekHighlighted),void 0!==e.todayHighlight&&(this.todayHighlight=e.todayHighlight),void 0!==e.weekStart&&(this.weekStart=e.weekStart,this.weekEnd=e.weekEnd,t=!0),e.locale){const i=this.locale=e.locale;this.dayNames=i.daysMin,this.switchLabelFormat=i.titleFormat,t=!0}if(void 0!==e.beforeShowDay&&(this.beforeShow="function"==typeof e.beforeShowDay?e.beforeShowDay:void 0),void 0!==e.calendarWeeks)if(e.calendarWeeks&&!this.calendarWeeks){const e=l(M).firstChild;this.calendarWeeks={element:e,dow:e.firstChild,weeks:e.lastChild},this.element.insertBefore(e,this.element.firstChild)}else this.calendarWeeks&&!e.calendarWeeks&&(this.element.removeChild(this.calendarWeeks.element),this.calendarWeeks=null);void 0!==e.showDaysOfWeek&&(e.showDaysOfWeek?(u(this.dow),this.calendarWeeks&&u(this.calendarWeeks.dow)):(h(this.dow),this.calendarWeeks&&h(this.calendarWeeks.dow))),t&&Array.from(this.dow.children).forEach(((e,t)=>{const i=(this.weekStart+t)%7;e.textContent=this.dayNames[i],e.className=this.daysOfWeekDisabled.includes(i)?"dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed":"dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400"}))}updateFocus(){const e=new Date(this.picker.viewDate),t=e.getFullYear(),i=e.getMonth(),r=(0,n.by)(t,i,1),a=(0,n.fr)(r,this.weekStart,this.weekStart);this.first=r,this.last=(0,n.by)(t,i+1,0),this.start=a,this.focused=this.picker.viewDate}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e,t&&(this.range=t.dates)}render(){this.today=this.todayHighlight?(0,n.Lg)():void 0,this.disabled=[...this.datesDisabled];const e=(0,a.p6)(this.focused,this.switchLabelFormat,this.locale);if(this.picker.setViewSwitchLabel(e),this.picker.setPrevBtnDisabled(this.first<=this.minDate),this.picker.setNextBtnDisabled(this.last>=this.maxDate),this.calendarWeeks){const e=(0,n.fr)(this.first,1,1);Array.from(this.calendarWeeks.weeks.children).forEach(((t,i)=>{t.textContent=(0,n.Qk)((0,n.jh)(e,i))}))}Array.from(this.grid.children).forEach(((e,t)=>{const i=e.classList,a=(0,n.E4)(this.start,t),s=new Date(a),o=s.getDay();if(e.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,e.dataset.date=a,e.textContent=s.getDate(),athis.last&&i.add("next","text-gray-500","dark:text-white"),this.today===a&&i.add("today","bg-gray-100","dark:bg-gray-600"),(athis.maxDate||this.disabled.includes(a))&&i.add("disabled","cursor-not-allowed"),this.daysOfWeekDisabled.includes(o)&&(i.add("disabled","cursor-not-allowed"),(0,r.$C)(this.disabled,a)),this.daysOfWeekHighlighted.includes(o)&&i.add("highlighted"),this.range){const[e,t]=this.range;a>e&&a{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","text-white","dark:bg-blue-600","dark:text-white","focused"),e.classList.add("text-gray-900","rounded-lg","dark:text-white")})),Array.from(this.grid.children).forEach((i=>{const r=Number(i.dataset.date),n=i.classList;n.remove("bg-gray-200","dark:bg-gray-600","rounded-l-lg","rounded-r-lg"),r>e&&r{e.classList.remove("focused")})),this.grid.children[e].classList.add("focused")}}function C(e,t){if(!e||!e[0]||!e[1])return;const[[i,r],[n,a]]=e;return i>t||ne})))),super.init(e)}setOptions(e){if(e.locale&&(this.monthNames=e.locale.monthsShort),(0,r.l$)(e,"minDate"))if(void 0===e.minDate)this.minYear=this.minMonth=this.minDate=void 0;else{const t=new Date(e.minDate);this.minYear=t.getFullYear(),this.minMonth=t.getMonth(),this.minDate=t.setDate(1)}if((0,r.l$)(e,"maxDate"))if(void 0===e.maxDate)this.maxYear=this.maxMonth=this.maxDate=void 0;else{const t=new Date(e.maxDate);this.maxYear=t.getFullYear(),this.maxMonth=t.getMonth(),this.maxDate=(0,n.by)(this.maxYear,this.maxMonth+1,0)}void 0!==e.beforeShowMonth&&(this.beforeShow="function"==typeof e.beforeShowMonth?e.beforeShowMonth:void 0)}updateFocus(){const e=new Date(this.picker.viewDate);this.year=e.getFullYear(),this.focused=e.getMonth()}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e.reduce(((e,t)=>{const i=new Date(t),n=i.getFullYear(),a=i.getMonth();return void 0===e[n]?e[n]=[a]:(0,r.$C)(e[n],a),e}),{}),t&&t.dates&&(this.range=t.dates.map((e=>{const t=new Date(e);return isNaN(t)?void 0:[t.getFullYear(),t.getMonth()]})))}render(){this.disabled=[],this.picker.setViewSwitchLabel(this.year),this.picker.setPrevBtnDisabled(this.year<=this.minYear),this.picker.setNextBtnDisabled(this.year>=this.maxYear);const e=this.selected[this.year]||[],t=this.yearthis.maxYear,i=this.year===this.minYear,r=this.year===this.maxYear,a=C(this.range,this.year);Array.from(this.grid.children).forEach(((s,o)=>{const d=s.classList,c=(0,n.by)(this.year,o,1);if(s.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,this.isMinView&&(s.dataset.date=c),s.textContent=this.monthNames[o],(t||i&&othis.maxMonth)&&d.add("disabled"),a){const[e,t]=a;o>e&&o{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","dark:bg-blue-600","dark:text-white","text-white","focused"),e.classList.add("text-gray-900","hover:bg-gray-100","dark:text-white","dark:hover:bg-gray-600")})),Array.from(this.grid.children).forEach(((r,n)=>{const a=r.classList;n>t&&n{e.classList.remove("focused")})),this.grid.children[this.focused].classList.add("focused")}}class F extends S{constructor(e,t){super(e,t)}init(e,t=!0){var i;t&&(this.navStep=10*this.step,this.beforeShowOption=`beforeShow${i=this.cellClass,[...i].reduce(((e,t,i)=>e+(i?t:t.toUpperCase())),"")}`,this.grid=this.element,this.element.classList.add(this.name,"datepicker-grid","w-64","grid","grid-cols-4"),this.grid.appendChild(l((0,r.em)("span",12)))),super.init(e)}setOptions(e){if((0,r.l$)(e,"minDate")&&(void 0===e.minDate?this.minYear=this.minDate=void 0:(this.minYear=(0,n.ak)(e.minDate,this.step),this.minDate=(0,n.by)(this.minYear,0,1))),(0,r.l$)(e,"maxDate")&&(void 0===e.maxDate?this.maxYear=this.maxDate=void 0:(this.maxYear=(0,n.ak)(e.maxDate,this.step),this.maxDate=(0,n.by)(this.maxYear,11,31))),void 0!==e[this.beforeShowOption]){const t=e[this.beforeShowOption];this.beforeShow="function"==typeof t?t:void 0}}updateFocus(){const e=new Date(this.picker.viewDate),t=(0,n.ak)(e,this.navStep),i=t+9*this.step;this.first=t,this.last=i,this.start=t-this.step,this.focused=(0,n.ak)(e,this.step)}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e.reduce(((e,t)=>(0,r.$C)(e,(0,n.ak)(t,this.step))),[]),t&&t.dates&&(this.range=t.dates.map((e=>{if(void 0!==e)return(0,n.ak)(e,this.step)})))}render(){this.disabled=[],this.picker.setViewSwitchLabel(`${this.first}-${this.last}`),this.picker.setPrevBtnDisabled(this.first<=this.minYear),this.picker.setNextBtnDisabled(this.last>=this.maxYear),Array.from(this.grid.children).forEach(((e,t)=>{const i=e.classList,r=this.start+t*this.step,a=(0,n.by)(r,0,1);if(e.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,this.isMinView&&(e.dataset.date=a),e.textContent=e.dataset.year=r,0===t?i.add("prev"):11===t&&i.add("next"),(rthis.maxYear)&&i.add("disabled"),this.range){const[e,t]=this.range;r>e&&r{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","text-white","dark:bg-blue-600","dark:text-white","focused")})),Array.from(this.grid.children).forEach((i=>{const r=Number(i.textContent),n=i.classList;r>e&&r{e.classList.remove("focused")})),this.grid.children[e].classList.add("focused")}}function L(e,t){const i={date:e.getDate(),viewDate:new Date(e.picker.viewDate),viewId:e.picker.currentView.id,datepicker:e};e.element.dispatchEvent(new CustomEvent(t,{detail:i}))}function V(e,t){const{minDate:i,maxDate:a}=e.config,{currentView:s,viewDate:o}=e.picker;let d;switch(s.id){case 0:d=(0,n.zI)(o,t);break;case 1:d=(0,n.Bc)(o,t);break;default:d=(0,n.Bc)(o,t*s.navStep)}d=(0,r.jG)(d,i,a),e.picker.changeFocus(d).render()}function B(e){const t=e.picker.currentView.id;t!==e.config.maxView&&e.picker.changeView(t+1).render()}function A(e){e.config.updateOnBlur?e.update({autohide:!0}):(e.refresh("input"),e.hide())}function N(e,t){const i=e.picker,r=new Date(i.viewDate),a=i.currentView.id,s=1===a?(0,n.zI)(r,t-r.getMonth()):(0,n.Bc)(r,t-r.getFullYear());i.changeFocus(s).changeView(a-1).render()}function W(e){const t=e.picker,i=(0,n.Lg)();if(1===e.config.todayBtnMode){if(e.config.autohide)return void e.setDate(i);e.setDate(i,{render:!1}),t.update()}t.viewDate!==i&&t.changeFocus(i),t.changeView(0).render()}function Y(e){e.setDate({clear:!0})}function $(e){B(e)}function j(e){V(e,-1)}function _(e){V(e,1)}function H(e,t){const i=(0,s.He)(t,".datepicker-cell");if(!i||i.classList.contains("disabled"))return;const{id:r,isMinView:n}=e.picker.currentView;n?e.setDate(Number(i.dataset.date)):N(e,Number(1===r?i.dataset.month:i.dataset.year))}function T(e){e.inline||e.config.disableTouchKeyboard||e.inputField.focus()}function K(e,t){if(void 0!==t.title&&(t.title?(e.controls.title.textContent=t.title,u(e.controls.title)):(e.controls.title.textContent="",h(e.controls.title))),t.prevArrow){const i=e.controls.prevBtn;g(i),t.prevArrow.forEach((e=>{i.appendChild(e.cloneNode(!0))}))}if(t.nextArrow){const i=e.controls.nextBtn;g(i),t.nextArrow.forEach((e=>{i.appendChild(e.cloneNode(!0))}))}if(t.locale&&(e.controls.todayBtn.textContent=t.locale.today,e.controls.clearBtn.textContent=t.locale.clear),void 0!==t.todayBtn&&(t.todayBtn?u(e.controls.todayBtn):h(e.controls.todayBtn)),(0,r.l$)(t,"minDate")||(0,r.l$)(t,"maxDate")){const{minDate:t,maxDate:i}=e.datepicker.config;e.controls.todayBtn.disabled=!(0,r.mh)((0,n.Lg)(),t,i)}void 0!==t.clearBtn&&(t.clearBtn?u(e.controls.clearBtn):h(e.controls.clearBtn))}function I(e){const{dates:t,config:i}=e,n=t.length>0?(0,r.Jm)(t):i.defaultViewDate;return(0,r.jG)(n,i.minDate,i.maxDate)}function P(e,t){const i=new Date(e.viewDate),r=new Date(t),{id:n,year:a,first:s,last:o}=e.currentView,d=r.getFullYear();switch(e.viewDate=t,d!==i.getFullYear()&&L(e.datepicker,"changeYear"),r.getMonth()!==i.getMonth()&&L(e.datepicker,"changeMonth"),n){case 0:return to;case 1:return d!==a;default:return do}}function R(e){return window.getComputedStyle(e).direction}class z{constructor(e){this.datepicker=e;const t=x.replace(/%buttonClass%/g,e.config.buttonClass),i=this.element=l(t).firstChild,[r,n,a]=i.firstChild.children,o=r.firstElementChild,[d,c,h]=r.lastElementChild.children,[u,g]=a.firstChild.children,f={title:o,prevBtn:d,viewSwitch:c,nextBtn:h,todayBtn:u,clearBtn:g};this.main=n,this.controls=f;const p=e.inline?"inline":"dropdown";i.classList.add(`datepicker-${p}`),"dropdown"===p&&i.classList.add("dropdown","absolute","top-0","left-0","z-50","pt-2"),K(this,e.config),this.viewDate=I(e),(0,s.cF)(e,[[i,"click",T.bind(null,e),{capture:!0}],[n,"click",H.bind(null,e)],[f.viewSwitch,"click",$.bind(null,e)],[f.prevBtn,"click",j.bind(null,e)],[f.nextBtn,"click",_.bind(null,e)],[f.todayBtn,"click",W.bind(null,e)],[f.clearBtn,"click",Y.bind(null,e)]]),this.views=[new O(this),new E(this),new F(this,{id:2,name:"years",cellClass:"year",step:1}),new F(this,{id:3,name:"decades",cellClass:"decade",step:10})],this.currentView=this.views[e.config.startView],this.currentView.render(),this.main.appendChild(this.currentView.element),e.config.container.appendChild(this.element)}setOptions(e){K(this,e),this.views.forEach((t=>{t.init(e,!1)})),this.currentView.render()}detach(){this.datepicker.config.container.removeChild(this.element)}show(){if(this.active)return;this.element.classList.add("active","block"),this.element.classList.remove("hidden"),this.active=!0;const e=this.datepicker;if(!e.inline){const t=R(e.inputField);t!==R(e.config.container)?this.element.dir=t:this.element.dir&&this.element.removeAttribute("dir"),this.place(),e.config.disableTouchKeyboard&&e.inputField.blur()}L(e,"show")}hide(){this.active&&(this.datepicker.exitEditMode(),this.element.classList.remove("active","block"),this.element.classList.add("active","block","hidden"),this.active=!1,L(this.datepicker,"hide"))}place(){const{classList:e,style:t}=this.element,{config:i,inputField:r}=this.datepicker,n=i.container,{width:a,height:s}=this.element.getBoundingClientRect(),{left:o,top:d,width:c}=n.getBoundingClientRect(),{left:l,top:h,width:u,height:g}=r.getBoundingClientRect();let f,p,m,{x:b,y:y}=i.orientation;n===document.body?(f=window.scrollY,p=l+window.scrollX,m=h+f):(f=n.scrollTop,p=l-o,m=h-d+f),"auto"===b&&(p<0?(b="left",p=10):b=p+a>c||"rtl"===R(r)?"right":"left"),"right"===b&&(p-=a-u),"auto"===y&&(y=m-s{e.updateFocus()})),this}update(){const e=I(this.datepicker);return this._renderMethod=P(this,e)?"render":"refresh",this.views.forEach((e=>{e.updateFocus(),e.updateSelection()})),this}render(e=!0){const t=e&&this._renderMethod||"render";delete this._renderMethod,this.currentView[t]()}}function q(e,t,i,n,a,s){if((0,r.mh)(e,a,s)){if(n(e)){return q(t(e,i),t,i,n,a,s)}return e}}function J(e,t,i,r){const a=e.picker,s=a.currentView,o=s.step||1;let d,c,l=a.viewDate;switch(s.id){case 0:l=r?(0,n.E4)(l,7*i):t.ctrlKey||t.metaKey?(0,n.Bc)(l,i):(0,n.E4)(l,i),d=n.E4,c=e=>s.disabled.includes(e);break;case 1:l=(0,n.zI)(l,r?4*i:i),d=n.zI,c=e=>{const t=new Date(e),{year:i,disabled:r}=s;return t.getFullYear()===i&&r.includes(t.getMonth())};break;default:l=(0,n.Bc)(l,i*(r?4:1)*o),d=n.Bc,c=e=>s.disabled.includes((0,n.ak)(e,o))}l=q(l,d,i<0?-o:o,c,s.minDate,s.maxDate),void 0!==l&&a.changeFocus(l).render()}function G(e,t){if("Tab"===t.key)return void A(e);const i=e.picker,{id:r,isMinView:n}=i.currentView;if(i.active)if(e.editMode)switch(t.key){case"Escape":i.hide();break;case"Enter":e.exitEditMode({update:!0,autohide:e.config.autohide});break;default:return}else switch(t.key){case"Escape":i.hide();break;case"ArrowLeft":if(t.ctrlKey||t.metaKey)V(e,-1);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,-1,!1)}break;case"ArrowRight":if(t.ctrlKey||t.metaKey)V(e,1);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,1,!1)}break;case"ArrowUp":if(t.ctrlKey||t.metaKey)B(e);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,-1,!0)}break;case"ArrowDown":if(t.shiftKey&&!t.ctrlKey&&!t.metaKey)return void e.enterEditMode();J(e,t,1,!0);break;case"Enter":n?e.setDate(i.viewDate):i.changeView(r-1).render();break;case"Backspace":case"Delete":return void e.enterEditMode();default:return void(1!==t.key.length||t.ctrlKey||t.metaKey||e.enterEditMode())}else switch(t.key){case"ArrowDown":case"Escape":i.show();break;case"Enter":e.update();break;default:return}t.preventDefault(),t.stopPropagation()}function Z(e){e.config.showOnFocus&&!e._showing&&e.show()}function U(e,t){const i=t.target;(e.picker.active||e.config.showOnClick)&&(i._active=i===document.activeElement,i._clicking=setTimeout((()=>{delete i._active,delete i._clicking}),2e3))}function Q(e,t){const i=t.target;i._clicking&&(clearTimeout(i._clicking),delete i._clicking,i._active&&e.enterEditMode(),delete i._active,e.config.showOnClick&&e.show())}function X(e,t){t.clipboardData.types.includes("text/plain")&&e.enterEditMode()}function ee(e,t){const i=e.element;if(i!==document.activeElement)return;const r=e.picker.element;(0,s.He)(t,(e=>e===i||e===r))||A(e)}function te(e,t){return e.map((e=>(0,a.p6)(e,t.format,t.locale))).join(t.dateDelimiter)}function ie(e,t,i=!1){const{config:n,dates:s,rangepicker:o}=e;if(0===t.length)return i?[]:void 0;const d=o&&e===o.datepickers[1];let c=t.reduce(((e,t)=>{let i=(0,a.sG)(t,n.format,n.locale);if(void 0===i)return e;if(n.pickLevel>0){const e=new Date(i);i=1===n.pickLevel?d?e.setMonth(e.getMonth()+1,0):e.setDate(1):d?e.setFullYear(e.getFullYear()+1,0,0):e.setMonth(0,1)}return!(0,r.mh)(i,n.minDate,n.maxDate)||e.includes(i)||n.datesDisabled.includes(i)||n.daysOfWeekDisabled.includes(new Date(i).getDay())||e.push(i),e}),[]);return 0!==c.length?(n.multidate&&!i&&(c=c.reduce(((e,t)=>(s.includes(t)||e.push(t),e)),s.filter((e=>!c.includes(e))))),n.maxNumberOfDates&&c.length>n.maxNumberOfDates?c.slice(-1*n.maxNumberOfDates):c):void 0}function re(e,t=3,i=!0){const{config:r,picker:n,inputField:a}=e;if(2&t){const e=n.active?r.pickLevel:r.startView;n.update().changeView(e).render(i)}1&t&&a&&(a.value=te(e.dates,r))}function ne(e,t,i){let{clear:r,render:n,autohide:a}=i;void 0===n&&(n=!0),n?void 0===a&&(a=e.config.autohide):a=!1;const s=ie(e,t,r);s&&(s.toString()!==e.dates.toString()?(e.dates=s,re(e,n?3:1),L(e,"changeDate")):re(e,1),a&&e.hide())}class ae{constructor(e,t={},i){e.datepicker=this,this.element=e;const a=this.config=Object.assign({buttonClass:t.buttonClass&&String(t.buttonClass)||"button",container:document.body,defaultViewDate:(0,n.Lg)(),maxDate:void 0,minDate:void 0},v(d,this));this._options=t,Object.assign(a,v(t,this));const o=this.inline="INPUT"!==e.tagName;let c,l;if(o)a.container=e,l=(0,r.W7)(e.dataset.date,a.dateDelimiter),delete e.dataset.date;else{const i=t.container?document.querySelector(t.container):null;i&&(a.container=i),c=this.inputField=e,c.classList.add("datepicker-input"),l=(0,r.W7)(c.value,a.dateDelimiter)}if(i){const e=i.inputs.indexOf(c),t=i.datepickers;if(e<0||e>1||!Array.isArray(t))throw Error("Invalid rangepicker object.");t[e]=this,Object.defineProperty(this,"rangepicker",{get(){return i}})}this.dates=[];const h=ie(this,l);h&&h.length>0&&(this.dates=h),c&&(c.value=te(this.dates,a));const u=this.picker=new z(this);if(o)this.show();else{const e=ee.bind(null,this),t=[[c,"keydown",G.bind(null,this)],[c,"focus",Z.bind(null,this)],[c,"mousedown",U.bind(null,this)],[c,"click",Q.bind(null,this)],[c,"paste",X.bind(null,this)],[document,"mousedown",e],[document,"touchstart",e],[window,"resize",u.place.bind(u)]];(0,s.cF)(this,t)}}static formatDate(e,t,i){return(0,a.p6)(e,t,i&&o[i]||o.en)}static parseDate(e,t,i){return(0,a.sG)(e,t,i&&o[i]||o.en)}static get locales(){return o}get active(){return!(!this.picker||!this.picker.active)}get pickerElement(){return this.picker?this.picker.element:void 0}setOptions(e){const t=this.picker,i=v(e,this);Object.assign(this._options,e),Object.assign(this.config,i),t.setOptions(i),re(this,3)}show(){if(this.inputField){if(this.inputField.disabled)return;this.inputField!==document.activeElement&&(this._showing=!0,this.inputField.focus(),delete this._showing)}this.picker.show()}hide(){this.inline||(this.picker.hide(),this.picker.update().changeView(this.config.startView).render())}destroy(){return this.hide(),(0,s.uV)(this),this.picker.detach(),this.inline||this.inputField.classList.remove("datepicker-input"),delete this.element.datepicker,this}getDate(e){const t=e?t=>(0,a.p6)(t,e,this.config.locale):e=>new Date(e);return this.config.multidate?this.dates.map(t):this.dates.length>0?t(this.dates[0]):void 0}setDate(...e){const t=[...e],i={},n=(0,r.Jm)(e);"object"!=typeof n||Array.isArray(n)||n instanceof Date||!n||Object.assign(i,t.pop());ne(this,Array.isArray(t[0])?t[0]:t,i)}update(e){if(this.inline)return;const t={clear:!0,autohide:!(!e||!e.autohide)};ne(this,(0,r.W7)(this.inputField.value,this.config.dateDelimiter),t)}refresh(e,t=!1){let i;e&&"string"!=typeof e&&(t=e,e=void 0),i="picker"===e?2:"input"===e?1:3,re(this,i,!t)}enterEditMode(){this.inline||!this.picker.active||this.editMode||(this.editMode=!0,this.inputField.classList.add("in-edit","border-blue-700"))}exitEditMode(e){if(this.inline||!this.editMode)return;const t=Object.assign({update:!1},e);delete this.editMode,this.inputField.classList.remove("in-edit","border-blue-700"),t.update&&this.update(t)}}},963:function(e,t,i){i.d(t,{CL:function(){return a},p6:function(){return f},sG:function(){return g}});var r=i(560),n=i(105);const a=/dd?|DD?|mm?|MM?|yy?(?:yy)?/,s=/[\s!-/:-@[-`{-~年月日]+/;let o={};const d={y(e,t){return new Date(e).setFullYear(parseInt(t,10))},m(e,t,i){const r=new Date(e);let n=parseInt(t,10)-1;if(isNaN(n)){if(!t)return NaN;const e=t.toLowerCase(),r=t=>t.toLowerCase().startsWith(e);if(n=i.monthsShort.findIndex(r),n<0&&(n=i.months.findIndex(r)),n<0)return NaN}return r.setMonth(n),r.getMonth()!==l(n)?r.setDate(0):r.getTime()},d(e,t){return new Date(e).setDate(parseInt(t,10))}},c={d(e){return e.getDate()},dd(e){return h(e.getDate(),2)},D(e,t){return t.daysShort[e.getDay()]},DD(e,t){return t.days[e.getDay()]},m(e){return e.getMonth()+1},mm(e){return h(e.getMonth()+1,2)},M(e,t){return t.monthsShort[e.getMonth()]},MM(e,t){return t.months[e.getMonth()]},y(e){return e.getFullYear()},yy(e){return h(e.getFullYear(),2).slice(-2)},yyyy(e){return h(e.getFullYear(),4)}};function l(e){return e>-1?e%12:l(e+12)}function h(e,t){return e.toString().padStart(t,"0")}function u(e){if("string"!=typeof e)throw new Error("Invalid date format.");if(e in o)return o[e];const t=e.split(a),i=e.match(new RegExp(a,"g"));if(0===t.length||!i)throw new Error("Invalid date format.");const l=i.map((e=>c[e])),h=Object.keys(d).reduce(((e,t)=>(i.find((e=>"D"!==e[0]&&e[0].toLowerCase()===t))&&e.push(t),e)),[]);return o[e]={parser(e,t){const n=e.split(s).reduce(((e,t,r)=>{if(t.length>0&&i[r]){const n=i[r][0];"M"===n?e.m=t:"D"!==n&&(e[n]=t)}return e}),{});return h.reduce(((e,i)=>{const r=d[i](e,n[i],t);return isNaN(r)?e:r}),(0,r.Lg)())},formatter(e,i){return l.reduce(((r,n,a)=>r+`${t[a]}${n(e,i)}`),"")+(0,n.Jm)(t)}}}function g(e,t,i){if(e instanceof Date||"number"==typeof e){const t=(0,r.xR)(e);return isNaN(t)?void 0:t}if(e){if("today"===e)return(0,r.Lg)();if(t&&t.toValue){const n=t.toValue(e,t,i);return isNaN(n)?void 0:(0,r.xR)(n)}return u(t).parser(e,i)}}function f(e,t,i){if(isNaN(e)||!e&&0!==e)return"";const r="number"==typeof e?new Date(e):e;return t.toDisplay?t.toDisplay(r,t,i):u(t).formatter(r,i)}},560:function(e,t,i){function r(e){return new Date(e).setHours(0,0,0,0)}function n(){return(new Date).setHours(0,0,0,0)}function a(...e){switch(e.length){case 0:return n();case 1:return r(e[0])}const t=new Date(0);return t.setFullYear(...e),t.setHours(0,0,0,0)}function s(e,t){const i=new Date(e);return i.setDate(i.getDate()+t)}function o(e,t){return s(e,7*t)}function d(e,t){const i=new Date(e),r=i.getMonth()+t;let n=r%12;n<0&&(n+=12);const a=i.setMonth(r);return i.getMonth()!==n?i.setDate(0):a}function c(e,t){const i=new Date(e),r=i.getMonth(),n=i.setFullYear(i.getFullYear()+t);return 1===r&&2===i.getMonth()?i.setDate(0):n}function l(e,t){return(e-t+7)%7}function h(e,t,i=0){const r=new Date(e).getDay();return s(e,l(t,i)-l(r,i))}function u(e){const t=h(e,4,1),i=h(new Date(t).setMonth(0,4),4,1);return Math.round((t-i)/6048e5)+1}function g(e,t){const i=new Date(e).getFullYear();return Math.floor(i/t)*t}i.d(t,{Bc:function(){return c},E4:function(){return s},Lg:function(){return n},Qk:function(){return u},ak:function(){return g},by:function(){return a},fr:function(){return h},jh:function(){return o},xR:function(){return r},zI:function(){return d}})},698:function(e,t,i){i.d(t,{He:function(){return c},cF:function(){return s},uV:function(){return o}});const r=new WeakMap,{addEventListener:n,removeEventListener:a}=EventTarget.prototype;function s(e,t){let i=r.get(e);i||(i=[],r.set(e,i)),t.forEach((e=>{n.call(...e),i.push(e)}))}function o(e){let t=r.get(e);t&&(t.forEach((e=>{a.call(...e)})),r.delete(e))}if(!Event.prototype.composedPath){const e=(t,i=[])=>{let r;return i.push(t),t.parentNode?r=t.parentNode:t.host?r=t.host:t.defaultView&&(r=t.defaultView),r?e(r,i):i};Event.prototype.composedPath=function(){return e(this.target)}}function d(e,t,i,r=0){const n=e[r];return t(n)?n:n!==i&&n.parentElement?d(e,t,i,r+1):void 0}function c(e,t){const i="function"==typeof t?t:e=>e.matches(t);return d(e.composedPath(),i,e.currentTarget)}},105:function(e,t,i){function r(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function n(e){return e[e.length-1]}function a(e,...t){return t.forEach((t=>{e.includes(t)||e.push(t)})),e}function s(e,t){return e?e.split(t):[]}function o(e,t,i){return(void 0===t||e>=t)&&(void 0===i||e<=i)}function d(e,t,i){return ei?i:e}function c(e,t,i={},r=0,n=""){n+=`<${Object.keys(i).reduce(((e,t)=>{let n=i[t];return"function"==typeof n&&(n=n(r)),`${e} ${t}="${n}"`}),e)}>`;const a=r+1;return a\s+/g,">").replace(/\s+ the end, swap them + if (changedSide === 0 && changedDate > otherDate) { + datepickers[0].setDate(otherDate, setDateOptions); + datepickers[1].setDate(changedDate, setDateOptions); + } else if (changedSide === 1 && changedDate < otherDate) { + datepickers[0].setDate(changedDate, setDateOptions); + datepickers[1].setDate(otherDate, setDateOptions); + } + } else if (!rangepicker.allowOneSidedRange) { + // to prevent the range from becoming one-sided, copy changed side's + // selection (no matter if it's empty) to the other side + if (changedDate !== undefined || otherDate !== undefined) { + setDateOptions.clear = true; + datepickers[otherSide].setDate(datepickers[changedSide].dates, setDateOptions); + } + } + datepickers[0].picker.update().render(); + datepickers[1].picker.update().render(); + delete rangepicker._updating; +} + +/** + * Class representing a date range picker + */ +class DateRangePicker { + /** + * Create a date range picker + * @param {Element} element - element to bind a date range picker + * @param {Object} [options] - config options + */ + constructor(element, options = {}) { + const inputs = Array.isArray(options.inputs) + ? options.inputs + : Array.from(element.querySelectorAll('input')); + if (inputs.length < 2) { + return; + } + + element.rangepicker = this; + this.element = element; + this.inputs = inputs.slice(0, 2); + this.allowOneSidedRange = !!options.allowOneSidedRange; + + const changeDateListener = onChangeDate.bind(null, this); + const cleanOptions = filterOptions(options); + // in order for initial date setup to work right when pcicLvel > 0, + // let Datepicker constructor add the instance to the rangepicker + const datepickers = []; + Object.defineProperty(this, 'datepickers', { + get() { + return datepickers; + }, + }); + setupDatepicker(this, changeDateListener, this.inputs[0], cleanOptions); + setupDatepicker(this, changeDateListener, this.inputs[1], cleanOptions); + Object.freeze(datepickers); + // normalize the range if inital dates are given + if (datepickers[0].dates.length > 0) { + onChangeDate(this, {target: this.inputs[0]}); + } else if (datepickers[1].dates.length > 0) { + onChangeDate(this, {target: this.inputs[1]}); + } + } + + /** + * @type {Array} - selected date of the linked date pickers + */ + get dates() { + return this.datepickers.length === 2 + ? [ + this.datepickers[0].dates[0], + this.datepickers[1].dates[0], + ] + : undefined; + } + + /** + * Set new values to the config options + * @param {Object} options - config options to update + */ + setOptions(options) { + this.allowOneSidedRange = !!options.allowOneSidedRange; + + const cleanOptions = filterOptions(options); + this.datepickers[0].setOptions(cleanOptions); + this.datepickers[1].setOptions(cleanOptions); + } + + /** + * Destroy the DateRangePicker instance + * @return {DateRangePicker} - the instance destroyed + */ + destroy() { + this.datepickers[0].destroy(); + this.datepickers[1].destroy(); + (0,_lib_event_js__WEBPACK_IMPORTED_MODULE_0__/* .unregisterListeners */ .uV)(this); + delete this.element.rangepicker; + } + + /** + * Get the start and end dates of the date range + * + * The method returns Date objects by default. If format string is passed, + * it returns date strings formatted in given format. + * The result array always contains 2 items (start date/end date) and + * undefined is used for unselected side. (e.g. If none is selected, + * the result will be [undefined, undefined]. If only the end date is set + * when allowOneSidedRange config option is true, [undefined, endDate] will + * be returned.) + * + * @param {String} [format] - Format string to stringify the dates + * @return {Array} - Start and end dates + */ + getDates(format = undefined) { + const callback = format + ? date => (0,_lib_date_format_js__WEBPACK_IMPORTED_MODULE_1__/* .formatDate */ .p6)(date, format, this.datepickers[0].config.locale) + : date => new Date(date); + + return this.dates.map(date => date === undefined ? date : callback(date)); + } + + /** + * Set the start and end dates of the date range + * + * The method calls datepicker.setDate() internally using each of the + * arguments in start→end order. + * + * When a clear: true option object is passed instead of a date, the method + * clears the date. + * + * If an invalid date, the same date as the current one or an option object + * without clear: true is passed, the method considers that argument as an + * "ineffective" argument because calling datepicker.setDate() with those + * values makes no changes to the date selection. + * + * When the allowOneSidedRange config option is false, passing {clear: true} + * to clear the range works only when it is done to the last effective + * argument (in other words, passed to rangeEnd or to rangeStart along with + * ineffective rangeEnd). This is because when the date range is changed, + * it gets normalized based on the last change at the end of the changing + * process. + * + * @param {Date|Number|String|Object} rangeStart - Start date of the range + * or {clear: true} to clear the date + * @param {Date|Number|String|Object} rangeEnd - End date of the range + * or {clear: true} to clear the date + */ + setDates(rangeStart, rangeEnd) { + const [datepicker0, datepicker1] = this.datepickers; + const origDates = this.dates; + + // If range normalization runs on every change, we can't set a new range + // that starts after the end of the current range correctly because the + // normalization process swaps start↔︎end right after setting the new start + // date. To prevent this, the normalization process needs to run once after + // both of the new dates are set. + this._updating = true; + datepicker0.setDate(rangeStart); + datepicker1.setDate(rangeEnd); + delete this._updating; + + if (datepicker1.dates[0] !== origDates[1]) { + onChangeDate(this, {target: this.inputs[1]}); + } else if (datepicker0.dates[0] !== origDates[0]) { + onChangeDate(this, {target: this.inputs[0]}); + } + } +} + + +/***/ }), + +/***/ 770: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "Z": function() { return /* binding */ Datepicker; } +}); + +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/utils.js +var utils = __webpack_require__(105); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/date.js +var lib_date = __webpack_require__(560); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/date-format.js +var date_format = __webpack_require__(963); +// EXTERNAL MODULE: ./node_modules/flowbite-datepicker/js/lib/event.js +var lib_event = __webpack_require__(698); +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/i18n/base-locales.js +// default locales +const locales = { + en: { + days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], + daysShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], + daysMin: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], + months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], + monthsShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], + today: "Today", + clear: "Clear", + titleFormat: "MM y" + } +}; + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/options/defaultOptions.js +// config options updatable by setOptions() and their default values +const defaultOptions = { + autohide: false, + beforeShowDay: null, + beforeShowDecade: null, + beforeShowMonth: null, + beforeShowYear: null, + calendarWeeks: false, + clearBtn: false, + dateDelimiter: ',', + datesDisabled: [], + daysOfWeekDisabled: [], + daysOfWeekHighlighted: [], + defaultViewDate: undefined, // placeholder, defaults to today() by the program + disableTouchKeyboard: false, + format: 'mm/dd/yyyy', + language: 'en', + maxDate: null, + maxNumberOfDates: 1, + maxView: 3, + minDate: null, + nextArrow: '', + orientation: 'auto', + pickLevel: 0, + prevArrow: '', + showDaysOfWeek: true, + showOnClick: true, + showOnFocus: true, + startView: 0, + title: '', + todayBtn: false, + todayBtnMode: 0, + todayHighlight: false, + updateOnBlur: true, + weekStart: 0, +}; + +/* harmony default export */ var options_defaultOptions = (defaultOptions); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/lib/dom.js +const range = document.createRange(); + +function parseHTML(html) { + return range.createContextualFragment(html); +} + +// equivalent to jQuery's :visble +function isVisible(el) { + return !!(el.offsetWidth || el.offsetHeight || el.getClientRects().length); +} + +function hideElement(el) { + if (el.style.display === 'none') { + return; + } + // back up the existing display setting in data-style-display + if (el.style.display) { + el.dataset.styleDisplay = el.style.display; + } + el.style.display = 'none'; +} + +function showElement(el) { + if (el.style.display !== 'none') { + return; + } + if (el.dataset.styleDisplay) { + // restore backed-up dispay property + el.style.display = el.dataset.styleDisplay; + delete el.dataset.styleDisplay; + } else { + el.style.display = ''; + } +} + +function emptyChildNodes(el) { + if (el.firstChild) { + el.removeChild(el.firstChild); + emptyChildNodes(el); + } +} + +function replaceChildNodes(el, newChildNodes) { + emptyChildNodes(el); + if (newChildNodes instanceof DocumentFragment) { + el.appendChild(newChildNodes); + } else if (typeof newChildNodes === 'string') { + el.appendChild(parseHTML(newChildNodes)); + } else if (typeof newChildNodes.forEach === 'function') { + newChildNodes.forEach((node) => { + el.appendChild(node); + }); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/options/processOptions.js + + + + + + +const { + language: defaultLang, + format: defaultFormat, + weekStart: defaultWeekStart, +} = options_defaultOptions; + +// Reducer function to filter out invalid day-of-week from the input +function sanitizeDOW(dow, day) { + return dow.length < 6 && day >= 0 && day < 7 + ? (0,utils/* pushUnique */.$C)(dow, day) + : dow; +} + +function calcEndOfWeek(startOfWeek) { + return (startOfWeek + 6) % 7; +} + +// validate input date. if invalid, fallback to the original value +function validateDate(value, format, locale, origValue) { + const date = (0,date_format/* parseDate */.sG)(value, format, locale); + return date !== undefined ? date : origValue; +} + +// Validate viewId. if invalid, fallback to the original value +function validateViewId(value, origValue, max = 3) { + const viewId = parseInt(value, 10); + return viewId >= 0 && viewId <= max ? viewId : origValue; +} + +// Create Datepicker configuration to set +function processOptions(options, datepicker) { + const inOpts = Object.assign({}, options); + const config = {}; + const locales = datepicker.constructor.locales; + let { + format, + language, + locale, + maxDate, + maxView, + minDate, + pickLevel, + startView, + weekStart, + } = datepicker.config || {}; + + if (inOpts.language) { + let lang; + if (inOpts.language !== language) { + if (locales[inOpts.language]) { + lang = inOpts.language; + } else { + // Check if langauge + region tag can fallback to the one without + // region (e.g. fr-CA → fr) + lang = inOpts.language.split('-')[0]; + if (locales[lang] === undefined) { + lang = false; + } + } + } + delete inOpts.language; + if (lang) { + language = config.language = lang; + + // update locale as well when updating language + const origLocale = locale || locales[defaultLang]; + // use default language's properties for the fallback + locale = Object.assign({ + format: defaultFormat, + weekStart: defaultWeekStart + }, locales[defaultLang]); + if (language !== defaultLang) { + Object.assign(locale, locales[language]); + } + config.locale = locale; + // if format and/or weekStart are the same as old locale's defaults, + // update them to new locale's defaults + if (format === origLocale.format) { + format = config.format = locale.format; + } + if (weekStart === origLocale.weekStart) { + weekStart = config.weekStart = locale.weekStart; + config.weekEnd = calcEndOfWeek(locale.weekStart); + } + } + } + + if (inOpts.format) { + const hasToDisplay = typeof inOpts.format.toDisplay === 'function'; + const hasToValue = typeof inOpts.format.toValue === 'function'; + const validFormatString = date_format/* reFormatTokens.test */.CL.test(inOpts.format); + if ((hasToDisplay && hasToValue) || validFormatString) { + format = config.format = inOpts.format; + } + delete inOpts.format; + } + + //*** dates ***// + // while min and maxDate for "no limit" in the options are better to be null + // (especially when updating), the ones in the config have to be undefined + // because null is treated as 0 (= unix epoch) when comparing with time value + let minDt = minDate; + let maxDt = maxDate; + if (inOpts.minDate !== undefined) { + minDt = inOpts.minDate === null + ? (0,lib_date/* dateValue */.by)(0, 0, 1) // set 0000-01-01 to prevent negative values for year + : validateDate(inOpts.minDate, format, locale, minDt); + delete inOpts.minDate; + } + if (inOpts.maxDate !== undefined) { + maxDt = inOpts.maxDate === null + ? undefined + : validateDate(inOpts.maxDate, format, locale, maxDt); + delete inOpts.maxDate; + } + if (maxDt < minDt) { + minDate = config.minDate = maxDt; + maxDate = config.maxDate = minDt; + } else { + if (minDate !== minDt) { + minDate = config.minDate = minDt; + } + if (maxDate !== maxDt) { + maxDate = config.maxDate = maxDt; + } + } + + if (inOpts.datesDisabled) { + config.datesDisabled = inOpts.datesDisabled.reduce((dates, dt) => { + const date = (0,date_format/* parseDate */.sG)(dt, format, locale); + return date !== undefined ? (0,utils/* pushUnique */.$C)(dates, date) : dates; + }, []); + delete inOpts.datesDisabled; + } + if (inOpts.defaultViewDate !== undefined) { + const viewDate = (0,date_format/* parseDate */.sG)(inOpts.defaultViewDate, format, locale); + if (viewDate !== undefined) { + config.defaultViewDate = viewDate; + } + delete inOpts.defaultViewDate; + } + + //*** days of week ***// + if (inOpts.weekStart !== undefined) { + const wkStart = Number(inOpts.weekStart) % 7; + if (!isNaN(wkStart)) { + weekStart = config.weekStart = wkStart; + config.weekEnd = calcEndOfWeek(wkStart); + } + delete inOpts.weekStart; + } + if (inOpts.daysOfWeekDisabled) { + config.daysOfWeekDisabled = inOpts.daysOfWeekDisabled.reduce(sanitizeDOW, []); + delete inOpts.daysOfWeekDisabled; + } + if (inOpts.daysOfWeekHighlighted) { + config.daysOfWeekHighlighted = inOpts.daysOfWeekHighlighted.reduce(sanitizeDOW, []); + delete inOpts.daysOfWeekHighlighted; + } + + //*** multi date ***// + if (inOpts.maxNumberOfDates !== undefined) { + const maxNumberOfDates = parseInt(inOpts.maxNumberOfDates, 10); + if (maxNumberOfDates >= 0) { + config.maxNumberOfDates = maxNumberOfDates; + config.multidate = maxNumberOfDates !== 1; + } + delete inOpts.maxNumberOfDates; + } + if (inOpts.dateDelimiter) { + config.dateDelimiter = String(inOpts.dateDelimiter); + delete inOpts.dateDelimiter; + } + + //*** pick level & view ***// + let newPickLevel = pickLevel; + if (inOpts.pickLevel !== undefined) { + newPickLevel = validateViewId(inOpts.pickLevel, 2); + delete inOpts.pickLevel; + } + if (newPickLevel !== pickLevel) { + pickLevel = config.pickLevel = newPickLevel; + } + + let newMaxView = maxView; + if (inOpts.maxView !== undefined) { + newMaxView = validateViewId(inOpts.maxView, maxView); + delete inOpts.maxView; + } + // ensure max view >= pick level + newMaxView = pickLevel > newMaxView ? pickLevel : newMaxView; + if (newMaxView !== maxView) { + maxView = config.maxView = newMaxView; + } + + let newStartView = startView; + if (inOpts.startView !== undefined) { + newStartView = validateViewId(inOpts.startView, newStartView); + delete inOpts.startView; + } + // ensure pick level <= start view <= max view + if (newStartView < pickLevel) { + newStartView = pickLevel; + } else if (newStartView > maxView) { + newStartView = maxView; + } + if (newStartView !== startView) { + config.startView = newStartView; + } + + //*** template ***// + if (inOpts.prevArrow) { + const prevArrow = parseHTML(inOpts.prevArrow); + if (prevArrow.childNodes.length > 0) { + config.prevArrow = prevArrow.childNodes; + } + delete inOpts.prevArrow; + } + if (inOpts.nextArrow) { + const nextArrow = parseHTML(inOpts.nextArrow); + if (nextArrow.childNodes.length > 0) { + config.nextArrow = nextArrow.childNodes; + } + delete inOpts.nextArrow; + } + + //*** misc ***// + if (inOpts.disableTouchKeyboard !== undefined) { + config.disableTouchKeyboard = 'ontouchstart' in document && !!inOpts.disableTouchKeyboard; + delete inOpts.disableTouchKeyboard; + } + if (inOpts.orientation) { + const orientation = inOpts.orientation.toLowerCase().split(/\s+/g); + config.orientation = { + x: orientation.find(x => (x === 'left' || x === 'right')) || 'auto', + y: orientation.find(y => (y === 'top' || y === 'bottom')) || 'auto', + }; + delete inOpts.orientation; + } + if (inOpts.todayBtnMode !== undefined) { + switch(inOpts.todayBtnMode) { + case 0: + case 1: + config.todayBtnMode = inOpts.todayBtnMode; + } + delete inOpts.todayBtnMode; + } + + //*** copy the rest ***// + Object.keys(inOpts).forEach((key) => { + if (inOpts[key] !== undefined && (0,utils/* hasProperty */.l$)(options_defaultOptions, key)) { + config[key] = inOpts[key]; + } + }); + + return config; +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/pickerTemplate.js + + +const pickerTemplate = (0,utils/* optimizeTemplateHTML */.zh)(``); + +/* harmony default export */ var templates_pickerTemplate = (pickerTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/daysTemplate.js + + +const daysTemplate = (0,utils/* optimizeTemplateHTML */.zh)(`
      +
      ${(0,utils/* createTagRepeat */.em)('span', 7, {class: 'dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      +
      ${(0,utils/* createTagRepeat */.em)('span', 42 , {class: 'block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'})}
      +
      `); + +/* harmony default export */ var templates_daysTemplate = (daysTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/templates/calendarWeeksTemplate.js + + +const calendarWeeksTemplate = (0,utils/* optimizeTemplateHTML */.zh)(`
      +
      +
      ${(0,utils/* createTagRepeat */.em)('span', 6, {class: 'week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      +
      `); + +/* harmony default export */ var templates_calendarWeeksTemplate = (calendarWeeksTemplate); + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/View.js + + + +// Base class of the view classes +class View { + constructor(picker, config) { + Object.assign(this, config, { + picker, + element: parseHTML(`
      `).firstChild, + selected: [], + }); + this.init(this.picker.datepicker.config); + } + + init(options) { + if (options.pickLevel !== undefined) { + this.isMinView = this.id === options.pickLevel; + } + this.setOptions(options); + this.updateFocus(); + this.updateSelection(); + } + + // Execute beforeShow() callback and apply the result to the element + // args: + // - current - current value on the iteration on view rendering + // - timeValue - time value of the date to pass to beforeShow() + performBeforeHook(el, current, timeValue) { + let result = this.beforeShow(new Date(timeValue)); + switch (typeof result) { + case 'boolean': + result = {enabled: result}; + break; + case 'string': + result = {classes: result}; + } + + if (result) { + if (result.enabled === false) { + el.classList.add('disabled'); + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + if (result.classes) { + const extraClasses = result.classes.split(/\s+/); + el.classList.add(...extraClasses); + if (extraClasses.includes('disabled')) { + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + } + if (result.content) { + replaceChildNodes(el, result.content); + } + } + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/DaysView.js + + + + + + + + +class DaysView extends View { + constructor(picker) { + super(picker, { + id: 0, + name: 'days', + cellClass: 'day', + }); + } + + init(options, onConstruction = true) { + if (onConstruction) { + const inner = parseHTML(templates_daysTemplate).firstChild; + this.dow = inner.firstChild; + this.grid = inner.lastChild; + this.element.appendChild(inner); + } + super.init(options); + } + + setOptions(options) { + let updateDOW; + + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + this.minDate = options.minDate; + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + this.maxDate = options.maxDate; + } + if (options.datesDisabled) { + this.datesDisabled = options.datesDisabled; + } + if (options.daysOfWeekDisabled) { + this.daysOfWeekDisabled = options.daysOfWeekDisabled; + updateDOW = true; + } + if (options.daysOfWeekHighlighted) { + this.daysOfWeekHighlighted = options.daysOfWeekHighlighted; + } + if (options.todayHighlight !== undefined) { + this.todayHighlight = options.todayHighlight; + } + if (options.weekStart !== undefined) { + this.weekStart = options.weekStart; + this.weekEnd = options.weekEnd; + updateDOW = true; + } + if (options.locale) { + const locale = this.locale = options.locale; + this.dayNames = locale.daysMin; + this.switchLabelFormat = locale.titleFormat; + updateDOW = true; + } + if (options.beforeShowDay !== undefined) { + this.beforeShow = typeof options.beforeShowDay === 'function' + ? options.beforeShowDay + : undefined; + } + + if (options.calendarWeeks !== undefined) { + if (options.calendarWeeks && !this.calendarWeeks) { + const weeksElem = parseHTML(templates_calendarWeeksTemplate).firstChild; + this.calendarWeeks = { + element: weeksElem, + dow: weeksElem.firstChild, + weeks: weeksElem.lastChild, + }; + this.element.insertBefore(weeksElem, this.element.firstChild); + } else if (this.calendarWeeks && !options.calendarWeeks) { + this.element.removeChild(this.calendarWeeks.element); + this.calendarWeeks = null; + } + } + if (options.showDaysOfWeek !== undefined) { + if (options.showDaysOfWeek) { + showElement(this.dow); + if (this.calendarWeeks) { + showElement(this.calendarWeeks.dow); + } + } else { + hideElement(this.dow); + if (this.calendarWeeks) { + hideElement(this.calendarWeeks.dow); + } + } + } + + // update days-of-week when locale, daysOfweekDisabled or weekStart is changed + if (updateDOW) { + Array.from(this.dow.children).forEach((el, index) => { + const dow = (this.weekStart + index) % 7; + el.textContent = this.dayNames[dow]; + el.className = this.daysOfWeekDisabled.includes(dow) ? 'dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed' : 'dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'; + }); + } + } + + // Apply update on the focused date to view's settings + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + const viewYear = viewDate.getFullYear(); + const viewMonth = viewDate.getMonth(); + const firstOfMonth = (0,lib_date/* dateValue */.by)(viewYear, viewMonth, 1); + const start = (0,lib_date/* dayOfTheWeekOf */.fr)(firstOfMonth, this.weekStart, this.weekStart); + + this.first = firstOfMonth; + this.last = (0,lib_date/* dateValue */.by)(viewYear, viewMonth + 1, 0); + this.start = start; + this.focused = this.picker.viewDate; + } + + // Apply update on the selected dates to view's settings + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates; + if (rangepicker) { + this.range = rangepicker.dates; + } + } + + // Update the entire view UI + render() { + // update today marker on ever render + this.today = this.todayHighlight ? (0,lib_date/* today */.Lg)() : undefined; + // refresh disabled dates on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = [...this.datesDisabled]; + + const switchLabel = (0,date_format/* formatDate */.p6)(this.focused, this.switchLabelFormat, this.locale); + this.picker.setViewSwitchLabel(switchLabel); + this.picker.setPrevBtnDisabled(this.first <= this.minDate); + this.picker.setNextBtnDisabled(this.last >= this.maxDate); + + if (this.calendarWeeks) { + // start of the UTC week (Monday) of the 1st of the month + const startOfWeek = (0,lib_date/* dayOfTheWeekOf */.fr)(this.first, 1, 1); + Array.from(this.calendarWeeks.weeks.children).forEach((el, index) => { + el.textContent = (0,lib_date/* getWeek */.Qk)((0,lib_date/* addWeeks */.jh)(startOfWeek, index)); + }); + } + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const current = (0,lib_date/* addDays */.E4)(this.start, index); + const date = new Date(current); + const day = date.getDay(); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + el.dataset.date = current; + el.textContent = date.getDate(); + + if (current < this.first) { + classList.add('prev', 'text-gray-500', 'dark:text-white'); + } else if (current > this.last) { + classList.add('next', 'text-gray-500', 'dark:text-white'); + } + if (this.today === current) { + classList.add('today', 'bg-gray-100', 'dark:bg-gray-600'); + } + if (current < this.minDate || current > this.maxDate || this.disabled.includes(current)) { + classList.add('disabled', 'cursor-not-allowed'); + } + if (this.daysOfWeekDisabled.includes(day)) { + classList.add('disabled', 'cursor-not-allowed'); + (0,utils/* pushUnique */.$C)(this.disabled, current); + } + if (this.daysOfWeekHighlighted.includes(day)) { + classList.add('highlighted'); + } + if (this.range) { + const [rangeStart, rangeEnd] = this.range; + if (current > rangeStart && current < rangeEnd) { + classList.add('range', 'bg-gray-200', 'dark:bg-gray-600'); + classList.remove('rounded-lg', 'rounded-l-lg', 'rounded-r-lg') + } + if (current === rangeStart) { + classList.add('range-start', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-l-lg'); + classList.remove('rounded-lg', 'rounded-r-lg'); + } + if (current === rangeEnd) { + classList.add('range-end', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-r-lg'); + classList.remove('rounded-lg', 'rounded-l-lg'); + } + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'text-gray-500', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'dark:bg-gray-600', 'bg-gray-100', 'bg-gray-200'); + } + if (current === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, current, current); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const [rangeStart, rangeEnd] = this.range || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused'); + el.classList.add('text-gray-900', 'rounded-lg', 'dark:text-white'); + }); + Array.from(this.grid.children).forEach((el) => { + const current = Number(el.dataset.date); + const classList = el.classList; + classList.remove('bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg', 'rounded-r-lg') + if (current > rangeStart && current < rangeEnd) { + classList.add('range', 'bg-gray-200', 'dark:bg-gray-600'); + classList.remove('rounded-lg'); + } + if (current === rangeStart) { + classList.add('range-start', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg'); + classList.remove('rounded-lg', 'rounded-r-lg'); + } + if (current === rangeEnd) { + classList.add('range-end', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-r-lg'); + classList.remove('rounded-lg', 'rounded-l-lg'); + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'bg-gray-100', 'bg-gray-200', 'dark:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + const index = Math.round((this.focused - this.start) / 86400000); + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[index].classList.add('focused'); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/MonthsView.js + + + + + +function computeMonthRange(range, thisYear) { + if (!range || !range[0] || !range[1]) { + return; + } + + const [[startY, startM], [endY, endM]] = range; + if (startY > thisYear || endY < thisYear) { + return; + } + return [ + startY === thisYear ? startM : -1, + endY === thisYear ? endM : 12, + ]; +} + +class MonthsView extends View { + constructor(picker) { + super(picker, { + id: 1, + name: 'months', + cellClass: 'month', + }); + } + + init(options, onConstruction = true) { + if (onConstruction) { + this.grid = this.element; + this.element.classList.add('months', 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4'); + this.grid.appendChild(parseHTML((0,utils/* createTagRepeat */.em)('span', 12, {'data-month': ix => ix}))); + } + super.init(options); + } + + setOptions(options) { + if (options.locale) { + this.monthNames = options.locale.monthsShort; + } + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + if (options.minDate === undefined) { + this.minYear = this.minMonth = this.minDate = undefined; + } else { + const minDateObj = new Date(options.minDate); + this.minYear = minDateObj.getFullYear(); + this.minMonth = minDateObj.getMonth(); + this.minDate = minDateObj.setDate(1); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + if (options.maxDate === undefined) { + this.maxYear = this.maxMonth = this.maxDate = undefined; + } else { + const maxDateObj = new Date(options.maxDate); + this.maxYear = maxDateObj.getFullYear(); + this.maxMonth = maxDateObj.getMonth(); + this.maxDate = (0,lib_date/* dateValue */.by)(this.maxYear, this.maxMonth + 1, 0); + } + } + if (options.beforeShowMonth !== undefined) { + this.beforeShow = typeof options.beforeShowMonth === 'function' + ? options.beforeShowMonth + : undefined; + } + } + + // Update view's settings to reflect the viewDate set on the picker + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + this.year = viewDate.getFullYear(); + this.focused = viewDate.getMonth(); + } + + // Update view's settings to reflect the selected dates + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates.reduce((selected, timeValue) => { + const date = new Date(timeValue); + const year = date.getFullYear(); + const month = date.getMonth(); + if (selected[year] === undefined) { + selected[year] = [month]; + } else { + (0,utils/* pushUnique */.$C)(selected[year], month); + } + return selected; + }, {}); + if (rangepicker && rangepicker.dates) { + this.range = rangepicker.dates.map(timeValue => { + const date = new Date(timeValue); + return isNaN(date) ? undefined : [date.getFullYear(), date.getMonth()]; + }); + } + } + + // Update the entire view UI + render() { + // refresh disabled months on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = []; + + this.picker.setViewSwitchLabel(this.year); + this.picker.setPrevBtnDisabled(this.year <= this.minYear); + this.picker.setNextBtnDisabled(this.year >= this.maxYear); + + const selected = this.selected[this.year] || []; + const yrOutOfRange = this.year < this.minYear || this.year > this.maxYear; + const isMinYear = this.year === this.minYear; + const isMaxYear = this.year === this.maxYear; + const range = computeMonthRange(this.range, this.year); + + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const date = (0,lib_date/* dateValue */.by)(this.year, index, 1); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + if (this.isMinView) { + el.dataset.date = date; + } + // reset text on every render to clear the custom content set + // by beforeShow hook at previous render + el.textContent = this.monthNames[index]; + + if ( + yrOutOfRange + || isMinYear && index < this.minMonth + || isMaxYear && index > this.maxMonth + ) { + classList.add('disabled'); + } + if (range) { + const [rangeStart, rangeEnd] = range; + if (index > rangeStart && index < rangeEnd) { + classList.add('range'); + } + if (index === rangeStart) { + classList.add('range-start'); + } + if (index === rangeEnd) { + classList.add('range-end'); + } + } + if (selected.includes(index)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (index === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, index, date); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const selected = this.selected[this.year] || []; + const [rangeStart, rangeEnd] = computeMonthRange(this.range, this.year) || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'dark:bg-blue-600', 'dark:text-white', 'text-white', 'focused'); + el.classList.add('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + }); + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + if (index > rangeStart && index < rangeEnd) { + classList.add('range'); + } + if (index === rangeStart) { + classList.add('range-start'); + } + if (index === rangeEnd) { + classList.add('range-end'); + } + if (selected.includes(index)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (index === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[this.focused].classList.add('focused'); + } +} +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/views/YearsView.js + + + + + +function toTitleCase(word) { + return [...word].reduce((str, ch, ix) => str += ix ? ch : ch.toUpperCase(), ''); +} + +// Class representing the years and decades view elements +class YearsView extends View { + constructor(picker, config) { + super(picker, config); + } + + init(options, onConstruction = true) { + if (onConstruction) { + this.navStep = this.step * 10; + this.beforeShowOption = `beforeShow${toTitleCase(this.cellClass)}`; + this.grid = this.element; + this.element.classList.add(this.name, 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4'); + this.grid.appendChild(parseHTML((0,utils/* createTagRepeat */.em)('span', 12))); + } + super.init(options); + } + + setOptions(options) { + if ((0,utils/* hasProperty */.l$)(options, 'minDate')) { + if (options.minDate === undefined) { + this.minYear = this.minDate = undefined; + } else { + this.minYear = (0,lib_date/* startOfYearPeriod */.ak)(options.minDate, this.step); + this.minDate = (0,lib_date/* dateValue */.by)(this.minYear, 0, 1); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'maxDate')) { + if (options.maxDate === undefined) { + this.maxYear = this.maxDate = undefined; + } else { + this.maxYear = (0,lib_date/* startOfYearPeriod */.ak)(options.maxDate, this.step); + this.maxDate = (0,lib_date/* dateValue */.by)(this.maxYear, 11, 31); + } + } + if (options[this.beforeShowOption] !== undefined) { + const beforeShow = options[this.beforeShowOption]; + this.beforeShow = typeof beforeShow === 'function' ? beforeShow : undefined; + } + } + + // Update view's settings to reflect the viewDate set on the picker + updateFocus() { + const viewDate = new Date(this.picker.viewDate); + const first = (0,lib_date/* startOfYearPeriod */.ak)(viewDate, this.navStep); + const last = first + 9 * this.step; + + this.first = first; + this.last = last; + this.start = first - this.step; + this.focused = (0,lib_date/* startOfYearPeriod */.ak)(viewDate, this.step); + } + + // Update view's settings to reflect the selected dates + updateSelection() { + const {dates, rangepicker} = this.picker.datepicker; + this.selected = dates.reduce((years, timeValue) => { + return (0,utils/* pushUnique */.$C)(years, (0,lib_date/* startOfYearPeriod */.ak)(timeValue, this.step)); + }, []); + if (rangepicker && rangepicker.dates) { + this.range = rangepicker.dates.map(timeValue => { + if (timeValue !== undefined) { + return (0,lib_date/* startOfYearPeriod */.ak)(timeValue, this.step); + } + }); + } + } + + // Update the entire view UI + render() { + // refresh disabled years on every render in order to clear the ones added + // by beforeShow hook at previous render + this.disabled = []; + + this.picker.setViewSwitchLabel(`${this.first}-${this.last}`); + this.picker.setPrevBtnDisabled(this.first <= this.minYear); + this.picker.setNextBtnDisabled(this.last >= this.maxYear); + + Array.from(this.grid.children).forEach((el, index) => { + const classList = el.classList; + const current = this.start + (index * this.step); + const date = (0,lib_date/* dateValue */.by)(current, 0, 1); + + el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`; + if (this.isMinView) { + el.dataset.date = date; + } + el.textContent = el.dataset.year = current; + + if (index === 0) { + classList.add('prev'); + } else if (index === 11) { + classList.add('next'); + } + if (current < this.minYear || current > this.maxYear) { + classList.add('disabled'); + } + if (this.range) { + const [rangeStart, rangeEnd] = this.range; + if (current > rangeStart && current < rangeEnd) { + classList.add('range'); + } + if (current === rangeStart) { + classList.add('range-start'); + } + if (current === rangeEnd) { + classList.add('range-end'); + } + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + + if (this.beforeShow) { + this.performBeforeHook(el, current, date); + } + }); + } + + // Update the view UI by applying the changes of selected and focused items + refresh() { + const [rangeStart, rangeEnd] = this.range || []; + this.grid + .querySelectorAll('.range, .range-start, .range-end, .selected, .focused') + .forEach((el) => { + el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused'); + }); + Array.from(this.grid.children).forEach((el) => { + const current = Number(el.textContent); + const classList = el.classList; + if (current > rangeStart && current < rangeEnd) { + classList.add('range'); + } + if (current === rangeStart) { + classList.add('range-start'); + } + if (current === rangeEnd) { + classList.add('range-end'); + } + if (this.selected.includes(current)) { + classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white'); + classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600'); + } + if (current === this.focused) { + classList.add('focused'); + } + }); + } + + // Update the view UI by applying the change of focused item + refreshFocus() { + const index = Math.round((this.focused - this.start) / this.step); + this.grid.querySelectorAll('.focused').forEach((el) => { + el.classList.remove('focused'); + }); + this.grid.children[index].classList.add('focused'); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/functions.js + + + +function triggerDatepickerEvent(datepicker, type) { + const detail = { + date: datepicker.getDate(), + viewDate: new Date(datepicker.picker.viewDate), + viewId: datepicker.picker.currentView.id, + datepicker, + }; + datepicker.element.dispatchEvent(new CustomEvent(type, {detail})); +} + +// direction: -1 (to previous), 1 (to next) +function goToPrevOrNext(datepicker, direction) { + const {minDate, maxDate} = datepicker.config; + const {currentView, viewDate} = datepicker.picker; + let newViewDate; + switch (currentView.id) { + case 0: + newViewDate = (0,lib_date/* addMonths */.zI)(viewDate, direction); + break; + case 1: + newViewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction); + break; + default: + newViewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction * currentView.navStep); + } + newViewDate = (0,utils/* limitToRange */.jG)(newViewDate, minDate, maxDate); + datepicker.picker.changeFocus(newViewDate).render(); +} + +function switchView(datepicker) { + const viewId = datepicker.picker.currentView.id; + if (viewId === datepicker.config.maxView) { + return; + } + datepicker.picker.changeView(viewId + 1).render(); +} + +function unfocus(datepicker) { + if (datepicker.config.updateOnBlur) { + datepicker.update({autohide: true}); + } else { + datepicker.refresh('input'); + datepicker.hide(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/pickerListeners.js + + + + +function goToSelectedMonthOrYear(datepicker, selection) { + const picker = datepicker.picker; + const viewDate = new Date(picker.viewDate); + const viewId = picker.currentView.id; + const newDate = viewId === 1 + ? (0,lib_date/* addMonths */.zI)(viewDate, selection - viewDate.getMonth()) + : (0,lib_date/* addYears */.Bc)(viewDate, selection - viewDate.getFullYear()); + + picker.changeFocus(newDate).changeView(viewId - 1).render(); +} + +function onClickTodayBtn(datepicker) { + const picker = datepicker.picker; + const currentDate = (0,lib_date/* today */.Lg)(); + if (datepicker.config.todayBtnMode === 1) { + if (datepicker.config.autohide) { + datepicker.setDate(currentDate); + return; + } + datepicker.setDate(currentDate, {render: false}); + picker.update(); + } + if (picker.viewDate !== currentDate) { + picker.changeFocus(currentDate); + } + picker.changeView(0).render(); +} + +function onClickClearBtn(datepicker) { + datepicker.setDate({clear: true}); +} + +function onClickViewSwitch(datepicker) { + switchView(datepicker); +} + +function onClickPrevBtn(datepicker) { + goToPrevOrNext(datepicker, -1); +} + +function onClickNextBtn(datepicker) { + goToPrevOrNext(datepicker, 1); +} + +// For the picker's main block to delegete the events from `datepicker-cell`s +function onClickView(datepicker, ev) { + const target = (0,lib_event/* findElementInEventPath */.He)(ev, '.datepicker-cell'); + if (!target || target.classList.contains('disabled')) { + return; + } + + const {id, isMinView} = datepicker.picker.currentView; + if (isMinView) { + datepicker.setDate(Number(target.dataset.date)); + } else if (id === 1) { + goToSelectedMonthOrYear(datepicker, Number(target.dataset.month)); + } else { + goToSelectedMonthOrYear(datepicker, Number(target.dataset.year)); + } +} + +function onClickPicker(datepicker) { + if (!datepicker.inline && !datepicker.config.disableTouchKeyboard) { + datepicker.inputField.focus(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/picker/Picker.js + + + + + + + + + + + +function processPickerOptions(picker, options) { + if (options.title !== undefined) { + if (options.title) { + picker.controls.title.textContent = options.title; + showElement(picker.controls.title); + } else { + picker.controls.title.textContent = ''; + hideElement(picker.controls.title); + } + } + if (options.prevArrow) { + const prevBtn = picker.controls.prevBtn; + emptyChildNodes(prevBtn); + options.prevArrow.forEach((node) => { + prevBtn.appendChild(node.cloneNode(true)); + }); + } + if (options.nextArrow) { + const nextBtn = picker.controls.nextBtn; + emptyChildNodes(nextBtn); + options.nextArrow.forEach((node) => { + nextBtn.appendChild(node.cloneNode(true)); + }); + } + if (options.locale) { + picker.controls.todayBtn.textContent = options.locale.today; + picker.controls.clearBtn.textContent = options.locale.clear; + } + if (options.todayBtn !== undefined) { + if (options.todayBtn) { + showElement(picker.controls.todayBtn); + } else { + hideElement(picker.controls.todayBtn); + } + } + if ((0,utils/* hasProperty */.l$)(options, 'minDate') || (0,utils/* hasProperty */.l$)(options, 'maxDate')) { + const {minDate, maxDate} = picker.datepicker.config; + picker.controls.todayBtn.disabled = !(0,utils/* isInRange */.mh)((0,lib_date/* today */.Lg)(), minDate, maxDate); + } + if (options.clearBtn !== undefined) { + if (options.clearBtn) { + showElement(picker.controls.clearBtn); + } else { + hideElement(picker.controls.clearBtn); + } + } +} + +// Compute view date to reset, which will be... +// - the last item of the selected dates or defaultViewDate if no selection +// - limitted to minDate or maxDate if it exceeds the range +function computeResetViewDate(datepicker) { + const {dates, config} = datepicker; + const viewDate = dates.length > 0 ? (0,utils/* lastItemOf */.Jm)(dates) : config.defaultViewDate; + return (0,utils/* limitToRange */.jG)(viewDate, config.minDate, config.maxDate); +} + +// Change current view's view date +function setViewDate(picker, newDate) { + const oldViewDate = new Date(picker.viewDate); + const newViewDate = new Date(newDate); + const {id, year, first, last} = picker.currentView; + const viewYear = newViewDate.getFullYear(); + + picker.viewDate = newDate; + if (viewYear !== oldViewDate.getFullYear()) { + triggerDatepickerEvent(picker.datepicker, 'changeYear'); + } + if (newViewDate.getMonth() !== oldViewDate.getMonth()) { + triggerDatepickerEvent(picker.datepicker, 'changeMonth'); + } + + // return whether the new date is in different period on time from the one + // displayed in the current view + // when true, the view needs to be re-rendered on the next UI refresh. + switch (id) { + case 0: + return newDate < first || newDate > last; + case 1: + return viewYear !== year; + default: + return viewYear < first || viewYear > last; + } +} + +function getTextDirection(el) { + return window.getComputedStyle(el).direction; +} + +// Class representing the picker UI +class Picker { + constructor(datepicker) { + this.datepicker = datepicker; + + const template = templates_pickerTemplate.replace(/%buttonClass%/g, datepicker.config.buttonClass); + const element = this.element = parseHTML(template).firstChild; + const [header, main, footer] = element.firstChild.children; + const title = header.firstElementChild; + const [prevBtn, viewSwitch, nextBtn] = header.lastElementChild.children; + const [todayBtn, clearBtn] = footer.firstChild.children; + const controls = { + title, + prevBtn, + viewSwitch, + nextBtn, + todayBtn, + clearBtn, + }; + this.main = main; + this.controls = controls; + + const elementClass = datepicker.inline ? 'inline' : 'dropdown'; + element.classList.add(`datepicker-${elementClass}`); + elementClass === 'dropdown' ? element.classList.add('dropdown', 'absolute', 'top-0', 'left-0', 'z-50', 'pt-2') : null; + + processPickerOptions(this, datepicker.config); + this.viewDate = computeResetViewDate(datepicker); + + // set up event listeners + (0,lib_event/* registerListeners */.cF)(datepicker, [ + [element, 'click', onClickPicker.bind(null, datepicker), {capture: true}], + [main, 'click', onClickView.bind(null, datepicker)], + [controls.viewSwitch, 'click', onClickViewSwitch.bind(null, datepicker)], + [controls.prevBtn, 'click', onClickPrevBtn.bind(null, datepicker)], + [controls.nextBtn, 'click', onClickNextBtn.bind(null, datepicker)], + [controls.todayBtn, 'click', onClickTodayBtn.bind(null, datepicker)], + [controls.clearBtn, 'click', onClickClearBtn.bind(null, datepicker)], + ]); + + // set up views + this.views = [ + new DaysView(this), + new MonthsView(this), + new YearsView(this, {id: 2, name: 'years', cellClass: 'year', step: 1}), + new YearsView(this, {id: 3, name: 'decades', cellClass: 'decade', step: 10}), + ]; + this.currentView = this.views[datepicker.config.startView]; + + this.currentView.render(); + this.main.appendChild(this.currentView.element); + datepicker.config.container.appendChild(this.element); + } + + setOptions(options) { + processPickerOptions(this, options); + this.views.forEach((view) => { + view.init(options, false); + }); + this.currentView.render(); + } + + detach() { + this.datepicker.config.container.removeChild(this.element); + } + + show() { + if (this.active) { + return; + } + this.element.classList.add('active', 'block'); + this.element.classList.remove('hidden'); + this.active = true; + + const datepicker = this.datepicker; + if (!datepicker.inline) { + // ensure picker's direction matches input's + const inputDirection = getTextDirection(datepicker.inputField); + if (inputDirection !== getTextDirection(datepicker.config.container)) { + this.element.dir = inputDirection; + } else if (this.element.dir) { + this.element.removeAttribute('dir'); + } + + this.place(); + if (datepicker.config.disableTouchKeyboard) { + datepicker.inputField.blur(); + } + } + triggerDatepickerEvent(datepicker, 'show'); + } + + hide() { + if (!this.active) { + return; + } + this.datepicker.exitEditMode(); + this.element.classList.remove('active', 'block'); + this.element.classList.add('active', 'block', 'hidden'); + this.active = false; + triggerDatepickerEvent(this.datepicker, 'hide'); + } + + place() { + const {classList, style} = this.element; + const {config, inputField} = this.datepicker; + const container = config.container; + const { + width: calendarWidth, + height: calendarHeight, + } = this.element.getBoundingClientRect(); + const { + left: containerLeft, + top: containerTop, + width: containerWidth, + } = container.getBoundingClientRect(); + const { + left: inputLeft, + top: inputTop, + width: inputWidth, + height: inputHeight + } = inputField.getBoundingClientRect(); + let {x: orientX, y: orientY} = config.orientation; + let scrollTop; + let left; + let top; + + if (container === document.body) { + scrollTop = window.scrollY; + left = inputLeft + window.scrollX; + top = inputTop + scrollTop; + } else { + scrollTop = container.scrollTop; + left = inputLeft - containerLeft; + top = inputTop - containerTop + scrollTop; + } + + if (orientX === 'auto') { + if (left < 0) { + // align to the left and move into visible area if input's left edge < window's + orientX = 'left'; + left = 10; + } else if (left + calendarWidth > containerWidth) { + // align to the right if canlendar's right edge > container's + orientX = 'right'; + } else { + orientX = getTextDirection(inputField) === 'rtl' ? 'right' : 'left'; + } + } + if (orientX === 'right') { + left -= calendarWidth - inputWidth; + } + + if (orientY === 'auto') { + orientY = top - calendarHeight < scrollTop ? 'bottom' : 'top'; + } + if (orientY === 'top') { + top -= calendarHeight; + } else { + top += inputHeight; + } + + classList.remove( + 'datepicker-orient-top', + 'datepicker-orient-bottom', + 'datepicker-orient-right', + 'datepicker-orient-left' + ); + classList.add(`datepicker-orient-${orientY}`, `datepicker-orient-${orientX}`); + + style.top = top ? `${top}px` : top; + style.left = left ? `${left}px` : left; + } + + setViewSwitchLabel(labelText) { + this.controls.viewSwitch.textContent = labelText; + } + + setPrevBtnDisabled(disabled) { + this.controls.prevBtn.disabled = disabled; + } + + setNextBtnDisabled(disabled) { + this.controls.nextBtn.disabled = disabled; + } + + changeView(viewId) { + const oldView = this.currentView; + const newView = this.views[viewId]; + if (newView.id !== oldView.id) { + this.currentView = newView; + this._renderMethod = 'render'; + triggerDatepickerEvent(this.datepicker, 'changeView'); + this.main.replaceChild(newView.element, oldView.element); + } + return this; + } + + // Change the focused date (view date) + changeFocus(newViewDate) { + this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refreshFocus'; + this.views.forEach((view) => { + view.updateFocus(); + }); + return this; + } + + // Apply the change of the selected dates + update() { + const newViewDate = computeResetViewDate(this.datepicker); + this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refresh'; + this.views.forEach((view) => { + view.updateFocus(); + view.updateSelection(); + }); + return this; + } + + // Refresh the picker UI + render(quickRender = true) { + const renderMethod = (quickRender && this._renderMethod) || 'render'; + delete this._renderMethod; + + this.currentView[renderMethod](); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/inputFieldListeners.js + + + + +// Find the closest date that doesn't meet the condition for unavailable date +// Returns undefined if no available date is found +// addFn: function to calculate the next date +// - args: time value, amount +// increase: amount to pass to addFn +// testFn: function to test the unavailablity of the date +// - args: time value; retun: true if unavailable +function findNextAvailableOne(date, addFn, increase, testFn, min, max) { + if (!(0,utils/* isInRange */.mh)(date, min, max)) { + return; + } + if (testFn(date)) { + const newDate = addFn(date, increase); + return findNextAvailableOne(newDate, addFn, increase, testFn, min, max); + } + return date; +} + +// direction: -1 (left/up), 1 (right/down) +// vertical: true for up/down, false for left/right +function moveByArrowKey(datepicker, ev, direction, vertical) { + const picker = datepicker.picker; + const currentView = picker.currentView; + const step = currentView.step || 1; + let viewDate = picker.viewDate; + let addFn; + let testFn; + switch (currentView.id) { + case 0: + if (vertical) { + viewDate = (0,lib_date/* addDays */.E4)(viewDate, direction * 7); + } else if (ev.ctrlKey || ev.metaKey) { + viewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction); + } else { + viewDate = (0,lib_date/* addDays */.E4)(viewDate, direction); + } + addFn = lib_date/* addDays */.E4; + testFn = (date) => currentView.disabled.includes(date); + break; + case 1: + viewDate = (0,lib_date/* addMonths */.zI)(viewDate, vertical ? direction * 4 : direction); + addFn = lib_date/* addMonths */.zI; + testFn = (date) => { + const dt = new Date(date); + const {year, disabled} = currentView; + return dt.getFullYear() === year && disabled.includes(dt.getMonth()); + }; + break; + default: + viewDate = (0,lib_date/* addYears */.Bc)(viewDate, direction * (vertical ? 4 : 1) * step); + addFn = lib_date/* addYears */.Bc; + testFn = date => currentView.disabled.includes((0,lib_date/* startOfYearPeriod */.ak)(date, step)); + } + viewDate = findNextAvailableOne( + viewDate, + addFn, + direction < 0 ? -step : step, + testFn, + currentView.minDate, + currentView.maxDate + ); + if (viewDate !== undefined) { + picker.changeFocus(viewDate).render(); + } +} + +function onKeydown(datepicker, ev) { + if (ev.key === 'Tab') { + unfocus(datepicker); + return; + } + + const picker = datepicker.picker; + const {id, isMinView} = picker.currentView; + if (!picker.active) { + switch (ev.key) { + case 'ArrowDown': + case 'Escape': + picker.show(); + break; + case 'Enter': + datepicker.update(); + break; + default: + return; + } + } else if (datepicker.editMode) { + switch (ev.key) { + case 'Escape': + picker.hide(); + break; + case 'Enter': + datepicker.exitEditMode({update: true, autohide: datepicker.config.autohide}); + break; + default: + return; + } + } else { + switch (ev.key) { + case 'Escape': + picker.hide(); + break; + case 'ArrowLeft': + if (ev.ctrlKey || ev.metaKey) { + goToPrevOrNext(datepicker, -1); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, -1, false); + } + break; + case 'ArrowRight': + if (ev.ctrlKey || ev.metaKey) { + goToPrevOrNext(datepicker, 1); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, 1, false); + } + break; + case 'ArrowUp': + if (ev.ctrlKey || ev.metaKey) { + switchView(datepicker); + } else if (ev.shiftKey) { + datepicker.enterEditMode(); + return; + } else { + moveByArrowKey(datepicker, ev, -1, true); + } + break; + case 'ArrowDown': + if (ev.shiftKey && !ev.ctrlKey && !ev.metaKey) { + datepicker.enterEditMode(); + return; + } + moveByArrowKey(datepicker, ev, 1, true); + break; + case 'Enter': + if (isMinView) { + datepicker.setDate(picker.viewDate); + } else { + picker.changeView(id - 1).render(); + } + break; + case 'Backspace': + case 'Delete': + datepicker.enterEditMode(); + return; + default: + if (ev.key.length === 1 && !ev.ctrlKey && !ev.metaKey) { + datepicker.enterEditMode(); + } + return; + } + } + ev.preventDefault(); + ev.stopPropagation(); +} + +function onFocus(datepicker) { + if (datepicker.config.showOnFocus && !datepicker._showing) { + datepicker.show(); + } +} + +// for the prevention for entering edit mode while getting focus on click +function onMousedown(datepicker, ev) { + const el = ev.target; + if (datepicker.picker.active || datepicker.config.showOnClick) { + el._active = el === document.activeElement; + el._clicking = setTimeout(() => { + delete el._active; + delete el._clicking; + }, 2000); + } +} + +function onClickInput(datepicker, ev) { + const el = ev.target; + if (!el._clicking) { + return; + } + clearTimeout(el._clicking); + delete el._clicking; + + if (el._active) { + datepicker.enterEditMode(); + } + delete el._active; + + if (datepicker.config.showOnClick) { + datepicker.show(); + } +} + +function onPaste(datepicker, ev) { + if (ev.clipboardData.types.includes('text/plain')) { + datepicker.enterEditMode(); + } +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/events/otherListeners.js + + + +// for the `document` to delegate the events from outside the picker/input field +function onClickOutside(datepicker, ev) { + const element = datepicker.element; + if (element !== document.activeElement) { + return; + } + const pickerElem = datepicker.picker.element; + if ((0,lib_event/* findElementInEventPath */.He)(ev, el => el === element || el === pickerElem)) { + return; + } + unfocus(datepicker); +} + +;// CONCATENATED MODULE: ./node_modules/flowbite-datepicker/js/Datepicker.js + + + + + + + + + + + + +function stringifyDates(dates, config) { + return dates + .map(dt => (0,date_format/* formatDate */.p6)(dt, config.format, config.locale)) + .join(config.dateDelimiter); +} + +// parse input dates and create an array of time values for selection +// returns undefined if there are no valid dates in inputDates +// when origDates (current selection) is passed, the function works to mix +// the input dates into the current selection +function processInputDates(datepicker, inputDates, clear = false) { + const {config, dates: origDates, rangepicker} = datepicker; + if (inputDates.length === 0) { + // empty input is considered valid unless origiDates is passed + return clear ? [] : undefined; + } + + const rangeEnd = rangepicker && datepicker === rangepicker.datepickers[1]; + let newDates = inputDates.reduce((dates, dt) => { + let date = (0,date_format/* parseDate */.sG)(dt, config.format, config.locale); + if (date === undefined) { + return dates; + } + if (config.pickLevel > 0) { + // adjust to 1st of the month/Jan 1st of the year + // or to the last day of the monh/Dec 31st of the year if the datepicker + // is the range-end picker of a rangepicker + const dt = new Date(date); + if (config.pickLevel === 1) { + date = rangeEnd + ? dt.setMonth(dt.getMonth() + 1, 0) + : dt.setDate(1); + } else { + date = rangeEnd + ? dt.setFullYear(dt.getFullYear() + 1, 0, 0) + : dt.setMonth(0, 1); + } + } + if ( + (0,utils/* isInRange */.mh)(date, config.minDate, config.maxDate) + && !dates.includes(date) + && !config.datesDisabled.includes(date) + && !config.daysOfWeekDisabled.includes(new Date(date).getDay()) + ) { + dates.push(date); + } + return dates; + }, []); + if (newDates.length === 0) { + return; + } + if (config.multidate && !clear) { + // get the synmetric difference between origDates and newDates + newDates = newDates.reduce((dates, date) => { + if (!origDates.includes(date)) { + dates.push(date); + } + return dates; + }, origDates.filter(date => !newDates.includes(date))); + } + // do length check always because user can input multiple dates regardless of the mode + return config.maxNumberOfDates && newDates.length > config.maxNumberOfDates + ? newDates.slice(config.maxNumberOfDates * -1) + : newDates; +} + +// refresh the UI elements +// modes: 1: input only, 2, picker only, 3 both +function refreshUI(datepicker, mode = 3, quickRender = true) { + const {config, picker, inputField} = datepicker; + if (mode & 2) { + const newView = picker.active ? config.pickLevel : config.startView; + picker.update().changeView(newView).render(quickRender); + } + if (mode & 1 && inputField) { + inputField.value = stringifyDates(datepicker.dates, config); + } +} + +function setDate(datepicker, inputDates, options) { + let {clear, render, autohide} = options; + if (render === undefined) { + render = true; + } + if (!render) { + autohide = false; + } else if (autohide === undefined) { + autohide = datepicker.config.autohide; + } + + const newDates = processInputDates(datepicker, inputDates, clear); + if (!newDates) { + return; + } + if (newDates.toString() !== datepicker.dates.toString()) { + datepicker.dates = newDates; + refreshUI(datepicker, render ? 3 : 1); + triggerDatepickerEvent(datepicker, 'changeDate'); + } else { + refreshUI(datepicker, 1); + } + if (autohide) { + datepicker.hide(); + } +} + +/** + * Class representing a date picker + */ +class Datepicker { + /** + * Create a date picker + * @param {Element} element - element to bind a date picker + * @param {Object} [options] - config options + * @param {DateRangePicker} [rangepicker] - DateRangePicker instance the + * date picker belongs to. Use this only when creating date picker as a part + * of date range picker + */ + constructor(element, options = {}, rangepicker = undefined) { + element.datepicker = this; + this.element = element; + + // set up config + const config = this.config = Object.assign({ + buttonClass: (options.buttonClass && String(options.buttonClass)) || 'button', + container: document.body, + defaultViewDate: (0,lib_date/* today */.Lg)(), + maxDate: undefined, + minDate: undefined, + }, processOptions(options_defaultOptions, this)); + this._options = options; + Object.assign(config, processOptions(options, this)); + + // configure by type + const inline = this.inline = element.tagName !== 'INPUT'; + let inputField; + let initialDates; + + if (inline) { + config.container = element; + initialDates = (0,utils/* stringToArray */.W7)(element.dataset.date, config.dateDelimiter); + delete element.dataset.date; + } else { + const container = options.container ? document.querySelector(options.container) : null; + if (container) { + config.container = container; + } + inputField = this.inputField = element; + inputField.classList.add('datepicker-input'); + initialDates = (0,utils/* stringToArray */.W7)(inputField.value, config.dateDelimiter); + } + if (rangepicker) { + // check validiry + const index = rangepicker.inputs.indexOf(inputField); + const datepickers = rangepicker.datepickers; + if (index < 0 || index > 1 || !Array.isArray(datepickers)) { + throw Error('Invalid rangepicker object.'); + } + // attach itaelf to the rangepicker here so that processInputDates() can + // determine if this is the range-end picker of the rangepicker while + // setting inital values when pickLevel > 0 + datepickers[index] = this; + // add getter for rangepicker + Object.defineProperty(this, 'rangepicker', { + get() { + return rangepicker; + }, + }); + } + + // set initial dates + this.dates = []; + // process initial value + const inputDateValues = processInputDates(this, initialDates); + if (inputDateValues && inputDateValues.length > 0) { + this.dates = inputDateValues; + } + if (inputField) { + inputField.value = stringifyDates(this.dates, config); + } + + const picker = this.picker = new Picker(this); + + if (inline) { + this.show(); + } else { + // set up event listeners in other modes + const onMousedownDocument = onClickOutside.bind(null, this); + const listeners = [ + [inputField, 'keydown', onKeydown.bind(null, this)], + [inputField, 'focus', onFocus.bind(null, this)], + [inputField, 'mousedown', onMousedown.bind(null, this)], + [inputField, 'click', onClickInput.bind(null, this)], + [inputField, 'paste', onPaste.bind(null, this)], + [document, 'mousedown', onMousedownDocument], + [document, 'touchstart', onMousedownDocument], + [window, 'resize', picker.place.bind(picker)] + ]; + (0,lib_event/* registerListeners */.cF)(this, listeners); + } + } + + /** + * Format Date object or time value in given format and language + * @param {Date|Number} date - date or time value to format + * @param {String|Object} format - format string or object that contains + * toDisplay() custom formatter, whose signature is + * - args: + * - date: {Date} - Date instance of the date passed to the method + * - format: {Object} - the format object passed to the method + * - locale: {Object} - locale for the language specified by `lang` + * - return: + * {String} formatted date + * @param {String} [lang=en] - language code for the locale to use + * @return {String} formatted date + */ + static formatDate(date, format, lang) { + return (0,date_format/* formatDate */.p6)(date, format, lang && locales[lang] || locales.en); + } + + /** + * Parse date string + * @param {String|Date|Number} dateStr - date string, Date object or time + * value to parse + * @param {String|Object} format - format string or object that contains + * toValue() custom parser, whose signature is + * - args: + * - dateStr: {String|Date|Number} - the dateStr passed to the method + * - format: {Object} - the format object passed to the method + * - locale: {Object} - locale for the language specified by `lang` + * - return: + * {Date|Number} parsed date or its time value + * @param {String} [lang=en] - language code for the locale to use + * @return {Number} time value of parsed date + */ + static parseDate(dateStr, format, lang) { + return (0,date_format/* parseDate */.sG)(dateStr, format, lang && locales[lang] || locales.en); + } + + /** + * @type {Object} - Installed locales in `[languageCode]: localeObject` format + * en`:_English (US)_ is pre-installed. + */ + static get locales() { + return locales; + } + + /** + * @type {Boolean} - Whether the picker element is shown. `true` whne shown + */ + get active() { + return !!(this.picker && this.picker.active); + } + + /** + * @type {HTMLDivElement} - DOM object of picker element + */ + get pickerElement() { + return this.picker ? this.picker.element : undefined; + } + + /** + * Set new values to the config options + * @param {Object} options - config options to update + */ + setOptions(options) { + const picker = this.picker; + const newOptions = processOptions(options, this); + Object.assign(this._options, options); + Object.assign(this.config, newOptions); + picker.setOptions(newOptions); + + refreshUI(this, 3); + } + + /** + * Show the picker element + */ + show() { + if (this.inputField) { + if (this.inputField.disabled) { + return; + } + if (this.inputField !== document.activeElement) { + this._showing = true; + this.inputField.focus(); + delete this._showing; + } + } + this.picker.show(); + } + + /** + * Hide the picker element + * Not available on inline picker + */ + hide() { + if (this.inline) { + return; + } + this.picker.hide(); + this.picker.update().changeView(this.config.startView).render(); + } + + /** + * Destroy the Datepicker instance + * @return {Detepicker} - the instance destroyed + */ + destroy() { + this.hide(); + (0,lib_event/* unregisterListeners */.uV)(this); + this.picker.detach(); + if (!this.inline) { + this.inputField.classList.remove('datepicker-input'); + } + delete this.element.datepicker; + return this; + } + + /** + * Get the selected date(s) + * + * The method returns a Date object of selected date by default, and returns + * an array of selected dates in multidate mode. If format string is passed, + * it returns date string(s) formatted in given format. + * + * @param {String} [format] - Format string to stringify the date(s) + * @return {Date|String|Date[]|String[]} - selected date(s), or if none is + * selected, empty array in multidate mode and untitled in sigledate mode + */ + getDate(format = undefined) { + const callback = format + ? date => (0,date_format/* formatDate */.p6)(date, format, this.config.locale) + : date => new Date(date); + + if (this.config.multidate) { + return this.dates.map(callback); + } + if (this.dates.length > 0) { + return callback(this.dates[0]); + } + } + + /** + * Set selected date(s) + * + * In multidate mode, you can pass multiple dates as a series of arguments + * or an array. (Since each date is parsed individually, the type of the + * dates doesn't have to be the same.) + * The given dates are used to toggle the select status of each date. The + * number of selected dates is kept from exceeding the length set to + * maxNumberOfDates. + * + * With clear: true option, the method can be used to clear the selection + * and to replace the selection instead of toggling in multidate mode. + * If the option is passed with no date arguments or an empty dates array, + * it works as "clear" (clear the selection then set nothing), and if the + * option is passed with new dates to select, it works as "replace" (clear + * the selection then set the given dates) + * + * When render: false option is used, the method omits re-rendering the + * picker element. In this case, you need to call refresh() method later in + * order for the picker element to reflect the changes. The input field is + * refreshed always regardless of this option. + * + * When invalid (unparsable, repeated, disabled or out-of-range) dates are + * passed, the method ignores them and applies only valid ones. In the case + * that all the given dates are invalid, which is distinguished from passing + * no dates, the method considers it as an error and leaves the selection + * untouched. + * + * @param {...(Date|Number|String)|Array} [dates] - Date strings, Date + * objects, time values or mix of those for new selection + * @param {Object} [options] - function options + * - clear: {boolean} - Whether to clear the existing selection + * defualt: false + * - render: {boolean} - Whether to re-render the picker element + * default: true + * - autohide: {boolean} - Whether to hide the picker element after re-render + * Ignored when used with render: false + * default: config.autohide + */ + setDate(...args) { + const dates = [...args]; + const opts = {}; + const lastArg = (0,utils/* lastItemOf */.Jm)(args); + if ( + typeof lastArg === 'object' + && !Array.isArray(lastArg) + && !(lastArg instanceof Date) + && lastArg + ) { + Object.assign(opts, dates.pop()); + } + + const inputDates = Array.isArray(dates[0]) ? dates[0] : dates; + setDate(this, inputDates, opts); + } + + /** + * Update the selected date(s) with input field's value + * Not available on inline picker + * + * The input field will be refreshed with properly formatted date string. + * + * @param {Object} [options] - function options + * - autohide: {boolean} - whether to hide the picker element after refresh + * default: false + */ + update(options = undefined) { + if (this.inline) { + return; + } + + const opts = {clear: true, autohide: !!(options && options.autohide)}; + const inputDates = (0,utils/* stringToArray */.W7)(this.inputField.value, this.config.dateDelimiter); + setDate(this, inputDates, opts); + } + + /** + * Refresh the picker element and the associated input field + * @param {String} [target] - target item when refreshing one item only + * 'picker' or 'input' + * @param {Boolean} [forceRender] - whether to re-render the picker element + * regardless of its state instead of optimized refresh + */ + refresh(target = undefined, forceRender = false) { + if (target && typeof target !== 'string') { + forceRender = target; + target = undefined; + } + + let mode; + if (target === 'picker') { + mode = 2; + } else if (target === 'input') { + mode = 1; + } else { + mode = 3; + } + refreshUI(this, mode, !forceRender); + } + + /** + * Enter edit mode + * Not available on inline picker or when the picker element is hidden + */ + enterEditMode() { + if (this.inline || !this.picker.active || this.editMode) { + return; + } + this.editMode = true; + this.inputField.classList.add('in-edit', 'border-blue-700'); + } + + /** + * Exit from edit mode + * Not available on inline picker + * @param {Object} [options] - function options + * - update: {boolean} - whether to call update() after exiting + * If false, input field is revert to the existing selection + * default: false + */ + exitEditMode(options = undefined) { + if (this.inline || !this.editMode) { + return; + } + const opts = Object.assign({update: false}, options); + delete this.editMode; + this.inputField.classList.remove('in-edit', 'border-blue-700'); + if (opts.update) { + this.update(opts); + } + } +} + + +/***/ }), + +/***/ 963: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "CL": function() { return /* binding */ reFormatTokens; }, +/* harmony export */ "p6": function() { return /* binding */ formatDate; }, +/* harmony export */ "sG": function() { return /* binding */ parseDate; } +/* harmony export */ }); +/* unused harmony export reNonDateParts */ +/* harmony import */ var _date_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(560); +/* harmony import */ var _utils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(105); + + + +// pattern for format parts +const reFormatTokens = /dd?|DD?|mm?|MM?|yy?(?:yy)?/; +// pattern for non date parts +const reNonDateParts = /[\s!-/:-@[-`{-~年月日]+/; +// cache for persed formats +let knownFormats = {}; +// parse funtions for date parts +const parseFns = { + y(date, year) { + return new Date(date).setFullYear(parseInt(year, 10)); + }, + m(date, month, locale) { + const newDate = new Date(date); + let monthIndex = parseInt(month, 10) - 1; + + if (isNaN(monthIndex)) { + if (!month) { + return NaN; + } + + const monthName = month.toLowerCase(); + const compareNames = name => name.toLowerCase().startsWith(monthName); + // compare with both short and full names because some locales have periods + // in the short names (not equal to the first X letters of the full names) + monthIndex = locale.monthsShort.findIndex(compareNames); + if (monthIndex < 0) { + monthIndex = locale.months.findIndex(compareNames); + } + if (monthIndex < 0) { + return NaN; + } + } + + newDate.setMonth(monthIndex); + return newDate.getMonth() !== normalizeMonth(monthIndex) + ? newDate.setDate(0) + : newDate.getTime(); + }, + d(date, day) { + return new Date(date).setDate(parseInt(day, 10)); + }, +}; +// format functions for date parts +const formatFns = { + d(date) { + return date.getDate(); + }, + dd(date) { + return padZero(date.getDate(), 2); + }, + D(date, locale) { + return locale.daysShort[date.getDay()]; + }, + DD(date, locale) { + return locale.days[date.getDay()]; + }, + m(date) { + return date.getMonth() + 1; + }, + mm(date) { + return padZero(date.getMonth() + 1, 2); + }, + M(date, locale) { + return locale.monthsShort[date.getMonth()]; + }, + MM(date, locale) { + return locale.months[date.getMonth()]; + }, + y(date) { + return date.getFullYear(); + }, + yy(date) { + return padZero(date.getFullYear(), 2).slice(-2); + }, + yyyy(date) { + return padZero(date.getFullYear(), 4); + }, +}; + +// get month index in normal range (0 - 11) from any number +function normalizeMonth(monthIndex) { + return monthIndex > -1 ? monthIndex % 12 : normalizeMonth(monthIndex + 12); +} + +function padZero(num, length) { + return num.toString().padStart(length, '0'); +} + +function parseFormatString(format) { + if (typeof format !== 'string') { + throw new Error("Invalid date format."); + } + if (format in knownFormats) { + return knownFormats[format]; + } + + // sprit the format string into parts and seprators + const separators = format.split(reFormatTokens); + const parts = format.match(new RegExp(reFormatTokens, 'g')); + if (separators.length === 0 || !parts) { + throw new Error("Invalid date format."); + } + + // collect format functions used in the format + const partFormatters = parts.map(token => formatFns[token]); + + // collect parse function keys used in the format + // iterate over parseFns' keys in order to keep the order of the keys. + const partParserKeys = Object.keys(parseFns).reduce((keys, key) => { + const token = parts.find(part => part[0] !== 'D' && part[0].toLowerCase() === key); + if (token) { + keys.push(key); + } + return keys; + }, []); + + return knownFormats[format] = { + parser(dateStr, locale) { + const dateParts = dateStr.split(reNonDateParts).reduce((dtParts, part, index) => { + if (part.length > 0 && parts[index]) { + const token = parts[index][0]; + if (token === 'M') { + dtParts.m = part; + } else if (token !== 'D') { + dtParts[token] = part; + } + } + return dtParts; + }, {}); + + // iterate over partParserkeys so that the parsing is made in the oder + // of year, month and day to prevent the day parser from correcting last + // day of month wrongly + return partParserKeys.reduce((origDate, key) => { + const newDate = parseFns[key](origDate, dateParts[key], locale); + // ingnore the part failed to parse + return isNaN(newDate) ? origDate : newDate; + }, (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .today */ .Lg)()); + }, + formatter(date, locale) { + let dateStr = partFormatters.reduce((str, fn, index) => { + return str += `${separators[index]}${fn(date, locale)}`; + }, ''); + // separators' length is always parts' length + 1, + return dateStr += (0,_utils_js__WEBPACK_IMPORTED_MODULE_1__/* .lastItemOf */ .Jm)(separators); + }, + }; +} + +function parseDate(dateStr, format, locale) { + if (dateStr instanceof Date || typeof dateStr === 'number') { + const date = (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .stripTime */ .xR)(dateStr); + return isNaN(date) ? undefined : date; + } + if (!dateStr) { + return undefined; + } + if (dateStr === 'today') { + return (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .today */ .Lg)(); + } + + if (format && format.toValue) { + const date = format.toValue(dateStr, format, locale); + return isNaN(date) ? undefined : (0,_date_js__WEBPACK_IMPORTED_MODULE_0__/* .stripTime */ .xR)(date); + } + + return parseFormatString(format).parser(dateStr, locale); +} + +function formatDate(date, format, locale) { + if (isNaN(date) || (!date && date !== 0)) { + return ''; + } + + const dateObj = typeof date === 'number' ? new Date(date) : date; + + if (format.toDisplay) { + return format.toDisplay(dateObj, format, locale); + } + + return parseFormatString(format).formatter(dateObj, locale); +} + + +/***/ }), + +/***/ 560: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Bc": function() { return /* binding */ addYears; }, +/* harmony export */ "E4": function() { return /* binding */ addDays; }, +/* harmony export */ "Lg": function() { return /* binding */ today; }, +/* harmony export */ "Qk": function() { return /* binding */ getWeek; }, +/* harmony export */ "ak": function() { return /* binding */ startOfYearPeriod; }, +/* harmony export */ "by": function() { return /* binding */ dateValue; }, +/* harmony export */ "fr": function() { return /* binding */ dayOfTheWeekOf; }, +/* harmony export */ "jh": function() { return /* binding */ addWeeks; }, +/* harmony export */ "xR": function() { return /* binding */ stripTime; }, +/* harmony export */ "zI": function() { return /* binding */ addMonths; } +/* harmony export */ }); +function stripTime(timeValue) { + return new Date(timeValue).setHours(0, 0, 0, 0); +} + +function today() { + return new Date().setHours(0, 0, 0, 0); +} + +// Get the time value of the start of given date or year, month and day +function dateValue(...args) { + switch (args.length) { + case 0: + return today(); + case 1: + return stripTime(args[0]); + } + + // use setFullYear() to keep 2-digit year from being mapped to 1900-1999 + const newDate = new Date(0); + newDate.setFullYear(...args); + return newDate.setHours(0, 0, 0, 0); +} + +function addDays(date, amount) { + const newDate = new Date(date); + return newDate.setDate(newDate.getDate() + amount); +} + +function addWeeks(date, amount) { + return addDays(date, amount * 7); +} + +function addMonths(date, amount) { + // If the day of the date is not in the new month, the last day of the new + // month will be returned. e.g. Jan 31 + 1 month → Feb 28 (not Mar 03) + const newDate = new Date(date); + const monthsToSet = newDate.getMonth() + amount; + let expectedMonth = monthsToSet % 12; + if (expectedMonth < 0) { + expectedMonth += 12; + } + + const time = newDate.setMonth(monthsToSet); + return newDate.getMonth() !== expectedMonth ? newDate.setDate(0) : time; +} + +function addYears(date, amount) { + // If the date is Feb 29 and the new year is not a leap year, Feb 28 of the + // new year will be returned. + const newDate = new Date(date); + const expectedMonth = newDate.getMonth(); + const time = newDate.setFullYear(newDate.getFullYear() + amount); + return expectedMonth === 1 && newDate.getMonth() === 2 ? newDate.setDate(0) : time; +} + +// Calculate the distance bettwen 2 days of the week +function dayDiff(day, from) { + return (day - from + 7) % 7; +} + +// Get the date of the specified day of the week of given base date +function dayOfTheWeekOf(baseDate, dayOfWeek, weekStart = 0) { + const baseDay = new Date(baseDate).getDay(); + return addDays(baseDate, dayDiff(dayOfWeek, weekStart) - dayDiff(baseDay, weekStart)); +} + +// Get the ISO week of a date +function getWeek(date) { + // start of ISO week is Monday + const thuOfTheWeek = dayOfTheWeekOf(date, 4, 1); + // 1st week == the week where the 4th of January is in + const firstThu = dayOfTheWeekOf(new Date(thuOfTheWeek).setMonth(0, 4), 4, 1); + return Math.round((thuOfTheWeek - firstThu) / 604800000) + 1; +} + +// Get the start year of the period of years that includes given date +// years: length of the year period +function startOfYearPeriod(date, years) { + /* @see https://en.wikipedia.org/wiki/Year_zero#ISO_8601 */ + const year = new Date(date).getFullYear(); + return Math.floor(year / years) * years; +} + + +/***/ }), + +/***/ 698: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "He": function() { return /* binding */ findElementInEventPath; }, +/* harmony export */ "cF": function() { return /* binding */ registerListeners; }, +/* harmony export */ "uV": function() { return /* binding */ unregisterListeners; } +/* harmony export */ }); +const listenerRegistry = new WeakMap(); +const {addEventListener, removeEventListener} = EventTarget.prototype; + +// Register event listeners to a key object +// listeners: array of listener definitions; +// - each definition must be a flat array of event target and the arguments +// used to call addEventListener() on the target +function registerListeners(keyObj, listeners) { + let registered = listenerRegistry.get(keyObj); + if (!registered) { + registered = []; + listenerRegistry.set(keyObj, registered); + } + listeners.forEach((listener) => { + addEventListener.call(...listener); + registered.push(listener); + }); +} + +function unregisterListeners(keyObj) { + let listeners = listenerRegistry.get(keyObj); + if (!listeners) { + return; + } + listeners.forEach((listener) => { + removeEventListener.call(...listener); + }); + listenerRegistry.delete(keyObj); +} + +// Event.composedPath() polyfill for Edge +// based on https://gist.github.com/kleinfreund/e9787d73776c0e3750dcfcdc89f100ec +if (!Event.prototype.composedPath) { + const getComposedPath = (node, path = []) => { + path.push(node); + + let parent; + if (node.parentNode) { + parent = node.parentNode; + } else if (node.host) { // ShadowRoot + parent = node.host; + } else if (node.defaultView) { // Document + parent = node.defaultView; + } + return parent ? getComposedPath(parent, path) : path; + }; + + Event.prototype.composedPath = function () { + return getComposedPath(this.target); + }; +} + +function findFromPath(path, criteria, currentTarget, index = 0) { + const el = path[index]; + if (criteria(el)) { + return el; + } else if (el === currentTarget || !el.parentElement) { + // stop when reaching currentTarget or + return; + } + return findFromPath(path, criteria, currentTarget, index + 1); +} + +// Search for the actual target of a delegated event +function findElementInEventPath(ev, selector) { + const criteria = typeof selector === 'function' ? selector : el => el.matches(selector); + return findFromPath(ev.composedPath(), criteria, ev.currentTarget); +} + + +/***/ }), + +/***/ 105: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "$C": function() { return /* binding */ pushUnique; }, +/* harmony export */ "Jm": function() { return /* binding */ lastItemOf; }, +/* harmony export */ "W7": function() { return /* binding */ stringToArray; }, +/* harmony export */ "em": function() { return /* binding */ createTagRepeat; }, +/* harmony export */ "jG": function() { return /* binding */ limitToRange; }, +/* harmony export */ "l$": function() { return /* binding */ hasProperty; }, +/* harmony export */ "mh": function() { return /* binding */ isInRange; }, +/* harmony export */ "zh": function() { return /* binding */ optimizeTemplateHTML; } +/* harmony export */ }); +function hasProperty(obj, prop) { + return Object.prototype.hasOwnProperty.call(obj, prop); +} + +function lastItemOf(arr) { + return arr[arr.length - 1]; +} + +// push only the items not included in the array +function pushUnique(arr, ...items) { + items.forEach((item) => { + if (arr.includes(item)) { + return; + } + arr.push(item); + }); + return arr; +} + +function stringToArray(str, separator) { + // convert empty string to an empty array + return str ? str.split(separator) : []; +} + +function isInRange(testVal, min, max) { + const minOK = min === undefined || testVal >= min; + const maxOK = max === undefined || testVal <= max; + return minOK && maxOK; +} + +function limitToRange(val, min, max) { + if (val < min) { + return min; + } + if (val > max) { + return max; + } + return val; +} + +function createTagRepeat(tagName, repeat, attributes = {}, index = 0, html = '') { + const openTagSrc = Object.keys(attributes).reduce((src, attr) => { + let val = attributes[attr]; + if (typeof val === 'function') { + val = val(index); + } + return `${src} ${attr}="${val}"`; + }, tagName); + html += `<${openTagSrc}>`; + + const next = index + 1; + return next < repeat + ? createTagRepeat(tagName, repeat, attributes, next, html) + : html; +} + +// Remove the spacing surrounding tags for HTML parser not to create text nodes +// before/after elements +function optimizeTemplateHTML(html) { + return html.replace(/>\s+/g, '>').replace(/\s+ {\n const buttons = datepickerEl.hasAttribute('datepicker-buttons');\n const autohide = datepickerEl.hasAttribute('datepicker-autohide');\n const format = datepickerEl.hasAttribute('datepicker-format');\n const orientation = datepickerEl.hasAttribute('datepicker-orientation');\n const title = datepickerEl.hasAttribute('datepicker-title');\n\n const options = {};\n if (buttons) {\n options.todayBtn = true;\n options.clearBtn = true;\n }\n if (autohide) {\n options.autohide = true;\n }\n if (format) {\n options.format = datepickerEl.getAttribute('datepicker-format');\n }\n if (orientation) {\n options.orientation = datepickerEl.getAttribute(\n 'datepicker-orientation'\n );\n }\n if (title) {\n options.title = datepickerEl.getAttribute('datepicker-title');\n }\n\n return options;\n};\n\nexport function initDatepickers() {\n document.querySelectorAll('[datepicker]').forEach(function (datepickerEl) {\n new Datepicker(datepickerEl, getDatepickerOptions(datepickerEl));\n });\n\n document\n .querySelectorAll('[inline-datepicker]')\n .forEach(function (datepickerEl) {\n new Datepicker(datepickerEl, getDatepickerOptions(datepickerEl));\n });\n\n document\n .querySelectorAll('[date-rangepicker]')\n .forEach(function (datepickerEl) {\n new DateRangePicker(\n datepickerEl,\n getDatepickerOptions(datepickerEl)\n );\n });\n}\n\nconst events = new Events('DOMContentLoaded', [initDatepickers]);\nevents.init();\n","import {registerListeners, unregisterListeners} from './lib/event.js';\nimport {formatDate} from './lib/date-format.js';\nimport Datepicker from './Datepicker.js';\n\n// filter out the config options inapproprite to pass to Datepicker\nfunction filterOptions(options) {\n const newOpts = Object.assign({}, options);\n\n delete newOpts.inputs;\n delete newOpts.allowOneSidedRange;\n delete newOpts.maxNumberOfDates; // to ensure each datepicker handles a single date\n\n return newOpts;\n}\n\nfunction setupDatepicker(rangepicker, changeDateListener, el, options) {\n registerListeners(rangepicker, [\n [el, 'changeDate', changeDateListener],\n ]);\n new Datepicker(el, options, rangepicker);\n}\n\nfunction onChangeDate(rangepicker, ev) {\n // to prevent both datepickers trigger the other side's update each other\n if (rangepicker._updating) {\n return;\n }\n rangepicker._updating = true;\n\n const target = ev.target;\n if (target.datepicker === undefined) {\n return;\n }\n\n const datepickers = rangepicker.datepickers;\n const setDateOptions = {render: false};\n const changedSide = rangepicker.inputs.indexOf(target);\n const otherSide = changedSide === 0 ? 1 : 0;\n const changedDate = datepickers[changedSide].dates[0];\n const otherDate = datepickers[otherSide].dates[0];\n\n if (changedDate !== undefined && otherDate !== undefined) {\n // if the start of the range > the end, swap them\n if (changedSide === 0 && changedDate > otherDate) {\n datepickers[0].setDate(otherDate, setDateOptions);\n datepickers[1].setDate(changedDate, setDateOptions);\n } else if (changedSide === 1 && changedDate < otherDate) {\n datepickers[0].setDate(changedDate, setDateOptions);\n datepickers[1].setDate(otherDate, setDateOptions);\n }\n } else if (!rangepicker.allowOneSidedRange) {\n // to prevent the range from becoming one-sided, copy changed side's\n // selection (no matter if it's empty) to the other side\n if (changedDate !== undefined || otherDate !== undefined) {\n setDateOptions.clear = true;\n datepickers[otherSide].setDate(datepickers[changedSide].dates, setDateOptions);\n }\n }\n datepickers[0].picker.update().render();\n datepickers[1].picker.update().render();\n delete rangepicker._updating;\n}\n\n/**\n * Class representing a date range picker\n */\nexport default class DateRangePicker {\n /**\n * Create a date range picker\n * @param {Element} element - element to bind a date range picker\n * @param {Object} [options] - config options\n */\n constructor(element, options = {}) {\n const inputs = Array.isArray(options.inputs)\n ? options.inputs\n : Array.from(element.querySelectorAll('input'));\n if (inputs.length < 2) {\n return;\n }\n\n element.rangepicker = this;\n this.element = element;\n this.inputs = inputs.slice(0, 2);\n this.allowOneSidedRange = !!options.allowOneSidedRange;\n\n const changeDateListener = onChangeDate.bind(null, this);\n const cleanOptions = filterOptions(options);\n // in order for initial date setup to work right when pcicLvel > 0,\n // let Datepicker constructor add the instance to the rangepicker\n const datepickers = [];\n Object.defineProperty(this, 'datepickers', {\n get() {\n return datepickers;\n },\n });\n setupDatepicker(this, changeDateListener, this.inputs[0], cleanOptions);\n setupDatepicker(this, changeDateListener, this.inputs[1], cleanOptions);\n Object.freeze(datepickers);\n // normalize the range if inital dates are given\n if (datepickers[0].dates.length > 0) {\n onChangeDate(this, {target: this.inputs[0]});\n } else if (datepickers[1].dates.length > 0) {\n onChangeDate(this, {target: this.inputs[1]});\n }\n }\n\n /**\n * @type {Array} - selected date of the linked date pickers\n */\n get dates() {\n return this.datepickers.length === 2\n ? [\n this.datepickers[0].dates[0],\n this.datepickers[1].dates[0],\n ]\n : undefined;\n }\n\n /**\n * Set new values to the config options\n * @param {Object} options - config options to update\n */\n setOptions(options) {\n this.allowOneSidedRange = !!options.allowOneSidedRange;\n\n const cleanOptions = filterOptions(options);\n this.datepickers[0].setOptions(cleanOptions);\n this.datepickers[1].setOptions(cleanOptions);\n }\n\n /**\n * Destroy the DateRangePicker instance\n * @return {DateRangePicker} - the instance destroyed\n */\n destroy() {\n this.datepickers[0].destroy();\n this.datepickers[1].destroy();\n unregisterListeners(this);\n delete this.element.rangepicker;\n }\n\n /**\n * Get the start and end dates of the date range\n *\n * The method returns Date objects by default. If format string is passed,\n * it returns date strings formatted in given format.\n * The result array always contains 2 items (start date/end date) and\n * undefined is used for unselected side. (e.g. If none is selected,\n * the result will be [undefined, undefined]. If only the end date is set\n * when allowOneSidedRange config option is true, [undefined, endDate] will\n * be returned.)\n *\n * @param {String} [format] - Format string to stringify the dates\n * @return {Array} - Start and end dates\n */\n getDates(format = undefined) {\n const callback = format\n ? date => formatDate(date, format, this.datepickers[0].config.locale)\n : date => new Date(date);\n\n return this.dates.map(date => date === undefined ? date : callback(date));\n }\n\n /**\n * Set the start and end dates of the date range\n *\n * The method calls datepicker.setDate() internally using each of the\n * arguments in start→end order.\n *\n * When a clear: true option object is passed instead of a date, the method\n * clears the date.\n *\n * If an invalid date, the same date as the current one or an option object\n * without clear: true is passed, the method considers that argument as an\n * \"ineffective\" argument because calling datepicker.setDate() with those\n * values makes no changes to the date selection.\n *\n * When the allowOneSidedRange config option is false, passing {clear: true}\n * to clear the range works only when it is done to the last effective\n * argument (in other words, passed to rangeEnd or to rangeStart along with\n * ineffective rangeEnd). This is because when the date range is changed,\n * it gets normalized based on the last change at the end of the changing\n * process.\n *\n * @param {Date|Number|String|Object} rangeStart - Start date of the range\n * or {clear: true} to clear the date\n * @param {Date|Number|String|Object} rangeEnd - End date of the range\n * or {clear: true} to clear the date\n */\n setDates(rangeStart, rangeEnd) {\n const [datepicker0, datepicker1] = this.datepickers;\n const origDates = this.dates;\n\n // If range normalization runs on every change, we can't set a new range\n // that starts after the end of the current range correctly because the\n // normalization process swaps start↔︎end right after setting the new start\n // date. To prevent this, the normalization process needs to run once after\n // both of the new dates are set.\n this._updating = true;\n datepicker0.setDate(rangeStart);\n datepicker1.setDate(rangeEnd);\n delete this._updating;\n\n if (datepicker1.dates[0] !== origDates[1]) {\n onChangeDate(this, {target: this.inputs[1]});\n } else if (datepicker0.dates[0] !== origDates[0]) {\n onChangeDate(this, {target: this.inputs[0]});\n }\n }\n}\n","// default locales\nexport const locales = {\n en: {\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n daysShort: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n daysMin: [\"Su\", \"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n monthsShort: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"],\n today: \"Today\",\n clear: \"Clear\",\n titleFormat: \"MM y\"\n }\n};\n","// config options updatable by setOptions() and their default values\nconst defaultOptions = {\n autohide: false,\n beforeShowDay: null,\n beforeShowDecade: null,\n beforeShowMonth: null,\n beforeShowYear: null,\n calendarWeeks: false,\n clearBtn: false,\n dateDelimiter: ',',\n datesDisabled: [],\n daysOfWeekDisabled: [],\n daysOfWeekHighlighted: [],\n defaultViewDate: undefined, // placeholder, defaults to today() by the program\n disableTouchKeyboard: false,\n format: 'mm/dd/yyyy',\n language: 'en',\n maxDate: null,\n maxNumberOfDates: 1,\n maxView: 3,\n minDate: null,\n nextArrow: '',\n orientation: 'auto',\n pickLevel: 0,\n prevArrow: '',\n showDaysOfWeek: true,\n showOnClick: true,\n showOnFocus: true,\n startView: 0,\n title: '',\n todayBtn: false,\n todayBtnMode: 0,\n todayHighlight: false,\n updateOnBlur: true,\n weekStart: 0,\n};\n\nexport default defaultOptions;\n","const range = document.createRange();\n\nexport function parseHTML(html) {\n return range.createContextualFragment(html);\n}\n\n// equivalent to jQuery's :visble\nexport function isVisible(el) {\n return !!(el.offsetWidth || el.offsetHeight || el.getClientRects().length);\n}\n\nexport function hideElement(el) {\n if (el.style.display === 'none') {\n return;\n }\n // back up the existing display setting in data-style-display\n if (el.style.display) {\n el.dataset.styleDisplay = el.style.display;\n }\n el.style.display = 'none';\n}\n\nexport function showElement(el) {\n if (el.style.display !== 'none') {\n return;\n }\n if (el.dataset.styleDisplay) {\n // restore backed-up dispay property\n el.style.display = el.dataset.styleDisplay;\n delete el.dataset.styleDisplay;\n } else {\n el.style.display = '';\n }\n}\n\nexport function emptyChildNodes(el) {\n if (el.firstChild) {\n el.removeChild(el.firstChild);\n emptyChildNodes(el);\n }\n}\n\nexport function replaceChildNodes(el, newChildNodes) {\n emptyChildNodes(el);\n if (newChildNodes instanceof DocumentFragment) {\n el.appendChild(newChildNodes);\n } else if (typeof newChildNodes === 'string') {\n el.appendChild(parseHTML(newChildNodes));\n } else if (typeof newChildNodes.forEach === 'function') {\n newChildNodes.forEach((node) => {\n el.appendChild(node);\n });\n }\n}\n","import {hasProperty, pushUnique} from '../lib/utils.js';\nimport {dateValue} from '../lib/date.js';\nimport {reFormatTokens, parseDate} from '../lib/date-format.js';\nimport {parseHTML} from '../lib/dom.js';\nimport defaultOptions from './defaultOptions.js';\n\nconst {\n language: defaultLang,\n format: defaultFormat,\n weekStart: defaultWeekStart,\n} = defaultOptions;\n\n// Reducer function to filter out invalid day-of-week from the input\nfunction sanitizeDOW(dow, day) {\n return dow.length < 6 && day >= 0 && day < 7\n ? pushUnique(dow, day)\n : dow;\n}\n\nfunction calcEndOfWeek(startOfWeek) {\n return (startOfWeek + 6) % 7;\n}\n\n// validate input date. if invalid, fallback to the original value\nfunction validateDate(value, format, locale, origValue) {\n const date = parseDate(value, format, locale);\n return date !== undefined ? date : origValue;\n}\n\n// Validate viewId. if invalid, fallback to the original value\nfunction validateViewId(value, origValue, max = 3) {\n const viewId = parseInt(value, 10);\n return viewId >= 0 && viewId <= max ? viewId : origValue;\n}\n\n// Create Datepicker configuration to set\nexport default function processOptions(options, datepicker) {\n const inOpts = Object.assign({}, options);\n const config = {};\n const locales = datepicker.constructor.locales;\n let {\n format,\n language,\n locale,\n maxDate,\n maxView,\n minDate,\n pickLevel,\n startView,\n weekStart,\n } = datepicker.config || {};\n\n if (inOpts.language) {\n let lang;\n if (inOpts.language !== language) {\n if (locales[inOpts.language]) {\n lang = inOpts.language;\n } else {\n // Check if langauge + region tag can fallback to the one without\n // region (e.g. fr-CA → fr)\n lang = inOpts.language.split('-')[0];\n if (locales[lang] === undefined) {\n lang = false;\n }\n }\n }\n delete inOpts.language;\n if (lang) {\n language = config.language = lang;\n\n // update locale as well when updating language\n const origLocale = locale || locales[defaultLang];\n // use default language's properties for the fallback\n locale = Object.assign({\n format: defaultFormat,\n weekStart: defaultWeekStart\n }, locales[defaultLang]);\n if (language !== defaultLang) {\n Object.assign(locale, locales[language]);\n }\n config.locale = locale;\n // if format and/or weekStart are the same as old locale's defaults,\n // update them to new locale's defaults\n if (format === origLocale.format) {\n format = config.format = locale.format;\n }\n if (weekStart === origLocale.weekStart) {\n weekStart = config.weekStart = locale.weekStart;\n config.weekEnd = calcEndOfWeek(locale.weekStart);\n }\n }\n }\n\n if (inOpts.format) {\n const hasToDisplay = typeof inOpts.format.toDisplay === 'function';\n const hasToValue = typeof inOpts.format.toValue === 'function';\n const validFormatString = reFormatTokens.test(inOpts.format);\n if ((hasToDisplay && hasToValue) || validFormatString) {\n format = config.format = inOpts.format;\n }\n delete inOpts.format;\n }\n\n //*** dates ***//\n // while min and maxDate for \"no limit\" in the options are better to be null\n // (especially when updating), the ones in the config have to be undefined\n // because null is treated as 0 (= unix epoch) when comparing with time value\n let minDt = minDate;\n let maxDt = maxDate;\n if (inOpts.minDate !== undefined) {\n minDt = inOpts.minDate === null\n ? dateValue(0, 0, 1) // set 0000-01-01 to prevent negative values for year\n : validateDate(inOpts.minDate, format, locale, minDt);\n delete inOpts.minDate;\n }\n if (inOpts.maxDate !== undefined) {\n maxDt = inOpts.maxDate === null\n ? undefined\n : validateDate(inOpts.maxDate, format, locale, maxDt);\n delete inOpts.maxDate;\n }\n if (maxDt < minDt) {\n minDate = config.minDate = maxDt;\n maxDate = config.maxDate = minDt;\n } else {\n if (minDate !== minDt) {\n minDate = config.minDate = minDt;\n }\n if (maxDate !== maxDt) {\n maxDate = config.maxDate = maxDt;\n }\n }\n\n if (inOpts.datesDisabled) {\n config.datesDisabled = inOpts.datesDisabled.reduce((dates, dt) => {\n const date = parseDate(dt, format, locale);\n return date !== undefined ? pushUnique(dates, date) : dates;\n }, []);\n delete inOpts.datesDisabled;\n }\n if (inOpts.defaultViewDate !== undefined) {\n const viewDate = parseDate(inOpts.defaultViewDate, format, locale);\n if (viewDate !== undefined) {\n config.defaultViewDate = viewDate;\n }\n delete inOpts.defaultViewDate;\n }\n\n //*** days of week ***//\n if (inOpts.weekStart !== undefined) {\n const wkStart = Number(inOpts.weekStart) % 7;\n if (!isNaN(wkStart)) {\n weekStart = config.weekStart = wkStart;\n config.weekEnd = calcEndOfWeek(wkStart);\n }\n delete inOpts.weekStart;\n }\n if (inOpts.daysOfWeekDisabled) {\n config.daysOfWeekDisabled = inOpts.daysOfWeekDisabled.reduce(sanitizeDOW, []);\n delete inOpts.daysOfWeekDisabled;\n }\n if (inOpts.daysOfWeekHighlighted) {\n config.daysOfWeekHighlighted = inOpts.daysOfWeekHighlighted.reduce(sanitizeDOW, []);\n delete inOpts.daysOfWeekHighlighted;\n }\n\n //*** multi date ***//\n if (inOpts.maxNumberOfDates !== undefined) {\n const maxNumberOfDates = parseInt(inOpts.maxNumberOfDates, 10);\n if (maxNumberOfDates >= 0) {\n config.maxNumberOfDates = maxNumberOfDates;\n config.multidate = maxNumberOfDates !== 1;\n }\n delete inOpts.maxNumberOfDates;\n }\n if (inOpts.dateDelimiter) {\n config.dateDelimiter = String(inOpts.dateDelimiter);\n delete inOpts.dateDelimiter;\n }\n\n //*** pick level & view ***//\n let newPickLevel = pickLevel;\n if (inOpts.pickLevel !== undefined) {\n newPickLevel = validateViewId(inOpts.pickLevel, 2);\n delete inOpts.pickLevel;\n }\n if (newPickLevel !== pickLevel) {\n pickLevel = config.pickLevel = newPickLevel;\n }\n\n let newMaxView = maxView;\n if (inOpts.maxView !== undefined) {\n newMaxView = validateViewId(inOpts.maxView, maxView);\n delete inOpts.maxView;\n }\n // ensure max view >= pick level\n newMaxView = pickLevel > newMaxView ? pickLevel : newMaxView;\n if (newMaxView !== maxView) {\n maxView = config.maxView = newMaxView;\n }\n\n let newStartView = startView;\n if (inOpts.startView !== undefined) {\n newStartView = validateViewId(inOpts.startView, newStartView);\n delete inOpts.startView;\n }\n // ensure pick level <= start view <= max view\n if (newStartView < pickLevel) {\n newStartView = pickLevel;\n } else if (newStartView > maxView) {\n newStartView = maxView;\n }\n if (newStartView !== startView) {\n config.startView = newStartView;\n }\n\n //*** template ***//\n if (inOpts.prevArrow) {\n const prevArrow = parseHTML(inOpts.prevArrow);\n if (prevArrow.childNodes.length > 0) {\n config.prevArrow = prevArrow.childNodes;\n }\n delete inOpts.prevArrow;\n }\n if (inOpts.nextArrow) {\n const nextArrow = parseHTML(inOpts.nextArrow);\n if (nextArrow.childNodes.length > 0) {\n config.nextArrow = nextArrow.childNodes;\n }\n delete inOpts.nextArrow;\n }\n\n //*** misc ***//\n if (inOpts.disableTouchKeyboard !== undefined) {\n config.disableTouchKeyboard = 'ontouchstart' in document && !!inOpts.disableTouchKeyboard;\n delete inOpts.disableTouchKeyboard;\n }\n if (inOpts.orientation) {\n const orientation = inOpts.orientation.toLowerCase().split(/\\s+/g);\n config.orientation = {\n x: orientation.find(x => (x === 'left' || x === 'right')) || 'auto',\n y: orientation.find(y => (y === 'top' || y === 'bottom')) || 'auto',\n };\n delete inOpts.orientation;\n }\n if (inOpts.todayBtnMode !== undefined) {\n switch(inOpts.todayBtnMode) {\n case 0:\n case 1:\n config.todayBtnMode = inOpts.todayBtnMode;\n }\n delete inOpts.todayBtnMode;\n }\n\n //*** copy the rest ***//\n Object.keys(inOpts).forEach((key) => {\n if (inOpts[key] !== undefined && hasProperty(defaultOptions, key)) {\n config[key] = inOpts[key];\n }\n });\n\n return config;\n}\n","import {optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst pickerTemplate = optimizeTemplateHTML(`
      \n
      \n
      \n
      \n
      \n \n \n \n
      \n
      \n
      \n
      \n
      \n \n \n
      \n
      \n
      \n
      `);\n\nexport default pickerTemplate;\n","import {createTagRepeat, optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst daysTemplate = optimizeTemplateHTML(`
      \n
      ${createTagRepeat('span', 7, {class: 'dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      \n
      ${createTagRepeat('span', 42 , {class: 'block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400'})}
      \n
      `);\n\nexport default daysTemplate;\n","import {createTagRepeat, optimizeTemplateHTML} from '../../lib/utils.js';\n\nconst calendarWeeksTemplate = optimizeTemplateHTML(`
      \n
      \n
      ${createTagRepeat('span', 6, {class: 'week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm'})}
      \n
      `);\n\nexport default calendarWeeksTemplate;\n","import {pushUnique} from '../../lib/utils.js';\nimport {parseHTML, replaceChildNodes} from '../../lib/dom.js';\n\n// Base class of the view classes\nexport default class View {\n constructor(picker, config) {\n Object.assign(this, config, {\n picker,\n element: parseHTML(`
      `).firstChild,\n selected: [],\n });\n this.init(this.picker.datepicker.config);\n }\n\n init(options) {\n if (options.pickLevel !== undefined) {\n this.isMinView = this.id === options.pickLevel;\n }\n this.setOptions(options);\n this.updateFocus();\n this.updateSelection();\n }\n\n // Execute beforeShow() callback and apply the result to the element\n // args:\n // - current - current value on the iteration on view rendering\n // - timeValue - time value of the date to pass to beforeShow()\n performBeforeHook(el, current, timeValue) {\n let result = this.beforeShow(new Date(timeValue));\n switch (typeof result) {\n case 'boolean':\n result = {enabled: result};\n break;\n case 'string':\n result = {classes: result};\n }\n\n if (result) {\n if (result.enabled === false) {\n el.classList.add('disabled');\n pushUnique(this.disabled, current);\n }\n if (result.classes) {\n const extraClasses = result.classes.split(/\\s+/);\n el.classList.add(...extraClasses);\n if (extraClasses.includes('disabled')) {\n pushUnique(this.disabled, current);\n }\n }\n if (result.content) {\n replaceChildNodes(el, result.content);\n }\n }\n }\n}\n","import {hasProperty, pushUnique} from '../../lib/utils.js';\nimport {today, dateValue, addDays, addWeeks, dayOfTheWeekOf, getWeek} from '../../lib/date.js';\nimport {formatDate} from '../../lib/date-format.js';\nimport {parseHTML, showElement, hideElement} from '../../lib/dom.js';\nimport daysTemplate from '../templates/daysTemplate.js';\nimport calendarWeeksTemplate from '../templates/calendarWeeksTemplate.js';\nimport View from './View.js';\n\nexport default class DaysView extends View {\n constructor(picker) {\n super(picker, {\n id: 0,\n name: 'days',\n cellClass: 'day',\n });\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n const inner = parseHTML(daysTemplate).firstChild;\n this.dow = inner.firstChild;\n this.grid = inner.lastChild;\n this.element.appendChild(inner);\n }\n super.init(options);\n }\n\n setOptions(options) {\n let updateDOW;\n\n if (hasProperty(options, 'minDate')) {\n this.minDate = options.minDate;\n }\n if (hasProperty(options, 'maxDate')) {\n this.maxDate = options.maxDate;\n }\n if (options.datesDisabled) {\n this.datesDisabled = options.datesDisabled;\n }\n if (options.daysOfWeekDisabled) {\n this.daysOfWeekDisabled = options.daysOfWeekDisabled;\n updateDOW = true;\n }\n if (options.daysOfWeekHighlighted) {\n this.daysOfWeekHighlighted = options.daysOfWeekHighlighted;\n }\n if (options.todayHighlight !== undefined) {\n this.todayHighlight = options.todayHighlight;\n }\n if (options.weekStart !== undefined) {\n this.weekStart = options.weekStart;\n this.weekEnd = options.weekEnd;\n updateDOW = true;\n }\n if (options.locale) {\n const locale = this.locale = options.locale;\n this.dayNames = locale.daysMin;\n this.switchLabelFormat = locale.titleFormat;\n updateDOW = true;\n }\n if (options.beforeShowDay !== undefined) {\n this.beforeShow = typeof options.beforeShowDay === 'function'\n ? options.beforeShowDay\n : undefined;\n }\n\n if (options.calendarWeeks !== undefined) {\n if (options.calendarWeeks && !this.calendarWeeks) {\n const weeksElem = parseHTML(calendarWeeksTemplate).firstChild;\n this.calendarWeeks = {\n element: weeksElem,\n dow: weeksElem.firstChild,\n weeks: weeksElem.lastChild,\n };\n this.element.insertBefore(weeksElem, this.element.firstChild);\n } else if (this.calendarWeeks && !options.calendarWeeks) {\n this.element.removeChild(this.calendarWeeks.element);\n this.calendarWeeks = null;\n }\n }\n if (options.showDaysOfWeek !== undefined) {\n if (options.showDaysOfWeek) {\n showElement(this.dow);\n if (this.calendarWeeks) {\n showElement(this.calendarWeeks.dow);\n }\n } else {\n hideElement(this.dow);\n if (this.calendarWeeks) {\n hideElement(this.calendarWeeks.dow);\n }\n }\n }\n\n // update days-of-week when locale, daysOfweekDisabled or weekStart is changed\n if (updateDOW) {\n Array.from(this.dow.children).forEach((el, index) => {\n const dow = (this.weekStart + index) % 7;\n el.textContent = this.dayNames[dow];\n el.className = this.daysOfWeekDisabled.includes(dow) ? 'dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed' : 'dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400';\n });\n }\n }\n\n // Apply update on the focused date to view's settings\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n const viewYear = viewDate.getFullYear();\n const viewMonth = viewDate.getMonth();\n const firstOfMonth = dateValue(viewYear, viewMonth, 1);\n const start = dayOfTheWeekOf(firstOfMonth, this.weekStart, this.weekStart);\n\n this.first = firstOfMonth;\n this.last = dateValue(viewYear, viewMonth + 1, 0);\n this.start = start;\n this.focused = this.picker.viewDate;\n }\n\n // Apply update on the selected dates to view's settings\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates;\n if (rangepicker) {\n this.range = rangepicker.dates;\n }\n }\n\n // Update the entire view UI\n render() {\n // update today marker on ever render\n this.today = this.todayHighlight ? today() : undefined;\n // refresh disabled dates on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [...this.datesDisabled];\n\n const switchLabel = formatDate(this.focused, this.switchLabelFormat, this.locale);\n this.picker.setViewSwitchLabel(switchLabel);\n this.picker.setPrevBtnDisabled(this.first <= this.minDate);\n this.picker.setNextBtnDisabled(this.last >= this.maxDate);\n\n if (this.calendarWeeks) {\n // start of the UTC week (Monday) of the 1st of the month\n const startOfWeek = dayOfTheWeekOf(this.first, 1, 1);\n Array.from(this.calendarWeeks.weeks.children).forEach((el, index) => {\n el.textContent = getWeek(addWeeks(startOfWeek, index));\n });\n }\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const current = addDays(this.start, index);\n const date = new Date(current);\n const day = date.getDay();\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n el.dataset.date = current;\n el.textContent = date.getDate();\n\n if (current < this.first) {\n classList.add('prev', 'text-gray-500', 'dark:text-white');\n } else if (current > this.last) {\n classList.add('next', 'text-gray-500', 'dark:text-white');\n }\n if (this.today === current) {\n classList.add('today', 'bg-gray-100', 'dark:bg-gray-600');\n }\n if (current < this.minDate || current > this.maxDate || this.disabled.includes(current)) {\n classList.add('disabled', 'cursor-not-allowed');\n }\n if (this.daysOfWeekDisabled.includes(day)) {\n classList.add('disabled', 'cursor-not-allowed');\n pushUnique(this.disabled, current);\n }\n if (this.daysOfWeekHighlighted.includes(day)) {\n classList.add('highlighted');\n }\n if (this.range) {\n const [rangeStart, rangeEnd] = this.range;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range', 'bg-gray-200', 'dark:bg-gray-600');\n classList.remove('rounded-lg', 'rounded-l-lg', 'rounded-r-lg')\n }\n if (current === rangeStart) {\n classList.add('range-start', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-l-lg');\n classList.remove('rounded-lg', 'rounded-r-lg');\n }\n if (current === rangeEnd) {\n classList.add('range-end', 'bg-gray-100', 'dark:bg-gray-600', 'rounded-r-lg');\n classList.remove('rounded-lg', 'rounded-l-lg');\n }\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'text-gray-500', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'dark:bg-gray-600', 'bg-gray-100', 'bg-gray-200');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, current, current);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const [rangeStart, rangeEnd] = this.range || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused');\n el.classList.add('text-gray-900', 'rounded-lg', 'dark:text-white');\n });\n Array.from(this.grid.children).forEach((el) => {\n const current = Number(el.dataset.date);\n const classList = el.classList;\n classList.remove('bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg', 'rounded-r-lg')\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range', 'bg-gray-200', 'dark:bg-gray-600');\n classList.remove('rounded-lg');\n }\n if (current === rangeStart) {\n classList.add('range-start', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-l-lg');\n classList.remove('rounded-lg', 'rounded-r-lg');\n }\n if (current === rangeEnd) {\n classList.add('range-end', 'bg-gray-200', 'dark:bg-gray-600', 'rounded-r-lg');\n classList.remove('rounded-lg', 'rounded-l-lg');\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600', 'bg-gray-100', 'bg-gray-200', 'dark:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n const index = Math.round((this.focused - this.start) / 86400000);\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[index].classList.add('focused');\n }\n}\n","import {hasProperty, pushUnique, createTagRepeat} from '../../lib/utils.js';\nimport {dateValue} from '../../lib/date.js';\nimport {parseHTML} from '../../lib/dom.js';\nimport View from './View.js';\n\nfunction computeMonthRange(range, thisYear) {\n if (!range || !range[0] || !range[1]) {\n return;\n }\n\n const [[startY, startM], [endY, endM]] = range;\n if (startY > thisYear || endY < thisYear) {\n return;\n }\n return [\n startY === thisYear ? startM : -1,\n endY === thisYear ? endM : 12,\n ];\n}\n\nexport default class MonthsView extends View {\n constructor(picker) {\n super(picker, {\n id: 1,\n name: 'months',\n cellClass: 'month',\n });\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n this.grid = this.element;\n this.element.classList.add('months', 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4');\n this.grid.appendChild(parseHTML(createTagRepeat('span', 12, {'data-month': ix => ix})));\n }\n super.init(options);\n }\n\n setOptions(options) {\n if (options.locale) {\n this.monthNames = options.locale.monthsShort;\n }\n if (hasProperty(options, 'minDate')) {\n if (options.minDate === undefined) {\n this.minYear = this.minMonth = this.minDate = undefined;\n } else {\n const minDateObj = new Date(options.minDate);\n this.minYear = minDateObj.getFullYear();\n this.minMonth = minDateObj.getMonth();\n this.minDate = minDateObj.setDate(1);\n }\n }\n if (hasProperty(options, 'maxDate')) {\n if (options.maxDate === undefined) {\n this.maxYear = this.maxMonth = this.maxDate = undefined;\n } else {\n const maxDateObj = new Date(options.maxDate);\n this.maxYear = maxDateObj.getFullYear();\n this.maxMonth = maxDateObj.getMonth();\n this.maxDate = dateValue(this.maxYear, this.maxMonth + 1, 0);\n }\n }\n if (options.beforeShowMonth !== undefined) {\n this.beforeShow = typeof options.beforeShowMonth === 'function'\n ? options.beforeShowMonth\n : undefined;\n }\n }\n\n // Update view's settings to reflect the viewDate set on the picker\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n this.year = viewDate.getFullYear();\n this.focused = viewDate.getMonth();\n }\n\n // Update view's settings to reflect the selected dates\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates.reduce((selected, timeValue) => {\n const date = new Date(timeValue);\n const year = date.getFullYear();\n const month = date.getMonth();\n if (selected[year] === undefined) {\n selected[year] = [month];\n } else {\n pushUnique(selected[year], month);\n }\n return selected;\n }, {});\n if (rangepicker && rangepicker.dates) {\n this.range = rangepicker.dates.map(timeValue => {\n const date = new Date(timeValue);\n return isNaN(date) ? undefined : [date.getFullYear(), date.getMonth()];\n });\n }\n }\n\n // Update the entire view UI\n render() {\n // refresh disabled months on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [];\n\n this.picker.setViewSwitchLabel(this.year);\n this.picker.setPrevBtnDisabled(this.year <= this.minYear);\n this.picker.setNextBtnDisabled(this.year >= this.maxYear);\n\n const selected = this.selected[this.year] || [];\n const yrOutOfRange = this.year < this.minYear || this.year > this.maxYear;\n const isMinYear = this.year === this.minYear;\n const isMaxYear = this.year === this.maxYear;\n const range = computeMonthRange(this.range, this.year);\n\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const date = dateValue(this.year, index, 1);\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n if (this.isMinView) {\n el.dataset.date = date;\n }\n // reset text on every render to clear the custom content set\n // by beforeShow hook at previous render\n el.textContent = this.monthNames[index];\n\n if (\n yrOutOfRange\n || isMinYear && index < this.minMonth\n || isMaxYear && index > this.maxMonth\n ) {\n classList.add('disabled');\n }\n if (range) {\n const [rangeStart, rangeEnd] = range;\n if (index > rangeStart && index < rangeEnd) {\n classList.add('range');\n }\n if (index === rangeStart) {\n classList.add('range-start');\n }\n if (index === rangeEnd) {\n classList.add('range-end');\n }\n }\n if (selected.includes(index)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (index === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, index, date);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const selected = this.selected[this.year] || [];\n const [rangeStart, rangeEnd] = computeMonthRange(this.range, this.year) || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'dark:bg-blue-600', 'dark:text-white', 'text-white', 'focused');\n el.classList.add('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n });\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n if (index > rangeStart && index < rangeEnd) {\n classList.add('range');\n }\n if (index === rangeStart) {\n classList.add('range-start');\n }\n if (index === rangeEnd) {\n classList.add('range-end');\n }\n if (selected.includes(index)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (index === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[this.focused].classList.add('focused');\n }\n}","import {hasProperty, pushUnique, createTagRepeat} from '../../lib/utils.js';\nimport {dateValue, startOfYearPeriod} from '../../lib/date.js';\nimport {parseHTML} from '../../lib/dom.js';\nimport View from './View.js';\n\nfunction toTitleCase(word) {\n return [...word].reduce((str, ch, ix) => str += ix ? ch : ch.toUpperCase(), '');\n}\n\n// Class representing the years and decades view elements\nexport default class YearsView extends View {\n constructor(picker, config) {\n super(picker, config);\n }\n\n init(options, onConstruction = true) {\n if (onConstruction) {\n this.navStep = this.step * 10;\n this.beforeShowOption = `beforeShow${toTitleCase(this.cellClass)}`;\n this.grid = this.element;\n this.element.classList.add(this.name, 'datepicker-grid', 'w-64', 'grid', 'grid-cols-4');\n this.grid.appendChild(parseHTML(createTagRepeat('span', 12)));\n }\n super.init(options);\n }\n\n setOptions(options) {\n if (hasProperty(options, 'minDate')) {\n if (options.minDate === undefined) {\n this.minYear = this.minDate = undefined;\n } else {\n this.minYear = startOfYearPeriod(options.minDate, this.step);\n this.minDate = dateValue(this.minYear, 0, 1);\n }\n }\n if (hasProperty(options, 'maxDate')) {\n if (options.maxDate === undefined) {\n this.maxYear = this.maxDate = undefined;\n } else {\n this.maxYear = startOfYearPeriod(options.maxDate, this.step);\n this.maxDate = dateValue(this.maxYear, 11, 31);\n }\n }\n if (options[this.beforeShowOption] !== undefined) {\n const beforeShow = options[this.beforeShowOption];\n this.beforeShow = typeof beforeShow === 'function' ? beforeShow : undefined;\n }\n }\n\n // Update view's settings to reflect the viewDate set on the picker\n updateFocus() {\n const viewDate = new Date(this.picker.viewDate);\n const first = startOfYearPeriod(viewDate, this.navStep);\n const last = first + 9 * this.step;\n\n this.first = first;\n this.last = last;\n this.start = first - this.step;\n this.focused = startOfYearPeriod(viewDate, this.step);\n }\n\n // Update view's settings to reflect the selected dates\n updateSelection() {\n const {dates, rangepicker} = this.picker.datepicker;\n this.selected = dates.reduce((years, timeValue) => {\n return pushUnique(years, startOfYearPeriod(timeValue, this.step));\n }, []);\n if (rangepicker && rangepicker.dates) {\n this.range = rangepicker.dates.map(timeValue => {\n if (timeValue !== undefined) {\n return startOfYearPeriod(timeValue, this.step);\n }\n });\n }\n }\n\n // Update the entire view UI\n render() {\n // refresh disabled years on every render in order to clear the ones added\n // by beforeShow hook at previous render\n this.disabled = [];\n\n this.picker.setViewSwitchLabel(`${this.first}-${this.last}`);\n this.picker.setPrevBtnDisabled(this.first <= this.minYear);\n this.picker.setNextBtnDisabled(this.last >= this.maxYear);\n\n Array.from(this.grid.children).forEach((el, index) => {\n const classList = el.classList;\n const current = this.start + (index * this.step);\n const date = dateValue(current, 0, 1);\n\n el.className = `datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`;\n if (this.isMinView) {\n el.dataset.date = date;\n }\n el.textContent = el.dataset.year = current;\n\n if (index === 0) {\n classList.add('prev');\n } else if (index === 11) {\n classList.add('next');\n }\n if (current < this.minYear || current > this.maxYear) {\n classList.add('disabled');\n }\n if (this.range) {\n const [rangeStart, rangeEnd] = this.range;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range');\n }\n if (current === rangeStart) {\n classList.add('range-start');\n }\n if (current === rangeEnd) {\n classList.add('range-end');\n }\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n\n if (this.beforeShow) {\n this.performBeforeHook(el, current, date);\n }\n });\n }\n\n // Update the view UI by applying the changes of selected and focused items\n refresh() {\n const [rangeStart, rangeEnd] = this.range || [];\n this.grid\n .querySelectorAll('.range, .range-start, .range-end, .selected, .focused')\n .forEach((el) => {\n el.classList.remove('range', 'range-start', 'range-end', 'selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white', 'focused');\n });\n Array.from(this.grid.children).forEach((el) => {\n const current = Number(el.textContent);\n const classList = el.classList;\n if (current > rangeStart && current < rangeEnd) {\n classList.add('range');\n }\n if (current === rangeStart) {\n classList.add('range-start');\n }\n if (current === rangeEnd) {\n classList.add('range-end');\n }\n if (this.selected.includes(current)) {\n classList.add('selected', 'bg-blue-700', 'text-white', 'dark:bg-blue-600', 'dark:text-white');\n classList.remove('text-gray-900', 'hover:bg-gray-100', 'dark:text-white', 'dark:hover:bg-gray-600');\n }\n if (current === this.focused) {\n classList.add('focused');\n }\n });\n }\n\n // Update the view UI by applying the change of focused item\n refreshFocus() {\n const index = Math.round((this.focused - this.start) / this.step);\n this.grid.querySelectorAll('.focused').forEach((el) => {\n el.classList.remove('focused');\n });\n this.grid.children[index].classList.add('focused');\n }\n}\n","import {limitToRange} from '../lib/utils.js';\nimport {addMonths, addYears} from '../lib/date.js';\n\nexport function triggerDatepickerEvent(datepicker, type) {\n const detail = {\n date: datepicker.getDate(),\n viewDate: new Date(datepicker.picker.viewDate),\n viewId: datepicker.picker.currentView.id,\n datepicker,\n };\n datepicker.element.dispatchEvent(new CustomEvent(type, {detail}));\n}\n\n// direction: -1 (to previous), 1 (to next)\nexport function goToPrevOrNext(datepicker, direction) {\n const {minDate, maxDate} = datepicker.config;\n const {currentView, viewDate} = datepicker.picker;\n let newViewDate;\n switch (currentView.id) {\n case 0:\n newViewDate = addMonths(viewDate, direction);\n break;\n case 1:\n newViewDate = addYears(viewDate, direction);\n break;\n default:\n newViewDate = addYears(viewDate, direction * currentView.navStep);\n }\n newViewDate = limitToRange(newViewDate, minDate, maxDate);\n datepicker.picker.changeFocus(newViewDate).render();\n}\n\nexport function switchView(datepicker) {\n const viewId = datepicker.picker.currentView.id;\n if (viewId === datepicker.config.maxView) {\n return;\n }\n datepicker.picker.changeView(viewId + 1).render();\n}\n\nexport function unfocus(datepicker) {\n if (datepicker.config.updateOnBlur) {\n datepicker.update({autohide: true});\n } else {\n datepicker.refresh('input');\n datepicker.hide();\n }\n}\n","import {today, addMonths, addYears} from '../lib/date.js';\nimport {findElementInEventPath} from '../lib/event.js';\nimport {goToPrevOrNext, switchView} from './functions.js';\n\nfunction goToSelectedMonthOrYear(datepicker, selection) {\n const picker = datepicker.picker;\n const viewDate = new Date(picker.viewDate);\n const viewId = picker.currentView.id;\n const newDate = viewId === 1\n ? addMonths(viewDate, selection - viewDate.getMonth())\n : addYears(viewDate, selection - viewDate.getFullYear());\n\n picker.changeFocus(newDate).changeView(viewId - 1).render();\n}\n\nexport function onClickTodayBtn(datepicker) {\n const picker = datepicker.picker;\n const currentDate = today();\n if (datepicker.config.todayBtnMode === 1) {\n if (datepicker.config.autohide) {\n datepicker.setDate(currentDate);\n return;\n }\n datepicker.setDate(currentDate, {render: false});\n picker.update();\n }\n if (picker.viewDate !== currentDate) {\n picker.changeFocus(currentDate);\n }\n picker.changeView(0).render();\n}\n\nexport function onClickClearBtn(datepicker) {\n datepicker.setDate({clear: true});\n}\n\nexport function onClickViewSwitch(datepicker) {\n switchView(datepicker);\n}\n\nexport function onClickPrevBtn(datepicker) {\n goToPrevOrNext(datepicker, -1);\n}\n\nexport function onClickNextBtn(datepicker) {\n goToPrevOrNext(datepicker, 1);\n}\n\n// For the picker's main block to delegete the events from `datepicker-cell`s\nexport function onClickView(datepicker, ev) {\n const target = findElementInEventPath(ev, '.datepicker-cell');\n if (!target || target.classList.contains('disabled')) {\n return;\n }\n\n const {id, isMinView} = datepicker.picker.currentView;\n if (isMinView) {\n datepicker.setDate(Number(target.dataset.date));\n } else if (id === 1) {\n goToSelectedMonthOrYear(datepicker, Number(target.dataset.month));\n } else {\n goToSelectedMonthOrYear(datepicker, Number(target.dataset.year));\n }\n}\n\nexport function onClickPicker(datepicker) {\n if (!datepicker.inline && !datepicker.config.disableTouchKeyboard) {\n datepicker.inputField.focus();\n }\n}\n","import {hasProperty, lastItemOf, isInRange, limitToRange} from '../lib/utils.js';\nimport {today} from '../lib/date.js';\nimport {parseHTML, showElement, hideElement, emptyChildNodes} from '../lib/dom.js';\nimport {registerListeners} from '../lib/event.js';\nimport pickerTemplate from './templates/pickerTemplate.js';\nimport DaysView from './views/DaysView.js';\nimport MonthsView from './views/MonthsView.js';\nimport YearsView from './views/YearsView.js';\nimport {triggerDatepickerEvent} from '../events/functions.js';\nimport {\n onClickTodayBtn,\n onClickClearBtn,\n onClickViewSwitch,\n onClickPrevBtn,\n onClickNextBtn,\n onClickView,\n onClickPicker,\n} from '../events/pickerListeners.js';\n\nfunction processPickerOptions(picker, options) {\n if (options.title !== undefined) {\n if (options.title) {\n picker.controls.title.textContent = options.title;\n showElement(picker.controls.title);\n } else {\n picker.controls.title.textContent = '';\n hideElement(picker.controls.title);\n }\n }\n if (options.prevArrow) {\n const prevBtn = picker.controls.prevBtn;\n emptyChildNodes(prevBtn);\n options.prevArrow.forEach((node) => {\n prevBtn.appendChild(node.cloneNode(true));\n });\n }\n if (options.nextArrow) {\n const nextBtn = picker.controls.nextBtn;\n emptyChildNodes(nextBtn);\n options.nextArrow.forEach((node) => {\n nextBtn.appendChild(node.cloneNode(true));\n });\n }\n if (options.locale) {\n picker.controls.todayBtn.textContent = options.locale.today;\n picker.controls.clearBtn.textContent = options.locale.clear;\n }\n if (options.todayBtn !== undefined) {\n if (options.todayBtn) {\n showElement(picker.controls.todayBtn);\n } else {\n hideElement(picker.controls.todayBtn);\n }\n }\n if (hasProperty(options, 'minDate') || hasProperty(options, 'maxDate')) {\n const {minDate, maxDate} = picker.datepicker.config;\n picker.controls.todayBtn.disabled = !isInRange(today(), minDate, maxDate);\n }\n if (options.clearBtn !== undefined) {\n if (options.clearBtn) {\n showElement(picker.controls.clearBtn);\n } else {\n hideElement(picker.controls.clearBtn);\n }\n }\n}\n\n// Compute view date to reset, which will be...\n// - the last item of the selected dates or defaultViewDate if no selection\n// - limitted to minDate or maxDate if it exceeds the range\nfunction computeResetViewDate(datepicker) {\n const {dates, config} = datepicker;\n const viewDate = dates.length > 0 ? lastItemOf(dates) : config.defaultViewDate;\n return limitToRange(viewDate, config.minDate, config.maxDate);\n}\n\n// Change current view's view date\nfunction setViewDate(picker, newDate) {\n const oldViewDate = new Date(picker.viewDate);\n const newViewDate = new Date(newDate);\n const {id, year, first, last} = picker.currentView;\n const viewYear = newViewDate.getFullYear();\n\n picker.viewDate = newDate;\n if (viewYear !== oldViewDate.getFullYear()) {\n triggerDatepickerEvent(picker.datepicker, 'changeYear');\n }\n if (newViewDate.getMonth() !== oldViewDate.getMonth()) {\n triggerDatepickerEvent(picker.datepicker, 'changeMonth');\n }\n\n // return whether the new date is in different period on time from the one\n // displayed in the current view\n // when true, the view needs to be re-rendered on the next UI refresh.\n switch (id) {\n case 0:\n return newDate < first || newDate > last;\n case 1:\n return viewYear !== year;\n default:\n return viewYear < first || viewYear > last;\n }\n}\n\nfunction getTextDirection(el) {\n return window.getComputedStyle(el).direction;\n}\n\n// Class representing the picker UI\nexport default class Picker {\n constructor(datepicker) {\n this.datepicker = datepicker;\n\n const template = pickerTemplate.replace(/%buttonClass%/g, datepicker.config.buttonClass);\n const element = this.element = parseHTML(template).firstChild;\n const [header, main, footer] = element.firstChild.children;\n const title = header.firstElementChild;\n const [prevBtn, viewSwitch, nextBtn] = header.lastElementChild.children;\n const [todayBtn, clearBtn] = footer.firstChild.children;\n const controls = {\n title,\n prevBtn,\n viewSwitch,\n nextBtn,\n todayBtn,\n clearBtn,\n };\n this.main = main;\n this.controls = controls;\n\n const elementClass = datepicker.inline ? 'inline' : 'dropdown';\n element.classList.add(`datepicker-${elementClass}`);\n elementClass === 'dropdown' ? element.classList.add('dropdown', 'absolute', 'top-0', 'left-0', 'z-50', 'pt-2') : null;\n\n processPickerOptions(this, datepicker.config);\n this.viewDate = computeResetViewDate(datepicker);\n\n // set up event listeners\n registerListeners(datepicker, [\n [element, 'click', onClickPicker.bind(null, datepicker), {capture: true}],\n [main, 'click', onClickView.bind(null, datepicker)],\n [controls.viewSwitch, 'click', onClickViewSwitch.bind(null, datepicker)],\n [controls.prevBtn, 'click', onClickPrevBtn.bind(null, datepicker)],\n [controls.nextBtn, 'click', onClickNextBtn.bind(null, datepicker)],\n [controls.todayBtn, 'click', onClickTodayBtn.bind(null, datepicker)],\n [controls.clearBtn, 'click', onClickClearBtn.bind(null, datepicker)],\n ]);\n\n // set up views\n this.views = [\n new DaysView(this),\n new MonthsView(this),\n new YearsView(this, {id: 2, name: 'years', cellClass: 'year', step: 1}),\n new YearsView(this, {id: 3, name: 'decades', cellClass: 'decade', step: 10}),\n ];\n this.currentView = this.views[datepicker.config.startView];\n\n this.currentView.render();\n this.main.appendChild(this.currentView.element);\n datepicker.config.container.appendChild(this.element);\n }\n\n setOptions(options) {\n processPickerOptions(this, options);\n this.views.forEach((view) => {\n view.init(options, false);\n });\n this.currentView.render();\n }\n\n detach() {\n this.datepicker.config.container.removeChild(this.element);\n }\n\n show() {\n if (this.active) {\n return;\n }\n this.element.classList.add('active', 'block');\n this.element.classList.remove('hidden');\n this.active = true;\n\n const datepicker = this.datepicker;\n if (!datepicker.inline) {\n // ensure picker's direction matches input's\n const inputDirection = getTextDirection(datepicker.inputField);\n if (inputDirection !== getTextDirection(datepicker.config.container)) {\n this.element.dir = inputDirection;\n } else if (this.element.dir) {\n this.element.removeAttribute('dir');\n }\n\n this.place();\n if (datepicker.config.disableTouchKeyboard) {\n datepicker.inputField.blur();\n }\n }\n triggerDatepickerEvent(datepicker, 'show');\n }\n\n hide() {\n if (!this.active) {\n return;\n }\n this.datepicker.exitEditMode();\n this.element.classList.remove('active', 'block');\n this.element.classList.add('active', 'block', 'hidden');\n this.active = false;\n triggerDatepickerEvent(this.datepicker, 'hide');\n }\n\n place() {\n const {classList, style} = this.element;\n const {config, inputField} = this.datepicker;\n const container = config.container;\n const {\n width: calendarWidth,\n height: calendarHeight,\n } = this.element.getBoundingClientRect();\n const {\n left: containerLeft,\n top: containerTop,\n width: containerWidth,\n } = container.getBoundingClientRect();\n const {\n left: inputLeft,\n top: inputTop,\n width: inputWidth,\n height: inputHeight\n } = inputField.getBoundingClientRect();\n let {x: orientX, y: orientY} = config.orientation;\n let scrollTop;\n let left;\n let top;\n\n if (container === document.body) {\n scrollTop = window.scrollY;\n left = inputLeft + window.scrollX;\n top = inputTop + scrollTop;\n } else {\n scrollTop = container.scrollTop;\n left = inputLeft - containerLeft;\n top = inputTop - containerTop + scrollTop;\n }\n\n if (orientX === 'auto') {\n if (left < 0) {\n // align to the left and move into visible area if input's left edge < window's\n orientX = 'left';\n left = 10;\n } else if (left + calendarWidth > containerWidth) {\n // align to the right if canlendar's right edge > container's\n orientX = 'right';\n } else {\n orientX = getTextDirection(inputField) === 'rtl' ? 'right' : 'left';\n }\n }\n if (orientX === 'right') {\n left -= calendarWidth - inputWidth;\n }\n\n if (orientY === 'auto') {\n orientY = top - calendarHeight < scrollTop ? 'bottom' : 'top';\n }\n if (orientY === 'top') {\n top -= calendarHeight;\n } else {\n top += inputHeight;\n }\n\n classList.remove(\n 'datepicker-orient-top',\n 'datepicker-orient-bottom',\n 'datepicker-orient-right',\n 'datepicker-orient-left'\n );\n classList.add(`datepicker-orient-${orientY}`, `datepicker-orient-${orientX}`);\n\n style.top = top ? `${top}px` : top;\n style.left = left ? `${left}px` : left;\n }\n\n setViewSwitchLabel(labelText) {\n this.controls.viewSwitch.textContent = labelText;\n }\n\n setPrevBtnDisabled(disabled) {\n this.controls.prevBtn.disabled = disabled;\n }\n\n setNextBtnDisabled(disabled) {\n this.controls.nextBtn.disabled = disabled;\n }\n\n changeView(viewId) {\n const oldView = this.currentView;\n const newView = this.views[viewId];\n if (newView.id !== oldView.id) {\n this.currentView = newView;\n this._renderMethod = 'render';\n triggerDatepickerEvent(this.datepicker, 'changeView');\n this.main.replaceChild(newView.element, oldView.element);\n }\n return this;\n }\n\n // Change the focused date (view date)\n changeFocus(newViewDate) {\n this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refreshFocus';\n this.views.forEach((view) => {\n view.updateFocus();\n });\n return this;\n }\n\n // Apply the change of the selected dates\n update() {\n const newViewDate = computeResetViewDate(this.datepicker);\n this._renderMethod = setViewDate(this, newViewDate) ? 'render' : 'refresh';\n this.views.forEach((view) => {\n view.updateFocus();\n view.updateSelection();\n });\n return this;\n }\n\n // Refresh the picker UI\n render(quickRender = true) {\n const renderMethod = (quickRender && this._renderMethod) || 'render';\n delete this._renderMethod;\n\n this.currentView[renderMethod]();\n }\n}\n","import {isInRange} from '../lib/utils.js';\nimport {addDays, addMonths, addYears, startOfYearPeriod} from '../lib/date.js';\nimport {goToPrevOrNext, switchView, unfocus} from './functions.js';\n\n// Find the closest date that doesn't meet the condition for unavailable date\n// Returns undefined if no available date is found\n// addFn: function to calculate the next date\n// - args: time value, amount\n// increase: amount to pass to addFn\n// testFn: function to test the unavailablity of the date\n// - args: time value; retun: true if unavailable\nfunction findNextAvailableOne(date, addFn, increase, testFn, min, max) {\n if (!isInRange(date, min, max)) {\n return;\n }\n if (testFn(date)) {\n const newDate = addFn(date, increase);\n return findNextAvailableOne(newDate, addFn, increase, testFn, min, max);\n }\n return date;\n}\n\n// direction: -1 (left/up), 1 (right/down)\n// vertical: true for up/down, false for left/right\nfunction moveByArrowKey(datepicker, ev, direction, vertical) {\n const picker = datepicker.picker;\n const currentView = picker.currentView;\n const step = currentView.step || 1;\n let viewDate = picker.viewDate;\n let addFn;\n let testFn;\n switch (currentView.id) {\n case 0:\n if (vertical) {\n viewDate = addDays(viewDate, direction * 7);\n } else if (ev.ctrlKey || ev.metaKey) {\n viewDate = addYears(viewDate, direction);\n } else {\n viewDate = addDays(viewDate, direction);\n }\n addFn = addDays;\n testFn = (date) => currentView.disabled.includes(date);\n break;\n case 1:\n viewDate = addMonths(viewDate, vertical ? direction * 4 : direction);\n addFn = addMonths;\n testFn = (date) => {\n const dt = new Date(date);\n const {year, disabled} = currentView;\n return dt.getFullYear() === year && disabled.includes(dt.getMonth());\n };\n break;\n default:\n viewDate = addYears(viewDate, direction * (vertical ? 4 : 1) * step);\n addFn = addYears;\n testFn = date => currentView.disabled.includes(startOfYearPeriod(date, step));\n }\n viewDate = findNextAvailableOne(\n viewDate,\n addFn,\n direction < 0 ? -step : step,\n testFn,\n currentView.minDate,\n currentView.maxDate\n );\n if (viewDate !== undefined) {\n picker.changeFocus(viewDate).render();\n }\n}\n\nexport function onKeydown(datepicker, ev) {\n if (ev.key === 'Tab') {\n unfocus(datepicker);\n return;\n }\n\n const picker = datepicker.picker;\n const {id, isMinView} = picker.currentView;\n if (!picker.active) {\n switch (ev.key) {\n case 'ArrowDown':\n case 'Escape':\n picker.show();\n break;\n case 'Enter':\n datepicker.update();\n break;\n default:\n return;\n }\n } else if (datepicker.editMode) {\n switch (ev.key) {\n case 'Escape':\n picker.hide();\n break;\n case 'Enter':\n datepicker.exitEditMode({update: true, autohide: datepicker.config.autohide});\n break;\n default:\n return;\n }\n } else {\n switch (ev.key) {\n case 'Escape':\n picker.hide();\n break;\n case 'ArrowLeft':\n if (ev.ctrlKey || ev.metaKey) {\n goToPrevOrNext(datepicker, -1);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, -1, false);\n }\n break;\n case 'ArrowRight':\n if (ev.ctrlKey || ev.metaKey) {\n goToPrevOrNext(datepicker, 1);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, 1, false);\n }\n break;\n case 'ArrowUp':\n if (ev.ctrlKey || ev.metaKey) {\n switchView(datepicker);\n } else if (ev.shiftKey) {\n datepicker.enterEditMode();\n return;\n } else {\n moveByArrowKey(datepicker, ev, -1, true);\n }\n break;\n case 'ArrowDown':\n if (ev.shiftKey && !ev.ctrlKey && !ev.metaKey) {\n datepicker.enterEditMode();\n return;\n }\n moveByArrowKey(datepicker, ev, 1, true);\n break;\n case 'Enter':\n if (isMinView) {\n datepicker.setDate(picker.viewDate);\n } else {\n picker.changeView(id - 1).render();\n }\n break;\n case 'Backspace':\n case 'Delete':\n datepicker.enterEditMode();\n return;\n default:\n if (ev.key.length === 1 && !ev.ctrlKey && !ev.metaKey) {\n datepicker.enterEditMode();\n }\n return;\n }\n }\n ev.preventDefault();\n ev.stopPropagation();\n}\n\nexport function onFocus(datepicker) {\n if (datepicker.config.showOnFocus && !datepicker._showing) {\n datepicker.show();\n }\n}\n\n// for the prevention for entering edit mode while getting focus on click\nexport function onMousedown(datepicker, ev) {\n const el = ev.target;\n if (datepicker.picker.active || datepicker.config.showOnClick) {\n el._active = el === document.activeElement;\n el._clicking = setTimeout(() => {\n delete el._active;\n delete el._clicking;\n }, 2000);\n }\n}\n\nexport function onClickInput(datepicker, ev) {\n const el = ev.target;\n if (!el._clicking) {\n return;\n }\n clearTimeout(el._clicking);\n delete el._clicking;\n\n if (el._active) {\n datepicker.enterEditMode();\n }\n delete el._active;\n\n if (datepicker.config.showOnClick) {\n datepicker.show();\n }\n}\n\nexport function onPaste(datepicker, ev) {\n if (ev.clipboardData.types.includes('text/plain')) {\n datepicker.enterEditMode();\n }\n}\n","import {findElementInEventPath} from '../lib/event.js';\nimport {unfocus} from './functions.js';\n\n// for the `document` to delegate the events from outside the picker/input field\nexport function onClickOutside(datepicker, ev) {\n const element = datepicker.element;\n if (element !== document.activeElement) {\n return;\n }\n const pickerElem = datepicker.picker.element;\n if (findElementInEventPath(ev, el => el === element || el === pickerElem)) {\n return;\n }\n unfocus(datepicker);\n}\n","import {lastItemOf, stringToArray, isInRange} from './lib/utils.js';\nimport {today} from './lib/date.js';\nimport {parseDate, formatDate} from './lib/date-format.js';\nimport {registerListeners, unregisterListeners} from './lib/event.js';\nimport {locales} from './i18n/base-locales.js';\nimport defaultOptions from './options/defaultOptions.js';\nimport processOptions from './options/processOptions.js';\nimport Picker from './picker/Picker.js';\nimport {triggerDatepickerEvent} from './events/functions.js';\nimport {onKeydown, onFocus, onMousedown, onClickInput, onPaste} from './events/inputFieldListeners.js';\nimport {onClickOutside} from './events/otherListeners.js';\n\nfunction stringifyDates(dates, config) {\n return dates\n .map(dt => formatDate(dt, config.format, config.locale))\n .join(config.dateDelimiter);\n}\n\n// parse input dates and create an array of time values for selection\n// returns undefined if there are no valid dates in inputDates\n// when origDates (current selection) is passed, the function works to mix\n// the input dates into the current selection\nfunction processInputDates(datepicker, inputDates, clear = false) {\n const {config, dates: origDates, rangepicker} = datepicker;\n if (inputDates.length === 0) {\n // empty input is considered valid unless origiDates is passed\n return clear ? [] : undefined;\n }\n\n const rangeEnd = rangepicker && datepicker === rangepicker.datepickers[1];\n let newDates = inputDates.reduce((dates, dt) => {\n let date = parseDate(dt, config.format, config.locale);\n if (date === undefined) {\n return dates;\n }\n if (config.pickLevel > 0) {\n // adjust to 1st of the month/Jan 1st of the year\n // or to the last day of the monh/Dec 31st of the year if the datepicker\n // is the range-end picker of a rangepicker\n const dt = new Date(date);\n if (config.pickLevel === 1) {\n date = rangeEnd\n ? dt.setMonth(dt.getMonth() + 1, 0)\n : dt.setDate(1);\n } else {\n date = rangeEnd\n ? dt.setFullYear(dt.getFullYear() + 1, 0, 0)\n : dt.setMonth(0, 1);\n }\n }\n if (\n isInRange(date, config.minDate, config.maxDate)\n && !dates.includes(date)\n && !config.datesDisabled.includes(date)\n && !config.daysOfWeekDisabled.includes(new Date(date).getDay())\n ) {\n dates.push(date);\n }\n return dates;\n }, []);\n if (newDates.length === 0) {\n return;\n }\n if (config.multidate && !clear) {\n // get the synmetric difference between origDates and newDates\n newDates = newDates.reduce((dates, date) => {\n if (!origDates.includes(date)) {\n dates.push(date);\n }\n return dates;\n }, origDates.filter(date => !newDates.includes(date)));\n }\n // do length check always because user can input multiple dates regardless of the mode\n return config.maxNumberOfDates && newDates.length > config.maxNumberOfDates\n ? newDates.slice(config.maxNumberOfDates * -1)\n : newDates;\n}\n\n// refresh the UI elements\n// modes: 1: input only, 2, picker only, 3 both\nfunction refreshUI(datepicker, mode = 3, quickRender = true) {\n const {config, picker, inputField} = datepicker;\n if (mode & 2) {\n const newView = picker.active ? config.pickLevel : config.startView;\n picker.update().changeView(newView).render(quickRender);\n }\n if (mode & 1 && inputField) {\n inputField.value = stringifyDates(datepicker.dates, config);\n }\n}\n\nfunction setDate(datepicker, inputDates, options) {\n let {clear, render, autohide} = options;\n if (render === undefined) {\n render = true;\n }\n if (!render) {\n autohide = false;\n } else if (autohide === undefined) {\n autohide = datepicker.config.autohide;\n }\n\n const newDates = processInputDates(datepicker, inputDates, clear);\n if (!newDates) {\n return;\n }\n if (newDates.toString() !== datepicker.dates.toString()) {\n datepicker.dates = newDates;\n refreshUI(datepicker, render ? 3 : 1);\n triggerDatepickerEvent(datepicker, 'changeDate');\n } else {\n refreshUI(datepicker, 1);\n }\n if (autohide) {\n datepicker.hide();\n }\n}\n\n/**\n * Class representing a date picker\n */\nexport default class Datepicker {\n /**\n * Create a date picker\n * @param {Element} element - element to bind a date picker\n * @param {Object} [options] - config options\n * @param {DateRangePicker} [rangepicker] - DateRangePicker instance the\n * date picker belongs to. Use this only when creating date picker as a part\n * of date range picker\n */\n constructor(element, options = {}, rangepicker = undefined) {\n element.datepicker = this;\n this.element = element;\n\n // set up config\n const config = this.config = Object.assign({\n buttonClass: (options.buttonClass && String(options.buttonClass)) || 'button',\n container: document.body,\n defaultViewDate: today(),\n maxDate: undefined,\n minDate: undefined,\n }, processOptions(defaultOptions, this));\n this._options = options;\n Object.assign(config, processOptions(options, this));\n\n // configure by type\n const inline = this.inline = element.tagName !== 'INPUT';\n let inputField;\n let initialDates;\n\n if (inline) {\n config.container = element;\n initialDates = stringToArray(element.dataset.date, config.dateDelimiter);\n delete element.dataset.date;\n } else {\n const container = options.container ? document.querySelector(options.container) : null;\n if (container) {\n config.container = container;\n }\n inputField = this.inputField = element;\n inputField.classList.add('datepicker-input');\n initialDates = stringToArray(inputField.value, config.dateDelimiter);\n }\n if (rangepicker) {\n // check validiry\n const index = rangepicker.inputs.indexOf(inputField);\n const datepickers = rangepicker.datepickers;\n if (index < 0 || index > 1 || !Array.isArray(datepickers)) {\n throw Error('Invalid rangepicker object.');\n }\n // attach itaelf to the rangepicker here so that processInputDates() can\n // determine if this is the range-end picker of the rangepicker while\n // setting inital values when pickLevel > 0\n datepickers[index] = this;\n // add getter for rangepicker\n Object.defineProperty(this, 'rangepicker', {\n get() {\n return rangepicker;\n },\n });\n }\n\n // set initial dates\n this.dates = [];\n // process initial value\n const inputDateValues = processInputDates(this, initialDates);\n if (inputDateValues && inputDateValues.length > 0) {\n this.dates = inputDateValues;\n }\n if (inputField) {\n inputField.value = stringifyDates(this.dates, config);\n }\n\n const picker = this.picker = new Picker(this);\n\n if (inline) {\n this.show();\n } else {\n // set up event listeners in other modes\n const onMousedownDocument = onClickOutside.bind(null, this);\n const listeners = [\n [inputField, 'keydown', onKeydown.bind(null, this)],\n [inputField, 'focus', onFocus.bind(null, this)],\n [inputField, 'mousedown', onMousedown.bind(null, this)],\n [inputField, 'click', onClickInput.bind(null, this)],\n [inputField, 'paste', onPaste.bind(null, this)],\n [document, 'mousedown', onMousedownDocument],\n [document, 'touchstart', onMousedownDocument],\n [window, 'resize', picker.place.bind(picker)]\n ];\n registerListeners(this, listeners);\n }\n }\n\n /**\n * Format Date object or time value in given format and language\n * @param {Date|Number} date - date or time value to format\n * @param {String|Object} format - format string or object that contains\n * toDisplay() custom formatter, whose signature is\n * - args:\n * - date: {Date} - Date instance of the date passed to the method\n * - format: {Object} - the format object passed to the method\n * - locale: {Object} - locale for the language specified by `lang`\n * - return:\n * {String} formatted date\n * @param {String} [lang=en] - language code for the locale to use\n * @return {String} formatted date\n */\n static formatDate(date, format, lang) {\n return formatDate(date, format, lang && locales[lang] || locales.en);\n }\n\n /**\n * Parse date string\n * @param {String|Date|Number} dateStr - date string, Date object or time\n * value to parse\n * @param {String|Object} format - format string or object that contains\n * toValue() custom parser, whose signature is\n * - args:\n * - dateStr: {String|Date|Number} - the dateStr passed to the method\n * - format: {Object} - the format object passed to the method\n * - locale: {Object} - locale for the language specified by `lang`\n * - return:\n * {Date|Number} parsed date or its time value\n * @param {String} [lang=en] - language code for the locale to use\n * @return {Number} time value of parsed date\n */\n static parseDate(dateStr, format, lang) {\n return parseDate(dateStr, format, lang && locales[lang] || locales.en);\n }\n\n /**\n * @type {Object} - Installed locales in `[languageCode]: localeObject` format\n * en`:_English (US)_ is pre-installed.\n */\n static get locales() {\n return locales;\n }\n\n /**\n * @type {Boolean} - Whether the picker element is shown. `true` whne shown\n */\n get active() {\n return !!(this.picker && this.picker.active);\n }\n\n /**\n * @type {HTMLDivElement} - DOM object of picker element\n */\n get pickerElement() {\n return this.picker ? this.picker.element : undefined;\n }\n\n /**\n * Set new values to the config options\n * @param {Object} options - config options to update\n */\n setOptions(options) {\n const picker = this.picker;\n const newOptions = processOptions(options, this);\n Object.assign(this._options, options);\n Object.assign(this.config, newOptions);\n picker.setOptions(newOptions);\n\n refreshUI(this, 3);\n }\n\n /**\n * Show the picker element\n */\n show() {\n if (this.inputField) {\n if (this.inputField.disabled) {\n return;\n }\n if (this.inputField !== document.activeElement) {\n this._showing = true;\n this.inputField.focus();\n delete this._showing;\n }\n }\n this.picker.show();\n }\n\n /**\n * Hide the picker element\n * Not available on inline picker\n */\n hide() {\n if (this.inline) {\n return;\n }\n this.picker.hide();\n this.picker.update().changeView(this.config.startView).render();\n }\n\n /**\n * Destroy the Datepicker instance\n * @return {Detepicker} - the instance destroyed\n */\n destroy() {\n this.hide();\n unregisterListeners(this);\n this.picker.detach();\n if (!this.inline) {\n this.inputField.classList.remove('datepicker-input');\n }\n delete this.element.datepicker;\n return this;\n }\n\n /**\n * Get the selected date(s)\n *\n * The method returns a Date object of selected date by default, and returns\n * an array of selected dates in multidate mode. If format string is passed,\n * it returns date string(s) formatted in given format.\n *\n * @param {String} [format] - Format string to stringify the date(s)\n * @return {Date|String|Date[]|String[]} - selected date(s), or if none is\n * selected, empty array in multidate mode and untitled in sigledate mode\n */\n getDate(format = undefined) {\n const callback = format\n ? date => formatDate(date, format, this.config.locale)\n : date => new Date(date);\n\n if (this.config.multidate) {\n return this.dates.map(callback);\n }\n if (this.dates.length > 0) {\n return callback(this.dates[0]);\n }\n }\n\n /**\n * Set selected date(s)\n *\n * In multidate mode, you can pass multiple dates as a series of arguments\n * or an array. (Since each date is parsed individually, the type of the\n * dates doesn't have to be the same.)\n * The given dates are used to toggle the select status of each date. The\n * number of selected dates is kept from exceeding the length set to\n * maxNumberOfDates.\n *\n * With clear: true option, the method can be used to clear the selection\n * and to replace the selection instead of toggling in multidate mode.\n * If the option is passed with no date arguments or an empty dates array,\n * it works as \"clear\" (clear the selection then set nothing), and if the\n * option is passed with new dates to select, it works as \"replace\" (clear\n * the selection then set the given dates)\n *\n * When render: false option is used, the method omits re-rendering the\n * picker element. In this case, you need to call refresh() method later in\n * order for the picker element to reflect the changes. The input field is\n * refreshed always regardless of this option.\n *\n * When invalid (unparsable, repeated, disabled or out-of-range) dates are\n * passed, the method ignores them and applies only valid ones. In the case\n * that all the given dates are invalid, which is distinguished from passing\n * no dates, the method considers it as an error and leaves the selection\n * untouched.\n *\n * @param {...(Date|Number|String)|Array} [dates] - Date strings, Date\n * objects, time values or mix of those for new selection\n * @param {Object} [options] - function options\n * - clear: {boolean} - Whether to clear the existing selection\n * defualt: false\n * - render: {boolean} - Whether to re-render the picker element\n * default: true\n * - autohide: {boolean} - Whether to hide the picker element after re-render\n * Ignored when used with render: false\n * default: config.autohide\n */\n setDate(...args) {\n const dates = [...args];\n const opts = {};\n const lastArg = lastItemOf(args);\n if (\n typeof lastArg === 'object'\n && !Array.isArray(lastArg)\n && !(lastArg instanceof Date)\n && lastArg\n ) {\n Object.assign(opts, dates.pop());\n }\n\n const inputDates = Array.isArray(dates[0]) ? dates[0] : dates;\n setDate(this, inputDates, opts);\n }\n\n /**\n * Update the selected date(s) with input field's value\n * Not available on inline picker\n *\n * The input field will be refreshed with properly formatted date string.\n *\n * @param {Object} [options] - function options\n * - autohide: {boolean} - whether to hide the picker element after refresh\n * default: false\n */\n update(options = undefined) {\n if (this.inline) {\n return;\n }\n\n const opts = {clear: true, autohide: !!(options && options.autohide)};\n const inputDates = stringToArray(this.inputField.value, this.config.dateDelimiter);\n setDate(this, inputDates, opts);\n }\n\n /**\n * Refresh the picker element and the associated input field\n * @param {String} [target] - target item when refreshing one item only\n * 'picker' or 'input'\n * @param {Boolean} [forceRender] - whether to re-render the picker element\n * regardless of its state instead of optimized refresh\n */\n refresh(target = undefined, forceRender = false) {\n if (target && typeof target !== 'string') {\n forceRender = target;\n target = undefined;\n }\n\n let mode;\n if (target === 'picker') {\n mode = 2;\n } else if (target === 'input') {\n mode = 1;\n } else {\n mode = 3;\n }\n refreshUI(this, mode, !forceRender);\n }\n\n /**\n * Enter edit mode\n * Not available on inline picker or when the picker element is hidden\n */\n enterEditMode() {\n if (this.inline || !this.picker.active || this.editMode) {\n return;\n }\n this.editMode = true;\n this.inputField.classList.add('in-edit', 'border-blue-700');\n }\n\n /**\n * Exit from edit mode\n * Not available on inline picker\n * @param {Object} [options] - function options\n * - update: {boolean} - whether to call update() after exiting\n * If false, input field is revert to the existing selection\n * default: false\n */\n exitEditMode(options = undefined) {\n if (this.inline || !this.editMode) {\n return;\n }\n const opts = Object.assign({update: false}, options);\n delete this.editMode;\n this.inputField.classList.remove('in-edit', 'border-blue-700');\n if (opts.update) {\n this.update(opts);\n }\n }\n}\n","import {stripTime, today} from './date.js';\nimport {lastItemOf} from './utils.js';\n\n// pattern for format parts\nexport const reFormatTokens = /dd?|DD?|mm?|MM?|yy?(?:yy)?/;\n// pattern for non date parts\nexport const reNonDateParts = /[\\s!-/:-@[-`{-~年月日]+/;\n// cache for persed formats\nlet knownFormats = {};\n// parse funtions for date parts\nconst parseFns = {\n y(date, year) {\n return new Date(date).setFullYear(parseInt(year, 10));\n },\n m(date, month, locale) {\n const newDate = new Date(date);\n let monthIndex = parseInt(month, 10) - 1;\n\n if (isNaN(monthIndex)) {\n if (!month) {\n return NaN;\n }\n\n const monthName = month.toLowerCase();\n const compareNames = name => name.toLowerCase().startsWith(monthName);\n // compare with both short and full names because some locales have periods\n // in the short names (not equal to the first X letters of the full names)\n monthIndex = locale.monthsShort.findIndex(compareNames);\n if (monthIndex < 0) {\n monthIndex = locale.months.findIndex(compareNames);\n }\n if (monthIndex < 0) {\n return NaN;\n }\n }\n\n newDate.setMonth(monthIndex);\n return newDate.getMonth() !== normalizeMonth(monthIndex)\n ? newDate.setDate(0)\n : newDate.getTime();\n },\n d(date, day) {\n return new Date(date).setDate(parseInt(day, 10));\n },\n};\n// format functions for date parts\nconst formatFns = {\n d(date) {\n return date.getDate();\n },\n dd(date) {\n return padZero(date.getDate(), 2);\n },\n D(date, locale) {\n return locale.daysShort[date.getDay()];\n },\n DD(date, locale) {\n return locale.days[date.getDay()];\n },\n m(date) {\n return date.getMonth() + 1;\n },\n mm(date) {\n return padZero(date.getMonth() + 1, 2);\n },\n M(date, locale) {\n return locale.monthsShort[date.getMonth()];\n },\n MM(date, locale) {\n return locale.months[date.getMonth()];\n },\n y(date) {\n return date.getFullYear();\n },\n yy(date) {\n return padZero(date.getFullYear(), 2).slice(-2);\n },\n yyyy(date) {\n return padZero(date.getFullYear(), 4);\n },\n};\n\n// get month index in normal range (0 - 11) from any number\nfunction normalizeMonth(monthIndex) {\n return monthIndex > -1 ? monthIndex % 12 : normalizeMonth(monthIndex + 12);\n}\n\nfunction padZero(num, length) {\n return num.toString().padStart(length, '0');\n}\n\nfunction parseFormatString(format) {\n if (typeof format !== 'string') {\n throw new Error(\"Invalid date format.\");\n }\n if (format in knownFormats) {\n return knownFormats[format];\n }\n\n // sprit the format string into parts and seprators\n const separators = format.split(reFormatTokens);\n const parts = format.match(new RegExp(reFormatTokens, 'g'));\n if (separators.length === 0 || !parts) {\n throw new Error(\"Invalid date format.\");\n }\n\n // collect format functions used in the format\n const partFormatters = parts.map(token => formatFns[token]);\n\n // collect parse function keys used in the format\n // iterate over parseFns' keys in order to keep the order of the keys.\n const partParserKeys = Object.keys(parseFns).reduce((keys, key) => {\n const token = parts.find(part => part[0] !== 'D' && part[0].toLowerCase() === key);\n if (token) {\n keys.push(key);\n }\n return keys;\n }, []);\n\n return knownFormats[format] = {\n parser(dateStr, locale) {\n const dateParts = dateStr.split(reNonDateParts).reduce((dtParts, part, index) => {\n if (part.length > 0 && parts[index]) {\n const token = parts[index][0];\n if (token === 'M') {\n dtParts.m = part;\n } else if (token !== 'D') {\n dtParts[token] = part;\n }\n }\n return dtParts;\n }, {});\n\n // iterate over partParserkeys so that the parsing is made in the oder\n // of year, month and day to prevent the day parser from correcting last\n // day of month wrongly\n return partParserKeys.reduce((origDate, key) => {\n const newDate = parseFns[key](origDate, dateParts[key], locale);\n // ingnore the part failed to parse\n return isNaN(newDate) ? origDate : newDate;\n }, today());\n },\n formatter(date, locale) {\n let dateStr = partFormatters.reduce((str, fn, index) => {\n return str += `${separators[index]}${fn(date, locale)}`;\n }, '');\n // separators' length is always parts' length + 1,\n return dateStr += lastItemOf(separators);\n },\n };\n}\n\nexport function parseDate(dateStr, format, locale) {\n if (dateStr instanceof Date || typeof dateStr === 'number') {\n const date = stripTime(dateStr);\n return isNaN(date) ? undefined : date;\n }\n if (!dateStr) {\n return undefined;\n }\n if (dateStr === 'today') {\n return today();\n }\n\n if (format && format.toValue) {\n const date = format.toValue(dateStr, format, locale);\n return isNaN(date) ? undefined : stripTime(date);\n }\n\n return parseFormatString(format).parser(dateStr, locale);\n}\n\nexport function formatDate(date, format, locale) {\n if (isNaN(date) || (!date && date !== 0)) {\n return '';\n }\n\n const dateObj = typeof date === 'number' ? new Date(date) : date;\n\n if (format.toDisplay) {\n return format.toDisplay(dateObj, format, locale);\n }\n\n return parseFormatString(format).formatter(dateObj, locale);\n}\n","export function stripTime(timeValue) {\n return new Date(timeValue).setHours(0, 0, 0, 0);\n}\n\nexport function today() {\n return new Date().setHours(0, 0, 0, 0);\n}\n\n// Get the time value of the start of given date or year, month and day\nexport function dateValue(...args) {\n switch (args.length) {\n case 0:\n return today();\n case 1:\n return stripTime(args[0]);\n }\n\n // use setFullYear() to keep 2-digit year from being mapped to 1900-1999\n const newDate = new Date(0);\n newDate.setFullYear(...args);\n return newDate.setHours(0, 0, 0, 0);\n}\n\nexport function addDays(date, amount) {\n const newDate = new Date(date);\n return newDate.setDate(newDate.getDate() + amount);\n}\n\nexport function addWeeks(date, amount) {\n return addDays(date, amount * 7);\n}\n\nexport function addMonths(date, amount) {\n // If the day of the date is not in the new month, the last day of the new\n // month will be returned. e.g. Jan 31 + 1 month → Feb 28 (not Mar 03)\n const newDate = new Date(date);\n const monthsToSet = newDate.getMonth() + amount;\n let expectedMonth = monthsToSet % 12;\n if (expectedMonth < 0) {\n expectedMonth += 12;\n }\n\n const time = newDate.setMonth(monthsToSet);\n return newDate.getMonth() !== expectedMonth ? newDate.setDate(0) : time;\n}\n\nexport function addYears(date, amount) {\n // If the date is Feb 29 and the new year is not a leap year, Feb 28 of the\n // new year will be returned.\n const newDate = new Date(date);\n const expectedMonth = newDate.getMonth();\n const time = newDate.setFullYear(newDate.getFullYear() + amount);\n return expectedMonth === 1 && newDate.getMonth() === 2 ? newDate.setDate(0) : time;\n}\n\n// Calculate the distance bettwen 2 days of the week\nfunction dayDiff(day, from) {\n return (day - from + 7) % 7;\n}\n\n// Get the date of the specified day of the week of given base date\nexport function dayOfTheWeekOf(baseDate, dayOfWeek, weekStart = 0) {\n const baseDay = new Date(baseDate).getDay();\n return addDays(baseDate, dayDiff(dayOfWeek, weekStart) - dayDiff(baseDay, weekStart));\n}\n\n// Get the ISO week of a date\nexport function getWeek(date) {\n // start of ISO week is Monday\n const thuOfTheWeek = dayOfTheWeekOf(date, 4, 1);\n // 1st week == the week where the 4th of January is in\n const firstThu = dayOfTheWeekOf(new Date(thuOfTheWeek).setMonth(0, 4), 4, 1);\n return Math.round((thuOfTheWeek - firstThu) / 604800000) + 1;\n}\n\n// Get the start year of the period of years that includes given date\n// years: length of the year period\nexport function startOfYearPeriod(date, years) {\n /* @see https://en.wikipedia.org/wiki/Year_zero#ISO_8601 */\n const year = new Date(date).getFullYear();\n return Math.floor(year / years) * years;\n}\n","const listenerRegistry = new WeakMap();\nconst {addEventListener, removeEventListener} = EventTarget.prototype;\n\n// Register event listeners to a key object\n// listeners: array of listener definitions;\n// - each definition must be a flat array of event target and the arguments\n// used to call addEventListener() on the target\nexport function registerListeners(keyObj, listeners) {\n let registered = listenerRegistry.get(keyObj);\n if (!registered) {\n registered = [];\n listenerRegistry.set(keyObj, registered);\n }\n listeners.forEach((listener) => {\n addEventListener.call(...listener);\n registered.push(listener);\n });\n}\n\nexport function unregisterListeners(keyObj) {\n let listeners = listenerRegistry.get(keyObj);\n if (!listeners) {\n return;\n }\n listeners.forEach((listener) => {\n removeEventListener.call(...listener);\n });\n listenerRegistry.delete(keyObj);\n}\n\n// Event.composedPath() polyfill for Edge\n// based on https://gist.github.com/kleinfreund/e9787d73776c0e3750dcfcdc89f100ec\nif (!Event.prototype.composedPath) {\n const getComposedPath = (node, path = []) => {\n path.push(node);\n\n let parent;\n if (node.parentNode) {\n parent = node.parentNode;\n } else if (node.host) { // ShadowRoot\n parent = node.host;\n } else if (node.defaultView) { // Document\n parent = node.defaultView;\n }\n return parent ? getComposedPath(parent, path) : path;\n };\n\n Event.prototype.composedPath = function () {\n return getComposedPath(this.target);\n };\n}\n\nfunction findFromPath(path, criteria, currentTarget, index = 0) {\n const el = path[index];\n if (criteria(el)) {\n return el;\n } else if (el === currentTarget || !el.parentElement) {\n // stop when reaching currentTarget or \n return;\n }\n return findFromPath(path, criteria, currentTarget, index + 1);\n}\n\n// Search for the actual target of a delegated event\nexport function findElementInEventPath(ev, selector) {\n const criteria = typeof selector === 'function' ? selector : el => el.matches(selector);\n return findFromPath(ev.composedPath(), criteria, ev.currentTarget);\n}\n","export function hasProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nexport function lastItemOf(arr) {\n return arr[arr.length - 1];\n}\n\n// push only the items not included in the array\nexport function pushUnique(arr, ...items) {\n items.forEach((item) => {\n if (arr.includes(item)) {\n return;\n }\n arr.push(item);\n });\n return arr;\n}\n\nexport function stringToArray(str, separator) {\n // convert empty string to an empty array\n return str ? str.split(separator) : [];\n}\n\nexport function isInRange(testVal, min, max) {\n const minOK = min === undefined || testVal >= min;\n const maxOK = max === undefined || testVal <= max;\n return minOK && maxOK;\n}\n\nexport function limitToRange(val, min, max) {\n if (val < min) {\n return min;\n }\n if (val > max) {\n return max;\n }\n return val;\n}\n\nexport function createTagRepeat(tagName, repeat, attributes = {}, index = 0, html = '') {\n const openTagSrc = Object.keys(attributes).reduce((src, attr) => {\n let val = attributes[attr];\n if (typeof val === 'function') {\n val = val(index);\n }\n return `${src} ${attr}=\"${val}\"`;\n }, tagName);\n html += `<${openTagSrc}>`;\n\n const next = index + 1;\n return next < repeat\n ? createTagRepeat(tagName, repeat, attributes, next, html)\n : html;\n}\n\n// Remove the spacing surrounding tags for HTML parser not to create text nodes\n// before/after elements\nexport function optimizeTemplateHTML(html) {\n return html.replace(/>\\s+/g, '>').replace(/\\s+ {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import { initDatepickers } from './datepicker';\nimport Datepicker from 'flowbite-datepicker/Datepicker';\nimport DateRangePicker from 'flowbite-datepicker/DateRangePicker';\nimport Events from '../dom/events';\n\nconst turboLoadEvents = new Events('turbo:load', [initDatepickers]);\nconst turboFrameLoadEvents = new Events('turbo:frame-load', [initDatepickers]);\n\nturboLoadEvents.init();\nturboFrameLoadEvents.init();\n\nexport default {\n Datepicker,\n DateRangePicker,\n};\n"],"names":["Datepicker","DateRangePicker","Events","getDatepickerOptions","datepickerEl","buttons","hasAttribute","autohide","format","orientation","title","options","todayBtn","clearBtn","getAttribute","initDatepickers","document","querySelectorAll","forEach","events","init","turboLoadEvents","turboFrameLoadEvents"],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/datepicker.turbo.min.js b/node_modules/flowbite/dist/datepicker.turbo.min.js new file mode 100644 index 0000000..4f39e7b --- /dev/null +++ b/node_modules/flowbite/dist/datepicker.turbo.min.js @@ -0,0 +1,2 @@ +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("Flowbite",[],t):"object"==typeof exports?exports.Flowbite=t():e.Flowbite=t()}(self,(function(){return function(){"use strict";var e={781:function(e,t,i){i.d(t,{initDatepickers:function(){return o}});var r=i(770),n=i(482),a=i(947),s=function(e){var t=e.hasAttribute("datepicker-buttons"),i=e.hasAttribute("datepicker-autohide"),r=e.hasAttribute("datepicker-format"),n=e.hasAttribute("datepicker-orientation"),a=e.hasAttribute("datepicker-title"),s={};return t&&(s.todayBtn=!0,s.clearBtn=!0),i&&(s.autohide=!0),r&&(s.format=e.getAttribute("datepicker-format")),n&&(s.orientation=e.getAttribute("datepicker-orientation")),a&&(s.title=e.getAttribute("datepicker-title")),s};function o(){document.querySelectorAll("[datepicker]").forEach((function(e){new r.Z(e,s(e))})),document.querySelectorAll("[inline-datepicker]").forEach((function(e){new r.Z(e,s(e))})),document.querySelectorAll("[date-rangepicker]").forEach((function(e){new n.Z(e,s(e))}))}new a.default("DOMContentLoaded",[o]).init()},482:function(e,t,i){i.d(t,{Z:function(){return c}});var r=i(698),n=i(963),a=i(770);function s(e){const t=Object.assign({},e);return delete t.inputs,delete t.allowOneSidedRange,delete t.maxNumberOfDates,t}function o(e,t,i,n){(0,r.cF)(e,[[i,"changeDate",t]]),new a.Z(i,n,e)}function d(e,t){if(e._updating)return;e._updating=!0;const i=t.target;if(void 0===i.datepicker)return;const r=e.datepickers,n={render:!1},a=e.inputs.indexOf(i),s=0===a?1:0,o=r[a].dates[0],d=r[s].dates[0];void 0!==o&&void 0!==d?0===a&&o>d?(r[0].setDate(d,n),r[1].setDate(o,n)):1===a&&o0?d(this,{target:this.inputs[0]}):a[1].dates.length>0&&d(this,{target:this.inputs[1]})}get dates(){return 2===this.datepickers.length?[this.datepickers[0].dates[0],this.datepickers[1].dates[0]]:void 0}setOptions(e){this.allowOneSidedRange=!!e.allowOneSidedRange;const t=s(e);this.datepickers[0].setOptions(t),this.datepickers[1].setOptions(t)}destroy(){this.datepickers[0].destroy(),this.datepickers[1].destroy(),(0,r.uV)(this),delete this.element.rangepicker}getDates(e){const t=e?t=>(0,n.p6)(t,e,this.datepickers[0].config.locale):e=>new Date(e);return this.dates.map((e=>void 0===e?e:t(e)))}setDates(e,t){const[i,r]=this.datepickers,n=this.dates;this._updating=!0,i.setDate(e),r.setDate(t),delete this._updating,r.dates[0]!==n[1]?d(this,{target:this.inputs[1]}):i.dates[0]!==n[0]&&d(this,{target:this.inputs[0]})}}},770:function(e,t,i){i.d(t,{Z:function(){return ae}});var r=i(105),n=i(560),a=i(963),s=i(698);const o={en:{days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],daysShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],daysMin:["Su","Mo","Tu","We","Th","Fr","Sa"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],monthsShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],today:"Today",clear:"Clear",titleFormat:"MM y"}};var d={autohide:!1,beforeShowDay:null,beforeShowDecade:null,beforeShowMonth:null,beforeShowYear:null,calendarWeeks:!1,clearBtn:!1,dateDelimiter:",",datesDisabled:[],daysOfWeekDisabled:[],daysOfWeekHighlighted:[],defaultViewDate:void 0,disableTouchKeyboard:!1,format:"mm/dd/yyyy",language:"en",maxDate:null,maxNumberOfDates:1,maxView:3,minDate:null,nextArrow:'',orientation:"auto",pickLevel:0,prevArrow:'',showDaysOfWeek:!0,showOnClick:!0,showOnFocus:!0,startView:0,title:"",todayBtn:!1,todayBtnMode:0,todayHighlight:!1,updateOnBlur:!0,weekStart:0};const c=document.createRange();function l(e){return c.createContextualFragment(e)}function h(e){"none"!==e.style.display&&(e.style.display&&(e.dataset.styleDisplay=e.style.display),e.style.display="none")}function u(e){"none"===e.style.display&&(e.dataset.styleDisplay?(e.style.display=e.dataset.styleDisplay,delete e.dataset.styleDisplay):e.style.display="")}function g(e){e.firstChild&&(e.removeChild(e.firstChild),g(e))}const{language:f,format:p,weekStart:m}=d;function b(e,t){return e.length<6&&t>=0&&t<7?(0,r.$C)(e,t):e}function y(e){return(e+6)%7}function w(e,t,i,r){const n=(0,a.sG)(e,t,i);return void 0!==n?n:r}function k(e,t,i=3){const r=parseInt(e,10);return r>=0&&r<=i?r:t}function v(e,t){const i=Object.assign({},e),s={},o=t.constructor.locales;let{format:c,language:h,locale:u,maxDate:g,maxView:v,minDate:D,pickLevel:x,startView:M,weekStart:S}=t.config||{};if(i.language){let e;if(i.language!==h&&(o[i.language]?e=i.language:(e=i.language.split("-")[0],void 0===o[e]&&(e=!1))),delete i.language,e){h=s.language=e;const t=u||o[f];u=Object.assign({format:p,weekStart:m},o[f]),h!==f&&Object.assign(u,o[h]),s.locale=u,c===t.format&&(c=s.format=u.format),S===t.weekStart&&(S=s.weekStart=u.weekStart,s.weekEnd=y(u.weekStart))}}if(i.format){const e="function"==typeof i.format.toDisplay,t="function"==typeof i.format.toValue,r=a.CL.test(i.format);(e&&t||r)&&(c=s.format=i.format),delete i.format}let O=D,C=g;if(void 0!==i.minDate&&(O=null===i.minDate?(0,n.by)(0,0,1):w(i.minDate,c,u,O),delete i.minDate),void 0!==i.maxDate&&(C=null===i.maxDate?void 0:w(i.maxDate,c,u,C),delete i.maxDate),C{const i=(0,a.sG)(t,c,u);return void 0!==i?(0,r.$C)(e,i):e}),[]),delete i.datesDisabled),void 0!==i.defaultViewDate){const e=(0,a.sG)(i.defaultViewDate,c,u);void 0!==e&&(s.defaultViewDate=e),delete i.defaultViewDate}if(void 0!==i.weekStart){const e=Number(i.weekStart)%7;isNaN(e)||(S=s.weekStart=e,s.weekEnd=y(e)),delete i.weekStart}if(i.daysOfWeekDisabled&&(s.daysOfWeekDisabled=i.daysOfWeekDisabled.reduce(b,[]),delete i.daysOfWeekDisabled),i.daysOfWeekHighlighted&&(s.daysOfWeekHighlighted=i.daysOfWeekHighlighted.reduce(b,[]),delete i.daysOfWeekHighlighted),void 0!==i.maxNumberOfDates){const e=parseInt(i.maxNumberOfDates,10);e>=0&&(s.maxNumberOfDates=e,s.multidate=1!==e),delete i.maxNumberOfDates}i.dateDelimiter&&(s.dateDelimiter=String(i.dateDelimiter),delete i.dateDelimiter);let E=x;void 0!==i.pickLevel&&(E=k(i.pickLevel,2),delete i.pickLevel),E!==x&&(x=s.pickLevel=E);let F=v;void 0!==i.maxView&&(F=k(i.maxView,v),delete i.maxView),F=x>F?x:F,F!==v&&(v=s.maxView=F);let L=M;if(void 0!==i.startView&&(L=k(i.startView,L),delete i.startView),Lv&&(L=v),L!==M&&(s.startView=L),i.prevArrow){const e=l(i.prevArrow);e.childNodes.length>0&&(s.prevArrow=e.childNodes),delete i.prevArrow}if(i.nextArrow){const e=l(i.nextArrow);e.childNodes.length>0&&(s.nextArrow=e.childNodes),delete i.nextArrow}if(void 0!==i.disableTouchKeyboard&&(s.disableTouchKeyboard="ontouchstart"in document&&!!i.disableTouchKeyboard,delete i.disableTouchKeyboard),i.orientation){const e=i.orientation.toLowerCase().split(/\s+/g);s.orientation={x:e.find((e=>"left"===e||"right"===e))||"auto",y:e.find((e=>"top"===e||"bottom"===e))||"auto"},delete i.orientation}if(void 0!==i.todayBtnMode){switch(i.todayBtnMode){case 0:case 1:s.todayBtnMode=i.todayBtnMode}delete i.todayBtnMode}return Object.keys(i).forEach((e=>{void 0!==i[e]&&(0,r.l$)(d,e)&&(s[e]=i[e])})),s}var D=(0,r.zh)('');var x=(0,r.zh)(`
      \n
      ${(0,r.em)("span",7,{class:"dow block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm"})}
      \n
      ${(0,r.em)("span",42,{class:"block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400"})}
      \n
      `);var M=(0,r.zh)(`
      \n
      \n
      ${(0,r.em)("span",6,{class:"week block flex-1 leading-9 border-0 rounded-lg cursor-default text-center text-gray-900 font-semibold text-sm"})}
      \n
      `);class S{constructor(e,t){Object.assign(this,t,{picker:e,element:l('
      ').firstChild,selected:[]}),this.init(this.picker.datepicker.config)}init(e){void 0!==e.pickLevel&&(this.isMinView=this.id===e.pickLevel),this.setOptions(e),this.updateFocus(),this.updateSelection()}performBeforeHook(e,t,i){let n=this.beforeShow(new Date(i));switch(typeof n){case"boolean":n={enabled:n};break;case"string":n={classes:n}}if(n){if(!1===n.enabled&&(e.classList.add("disabled"),(0,r.$C)(this.disabled,t)),n.classes){const i=n.classes.split(/\s+/);e.classList.add(...i),i.includes("disabled")&&(0,r.$C)(this.disabled,t)}n.content&&function(e,t){g(e),t instanceof DocumentFragment?e.appendChild(t):"string"==typeof t?e.appendChild(l(t)):"function"==typeof t.forEach&&t.forEach((t=>{e.appendChild(t)}))}(e,n.content)}}}class O extends S{constructor(e){super(e,{id:0,name:"days",cellClass:"day"})}init(e,t=!0){if(t){const e=l(x).firstChild;this.dow=e.firstChild,this.grid=e.lastChild,this.element.appendChild(e)}super.init(e)}setOptions(e){let t;if((0,r.l$)(e,"minDate")&&(this.minDate=e.minDate),(0,r.l$)(e,"maxDate")&&(this.maxDate=e.maxDate),e.datesDisabled&&(this.datesDisabled=e.datesDisabled),e.daysOfWeekDisabled&&(this.daysOfWeekDisabled=e.daysOfWeekDisabled,t=!0),e.daysOfWeekHighlighted&&(this.daysOfWeekHighlighted=e.daysOfWeekHighlighted),void 0!==e.todayHighlight&&(this.todayHighlight=e.todayHighlight),void 0!==e.weekStart&&(this.weekStart=e.weekStart,this.weekEnd=e.weekEnd,t=!0),e.locale){const i=this.locale=e.locale;this.dayNames=i.daysMin,this.switchLabelFormat=i.titleFormat,t=!0}if(void 0!==e.beforeShowDay&&(this.beforeShow="function"==typeof e.beforeShowDay?e.beforeShowDay:void 0),void 0!==e.calendarWeeks)if(e.calendarWeeks&&!this.calendarWeeks){const e=l(M).firstChild;this.calendarWeeks={element:e,dow:e.firstChild,weeks:e.lastChild},this.element.insertBefore(e,this.element.firstChild)}else this.calendarWeeks&&!e.calendarWeeks&&(this.element.removeChild(this.calendarWeeks.element),this.calendarWeeks=null);void 0!==e.showDaysOfWeek&&(e.showDaysOfWeek?(u(this.dow),this.calendarWeeks&&u(this.calendarWeeks.dow)):(h(this.dow),this.calendarWeeks&&h(this.calendarWeeks.dow))),t&&Array.from(this.dow.children).forEach(((e,t)=>{const i=(this.weekStart+t)%7;e.textContent=this.dayNames[i],e.className=this.daysOfWeekDisabled.includes(i)?"dow disabled text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400 cursor-not-allowed":"dow text-center h-6 leading-6 text-sm font-medium text-gray-500 dark:text-gray-400"}))}updateFocus(){const e=new Date(this.picker.viewDate),t=e.getFullYear(),i=e.getMonth(),r=(0,n.by)(t,i,1),a=(0,n.fr)(r,this.weekStart,this.weekStart);this.first=r,this.last=(0,n.by)(t,i+1,0),this.start=a,this.focused=this.picker.viewDate}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e,t&&(this.range=t.dates)}render(){this.today=this.todayHighlight?(0,n.Lg)():void 0,this.disabled=[...this.datesDisabled];const e=(0,a.p6)(this.focused,this.switchLabelFormat,this.locale);if(this.picker.setViewSwitchLabel(e),this.picker.setPrevBtnDisabled(this.first<=this.minDate),this.picker.setNextBtnDisabled(this.last>=this.maxDate),this.calendarWeeks){const e=(0,n.fr)(this.first,1,1);Array.from(this.calendarWeeks.weeks.children).forEach(((t,i)=>{t.textContent=(0,n.Qk)((0,n.jh)(e,i))}))}Array.from(this.grid.children).forEach(((e,t)=>{const i=e.classList,a=(0,n.E4)(this.start,t),s=new Date(a),o=s.getDay();if(e.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,e.dataset.date=a,e.textContent=s.getDate(),athis.last&&i.add("next","text-gray-500","dark:text-white"),this.today===a&&i.add("today","bg-gray-100","dark:bg-gray-600"),(athis.maxDate||this.disabled.includes(a))&&i.add("disabled","cursor-not-allowed"),this.daysOfWeekDisabled.includes(o)&&(i.add("disabled","cursor-not-allowed"),(0,r.$C)(this.disabled,a)),this.daysOfWeekHighlighted.includes(o)&&i.add("highlighted"),this.range){const[e,t]=this.range;a>e&&a{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","text-white","dark:bg-blue-600","dark:text-white","focused"),e.classList.add("text-gray-900","rounded-lg","dark:text-white")})),Array.from(this.grid.children).forEach((i=>{const r=Number(i.dataset.date),n=i.classList;n.remove("bg-gray-200","dark:bg-gray-600","rounded-l-lg","rounded-r-lg"),r>e&&r{e.classList.remove("focused")})),this.grid.children[e].classList.add("focused")}}function C(e,t){if(!e||!e[0]||!e[1])return;const[[i,r],[n,a]]=e;return i>t||ne})))),super.init(e)}setOptions(e){if(e.locale&&(this.monthNames=e.locale.monthsShort),(0,r.l$)(e,"minDate"))if(void 0===e.minDate)this.minYear=this.minMonth=this.minDate=void 0;else{const t=new Date(e.minDate);this.minYear=t.getFullYear(),this.minMonth=t.getMonth(),this.minDate=t.setDate(1)}if((0,r.l$)(e,"maxDate"))if(void 0===e.maxDate)this.maxYear=this.maxMonth=this.maxDate=void 0;else{const t=new Date(e.maxDate);this.maxYear=t.getFullYear(),this.maxMonth=t.getMonth(),this.maxDate=(0,n.by)(this.maxYear,this.maxMonth+1,0)}void 0!==e.beforeShowMonth&&(this.beforeShow="function"==typeof e.beforeShowMonth?e.beforeShowMonth:void 0)}updateFocus(){const e=new Date(this.picker.viewDate);this.year=e.getFullYear(),this.focused=e.getMonth()}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e.reduce(((e,t)=>{const i=new Date(t),n=i.getFullYear(),a=i.getMonth();return void 0===e[n]?e[n]=[a]:(0,r.$C)(e[n],a),e}),{}),t&&t.dates&&(this.range=t.dates.map((e=>{const t=new Date(e);return isNaN(t)?void 0:[t.getFullYear(),t.getMonth()]})))}render(){this.disabled=[],this.picker.setViewSwitchLabel(this.year),this.picker.setPrevBtnDisabled(this.year<=this.minYear),this.picker.setNextBtnDisabled(this.year>=this.maxYear);const e=this.selected[this.year]||[],t=this.yearthis.maxYear,i=this.year===this.minYear,r=this.year===this.maxYear,a=C(this.range,this.year);Array.from(this.grid.children).forEach(((s,o)=>{const d=s.classList,c=(0,n.by)(this.year,o,1);if(s.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,this.isMinView&&(s.dataset.date=c),s.textContent=this.monthNames[o],(t||i&&othis.maxMonth)&&d.add("disabled"),a){const[e,t]=a;o>e&&o{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","dark:bg-blue-600","dark:text-white","text-white","focused"),e.classList.add("text-gray-900","hover:bg-gray-100","dark:text-white","dark:hover:bg-gray-600")})),Array.from(this.grid.children).forEach(((r,n)=>{const a=r.classList;n>t&&n{e.classList.remove("focused")})),this.grid.children[this.focused].classList.add("focused")}}class F extends S{constructor(e,t){super(e,t)}init(e,t=!0){var i;t&&(this.navStep=10*this.step,this.beforeShowOption=`beforeShow${i=this.cellClass,[...i].reduce(((e,t,i)=>e+(i?t:t.toUpperCase())),"")}`,this.grid=this.element,this.element.classList.add(this.name,"datepicker-grid","w-64","grid","grid-cols-4"),this.grid.appendChild(l((0,r.em)("span",12)))),super.init(e)}setOptions(e){if((0,r.l$)(e,"minDate")&&(void 0===e.minDate?this.minYear=this.minDate=void 0:(this.minYear=(0,n.ak)(e.minDate,this.step),this.minDate=(0,n.by)(this.minYear,0,1))),(0,r.l$)(e,"maxDate")&&(void 0===e.maxDate?this.maxYear=this.maxDate=void 0:(this.maxYear=(0,n.ak)(e.maxDate,this.step),this.maxDate=(0,n.by)(this.maxYear,11,31))),void 0!==e[this.beforeShowOption]){const t=e[this.beforeShowOption];this.beforeShow="function"==typeof t?t:void 0}}updateFocus(){const e=new Date(this.picker.viewDate),t=(0,n.ak)(e,this.navStep),i=t+9*this.step;this.first=t,this.last=i,this.start=t-this.step,this.focused=(0,n.ak)(e,this.step)}updateSelection(){const{dates:e,rangepicker:t}=this.picker.datepicker;this.selected=e.reduce(((e,t)=>(0,r.$C)(e,(0,n.ak)(t,this.step))),[]),t&&t.dates&&(this.range=t.dates.map((e=>{if(void 0!==e)return(0,n.ak)(e,this.step)})))}render(){this.disabled=[],this.picker.setViewSwitchLabel(`${this.first}-${this.last}`),this.picker.setPrevBtnDisabled(this.first<=this.minYear),this.picker.setNextBtnDisabled(this.last>=this.maxYear),Array.from(this.grid.children).forEach(((e,t)=>{const i=e.classList,r=this.start+t*this.step,a=(0,n.by)(r,0,1);if(e.className=`datepicker-cell hover:bg-gray-100 dark:hover:bg-gray-600 block flex-1 leading-9 border-0 rounded-lg cursor-pointer text-center text-gray-900 dark:text-white font-semibold text-sm ${this.cellClass}`,this.isMinView&&(e.dataset.date=a),e.textContent=e.dataset.year=r,0===t?i.add("prev"):11===t&&i.add("next"),(rthis.maxYear)&&i.add("disabled"),this.range){const[e,t]=this.range;r>e&&r{e.classList.remove("range","range-start","range-end","selected","bg-blue-700","text-white","dark:bg-blue-600","dark:text-white","focused")})),Array.from(this.grid.children).forEach((i=>{const r=Number(i.textContent),n=i.classList;r>e&&r{e.classList.remove("focused")})),this.grid.children[e].classList.add("focused")}}function L(e,t){const i={date:e.getDate(),viewDate:new Date(e.picker.viewDate),viewId:e.picker.currentView.id,datepicker:e};e.element.dispatchEvent(new CustomEvent(t,{detail:i}))}function V(e,t){const{minDate:i,maxDate:a}=e.config,{currentView:s,viewDate:o}=e.picker;let d;switch(s.id){case 0:d=(0,n.zI)(o,t);break;case 1:d=(0,n.Bc)(o,t);break;default:d=(0,n.Bc)(o,t*s.navStep)}d=(0,r.jG)(d,i,a),e.picker.changeFocus(d).render()}function B(e){const t=e.picker.currentView.id;t!==e.config.maxView&&e.picker.changeView(t+1).render()}function A(e){e.config.updateOnBlur?e.update({autohide:!0}):(e.refresh("input"),e.hide())}function N(e,t){const i=e.picker,r=new Date(i.viewDate),a=i.currentView.id,s=1===a?(0,n.zI)(r,t-r.getMonth()):(0,n.Bc)(r,t-r.getFullYear());i.changeFocus(s).changeView(a-1).render()}function W(e){const t=e.picker,i=(0,n.Lg)();if(1===e.config.todayBtnMode){if(e.config.autohide)return void e.setDate(i);e.setDate(i,{render:!1}),t.update()}t.viewDate!==i&&t.changeFocus(i),t.changeView(0).render()}function Y(e){e.setDate({clear:!0})}function $(e){B(e)}function j(e){V(e,-1)}function _(e){V(e,1)}function H(e,t){const i=(0,s.He)(t,".datepicker-cell");if(!i||i.classList.contains("disabled"))return;const{id:r,isMinView:n}=e.picker.currentView;n?e.setDate(Number(i.dataset.date)):N(e,Number(1===r?i.dataset.month:i.dataset.year))}function T(e){e.inline||e.config.disableTouchKeyboard||e.inputField.focus()}function K(e,t){if(void 0!==t.title&&(t.title?(e.controls.title.textContent=t.title,u(e.controls.title)):(e.controls.title.textContent="",h(e.controls.title))),t.prevArrow){const i=e.controls.prevBtn;g(i),t.prevArrow.forEach((e=>{i.appendChild(e.cloneNode(!0))}))}if(t.nextArrow){const i=e.controls.nextBtn;g(i),t.nextArrow.forEach((e=>{i.appendChild(e.cloneNode(!0))}))}if(t.locale&&(e.controls.todayBtn.textContent=t.locale.today,e.controls.clearBtn.textContent=t.locale.clear),void 0!==t.todayBtn&&(t.todayBtn?u(e.controls.todayBtn):h(e.controls.todayBtn)),(0,r.l$)(t,"minDate")||(0,r.l$)(t,"maxDate")){const{minDate:t,maxDate:i}=e.datepicker.config;e.controls.todayBtn.disabled=!(0,r.mh)((0,n.Lg)(),t,i)}void 0!==t.clearBtn&&(t.clearBtn?u(e.controls.clearBtn):h(e.controls.clearBtn))}function I(e){const{dates:t,config:i}=e,n=t.length>0?(0,r.Jm)(t):i.defaultViewDate;return(0,r.jG)(n,i.minDate,i.maxDate)}function P(e,t){const i=new Date(e.viewDate),r=new Date(t),{id:n,year:a,first:s,last:o}=e.currentView,d=r.getFullYear();switch(e.viewDate=t,d!==i.getFullYear()&&L(e.datepicker,"changeYear"),r.getMonth()!==i.getMonth()&&L(e.datepicker,"changeMonth"),n){case 0:return to;case 1:return d!==a;default:return do}}function R(e){return window.getComputedStyle(e).direction}class z{constructor(e){this.datepicker=e;const t=D.replace(/%buttonClass%/g,e.config.buttonClass),i=this.element=l(t).firstChild,[r,n,a]=i.firstChild.children,o=r.firstElementChild,[d,c,h]=r.lastElementChild.children,[u,g]=a.firstChild.children,f={title:o,prevBtn:d,viewSwitch:c,nextBtn:h,todayBtn:u,clearBtn:g};this.main=n,this.controls=f;const p=e.inline?"inline":"dropdown";i.classList.add(`datepicker-${p}`),"dropdown"===p&&i.classList.add("dropdown","absolute","top-0","left-0","z-50","pt-2"),K(this,e.config),this.viewDate=I(e),(0,s.cF)(e,[[i,"click",T.bind(null,e),{capture:!0}],[n,"click",H.bind(null,e)],[f.viewSwitch,"click",$.bind(null,e)],[f.prevBtn,"click",j.bind(null,e)],[f.nextBtn,"click",_.bind(null,e)],[f.todayBtn,"click",W.bind(null,e)],[f.clearBtn,"click",Y.bind(null,e)]]),this.views=[new O(this),new E(this),new F(this,{id:2,name:"years",cellClass:"year",step:1}),new F(this,{id:3,name:"decades",cellClass:"decade",step:10})],this.currentView=this.views[e.config.startView],this.currentView.render(),this.main.appendChild(this.currentView.element),e.config.container.appendChild(this.element)}setOptions(e){K(this,e),this.views.forEach((t=>{t.init(e,!1)})),this.currentView.render()}detach(){this.datepicker.config.container.removeChild(this.element)}show(){if(this.active)return;this.element.classList.add("active","block"),this.element.classList.remove("hidden"),this.active=!0;const e=this.datepicker;if(!e.inline){const t=R(e.inputField);t!==R(e.config.container)?this.element.dir=t:this.element.dir&&this.element.removeAttribute("dir"),this.place(),e.config.disableTouchKeyboard&&e.inputField.blur()}L(e,"show")}hide(){this.active&&(this.datepicker.exitEditMode(),this.element.classList.remove("active","block"),this.element.classList.add("active","block","hidden"),this.active=!1,L(this.datepicker,"hide"))}place(){const{classList:e,style:t}=this.element,{config:i,inputField:r}=this.datepicker,n=i.container,{width:a,height:s}=this.element.getBoundingClientRect(),{left:o,top:d,width:c}=n.getBoundingClientRect(),{left:l,top:h,width:u,height:g}=r.getBoundingClientRect();let f,p,m,{x:b,y:y}=i.orientation;n===document.body?(f=window.scrollY,p=l+window.scrollX,m=h+f):(f=n.scrollTop,p=l-o,m=h-d+f),"auto"===b&&(p<0?(b="left",p=10):b=p+a>c||"rtl"===R(r)?"right":"left"),"right"===b&&(p-=a-u),"auto"===y&&(y=m-s{e.updateFocus()})),this}update(){const e=I(this.datepicker);return this._renderMethod=P(this,e)?"render":"refresh",this.views.forEach((e=>{e.updateFocus(),e.updateSelection()})),this}render(e=!0){const t=e&&this._renderMethod||"render";delete this._renderMethod,this.currentView[t]()}}function q(e,t,i,n,a,s){if((0,r.mh)(e,a,s)){if(n(e)){return q(t(e,i),t,i,n,a,s)}return e}}function J(e,t,i,r){const a=e.picker,s=a.currentView,o=s.step||1;let d,c,l=a.viewDate;switch(s.id){case 0:l=r?(0,n.E4)(l,7*i):t.ctrlKey||t.metaKey?(0,n.Bc)(l,i):(0,n.E4)(l,i),d=n.E4,c=e=>s.disabled.includes(e);break;case 1:l=(0,n.zI)(l,r?4*i:i),d=n.zI,c=e=>{const t=new Date(e),{year:i,disabled:r}=s;return t.getFullYear()===i&&r.includes(t.getMonth())};break;default:l=(0,n.Bc)(l,i*(r?4:1)*o),d=n.Bc,c=e=>s.disabled.includes((0,n.ak)(e,o))}l=q(l,d,i<0?-o:o,c,s.minDate,s.maxDate),void 0!==l&&a.changeFocus(l).render()}function G(e,t){if("Tab"===t.key)return void A(e);const i=e.picker,{id:r,isMinView:n}=i.currentView;if(i.active)if(e.editMode)switch(t.key){case"Escape":i.hide();break;case"Enter":e.exitEditMode({update:!0,autohide:e.config.autohide});break;default:return}else switch(t.key){case"Escape":i.hide();break;case"ArrowLeft":if(t.ctrlKey||t.metaKey)V(e,-1);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,-1,!1)}break;case"ArrowRight":if(t.ctrlKey||t.metaKey)V(e,1);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,1,!1)}break;case"ArrowUp":if(t.ctrlKey||t.metaKey)B(e);else{if(t.shiftKey)return void e.enterEditMode();J(e,t,-1,!0)}break;case"ArrowDown":if(t.shiftKey&&!t.ctrlKey&&!t.metaKey)return void e.enterEditMode();J(e,t,1,!0);break;case"Enter":n?e.setDate(i.viewDate):i.changeView(r-1).render();break;case"Backspace":case"Delete":return void e.enterEditMode();default:return void(1!==t.key.length||t.ctrlKey||t.metaKey||e.enterEditMode())}else switch(t.key){case"ArrowDown":case"Escape":i.show();break;case"Enter":e.update();break;default:return}t.preventDefault(),t.stopPropagation()}function Z(e){e.config.showOnFocus&&!e._showing&&e.show()}function U(e,t){const i=t.target;(e.picker.active||e.config.showOnClick)&&(i._active=i===document.activeElement,i._clicking=setTimeout((()=>{delete i._active,delete i._clicking}),2e3))}function Q(e,t){const i=t.target;i._clicking&&(clearTimeout(i._clicking),delete i._clicking,i._active&&e.enterEditMode(),delete i._active,e.config.showOnClick&&e.show())}function X(e,t){t.clipboardData.types.includes("text/plain")&&e.enterEditMode()}function ee(e,t){const i=e.element;if(i!==document.activeElement)return;const r=e.picker.element;(0,s.He)(t,(e=>e===i||e===r))||A(e)}function te(e,t){return e.map((e=>(0,a.p6)(e,t.format,t.locale))).join(t.dateDelimiter)}function ie(e,t,i=!1){const{config:n,dates:s,rangepicker:o}=e;if(0===t.length)return i?[]:void 0;const d=o&&e===o.datepickers[1];let c=t.reduce(((e,t)=>{let i=(0,a.sG)(t,n.format,n.locale);if(void 0===i)return e;if(n.pickLevel>0){const e=new Date(i);i=1===n.pickLevel?d?e.setMonth(e.getMonth()+1,0):e.setDate(1):d?e.setFullYear(e.getFullYear()+1,0,0):e.setMonth(0,1)}return!(0,r.mh)(i,n.minDate,n.maxDate)||e.includes(i)||n.datesDisabled.includes(i)||n.daysOfWeekDisabled.includes(new Date(i).getDay())||e.push(i),e}),[]);return 0!==c.length?(n.multidate&&!i&&(c=c.reduce(((e,t)=>(s.includes(t)||e.push(t),e)),s.filter((e=>!c.includes(e))))),n.maxNumberOfDates&&c.length>n.maxNumberOfDates?c.slice(-1*n.maxNumberOfDates):c):void 0}function re(e,t=3,i=!0){const{config:r,picker:n,inputField:a}=e;if(2&t){const e=n.active?r.pickLevel:r.startView;n.update().changeView(e).render(i)}1&t&&a&&(a.value=te(e.dates,r))}function ne(e,t,i){let{clear:r,render:n,autohide:a}=i;void 0===n&&(n=!0),n?void 0===a&&(a=e.config.autohide):a=!1;const s=ie(e,t,r);s&&(s.toString()!==e.dates.toString()?(e.dates=s,re(e,n?3:1),L(e,"changeDate")):re(e,1),a&&e.hide())}class ae{constructor(e,t={},i){e.datepicker=this,this.element=e;const a=this.config=Object.assign({buttonClass:t.buttonClass&&String(t.buttonClass)||"button",container:document.body,defaultViewDate:(0,n.Lg)(),maxDate:void 0,minDate:void 0},v(d,this));this._options=t,Object.assign(a,v(t,this));const o=this.inline="INPUT"!==e.tagName;let c,l;if(o)a.container=e,l=(0,r.W7)(e.dataset.date,a.dateDelimiter),delete e.dataset.date;else{const i=t.container?document.querySelector(t.container):null;i&&(a.container=i),c=this.inputField=e,c.classList.add("datepicker-input"),l=(0,r.W7)(c.value,a.dateDelimiter)}if(i){const e=i.inputs.indexOf(c),t=i.datepickers;if(e<0||e>1||!Array.isArray(t))throw Error("Invalid rangepicker object.");t[e]=this,Object.defineProperty(this,"rangepicker",{get(){return i}})}this.dates=[];const h=ie(this,l);h&&h.length>0&&(this.dates=h),c&&(c.value=te(this.dates,a));const u=this.picker=new z(this);if(o)this.show();else{const e=ee.bind(null,this),t=[[c,"keydown",G.bind(null,this)],[c,"focus",Z.bind(null,this)],[c,"mousedown",U.bind(null,this)],[c,"click",Q.bind(null,this)],[c,"paste",X.bind(null,this)],[document,"mousedown",e],[document,"touchstart",e],[window,"resize",u.place.bind(u)]];(0,s.cF)(this,t)}}static formatDate(e,t,i){return(0,a.p6)(e,t,i&&o[i]||o.en)}static parseDate(e,t,i){return(0,a.sG)(e,t,i&&o[i]||o.en)}static get locales(){return o}get active(){return!(!this.picker||!this.picker.active)}get pickerElement(){return this.picker?this.picker.element:void 0}setOptions(e){const t=this.picker,i=v(e,this);Object.assign(this._options,e),Object.assign(this.config,i),t.setOptions(i),re(this,3)}show(){if(this.inputField){if(this.inputField.disabled)return;this.inputField!==document.activeElement&&(this._showing=!0,this.inputField.focus(),delete this._showing)}this.picker.show()}hide(){this.inline||(this.picker.hide(),this.picker.update().changeView(this.config.startView).render())}destroy(){return this.hide(),(0,s.uV)(this),this.picker.detach(),this.inline||this.inputField.classList.remove("datepicker-input"),delete this.element.datepicker,this}getDate(e){const t=e?t=>(0,a.p6)(t,e,this.config.locale):e=>new Date(e);return this.config.multidate?this.dates.map(t):this.dates.length>0?t(this.dates[0]):void 0}setDate(...e){const t=[...e],i={},n=(0,r.Jm)(e);"object"!=typeof n||Array.isArray(n)||n instanceof Date||!n||Object.assign(i,t.pop());ne(this,Array.isArray(t[0])?t[0]:t,i)}update(e){if(this.inline)return;const t={clear:!0,autohide:!(!e||!e.autohide)};ne(this,(0,r.W7)(this.inputField.value,this.config.dateDelimiter),t)}refresh(e,t=!1){let i;e&&"string"!=typeof e&&(t=e,e=void 0),i="picker"===e?2:"input"===e?1:3,re(this,i,!t)}enterEditMode(){this.inline||!this.picker.active||this.editMode||(this.editMode=!0,this.inputField.classList.add("in-edit","border-blue-700"))}exitEditMode(e){if(this.inline||!this.editMode)return;const t=Object.assign({update:!1},e);delete this.editMode,this.inputField.classList.remove("in-edit","border-blue-700"),t.update&&this.update(t)}}},963:function(e,t,i){i.d(t,{CL:function(){return a},p6:function(){return f},sG:function(){return g}});var r=i(560),n=i(105);const a=/dd?|DD?|mm?|MM?|yy?(?:yy)?/,s=/[\s!-/:-@[-`{-~年月日]+/;let o={};const d={y(e,t){return new Date(e).setFullYear(parseInt(t,10))},m(e,t,i){const r=new Date(e);let n=parseInt(t,10)-1;if(isNaN(n)){if(!t)return NaN;const e=t.toLowerCase(),r=t=>t.toLowerCase().startsWith(e);if(n=i.monthsShort.findIndex(r),n<0&&(n=i.months.findIndex(r)),n<0)return NaN}return r.setMonth(n),r.getMonth()!==l(n)?r.setDate(0):r.getTime()},d(e,t){return new Date(e).setDate(parseInt(t,10))}},c={d(e){return e.getDate()},dd(e){return h(e.getDate(),2)},D(e,t){return t.daysShort[e.getDay()]},DD(e,t){return t.days[e.getDay()]},m(e){return e.getMonth()+1},mm(e){return h(e.getMonth()+1,2)},M(e,t){return t.monthsShort[e.getMonth()]},MM(e,t){return t.months[e.getMonth()]},y(e){return e.getFullYear()},yy(e){return h(e.getFullYear(),2).slice(-2)},yyyy(e){return h(e.getFullYear(),4)}};function l(e){return e>-1?e%12:l(e+12)}function h(e,t){return e.toString().padStart(t,"0")}function u(e){if("string"!=typeof e)throw new Error("Invalid date format.");if(e in o)return o[e];const t=e.split(a),i=e.match(new RegExp(a,"g"));if(0===t.length||!i)throw new Error("Invalid date format.");const l=i.map((e=>c[e])),h=Object.keys(d).reduce(((e,t)=>(i.find((e=>"D"!==e[0]&&e[0].toLowerCase()===t))&&e.push(t),e)),[]);return o[e]={parser(e,t){const n=e.split(s).reduce(((e,t,r)=>{if(t.length>0&&i[r]){const n=i[r][0];"M"===n?e.m=t:"D"!==n&&(e[n]=t)}return e}),{});return h.reduce(((e,i)=>{const r=d[i](e,n[i],t);return isNaN(r)?e:r}),(0,r.Lg)())},formatter(e,i){return l.reduce(((r,n,a)=>r+`${t[a]}${n(e,i)}`),"")+(0,n.Jm)(t)}}}function g(e,t,i){if(e instanceof Date||"number"==typeof e){const t=(0,r.xR)(e);return isNaN(t)?void 0:t}if(e){if("today"===e)return(0,r.Lg)();if(t&&t.toValue){const n=t.toValue(e,t,i);return isNaN(n)?void 0:(0,r.xR)(n)}return u(t).parser(e,i)}}function f(e,t,i){if(isNaN(e)||!e&&0!==e)return"";const r="number"==typeof e?new Date(e):e;return t.toDisplay?t.toDisplay(r,t,i):u(t).formatter(r,i)}},560:function(e,t,i){function r(e){return new Date(e).setHours(0,0,0,0)}function n(){return(new Date).setHours(0,0,0,0)}function a(...e){switch(e.length){case 0:return n();case 1:return r(e[0])}const t=new Date(0);return t.setFullYear(...e),t.setHours(0,0,0,0)}function s(e,t){const i=new Date(e);return i.setDate(i.getDate()+t)}function o(e,t){return s(e,7*t)}function d(e,t){const i=new Date(e),r=i.getMonth()+t;let n=r%12;n<0&&(n+=12);const a=i.setMonth(r);return i.getMonth()!==n?i.setDate(0):a}function c(e,t){const i=new Date(e),r=i.getMonth(),n=i.setFullYear(i.getFullYear()+t);return 1===r&&2===i.getMonth()?i.setDate(0):n}function l(e,t){return(e-t+7)%7}function h(e,t,i=0){const r=new Date(e).getDay();return s(e,l(t,i)-l(r,i))}function u(e){const t=h(e,4,1),i=h(new Date(t).setMonth(0,4),4,1);return Math.round((t-i)/6048e5)+1}function g(e,t){const i=new Date(e).getFullYear();return Math.floor(i/t)*t}i.d(t,{Bc:function(){return c},E4:function(){return s},Lg:function(){return n},Qk:function(){return u},ak:function(){return g},by:function(){return a},fr:function(){return h},jh:function(){return o},xR:function(){return r},zI:function(){return d}})},698:function(e,t,i){i.d(t,{He:function(){return c},cF:function(){return s},uV:function(){return o}});const r=new WeakMap,{addEventListener:n,removeEventListener:a}=EventTarget.prototype;function s(e,t){let i=r.get(e);i||(i=[],r.set(e,i)),t.forEach((e=>{n.call(...e),i.push(e)}))}function o(e){let t=r.get(e);t&&(t.forEach((e=>{a.call(...e)})),r.delete(e))}if(!Event.prototype.composedPath){const e=(t,i=[])=>{let r;return i.push(t),t.parentNode?r=t.parentNode:t.host?r=t.host:t.defaultView&&(r=t.defaultView),r?e(r,i):i};Event.prototype.composedPath=function(){return e(this.target)}}function d(e,t,i,r=0){const n=e[r];return t(n)?n:n!==i&&n.parentElement?d(e,t,i,r+1):void 0}function c(e,t){const i="function"==typeof t?t:e=>e.matches(t);return d(e.composedPath(),i,e.currentTarget)}},105:function(e,t,i){function r(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function n(e){return e[e.length-1]}function a(e,...t){return t.forEach((t=>{e.includes(t)||e.push(t)})),e}function s(e,t){return e?e.split(t):[]}function o(e,t,i){return(void 0===t||e>=t)&&(void 0===i||e<=i)}function d(e,t,i){return ei?i:e}function c(e,t,i={},r=0,n=""){n+=`<${Object.keys(i).reduce(((e,t)=>{let n=i[t];return"function"==typeof n&&(n=n(r)),`${e} ${t}="${n}"`}),e)}>`;const a=r+1;return a\s+/g,">").replace(/\s+ .tooltip-arrow:before { + border-style: solid; + border-color: #e5e7eb; +} + +[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='top'] > .tooltip-arrow:before { + border-bottom-width: 1px; + border-right-width: 1px; +} + +[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='right'] > .tooltip-arrow:before { + border-bottom-width: 1px; + border-left-width: 1px; +} + +[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='bottom'] > .tooltip-arrow:before { + border-top-width: 1px; + border-left-width: 1px; +} + +[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='left'] > .tooltip-arrow:before { + border-top-width: 1px; + border-right-width: 1px; +} + +.tooltip[data-popper-placement^='top'] > .tooltip-arrow { + bottom: -4px; +} + +.tooltip[data-popper-placement^='bottom'] > .tooltip-arrow { + top: -4px; +} + +.tooltip[data-popper-placement^='left'] > .tooltip-arrow { + right: -4px; +} + +.tooltip[data-popper-placement^='right'] > .tooltip-arrow { + left: -4px; +} + +.tooltip.invisible > .tooltip-arrow:before { + visibility: hidden; +} + +[data-popper-arrow],[data-popper-arrow]:before { + position: absolute; + width: 8px; + height: 8px; + background: inherit; +} + +[data-popper-arrow] { + visibility: hidden; +} + +[data-popper-arrow]:before { + content: ""; + visibility: visible; + transform: rotate(45deg); +} + +[data-popper-arrow]:after { + content: ""; + visibility: visible; + transform: rotate(45deg); + position: absolute; + width: 9px; + height: 9px; + background: inherit; +} + +[role="tooltip"] > [data-popper-arrow]:before { + border-style: solid; + border-color: #e5e7eb; +} + +.dark [role="tooltip"] > [data-popper-arrow]:before { + border-style: solid; + border-color: #4b5563; +} + +[role="tooltip"] > [data-popper-arrow]:after { + border-style: solid; + border-color: #e5e7eb; +} + +.dark [role="tooltip"] > [data-popper-arrow]:after { + border-style: solid; + border-color: #4b5563; +} + +[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:before { + border-bottom-width: 1px; + border-right-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:after { + border-bottom-width: 1px; + border-right-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:before { + border-bottom-width: 1px; + border-left-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:after { + border-bottom-width: 1px; + border-left-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:before { + border-top-width: 1px; + border-left-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:after { + border-top-width: 1px; + border-left-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:before { + border-top-width: 1px; + border-right-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:after { + border-top-width: 1px; + border-right-width: 1px; +} + +[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow] { + bottom: -5px; +} + +[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow] { + top: -5px; +} + +[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow] { + right: -5px; +} + +[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow] { + left: -5px; +} + +[role="tooltip"].invisible > [data-popper-arrow]:before { + visibility: hidden; +} + +[role="tooltip"].invisible > [data-popper-arrow]:after { + visibility: hidden; +} + +[type='text'],[type='email'],[type='url'],[type='password'],[type='number'],[type='date'],[type='datetime-local'],[type='month'],[type='search'],[type='tel'],[type='time'],[type='week'],[multiple],textarea,select { + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + background-color: #fff; + border-color: #6B7280; + border-width: 1px; + border-radius: 0px; + padding-top: 0.5rem; + padding-right: 0.75rem; + padding-bottom: 0.5rem; + padding-left: 0.75rem; + font-size: 1rem; + line-height: 1.5rem; + --tw-shadow: 0 0 #0000; +} + +[type='text']:focus, [type='email']:focus, [type='url']:focus, [type='password']:focus, [type='number']:focus, [type='date']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='week']:focus, [multiple]:focus, textarea:focus, select:focus { + outline: 2px solid transparent; + outline-offset: 2px; + --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/); + --tw-ring-offset-width: 0px; + --tw-ring-offset-color: #fff; + --tw-ring-color: #1C64F2; + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow); + border-color: #1C64F2; +} + +input::-moz-placeholder, textarea::-moz-placeholder { + color: #6B7280; + opacity: 1; +} + +input::placeholder,textarea::placeholder { + color: #6B7280; + opacity: 1; +} + +::-webkit-datetime-edit-fields-wrapper { + padding: 0; +} + +::-webkit-date-and-time-value { + min-height: 1.5em; +} + +select:not([size]) { + background-image: url("data:image/svg+xml,%3csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 10 6'%3e %3cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 1 4 4 4-4'/%3e %3c/svg%3e"); + background-position: right 0.75rem center; + background-repeat: no-repeat; + background-size: 0.75em 0.75em; + padding-right: 2.5rem; + -webkit-print-color-adjust: exact; + print-color-adjust: exact; +} + +[multiple] { + background-image: initial; + background-position: initial; + background-repeat: unset; + background-size: initial; + padding-right: 0.75rem; + -webkit-print-color-adjust: unset; + print-color-adjust: unset; +} + +[type='checkbox'],[type='radio'] { + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + padding: 0; + -webkit-print-color-adjust: exact; + print-color-adjust: exact; + display: inline-block; + vertical-align: middle; + background-origin: border-box; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + flex-shrink: 0; + height: 1rem; + width: 1rem; + color: #1C64F2; + background-color: #fff; + border-color: #6B7280; + border-width: 1px; + --tw-shadow: 0 0 #0000; +} + +[type='checkbox'] { + border-radius: 0px; +} + +[type='radio'] { + border-radius: 100%; +} + +[type='checkbox']:focus,[type='radio']:focus { + outline: 2px solid transparent; + outline-offset: 2px; + --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/); + --tw-ring-offset-width: 2px; + --tw-ring-offset-color: #fff; + --tw-ring-color: #1C64F2; + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow); +} + +[type='checkbox']:checked,[type='radio']:checked,.dark [type='checkbox']:checked,.dark [type='radio']:checked { + border-color: transparent; + background-color: currentColor; + background-size: 0.55em 0.55em; + background-position: center; + background-repeat: no-repeat; +} + +[type='checkbox']:checked { + background-image: url("data:image/svg+xml,%3csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 12'%3e %3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M1 5.917 5.724 10.5 15 1.5'/%3e %3c/svg%3e"); + background-repeat: no-repeat; + background-size: 0.55em 0.55em; + -webkit-print-color-adjust: exact; + print-color-adjust: exact; +} + +[type='radio']:checked { + background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e"); + background-size: 1em 1em; +} + +.dark [type='radio']:checked { + background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e"); + background-size: 1em 1em; +} + +[type='checkbox']:indeterminate { + background-image: url("data:image/svg+xml,%3csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 12'%3e %3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M1 5.917 5.724 10.5 15 1.5'/%3e %3c/svg%3e"); + background-color: currentColor; + border-color: transparent; + background-position: center; + background-repeat: no-repeat; + background-size: 0.55em 0.55em; + -webkit-print-color-adjust: exact; + print-color-adjust: exact; +} + +[type='checkbox']:indeterminate:hover,[type='checkbox']:indeterminate:focus { + border-color: transparent; + background-color: currentColor; +} + +[type='file'] { + background: unset; + border-color: inherit; + border-width: 0; + border-radius: 0; + padding: 0; + font-size: unset; + line-height: inherit; +} + +[type='file']:focus { + outline: 1px auto inherit; +} + +input[type=file]::file-selector-button { + color: white; + background: #1F2937; + border: 0; + font-weight: 500; + font-size: 0.875rem; + cursor: pointer; + padding-top: 0.625rem; + padding-bottom: 0.625rem; + padding-left: 2rem; + padding-right: 1rem; + -webkit-margin-start: -1rem; + margin-inline-start: -1rem; + -webkit-margin-end: 1rem; + margin-inline-end: 1rem; +} + +input[type=file]::file-selector-button:hover { + background: #374151; +} + +.dark input[type=file]::file-selector-button { + color: white; + background: #4B5563; +} + +.dark input[type=file]::file-selector-button:hover { + background: #6B7280; +} + +input[type="range"]::-webkit-slider-thumb { + height: 1.25rem; + width: 1.25rem; + background: #1C64F2; + border-radius: 9999px; + border: 0; + appearance: none; + -moz-appearance: none; + -webkit-appearance: none; + cursor: pointer; +} + +input[type="range"]:disabled::-webkit-slider-thumb { + background: #9CA3AF; +} + +.dark input[type="range"]:disabled::-webkit-slider-thumb { + background: #6B7280; +} + +input[type="range"]:focus::-webkit-slider-thumb { + outline: 2px solid transparent; + outline-offset: 2px; + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); + --tw-ring-opacity: 1px; + --tw-ring-color: rgb(164 202 254 / var(--tw-ring-opacity)); +} + +input[type="range"]::-moz-range-thumb { + height: 1.25rem; + width: 1.25rem; + background: #1C64F2; + border-radius: 9999px; + border: 0; + appearance: none; + -moz-appearance: none; + -webkit-appearance: none; + cursor: pointer; +} + +input[type="range"]:disabled::-moz-range-thumb { + background: #9CA3AF; +} + +.dark input[type="range"]:disabled::-moz-range-thumb { + background: #6B7280; +} + +input[type="range"]::-moz-range-progress { + background: #3F83F8; +} + +input[type="range"]::-ms-fill-lower { + background: #3F83F8; +} + +input[type="range"].range-sm::-webkit-slider-thumb { + height: 1rem; + width: 1rem; +} + +input[type="range"].range-lg::-webkit-slider-thumb { + height: 1.5rem; + width: 1.5rem; +} + +input[type="range"].range-sm::-moz-range-thumb { + height: 1rem; + width: 1rem; +} + +input[type="range"].range-lg::-moz-range-thumb { + height: 1.5rem; + width: 1.5rem; +} + +.toggle-bg:after { + content: ""; + position: absolute; + top: 0.125rem; + left: 0.125rem; + background: white; + border-color: #D1D5DB; + border-width: 1px; + border-radius: 9999px; + height: 1.25rem; + width: 1.25rem; + transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter; + transition-duration: .15s; + box-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color); +} + +input:checked + .toggle-bg:after { + transform: translateX(100%);; + border-color: white; +} + +input:checked + .toggle-bg { + background: #1C64F2; + border-color: #1C64F2; +} + +*, ::before, ::after { + --tw-border-spacing-x: 0; + --tw-border-spacing-y: 0; + --tw-translate-x: 0; + --tw-translate-y: 0; + --tw-rotate: 0; + --tw-skew-x: 0; + --tw-skew-y: 0; + --tw-scale-x: 1; + --tw-scale-y: 1; + --tw-pan-x: ; + --tw-pan-y: ; + --tw-pinch-zoom: ; + --tw-scroll-snap-strictness: proximity; + --tw-ordinal: ; + --tw-slashed-zero: ; + --tw-numeric-figure: ; + --tw-numeric-spacing: ; + --tw-numeric-fraction: ; + --tw-ring-inset: ; + --tw-ring-offset-width: 0px; + --tw-ring-offset-color: #fff; + --tw-ring-color: rgb(63 131 248 / 0.5); + --tw-ring-offset-shadow: 0 0 #0000; + --tw-ring-shadow: 0 0 #0000; + --tw-shadow: 0 0 #0000; + --tw-shadow-colored: 0 0 #0000; + --tw-blur: ; + --tw-brightness: ; + --tw-contrast: ; + --tw-grayscale: ; + --tw-hue-rotate: ; + --tw-invert: ; + --tw-saturate: ; + --tw-sepia: ; + --tw-drop-shadow: ; + --tw-backdrop-blur: ; + --tw-backdrop-brightness: ; + --tw-backdrop-contrast: ; + --tw-backdrop-grayscale: ; + --tw-backdrop-hue-rotate: ; + --tw-backdrop-invert: ; + --tw-backdrop-opacity: ; + --tw-backdrop-saturate: ; + --tw-backdrop-sepia: ; +} + +::backdrop { + --tw-border-spacing-x: 0; + --tw-border-spacing-y: 0; + --tw-translate-x: 0; + --tw-translate-y: 0; + --tw-rotate: 0; + --tw-skew-x: 0; + --tw-skew-y: 0; + --tw-scale-x: 1; + --tw-scale-y: 1; + --tw-pan-x: ; + --tw-pan-y: ; + --tw-pinch-zoom: ; + --tw-scroll-snap-strictness: proximity; + --tw-ordinal: ; + --tw-slashed-zero: ; + --tw-numeric-figure: ; + --tw-numeric-spacing: ; + --tw-numeric-fraction: ; + --tw-ring-inset: ; + --tw-ring-offset-width: 0px; + --tw-ring-offset-color: #fff; + --tw-ring-color: rgb(63 131 248 / 0.5); + --tw-ring-offset-shadow: 0 0 #0000; + --tw-ring-shadow: 0 0 #0000; + --tw-shadow: 0 0 #0000; + --tw-shadow-colored: 0 0 #0000; + --tw-blur: ; + --tw-brightness: ; + --tw-contrast: ; + --tw-grayscale: ; + --tw-hue-rotate: ; + --tw-invert: ; + --tw-saturate: ; + --tw-sepia: ; + --tw-drop-shadow: ; + --tw-backdrop-blur: ; + --tw-backdrop-brightness: ; + --tw-backdrop-contrast: ; + --tw-backdrop-grayscale: ; + --tw-backdrop-hue-rotate: ; + --tw-backdrop-invert: ; + --tw-backdrop-opacity: ; + --tw-backdrop-saturate: ; + --tw-backdrop-sepia: ; +} +.container { + width: 100%; +} +@media (min-width: 640px) { + + .container { + max-width: 640px; + } +} +@media (min-width: 768px) { + + .container { + max-width: 768px; + } +} +@media (min-width: 1024px) { + + .container { + max-width: 1024px; + } +} +@media (min-width: 1280px) { + + .container { + max-width: 1280px; + } +} +@media (min-width: 1536px) { + + .container { + max-width: 1536px; + } +} +.apexcharts-canvas .apexcharts-tooltip { + background-color: white; + color: #6B7280; + border: 0 !important; + border-radius: 0.25rem; + box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); +} +.dark .apexcharts-canvas .apexcharts-tooltip { + background-color: #374151; + color: #9CA3AF; + border-color: transparent; + box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); +} +.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title { + padding-top: 0.5rem; + padding-bottom: 0.5rem; + padding-right: 0.75rem; + padding-left: 0.75rem; + margin-bottom: 0.75rem; + background-color: #F3F4F6; + border-bottom-color: #E5E7EB; + font-size: 0.875rem !important; + font-weight: 400; + color: #6B7280; +} +.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title { + background-color: #4B5563; + border-color: #6B7280; + color: #9CA3AF; +} +.apexcharts-canvas .apexcharts-xaxistooltip { + color: #6B7280; + padding-top: 0.5rem; + padding-bottom: 0.5rem; + padding-right: 0.75rem; + padding-left: 0.75rem; + border-color: transparent; + background-color: white; + border-radius: 0.25rem; + box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); +} +.dark .apexcharts-canvas .apexcharts-xaxistooltip { + color: #9CA3AF; + background-color: #374151; +} +.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label { + color: #6B7280; + font-size: 0.875rem; +} +.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label { + color: #9CA3AF; +} +.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value { + color: #111827; + font-size: 0.875rem; +} +.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value { + color: white; +} +.apexcharts-canvas .apexcharts-xaxistooltip-text { + font-weight: 400; + font-size: 0.875rem !important; +} +.apexcharts-canvas .apexcharts-xaxistooltip:after, .apexcharts-canvas .apexcharts-xaxistooltip:before { + border-bottom-color: white; +} +.apexcharts-canvas .apexcharts-xaxistooltip:after { + border-width: 8px; + margin-left: -8px; +} +.apexcharts-canvas .apexcharts-xaxistooltip:before { + border-width: 10px; + margin-left: -10px; +} +.dark .apexcharts-canvas .apexcharts-xaxistooltip:after, .dark .apexcharts-canvas .apexcharts-xaxistooltip:before { + border-bottom-color: #374151; +} +.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-y-group { + padding: 0; +} +.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active { + padding-left: 0.75rem; + padding-right: 0.75rem; + padding-bottom: 0.75rem; + background-color: white !important; + color: #6B7280 !important; +} +.dark .apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active { + background-color: #374151 !important; + color: #9CA3AF !important; +} +.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active:first-of-type { + padding-top: 0.75rem; +} +.apexcharts-canvas .apexcharts-legend { + padding: 0 !important; +} +.apexcharts-canvas .apexcharts-legend-text { + font-size: 0.75rem; + font-weight: 500 !important; + padding-left: 1.25rem; + color: #6B7280 !important; +} +.apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover { + color: #111827 !important; +} +.dark .apexcharts-canvas .apexcharts-legend-text { + color: #9CA3AF !important; +} +.dark .apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover { + color: white !important; +} +.apexcharts-canvas .apexcharts-legend-series { + margin-left: 0.5rem; + margin-right: 0.5rem; + margin-bottom: 0.25rem !important; + display: flex; + align-items: center; +} +.apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value { + fill: #111827 !important; + font-size: 1.875rem; + font-weight: 700; +} +.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value { + fill: white !important; +} +.apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label { + fill: #6B7280 !important; + font-size: 1rem; + font-weight: 400; +} +.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label { + fill: #9CA3AF !important; +} +.apexcharts-canvas .apexcharts-datalabels .apexcharts-text.apexcharts-pie-label { + font-size: 0.75rem !important; + font-weight: 600 !important; + text-shadow: none !important; + filter: none !important; +} +.apexcharts-gridline, .apexcharts-xcrosshairs, .apexcharts-ycrosshairs { + stroke: #E5E7EB !important; +} +.dark .apexcharts-gridline, .dark .apexcharts-xcrosshairs, .dark .apexcharts-ycrosshairs { + stroke: #374151 !important; +} +.sr-only { + position: absolute; + width: 1px; + height: 1px; + padding: 0; + margin: -1px; + overflow: hidden; + clip: rect(0, 0, 0, 0); + white-space: nowrap; + border-width: 0; +} +.pointer-events-none { + pointer-events: none; +} +.visible { + visibility: visible; +} +.invisible { + visibility: hidden; +} +.collapse { + visibility: collapse; +} +.static { + position: static; +} +.fixed { + position: fixed; +} +.absolute { + position: absolute; +} +.relative { + position: relative; +} +.sticky { + position: sticky; +} +.inset-0 { + inset: 0px; +} +.inset-y-0 { + top: 0px; + bottom: 0px; +} +.-left-1 { + left: -0.25rem; +} +.-left-1\.5 { + left: -0.375rem; +} +.-left-14 { + left: -3.5rem; +} +.-left-3 { + left: -0.75rem; +} +.-left-4 { + left: -1rem; +} +.-left-\[17px\] { + left: -17px; +} +.-right-2 { + right: -0.5rem; +} +.-right-\[16px\] { + right: -16px; +} +.-right-\[17px\] { + right: -17px; +} +.-top-2 { + top: -0.5rem; +} +.-top-\[140px\] { + top: -140px; +} +.bottom-0 { + bottom: 0px; +} +.bottom-2 { + bottom: 0.5rem; +} +.bottom-2\.5 { + bottom: 0.625rem; +} +.bottom-4 { + bottom: 1rem; +} +.bottom-5 { + bottom: 1.25rem; +} +.bottom-6 { + bottom: 1.5rem; +} +.bottom-\[\*px\] { + bottom: *px; +} +.bottom-\[60px\] { + bottom: 60px; +} +.left-0 { + left: 0px; +} +.left-1 { + left: 0.25rem; +} +.left-1\/2 { + left: 50%; +} +.left-2 { + left: 0.5rem; +} +.left-2\.5 { + left: 0.625rem; +} +.left-5 { + left: 1.25rem; +} +.left-6 { + left: 1.5rem; +} +.left-7 { + left: 1.75rem; +} +.left-8 { + left: 2rem; +} +.left-auto { + left: auto; +} +.right-0 { + right: 0px; +} +.right-1\/2 { + right: 50%; +} +.right-2 { + right: 0.5rem; +} +.right-2\.5 { + right: 0.625rem; +} +.right-24 { + right: 6rem; +} +.right-3 { + right: 0.75rem; +} +.right-5 { + right: 1.25rem; +} +.right-6 { + right: 1.5rem; +} +.right-auto { + right: auto; +} +.top-0 { + top: 0px; +} +.top-1 { + top: 0.25rem; +} +.top-1\/2 { + top: 50%; +} +.top-2 { + top: 0.5rem; +} +.top-2\.5 { + top: 0.625rem; +} +.top-2\/4 { + top: 50%; +} +.top-28 { + top: 7rem; +} +.top-3 { + top: 0.75rem; +} +.top-4 { + top: 1rem; +} +.top-5 { + top: 1.25rem; +} +.top-6 { + top: 1.5rem; +} +.top-\[124px\] { + top: 124px; +} +.top-\[142px\] { + top: 142px; +} +.top-\[178px\] { + top: 178px; +} +.top-\[40px\] { + top: 40px; +} +.top-\[72px\] { + top: 72px; +} +.top-\[88px\] { + top: 88px; +} +.-z-10 { + z-index: -10; +} +.z-0 { + z-index: 0; +} +.z-10 { + z-index: 10; +} +.z-20 { + z-index: 20; +} +.z-30 { + z-index: 30; +} +.z-40 { + z-index: 40; +} +.z-50 { + z-index: 50; +} +.col-span-1 { + grid-column: span 1 / span 1; +} +.col-span-2 { + grid-column: span 2 / span 2; +} +.col-span-3 { + grid-column: span 3 / span 3; +} +.col-span-6 { + grid-column: span 6 / span 6; +} +.m-2 { + margin: 0.5rem; +} +.m-2\.5 { + margin: 0.625rem; +} +.m-4 { + margin: 1rem; +} +.-mx-1 { + margin-left: -0.25rem; + margin-right: -0.25rem; +} +.-mx-1\.5 { + margin-left: -0.375rem; + margin-right: -0.375rem; +} +.-my-1 { + margin-top: -0.25rem; + margin-bottom: -0.25rem; +} +.-my-1\.5 { + margin-top: -0.375rem; + margin-bottom: -0.375rem; +} +.mx-1 { + margin-left: 0.25rem; + margin-right: 0.25rem; +} +.mx-1\.5 { + margin-left: 0.375rem; + margin-right: 0.375rem; +} +.mx-2 { + margin-left: 0.5rem; + margin-right: 0.5rem; +} +.mx-3 { + margin-left: 0.75rem; + margin-right: 0.75rem; +} +.mx-4 { + margin-left: 1rem; + margin-right: 1rem; +} +.mx-auto { + margin-left: auto; + margin-right: auto; +} +.my-10 { + margin-top: 2.5rem; + margin-bottom: 2.5rem; +} +.my-12 { + margin-top: 3rem; + margin-bottom: 3rem; +} +.my-2 { + margin-top: 0.5rem; + margin-bottom: 0.5rem; +} +.my-3 { + margin-top: 0.75rem; + margin-bottom: 0.75rem; +} +.my-4 { + margin-top: 1rem; + margin-bottom: 1rem; +} +.my-6 { + margin-top: 1.5rem; + margin-bottom: 1.5rem; +} +.my-7 { + margin-top: 1.75rem; + margin-bottom: 1.75rem; +} +.my-8 { + margin-top: 2rem; + margin-bottom: 2rem; +} +.-mb-5 { + margin-bottom: -1.25rem; +} +.-mb-px { + margin-bottom: -1px; +} +.-ml-0 { + margin-left: -0px; +} +.-ml-0\.5 { + margin-left: -0.125rem; +} +.-ml-1 { + margin-left: -0.25rem; +} +.-mr-0 { + margin-right: -0px; +} +.-mr-0\.5 { + margin-right: -0.125rem; +} +.-mr-1 { + margin-right: -0.25rem; +} +.-mt-1 { + margin-top: -0.25rem; +} +.-mt-5 { + margin-top: -1.25rem; +} +.mb-0 { + margin-bottom: 0px; +} +.mb-1 { + margin-bottom: 0.25rem; +} +.mb-1\.5 { + margin-bottom: 0.375rem; +} +.mb-10 { + margin-bottom: 2.5rem; +} +.mb-2 { + margin-bottom: 0.5rem; +} +.mb-2\.5 { + margin-bottom: 0.625rem; +} +.mb-3 { + margin-bottom: 0.75rem; +} +.mb-4 { + margin-bottom: 1rem; +} +.mb-5 { + margin-bottom: 1.25rem; +} +.mb-6 { + margin-bottom: 1.5rem; +} +.mb-7 { + margin-bottom: 1.75rem; +} +.mb-8 { + margin-bottom: 2rem; +} +.mb-px { + margin-bottom: 1px; +} +.ml-0 { + margin-left: 0px; +} +.ml-1 { + margin-left: 0.25rem; +} +.ml-1\.5 { + margin-left: 0.375rem; +} +.ml-2 { + margin-left: 0.5rem; +} +.ml-2\.5 { + margin-left: 0.625rem; +} +.ml-3 { + margin-left: 0.75rem; +} +.ml-4 { + margin-left: 1rem; +} +.ml-6 { + margin-left: 1.5rem; +} +.ml-auto { + margin-left: auto; +} +.mr-1 { + margin-right: 0.25rem; +} +.mr-1\.5 { + margin-right: 0.375rem; +} +.mr-2 { + margin-right: 0.5rem; +} +.mr-2\.5 { + margin-right: 0.625rem; +} +.mr-3 { + margin-right: 0.75rem; +} +.mr-4 { + margin-right: 1rem; +} +.mr-5 { + margin-right: 1.25rem; +} +.mr-6 { + margin-right: 1.5rem; +} +.mr-8 { + margin-right: 2rem; +} +.mr-auto { + margin-right: auto; +} +.mt-0 { + margin-top: 0px; +} +.mt-1 { + margin-top: 0.25rem; +} +.mt-1\.5 { + margin-top: 0.375rem; +} +.mt-10 { + margin-top: 2.5rem; +} +.mt-14 { + margin-top: 3.5rem; +} +.mt-2 { + margin-top: 0.5rem; +} +.mt-2\.5 { + margin-top: 0.625rem; +} +.mt-3 { + margin-top: 0.75rem; +} +.mt-4 { + margin-top: 1rem; +} +.mt-5 { + margin-top: 1.25rem; +} +.mt-6 { + margin-top: 1.5rem; +} +.mt-7 { + margin-top: 1.75rem; +} +.mt-8 { + margin-top: 2rem; +} +.mt-\[2px\] { + margin-top: 2px; +} +.block { + display: block; +} +.inline-block { + display: inline-block; +} +.inline { + display: inline; +} +.flex { + display: flex; +} +.inline-flex { + display: inline-flex; +} +.table { + display: table; +} +.flow-root { + display: flow-root; +} +.grid { + display: grid; +} +.contents { + display: contents; +} +.hidden { + display: none; +} +.h-0 { + height: 0px; +} +.h-0\.5 { + height: 0.125rem; +} +.h-1 { + height: 0.25rem; +} +.h-1\.5 { + height: 0.375rem; +} +.h-10 { + height: 2.5rem; +} +.h-11 { + height: 2.75rem; +} +.h-12 { + height: 3rem; +} +.h-14 { + height: 3.5rem; +} +.h-16 { + height: 4rem; +} +.h-2 { + height: 0.5rem; +} +.h-2\.5 { + height: 0.625rem; +} +.h-20 { + height: 5rem; +} +.h-24 { + height: 6rem; +} +.h-28 { + height: 7rem; +} +.h-3 { + height: 0.75rem; +} +.h-3\.5 { + height: 0.875rem; +} +.h-36 { + height: 9rem; +} +.h-4 { + height: 1rem; +} +.h-48 { + height: 12rem; +} +.h-5 { + height: 1.25rem; +} +.h-56 { + height: 14rem; +} +.h-6 { + height: 1.5rem; +} +.h-64 { + height: 16rem; +} +.h-7 { + height: 1.75rem; +} +.h-72 { + height: 18rem; +} +.h-8 { + height: 2rem; +} +.h-80 { + height: 20rem; +} +.h-9 { + height: 2.25rem; +} +.h-96 { + height: 24rem; +} +.h-\[1\.1rem\] { + height: 1.1rem; +} +.h-\[140px\] { + height: 140px; +} +.h-\[156px\] { + height: 156px; +} +.h-\[172px\] { + height: 172px; +} +.h-\[17px\] { + height: 17px; +} +.h-\[18px\] { + height: 18px; +} +.h-\[193px\] { + height: 193px; +} +.h-\[213px\] { + height: 213px; +} +.h-\[24px\] { + height: 24px; +} +.h-\[32px\] { + height: 32px; +} +.h-\[41px\] { + height: 41px; +} +.h-\[426px\] { + height: 426px; +} +.h-\[454px\] { + height: 454px; +} +.h-\[46px\] { + height: 46px; +} +.h-\[48px\] { + height: 48px; +} +.h-\[52px\] { + height: 52px; +} +.h-\[55px\] { + height: 55px; +} +.h-\[56px\] { + height: 56px; +} +.h-\[572px\] { + height: 572px; +} +.h-\[5px\] { + height: 5px; +} +.h-\[600px\] { + height: 600px; +} +.h-\[63px\] { + height: 63px; +} +.h-\[64px\] { + height: 64px; +} +.h-\[78px\] { + height: 78px; +} +.h-\[calc\(100\%-1rem\)\] { + height: calc(100% - 1rem); +} +.h-\[calc\(100vh-5rem\)\] { + height: calc(100vh - 5rem); +} +.h-auto { + height: auto; +} +.h-full { + height: 100%; +} +.h-px { + height: 1px; +} +.h-screen { + height: 100vh; +} +.max-h-72 { + max-height: 18rem; +} +.max-h-\[48px\] { + max-height: 48px; +} +.max-h-full { + max-height: 100%; +} +.w-1 { + width: 0.25rem; +} +.w-1\/2 { + width: 50%; +} +.w-10 { + width: 2.5rem; +} +.w-11 { + width: 2.75rem; +} +.w-12 { + width: 3rem; +} +.w-14 { + width: 3.5rem; +} +.w-2 { + width: 0.5rem; +} +.w-2\.5 { + width: 0.625rem; +} +.w-2\/4 { + width: 50%; +} +.w-20 { + width: 5rem; +} +.w-24 { + width: 6rem; +} +.w-3 { + width: 0.75rem; +} +.w-3\.5 { + width: 0.875rem; +} +.w-32 { + width: 8rem; +} +.w-36 { + width: 9rem; +} +.w-4 { + width: 1rem; +} +.w-44 { + width: 11rem; +} +.w-48 { + width: 12rem; +} +.w-5 { + width: 1.25rem; +} +.w-52 { + width: 13rem; +} +.w-56 { + width: 14rem; +} +.w-6 { + width: 1.5rem; +} +.w-60 { + width: 15rem; +} +.w-64 { + width: 16rem; +} +.w-7 { + width: 1.75rem; +} +.w-72 { + width: 18rem; +} +.w-8 { + width: 2rem; +} +.w-80 { + width: 20rem; +} +.w-9 { + width: 2.25rem; +} +.w-96 { + width: 24rem; +} +.w-\[1\.1rem\] { + width: 1.1rem; +} +.w-\[148px\] { + width: 148px; +} +.w-\[188px\] { + width: 188px; +} +.w-\[208px\] { + width: 208px; +} +.w-\[272px\] { + width: 272px; +} +.w-\[300px\] { + width: 300px; +} +.w-\[3px\] { + width: 3px; +} +.w-\[48px\] { + width: 48px; +} +.w-\[52px\] { + width: 52px; +} +.w-\[56px\] { + width: 56px; +} +.w-\[6px\] { + width: 6px; +} +.w-\[calc\(100\%-2rem\)\] { + width: calc(100% - 2rem); +} +.w-auto { + width: auto; +} +.w-full { + width: 100%; +} +.min-w-0 { + min-width: 0px; +} +.min-w-max { + min-width: -moz-max-content; + min-width: max-content; +} +.max-w-2xl { + max-width: 42rem; +} +.max-w-2xs { + max-width: 16rem; +} +.max-w-4xl { + max-width: 56rem; +} +.max-w-7xl { + max-width: 80rem; +} +.max-w-8xl { + max-width: 90rem; +} +.max-w-\[128px\] { + max-width: 128px; +} +.max-w-\[133px\] { + max-width: 133px; +} +.max-w-\[300px\] { + max-width: 300px; +} +.max-w-\[301px\] { + max-width: 301px; +} +.max-w-\[330px\] { + max-width: 330px; +} +.max-w-\[341px\] { + max-width: 341px; +} +.max-w-\[351px\] { + max-width: 351px; +} +.max-w-\[360px\] { + max-width: 360px; +} +.max-w-\[380px\] { + max-width: 380px; +} +.max-w-\[400px\] { + max-width: 400px; +} +.max-w-\[440px\] { + max-width: 440px; +} +.max-w-\[450px\] { + max-width: 450px; +} +.max-w-\[460px\] { + max-width: 460px; +} +.max-w-\[480px\] { + max-width: 480px; +} +.max-w-\[48px\] { + max-width: 48px; +} +.max-w-\[500px\] { + max-width: 500px; +} +.max-w-\[540px\] { + max-width: 540px; +} +.max-w-\[640px\] { + max-width: 640px; +} +.max-w-\[83px\] { + max-width: 83px; +} +.max-w-full { + max-width: 100%; +} +.max-w-lg { + max-width: 32rem; +} +.max-w-md { + max-width: 28rem; +} +.max-w-none { + max-width: none; +} +.max-w-screen-md { + max-width: 768px; +} +.max-w-screen-xl { + max-width: 1280px; +} +.max-w-sm { + max-width: 24rem; +} +.max-w-xl { + max-width: 36rem; +} +.max-w-xs { + max-width: 20rem; +} +.flex-1 { + flex: 1 1 0%; +} +.flex-auto { + flex: 1 1 auto; +} +.flex-none { + flex: none; +} +.flex-shrink-0 { + flex-shrink: 0; +} +.shrink-0 { + flex-shrink: 0; +} +.grow { + flex-grow: 1; +} +.origin-\[0\] { + transform-origin: 0; +} +.-translate-x-1\/2 { + --tw-translate-x: -50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-x-full { + --tw-translate-x: -100%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-y-1\/2 { + --tw-translate-y: -50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-y-3 { + --tw-translate-y: -0.75rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-y-4 { + --tw-translate-y: -1rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-y-6 { + --tw-translate-y: -1.5rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.-translate-y-full { + --tw-translate-y: -100%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-x-0 { + --tw-translate-x: 0px; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-x-1\/2 { + --tw-translate-x: 50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-x-full { + --tw-translate-x: 100%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-y-1\/2 { + --tw-translate-y: 50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-y-1\/4 { + --tw-translate-y: 25%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.translate-y-full { + --tw-translate-y: 100%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.rotate-180 { + --tw-rotate: 180deg; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.rotate-45 { + --tw-rotate: 45deg; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.rotate-90 { + --tw-rotate: 90deg; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.scale-75 { + --tw-scale-x: .75; + --tw-scale-y: .75; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.transform { + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} +.transform-none { + transform: none; +} +@keyframes pulse { + + 50% { + opacity: .5; + } +} +.animate-pulse { + animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; +} +@keyframes spin { + + to { + transform: rotate(360deg); + } +} +.animate-spin { + animation: spin 1s linear infinite; +} +.cursor-not-allowed { + cursor: not-allowed; +} +.cursor-pointer { + cursor: pointer; +} +.list-inside { + list-style-position: inside; +} +.list-decimal { + list-style-type: decimal; +} +.list-disc { + list-style-type: disc; +} +.list-none { + list-style-type: none; +} +.appearance-none { + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; +} +.grid-cols-1 { + grid-template-columns: repeat(1, minmax(0, 1fr)); +} +.grid-cols-10 { + grid-template-columns: repeat(10, minmax(0, 1fr)); +} +.grid-cols-2 { + grid-template-columns: repeat(2, minmax(0, 1fr)); +} +.grid-cols-3 { + grid-template-columns: repeat(3, minmax(0, 1fr)); +} +.grid-cols-4 { + grid-template-columns: repeat(4, minmax(0, 1fr)); +} +.grid-cols-5 { + grid-template-columns: repeat(5, minmax(0, 1fr)); +} +.grid-cols-6 { + grid-template-columns: repeat(6, minmax(0, 1fr)); +} +.grid-cols-7 { + grid-template-columns: repeat(7, minmax(0, 1fr)); +} +.flex-row { + flex-direction: row; +} +.flex-col { + flex-direction: column; +} +.flex-wrap { + flex-wrap: wrap; +} +.items-start { + align-items: flex-start; +} +.items-end { + align-items: flex-end; +} +.items-center { + align-items: center; +} +.items-baseline { + align-items: baseline; +} +.justify-start { + justify-content: flex-start; +} +.justify-end { + justify-content: flex-end; +} +.justify-center { + justify-content: center; +} +.justify-between { + justify-content: space-between; +} +.gap-1 { + gap: 0.25rem; +} +.gap-12 { + gap: 3rem; +} +.gap-16 { + gap: 4rem; +} +.gap-2 { + gap: 0.5rem; +} +.gap-3 { + gap: 0.75rem; +} +.gap-4 { + gap: 1rem; +} +.gap-5 { + gap: 1.25rem; +} +.gap-6 { + gap: 1.5rem; +} +.gap-8 { + gap: 2rem; +} +.gap-x-16 { + -moz-column-gap: 4rem; + column-gap: 4rem; +} +.gap-x-4 { + -moz-column-gap: 1rem; + column-gap: 1rem; +} +.gap-y-3 { + row-gap: 0.75rem; +} +.-space-x-3 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(-0.75rem * var(--tw-space-x-reverse)); + margin-left: calc(-0.75rem * calc(1 - var(--tw-space-x-reverse))); +} +.-space-x-4 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(-1rem * var(--tw-space-x-reverse)); + margin-left: calc(-1rem * calc(1 - var(--tw-space-x-reverse))); +} +.-space-x-px > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(-1px * var(--tw-space-x-reverse)); + margin-left: calc(-1px * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-1 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.25rem * var(--tw-space-x-reverse)); + margin-left: calc(0.25rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-2 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.5rem * var(--tw-space-x-reverse)); + margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-2\.5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.625rem * var(--tw-space-x-reverse)); + margin-left: calc(0.625rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-3 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.75rem * var(--tw-space-x-reverse)); + margin-left: calc(0.75rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-4 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(1rem * var(--tw-space-x-reverse)); + margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(1.25rem * var(--tw-space-x-reverse)); + margin-left: calc(1.25rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-6 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(1.5rem * var(--tw-space-x-reverse)); + margin-left: calc(1.5rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-x-8 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(2rem * var(--tw-space-x-reverse)); + margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse))); +} +.space-y-0 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0px * var(--tw-space-y-reverse)); +} +.space-y-0\.5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.125rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.125rem * var(--tw-space-y-reverse)); +} +.space-y-1 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.25rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.25rem * var(--tw-space-y-reverse)); +} +.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.375rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.375rem * var(--tw-space-y-reverse)); +} +.space-y-2 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.5rem * var(--tw-space-y-reverse)); +} +.space-y-2\.5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.625rem * var(--tw-space-y-reverse)); +} +.space-y-3 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0.75rem * var(--tw-space-y-reverse)); +} +.space-y-4 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(1rem * var(--tw-space-y-reverse)); +} +.space-y-5 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(1.25rem * var(--tw-space-y-reverse)); +} +.space-y-6 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(1.5rem * var(--tw-space-y-reverse)); +} +.space-y-8 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(2rem * var(--tw-space-y-reverse)); +} +.divide-x > :not([hidden]) ~ :not([hidden]) { + --tw-divide-x-reverse: 0; + border-right-width: calc(1px * var(--tw-divide-x-reverse)); + border-left-width: calc(1px * calc(1 - var(--tw-divide-x-reverse))); +} +.divide-x-2 > :not([hidden]) ~ :not([hidden]) { + --tw-divide-x-reverse: 0; + border-right-width: calc(2px * var(--tw-divide-x-reverse)); + border-left-width: calc(2px * calc(1 - var(--tw-divide-x-reverse))); +} +.divide-y > :not([hidden]) ~ :not([hidden]) { + --tw-divide-y-reverse: 0; + border-top-width: calc(1px * calc(1 - var(--tw-divide-y-reverse))); + border-bottom-width: calc(1px * var(--tw-divide-y-reverse)); +} +.divide-gray-100 > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(243 244 246 / var(--tw-divide-opacity)); +} +.divide-gray-200 > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(229 231 235 / var(--tw-divide-opacity)); +} +.divide-gray-300 > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(209 213 219 / var(--tw-divide-opacity)); +} +.divide-gray-500 > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(107 114 128 / var(--tw-divide-opacity)); +} +.place-self-center { + place-self: center; +} +.self-center { + align-self: center; +} +.overflow-hidden { + overflow: hidden; +} +.overflow-x-auto { + overflow-x: auto; +} +.overflow-y-auto { + overflow-y: auto; +} +.overflow-x-hidden { + overflow-x: hidden; +} +.overflow-y-scroll { + overflow-y: scroll; +} +.truncate { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} +.whitespace-normal { + white-space: normal; +} +.whitespace-nowrap { + white-space: nowrap; +} +.whitespace-pre-line { + white-space: pre-line; +} +.rounded { + border-radius: 0.25rem; +} +.rounded-\[2\.5rem\] { + border-radius: 2.5rem; +} +.rounded-\[2rem\] { + border-radius: 2rem; +} +.rounded-full { + border-radius: 9999px; +} +.rounded-lg { + border-radius: 0.5rem; +} +.rounded-md { + border-radius: 0.375rem; +} +.rounded-none { + border-radius: 0px; +} +.rounded-sm { + border-radius: 0.125rem; +} +.rounded-xl { + border-radius: 0.75rem; +} +.rounded-b { + border-bottom-right-radius: 0.25rem; + border-bottom-left-radius: 0.25rem; +} +.rounded-b-\[1rem\] { + border-bottom-right-radius: 1rem; + border-bottom-left-radius: 1rem; +} +.rounded-b-\[2\.5rem\] { + border-bottom-right-radius: 2.5rem; + border-bottom-left-radius: 2.5rem; +} +.rounded-b-lg { + border-bottom-right-radius: 0.5rem; + border-bottom-left-radius: 0.5rem; +} +.rounded-b-xl { + border-bottom-right-radius: 0.75rem; + border-bottom-left-radius: 0.75rem; +} +.rounded-l { + border-top-left-radius: 0.25rem; + border-bottom-left-radius: 0.25rem; +} +.rounded-l-full { + border-top-left-radius: 9999px; + border-bottom-left-radius: 9999px; +} +.rounded-l-lg { + border-top-left-radius: 0.5rem; + border-bottom-left-radius: 0.5rem; +} +.rounded-l-md { + border-top-left-radius: 0.375rem; + border-bottom-left-radius: 0.375rem; +} +.rounded-r { + border-top-right-radius: 0.25rem; + border-bottom-right-radius: 0.25rem; +} +.rounded-r-full { + border-top-right-radius: 9999px; + border-bottom-right-radius: 9999px; +} +.rounded-r-lg { + border-top-right-radius: 0.5rem; + border-bottom-right-radius: 0.5rem; +} +.rounded-r-md { + border-top-right-radius: 0.375rem; + border-bottom-right-radius: 0.375rem; +} +.rounded-t { + border-top-left-radius: 0.25rem; + border-top-right-radius: 0.25rem; +} +.rounded-t-\[2\.5rem\] { + border-top-left-radius: 2.5rem; + border-top-right-radius: 2.5rem; +} +.rounded-t-lg { + border-top-left-radius: 0.5rem; + border-top-right-radius: 0.5rem; +} +.rounded-t-md { + border-top-left-radius: 0.375rem; + border-top-right-radius: 0.375rem; +} +.rounded-t-sm { + border-top-left-radius: 0.125rem; + border-top-right-radius: 0.125rem; +} +.rounded-t-xl { + border-top-left-radius: 0.75rem; + border-top-right-radius: 0.75rem; +} +.rounded-bl-lg { + border-bottom-left-radius: 0.5rem; +} +.rounded-tl-lg { + border-top-left-radius: 0.5rem; +} +.rounded-tr-lg { + border-top-right-radius: 0.5rem; +} +.border { + border-width: 1px; +} +.border-0 { + border-width: 0px; +} +.border-2 { + border-width: 2px; +} +.border-\[10px\] { + border-width: 10px; +} +.border-\[14px\] { + border-width: 14px; +} +.border-\[16px\] { + border-width: 16px; +} +.border-\[8px\] { + border-width: 8px; +} +.border-x { + border-left-width: 1px; + border-right-width: 1px; +} +.border-y { + border-top-width: 1px; + border-bottom-width: 1px; +} +.border-b { + border-bottom-width: 1px; +} +.border-b-0 { + border-bottom-width: 0px; +} +.border-b-2 { + border-bottom-width: 2px; +} +.border-l { + border-left-width: 1px; +} +.border-l-2 { + border-left-width: 2px; +} +.border-l-4 { + border-left-width: 4px; +} +.border-r { + border-right-width: 1px; +} +.border-r-0 { + border-right-width: 0px; +} +.border-t { + border-top-width: 1px; +} +.border-t-0 { + border-top-width: 0px; +} +.border-t-4 { + border-top-width: 4px; +} +.border-dashed { + border-style: dashed; +} +.\!border-blue-700 { + --tw-border-opacity: 1 !important; + border-color: rgb(26 86 219 / var(--tw-border-opacity)) !important; +} +.border-blue-100 { + --tw-border-opacity: 1; + border-color: rgb(225 239 254 / var(--tw-border-opacity)); +} +.border-blue-300 { + --tw-border-opacity: 1; + border-color: rgb(164 202 254 / var(--tw-border-opacity)); +} +.border-blue-400 { + --tw-border-opacity: 1; + border-color: rgb(118 169 250 / var(--tw-border-opacity)); +} +.border-blue-600 { + --tw-border-opacity: 1; + border-color: rgb(28 100 242 / var(--tw-border-opacity)); +} +.border-blue-700 { + --tw-border-opacity: 1; + border-color: rgb(26 86 219 / var(--tw-border-opacity)); +} +.border-blue-800 { + --tw-border-opacity: 1; + border-color: rgb(30 66 159 / var(--tw-border-opacity)); +} +.border-gray-100 { + --tw-border-opacity: 1; + border-color: rgb(243 244 246 / var(--tw-border-opacity)); +} +.border-gray-200 { + --tw-border-opacity: 1; + border-color: rgb(229 231 235 / var(--tw-border-opacity)); +} +.border-gray-300 { + --tw-border-opacity: 1; + border-color: rgb(209 213 219 / var(--tw-border-opacity)); +} +.border-gray-500 { + --tw-border-opacity: 1; + border-color: rgb(107 114 128 / var(--tw-border-opacity)); +} +.border-gray-700 { + --tw-border-opacity: 1; + border-color: rgb(55 65 81 / var(--tw-border-opacity)); +} +.border-gray-800 { + --tw-border-opacity: 1; + border-color: rgb(31 41 55 / var(--tw-border-opacity)); +} +.border-gray-900 { + --tw-border-opacity: 1; + border-color: rgb(17 24 39 / var(--tw-border-opacity)); +} +.border-green-300 { + --tw-border-opacity: 1; + border-color: rgb(132 225 188 / var(--tw-border-opacity)); +} +.border-green-400 { + --tw-border-opacity: 1; + border-color: rgb(49 196 141 / var(--tw-border-opacity)); +} +.border-green-500 { + --tw-border-opacity: 1; + border-color: rgb(14 159 110 / var(--tw-border-opacity)); +} +.border-green-600 { + --tw-border-opacity: 1; + border-color: rgb(5 122 85 / var(--tw-border-opacity)); +} +.border-green-700 { + --tw-border-opacity: 1; + border-color: rgb(4 108 78 / var(--tw-border-opacity)); +} +.border-green-800 { + --tw-border-opacity: 1; + border-color: rgb(3 84 63 / var(--tw-border-opacity)); +} +.border-indigo-400 { + --tw-border-opacity: 1; + border-color: rgb(141 162 251 / var(--tw-border-opacity)); +} +.border-pink-400 { + --tw-border-opacity: 1; + border-color: rgb(241 126 184 / var(--tw-border-opacity)); +} +.border-purple-400 { + --tw-border-opacity: 1; + border-color: rgb(172 148 250 / var(--tw-border-opacity)); +} +.border-purple-700 { + --tw-border-opacity: 1; + border-color: rgb(108 43 217 / var(--tw-border-opacity)); +} +.border-red-300 { + --tw-border-opacity: 1; + border-color: rgb(248 180 180 / var(--tw-border-opacity)); +} +.border-red-400 { + --tw-border-opacity: 1; + border-color: rgb(249 128 128 / var(--tw-border-opacity)); +} +.border-red-500 { + --tw-border-opacity: 1; + border-color: rgb(240 82 82 / var(--tw-border-opacity)); +} +.border-red-600 { + --tw-border-opacity: 1; + border-color: rgb(224 36 36 / var(--tw-border-opacity)); +} +.border-red-700 { + --tw-border-opacity: 1; + border-color: rgb(200 30 30 / var(--tw-border-opacity)); +} +.border-red-800 { + --tw-border-opacity: 1; + border-color: rgb(155 28 28 / var(--tw-border-opacity)); +} +.border-transparent { + border-color: transparent; +} +.border-white { + --tw-border-opacity: 1; + border-color: rgb(255 255 255 / var(--tw-border-opacity)); +} +.border-yellow-300 { + --tw-border-opacity: 1; + border-color: rgb(250 202 21 / var(--tw-border-opacity)); +} +.border-yellow-400 { + --tw-border-opacity: 1; + border-color: rgb(227 160 8 / var(--tw-border-opacity)); +} +.border-yellow-800 { + --tw-border-opacity: 1; + border-color: rgb(114 59 19 / var(--tw-border-opacity)); +} +.border-l-gray-100 { + --tw-border-opacity: 1; + border-left-color: rgb(243 244 246 / var(--tw-border-opacity)); +} +.border-l-gray-50 { + --tw-border-opacity: 1; + border-left-color: rgb(249 250 251 / var(--tw-border-opacity)); +} +.bg-\[\#050708\] { + --tw-bg-opacity: 1; + background-color: rgb(5 7 8 / var(--tw-bg-opacity)); +} +.bg-\[\#1da1f2\] { + --tw-bg-opacity: 1; + background-color: rgb(29 161 242 / var(--tw-bg-opacity)); +} +.bg-\[\#24292F\] { + --tw-bg-opacity: 1; + background-color: rgb(36 41 47 / var(--tw-bg-opacity)); +} +.bg-\[\#2557D6\] { + --tw-bg-opacity: 1; + background-color: rgb(37 87 214 / var(--tw-bg-opacity)); +} +.bg-\[\#3b5998\] { + --tw-bg-opacity: 1; + background-color: rgb(59 89 152 / var(--tw-bg-opacity)); +} +.bg-\[\#4285F4\] { + --tw-bg-opacity: 1; + background-color: rgb(66 133 244 / var(--tw-bg-opacity)); +} +.bg-\[\#F7BE38\] { + --tw-bg-opacity: 1; + background-color: rgb(247 190 56 / var(--tw-bg-opacity)); +} +.bg-\[\#FF9119\] { + --tw-bg-opacity: 1; + background-color: rgb(255 145 25 / var(--tw-bg-opacity)); +} +.bg-\[\#hex\] { + background-color: #hex; +} +.bg-blue-100 { + --tw-bg-opacity: 1; + background-color: rgb(225 239 254 / var(--tw-bg-opacity)); +} +.bg-blue-200 { + --tw-bg-opacity: 1; + background-color: rgb(195 221 253 / var(--tw-bg-opacity)); +} +.bg-blue-300 { + --tw-bg-opacity: 1; + background-color: rgb(164 202 254 / var(--tw-bg-opacity)); +} +.bg-blue-400 { + --tw-bg-opacity: 1; + background-color: rgb(118 169 250 / var(--tw-bg-opacity)); +} +.bg-blue-50 { + --tw-bg-opacity: 1; + background-color: rgb(235 245 255 / var(--tw-bg-opacity)); +} +.bg-blue-500 { + --tw-bg-opacity: 1; + background-color: rgb(63 131 248 / var(--tw-bg-opacity)); +} +.bg-blue-600 { + --tw-bg-opacity: 1; + background-color: rgb(28 100 242 / var(--tw-bg-opacity)); +} +.bg-blue-700 { + --tw-bg-opacity: 1; + background-color: rgb(26 86 219 / var(--tw-bg-opacity)); +} +.bg-blue-800 { + --tw-bg-opacity: 1; + background-color: rgb(30 66 159 / var(--tw-bg-opacity)); +} +.bg-blue-900 { + --tw-bg-opacity: 1; + background-color: rgb(35 56 118 / var(--tw-bg-opacity)); +} +.bg-gray-100 { + --tw-bg-opacity: 1; + background-color: rgb(243 244 246 / var(--tw-bg-opacity)); +} +.bg-gray-200 { + --tw-bg-opacity: 1; + background-color: rgb(229 231 235 / var(--tw-bg-opacity)); +} +.bg-gray-300 { + --tw-bg-opacity: 1; + background-color: rgb(209 213 219 / var(--tw-bg-opacity)); +} +.bg-gray-400 { + --tw-bg-opacity: 1; + background-color: rgb(156 163 175 / var(--tw-bg-opacity)); +} +.bg-gray-50 { + --tw-bg-opacity: 1; + background-color: rgb(249 250 251 / var(--tw-bg-opacity)); +} +.bg-gray-500 { + --tw-bg-opacity: 1; + background-color: rgb(107 114 128 / var(--tw-bg-opacity)); +} +.bg-gray-600 { + --tw-bg-opacity: 1; + background-color: rgb(75 85 99 / var(--tw-bg-opacity)); +} +.bg-gray-700 { + --tw-bg-opacity: 1; + background-color: rgb(55 65 81 / var(--tw-bg-opacity)); +} +.bg-gray-800 { + --tw-bg-opacity: 1; + background-color: rgb(31 41 55 / var(--tw-bg-opacity)); +} +.bg-gray-900 { + --tw-bg-opacity: 1; + background-color: rgb(17 24 39 / var(--tw-bg-opacity)); +} +.bg-gray-900\/50 { + background-color: rgb(17 24 39 / 0.5); +} +.bg-green-100 { + --tw-bg-opacity: 1; + background-color: rgb(222 247 236 / var(--tw-bg-opacity)); +} +.bg-green-200 { + --tw-bg-opacity: 1; + background-color: rgb(188 240 218 / var(--tw-bg-opacity)); +} +.bg-green-300 { + --tw-bg-opacity: 1; + background-color: rgb(132 225 188 / var(--tw-bg-opacity)); +} +.bg-green-400 { + --tw-bg-opacity: 1; + background-color: rgb(49 196 141 / var(--tw-bg-opacity)); +} +.bg-green-50 { + --tw-bg-opacity: 1; + background-color: rgb(243 250 247 / var(--tw-bg-opacity)); +} +.bg-green-500 { + --tw-bg-opacity: 1; + background-color: rgb(14 159 110 / var(--tw-bg-opacity)); +} +.bg-green-600 { + --tw-bg-opacity: 1; + background-color: rgb(5 122 85 / var(--tw-bg-opacity)); +} +.bg-green-700 { + --tw-bg-opacity: 1; + background-color: rgb(4 108 78 / var(--tw-bg-opacity)); +} +.bg-green-800 { + --tw-bg-opacity: 1; + background-color: rgb(3 84 63 / var(--tw-bg-opacity)); +} +.bg-green-900 { + --tw-bg-opacity: 1; + background-color: rgb(1 71 55 / var(--tw-bg-opacity)); +} +.bg-indigo-100 { + --tw-bg-opacity: 1; + background-color: rgb(229 237 255 / var(--tw-bg-opacity)); +} +.bg-indigo-200 { + --tw-bg-opacity: 1; + background-color: rgb(205 219 254 / var(--tw-bg-opacity)); +} +.bg-indigo-300 { + --tw-bg-opacity: 1; + background-color: rgb(180 198 252 / var(--tw-bg-opacity)); +} +.bg-indigo-400 { + --tw-bg-opacity: 1; + background-color: rgb(141 162 251 / var(--tw-bg-opacity)); +} +.bg-indigo-50 { + --tw-bg-opacity: 1; + background-color: rgb(240 245 255 / var(--tw-bg-opacity)); +} +.bg-indigo-500 { + --tw-bg-opacity: 1; + background-color: rgb(104 117 245 / var(--tw-bg-opacity)); +} +.bg-indigo-600 { + --tw-bg-opacity: 1; + background-color: rgb(88 80 236 / var(--tw-bg-opacity)); +} +.bg-indigo-700 { + --tw-bg-opacity: 1; + background-color: rgb(81 69 205 / var(--tw-bg-opacity)); +} +.bg-indigo-800 { + --tw-bg-opacity: 1; + background-color: rgb(66 56 157 / var(--tw-bg-opacity)); +} +.bg-indigo-900 { + --tw-bg-opacity: 1; + background-color: rgb(54 47 120 / var(--tw-bg-opacity)); +} +.bg-orange-100 { + --tw-bg-opacity: 1; + background-color: rgb(254 236 220 / var(--tw-bg-opacity)); +} +.bg-orange-300 { + --tw-bg-opacity: 1; + background-color: rgb(253 186 140 / var(--tw-bg-opacity)); +} +.bg-orange-50 { + --tw-bg-opacity: 1; + background-color: rgb(255 248 241 / var(--tw-bg-opacity)); +} +.bg-pink-100 { + --tw-bg-opacity: 1; + background-color: rgb(252 232 243 / var(--tw-bg-opacity)); +} +.bg-pink-200 { + --tw-bg-opacity: 1; + background-color: rgb(250 209 232 / var(--tw-bg-opacity)); +} +.bg-pink-300 { + --tw-bg-opacity: 1; + background-color: rgb(248 180 217 / var(--tw-bg-opacity)); +} +.bg-pink-400 { + --tw-bg-opacity: 1; + background-color: rgb(241 126 184 / var(--tw-bg-opacity)); +} +.bg-pink-50 { + --tw-bg-opacity: 1; + background-color: rgb(253 242 248 / var(--tw-bg-opacity)); +} +.bg-pink-500 { + --tw-bg-opacity: 1; + background-color: rgb(231 70 148 / var(--tw-bg-opacity)); +} +.bg-pink-600 { + --tw-bg-opacity: 1; + background-color: rgb(214 31 105 / var(--tw-bg-opacity)); +} +.bg-pink-700 { + --tw-bg-opacity: 1; + background-color: rgb(191 18 93 / var(--tw-bg-opacity)); +} +.bg-pink-800 { + --tw-bg-opacity: 1; + background-color: rgb(153 21 75 / var(--tw-bg-opacity)); +} +.bg-pink-900 { + --tw-bg-opacity: 1; + background-color: rgb(117 26 61 / var(--tw-bg-opacity)); +} +.bg-purple-100 { + --tw-bg-opacity: 1; + background-color: rgb(237 235 254 / var(--tw-bg-opacity)); +} +.bg-purple-200 { + --tw-bg-opacity: 1; + background-color: rgb(220 215 254 / var(--tw-bg-opacity)); +} +.bg-purple-300 { + --tw-bg-opacity: 1; + background-color: rgb(202 191 253 / var(--tw-bg-opacity)); +} +.bg-purple-400 { + --tw-bg-opacity: 1; + background-color: rgb(172 148 250 / var(--tw-bg-opacity)); +} +.bg-purple-50 { + --tw-bg-opacity: 1; + background-color: rgb(246 245 255 / var(--tw-bg-opacity)); +} +.bg-purple-500 { + --tw-bg-opacity: 1; + background-color: rgb(144 97 249 / var(--tw-bg-opacity)); +} +.bg-purple-600 { + --tw-bg-opacity: 1; + background-color: rgb(126 58 242 / var(--tw-bg-opacity)); +} +.bg-purple-700 { + --tw-bg-opacity: 1; + background-color: rgb(108 43 217 / var(--tw-bg-opacity)); +} +.bg-purple-800 { + --tw-bg-opacity: 1; + background-color: rgb(85 33 181 / var(--tw-bg-opacity)); +} +.bg-purple-900 { + --tw-bg-opacity: 1; + background-color: rgb(74 29 150 / var(--tw-bg-opacity)); +} +.bg-red-100 { + --tw-bg-opacity: 1; + background-color: rgb(253 232 232 / var(--tw-bg-opacity)); +} +.bg-red-200 { + --tw-bg-opacity: 1; + background-color: rgb(251 213 213 / var(--tw-bg-opacity)); +} +.bg-red-300 { + --tw-bg-opacity: 1; + background-color: rgb(248 180 180 / var(--tw-bg-opacity)); +} +.bg-red-400 { + --tw-bg-opacity: 1; + background-color: rgb(249 128 128 / var(--tw-bg-opacity)); +} +.bg-red-50 { + --tw-bg-opacity: 1; + background-color: rgb(253 242 242 / var(--tw-bg-opacity)); +} +.bg-red-500 { + --tw-bg-opacity: 1; + background-color: rgb(240 82 82 / var(--tw-bg-opacity)); +} +.bg-red-600 { + --tw-bg-opacity: 1; + background-color: rgb(224 36 36 / var(--tw-bg-opacity)); +} +.bg-red-700 { + --tw-bg-opacity: 1; + background-color: rgb(200 30 30 / var(--tw-bg-opacity)); +} +.bg-red-800 { + --tw-bg-opacity: 1; + background-color: rgb(155 28 28 / var(--tw-bg-opacity)); +} +.bg-red-900 { + --tw-bg-opacity: 1; + background-color: rgb(119 29 29 / var(--tw-bg-opacity)); +} +.bg-teal-100 { + --tw-bg-opacity: 1; + background-color: rgb(213 245 246 / var(--tw-bg-opacity)); +} +.bg-teal-50 { + --tw-bg-opacity: 1; + background-color: rgb(237 250 250 / var(--tw-bg-opacity)); +} +.bg-teal-500 { + --tw-bg-opacity: 1; + background-color: rgb(6 148 162 / var(--tw-bg-opacity)); +} +.bg-transparent { + background-color: transparent; +} +.bg-white { + --tw-bg-opacity: 1; + background-color: rgb(255 255 255 / var(--tw-bg-opacity)); +} +.bg-white\/30 { + background-color: rgb(255 255 255 / 0.3); +} +.bg-white\/50 { + background-color: rgb(255 255 255 / 0.5); +} +.bg-yellow-100 { + --tw-bg-opacity: 1; + background-color: rgb(253 246 178 / var(--tw-bg-opacity)); +} +.bg-yellow-200 { + --tw-bg-opacity: 1; + background-color: rgb(252 233 106 / var(--tw-bg-opacity)); +} +.bg-yellow-300 { + --tw-bg-opacity: 1; + background-color: rgb(250 202 21 / var(--tw-bg-opacity)); +} +.bg-yellow-400 { + --tw-bg-opacity: 1; + background-color: rgb(227 160 8 / var(--tw-bg-opacity)); +} +.bg-yellow-50 { + --tw-bg-opacity: 1; + background-color: rgb(253 253 234 / var(--tw-bg-opacity)); +} +.bg-yellow-500 { + --tw-bg-opacity: 1; + background-color: rgb(194 120 3 / var(--tw-bg-opacity)); +} +.bg-yellow-600 { + --tw-bg-opacity: 1; + background-color: rgb(159 88 10 / var(--tw-bg-opacity)); +} +.bg-yellow-700 { + --tw-bg-opacity: 1; + background-color: rgb(142 75 16 / var(--tw-bg-opacity)); +} +.bg-yellow-800 { + --tw-bg-opacity: 1; + background-color: rgb(114 59 19 / var(--tw-bg-opacity)); +} +.bg-yellow-900 { + --tw-bg-opacity: 1; + background-color: rgb(99 49 18 / var(--tw-bg-opacity)); +} +.bg-opacity-50 { + --tw-bg-opacity: 0.5; +} +.bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/conference\.jpg\'\)\] { + background-image: url('https://flowbite.s3.amazonaws.com/docs/jumbotron/conference.jpg'); +} +.bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/hero-pattern\.svg\'\)\] { + background-image: url('https://flowbite.s3.amazonaws.com/docs/jumbotron/hero-pattern.svg'); +} +.bg-gradient-to-b { + background-image: linear-gradient(to bottom, var(--tw-gradient-stops)); +} +.bg-gradient-to-br { + background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); +} +.bg-gradient-to-r { + background-image: linear-gradient(to right, var(--tw-gradient-stops)); +} +.from-blue-50 { + --tw-gradient-from: #EBF5FF var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(235 245 255 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-blue-500 { + --tw-gradient-from: #3F83F8 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(63 131 248 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-cyan-400 { + --tw-gradient-from: #22d3ee var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(34 211 238 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-cyan-500 { + --tw-gradient-from: #06b6d4 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(6 182 212 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-green-400 { + --tw-gradient-from: #31C48D var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(49 196 141 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-lime-200 { + --tw-gradient-from: #d9f99d var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(217 249 157 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-pink-400 { + --tw-gradient-from: #F17EB8 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(241 126 184 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-pink-500 { + --tw-gradient-from: #E74694 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(231 70 148 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-purple-500 { + --tw-gradient-from: #9061F9 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(144 97 249 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-purple-600 { + --tw-gradient-from: #7E3AF2 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(126 58 242 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-red-200 { + --tw-gradient-from: #FBD5D5 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(251 213 213 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-red-400 { + --tw-gradient-from: #F98080 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(249 128 128 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-sky-400 { + --tw-gradient-from: #38bdf8 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(56 189 248 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-teal-200 { + --tw-gradient-from: #AFECEF var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(175 236 239 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-teal-300 { + --tw-gradient-from: #7EDCE2 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(126 220 226 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.from-teal-400 { + --tw-gradient-from: #16BDCA var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(22 189 202 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} +.via-blue-600 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(28 100 242 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #1C64F2 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-cyan-500 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(6 182 212 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #06b6d4 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-green-500 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(14 159 110 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #0E9F6E var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-lime-400 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(163 230 53 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #a3e635 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-pink-500 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(231 70 148 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #E74694 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-purple-600 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(126 58 242 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #7E3AF2 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-red-300 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(248 180 180 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #F8B4B4 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-red-500 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(240 82 82 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #F05252 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.via-teal-500 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(6 148 162 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #0694A2 var(--tw-gradient-via-position), var(--tw-gradient-to); +} +.to-blue-500 { + --tw-gradient-to: #3F83F8 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-blue-600 { + --tw-gradient-to: #1C64F2 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-blue-700 { + --tw-gradient-to: #1A56DB var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-cyan-600 { + --tw-gradient-to: #0891b2 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-emerald-600 { + --tw-gradient-to: #059669 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-green-600 { + --tw-gradient-to: #057A55 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-lime-200 { + --tw-gradient-to: #d9f99d var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-lime-300 { + --tw-gradient-to: #bef264 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-lime-500 { + --tw-gradient-to: #84cc16 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-orange-400 { + --tw-gradient-to: #FF8A4C var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-pink-500 { + --tw-gradient-to: #E74694 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-pink-600 { + --tw-gradient-to: #D61F69 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-purple-700 { + --tw-gradient-to: #6C2BD9 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-red-600 { + --tw-gradient-to: #E02424 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-teal-600 { + --tw-gradient-to: #047481 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-transparent { + --tw-gradient-to: transparent var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.to-yellow-200 { + --tw-gradient-to: #FCE96A var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} +.bg-cover { + background-size: cover; +} +.bg-local { + background-attachment: local; +} +.bg-clip-text { + -webkit-background-clip: text; + background-clip: text; +} +.bg-center { + background-position: center; +} +.bg-no-repeat { + background-repeat: no-repeat; +} +.fill-blue-600 { + fill: #1C64F2; +} +.fill-gray-500 { + fill: #6B7280; +} +.fill-gray-600 { + fill: #4B5563; +} +.fill-green-500 { + fill: #0E9F6E; +} +.fill-pink-600 { + fill: #D61F69; +} +.fill-purple-600 { + fill: #7E3AF2; +} +.fill-red-600 { + fill: #E02424; +} +.fill-yellow-400 { + fill: #E3A008; +} +.object-cover { + -o-object-fit: cover; + object-fit: cover; +} +.\!p-0 { + padding: 0px !important; +} +.p-0 { + padding: 0px; +} +.p-0\.5 { + padding: 0.125rem; +} +.p-1 { + padding: 0.25rem; +} +.p-1\.5 { + padding: 0.375rem; +} +.p-2 { + padding: 0.5rem; +} +.p-2\.5 { + padding: 0.625rem; +} +.p-3 { + padding: 0.75rem; +} +.p-4 { + padding: 1rem; +} +.p-5 { + padding: 1.25rem; +} +.p-6 { + padding: 1.5rem; +} +.p-8 { + padding: 2rem; +} +.px-0 { + padding-left: 0px; + padding-right: 0px; +} +.px-0\.5 { + padding-left: 0.125rem; + padding-right: 0.125rem; +} +.px-1 { + padding-left: 0.25rem; + padding-right: 0.25rem; +} +.px-1\.5 { + padding-left: 0.375rem; + padding-right: 0.375rem; +} +.px-2 { + padding-left: 0.5rem; + padding-right: 0.5rem; +} +.px-2\.5 { + padding-left: 0.625rem; + padding-right: 0.625rem; +} +.px-3 { + padding-left: 0.75rem; + padding-right: 0.75rem; +} +.px-4 { + padding-left: 1rem; + padding-right: 1rem; +} +.px-5 { + padding-left: 1.25rem; + padding-right: 1.25rem; +} +.px-6 { + padding-left: 1.5rem; + padding-right: 1.5rem; +} +.px-8 { + padding-left: 2rem; + padding-right: 2rem; +} +.py-0 { + padding-top: 0px; + padding-bottom: 0px; +} +.py-0\.5 { + padding-top: 0.125rem; + padding-bottom: 0.125rem; +} +.py-1 { + padding-top: 0.25rem; + padding-bottom: 0.25rem; +} +.py-1\.5 { + padding-top: 0.375rem; + padding-bottom: 0.375rem; +} +.py-12 { + padding-top: 3rem; + padding-bottom: 3rem; +} +.py-2 { + padding-top: 0.5rem; + padding-bottom: 0.5rem; +} +.py-2\.5 { + padding-top: 0.625rem; + padding-bottom: 0.625rem; +} +.py-24 { + padding-top: 6rem; + padding-bottom: 6rem; +} +.py-3 { + padding-top: 0.75rem; + padding-bottom: 0.75rem; +} +.py-3\.5 { + padding-top: 0.875rem; + padding-bottom: 0.875rem; +} +.py-4 { + padding-top: 1rem; + padding-bottom: 1rem; +} +.py-48 { + padding-top: 12rem; + padding-bottom: 12rem; +} +.py-5 { + padding-top: 1.25rem; + padding-bottom: 1.25rem; +} +.py-6 { + padding-top: 1.5rem; + padding-bottom: 1.5rem; +} +.py-8 { + padding-top: 2rem; + padding-bottom: 2rem; +} +.py-px { + padding-top: 1px; + padding-bottom: 1px; +} +.pb-0 { + padding-bottom: 0px; +} +.pb-1 { + padding-bottom: 0.25rem; +} +.pb-1\.5 { + padding-bottom: 0.375rem; +} +.pb-10 { + padding-bottom: 2.5rem; +} +.pb-16 { + padding-bottom: 4rem; +} +.pb-2 { + padding-bottom: 0.5rem; +} +.pb-2\.5 { + padding-bottom: 0.625rem; +} +.pb-3 { + padding-bottom: 0.75rem; +} +.pb-4 { + padding-bottom: 1rem; +} +.pb-48 { + padding-bottom: 12rem; +} +.pb-5 { + padding-bottom: 1.25rem; +} +.pb-6 { + padding-bottom: 1.5rem; +} +.pb-8 { + padding-bottom: 2rem; +} +.pb-96 { + padding-bottom: 24rem; +} +.pl-0 { + padding-left: 0px; +} +.pl-10 { + padding-left: 2.5rem; +} +.pl-11 { + padding-left: 2.75rem; +} +.pl-2 { + padding-left: 0.5rem; +} +.pl-2\.5 { + padding-left: 0.625rem; +} +.pl-3 { + padding-left: 0.75rem; +} +.pl-3\.5 { + padding-left: 0.875rem; +} +.pl-4 { + padding-left: 1rem; +} +.pl-5 { + padding-left: 1.25rem; +} +.pl-8 { + padding-left: 2rem; +} +.pr-1 { + padding-right: 0.25rem; +} +.pr-3 { + padding-right: 0.75rem; +} +.pr-4 { + padding-right: 1rem; +} +.pt-0 { + padding-top: 0px; +} +.pt-10 { + padding-top: 2.5rem; +} +.pt-16 { + padding-top: 4rem; +} +.pt-2 { + padding-top: 0.5rem; +} +.pt-20 { + padding-top: 5rem; +} +.pt-24 { + padding-top: 6rem; +} +.pt-3 { + padding-top: 0.75rem; +} +.pt-32 { + padding-top: 8rem; +} +.pt-36 { + padding-top: 9rem; +} +.pt-4 { + padding-top: 1rem; +} +.pt-5 { + padding-top: 1.25rem; +} +.pt-52 { + padding-top: 13rem; +} +.pt-6 { + padding-top: 1.5rem; +} +.pt-60 { + padding-top: 15rem; +} +.pt-64 { + padding-top: 16rem; +} +.pt-8 { + padding-top: 2rem; +} +.pt-80 { + padding-top: 20rem; +} +.text-left { + text-align: left; +} +.text-center { + text-align: center; +} +.text-right { + text-align: right; +} +.text-justify { + text-align: justify; +} +.font-sans { + font-family: Inter, ui-sans-serif, system-ui, -apple-system, system-ui, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji; +} +.text-2xl { + font-size: 1.5rem; + line-height: 2rem; +} +.text-2xs { + font-size: 0.625rem; +} +.text-3xl { + font-size: 1.875rem; + line-height: 2.25rem; +} +.text-4xl { + font-size: 2.25rem; + line-height: 2.5rem; +} +.text-5xl { + font-size: 3rem; + line-height: 1; +} +.text-6xl { + font-size: 3.75rem; + line-height: 1; +} +.text-7xl { + font-size: 4.5rem; + line-height: 1; +} +.text-8xl { + font-size: 6rem; + line-height: 1; +} +.text-9xl { + font-size: 8rem; + line-height: 1; +} +.text-base { + font-size: 1rem; + line-height: 1.5rem; +} +.text-lg { + font-size: 1.125rem; + line-height: 1.75rem; +} +.text-sm { + font-size: 0.875rem; + line-height: 1.25rem; +} +.text-xl { + font-size: 1.25rem; + line-height: 1.75rem; +} +.text-xs { + font-size: 0.75rem; + line-height: 1rem; +} +.font-black { + font-weight: 900; +} +.font-bold { + font-weight: 700; +} +.font-extrabold { + font-weight: 800; +} +.font-extralight { + font-weight: 200; +} +.font-medium { + font-weight: 500; +} +.font-normal { + font-weight: 400; +} +.font-semibold { + font-weight: 600; +} +.font-thin { + font-weight: 100; +} +.uppercase { + text-transform: uppercase; +} +.lowercase { + text-transform: lowercase; +} +.italic { + font-style: italic; +} +.leading-6 { + line-height: 1.5rem; +} +.leading-9 { + line-height: 2.25rem; +} +.leading-loose { + line-height: 2; +} +.leading-none { + line-height: 1; +} +.leading-normal { + line-height: 1.5; +} +.leading-relaxed { + line-height: 1.625; +} +.leading-tight { + line-height: 1.25; +} +.tracking-normal { + letter-spacing: 0em; +} +.tracking-tight { + letter-spacing: -0.025em; +} +.tracking-tighter { + letter-spacing: -0.05em; +} +.tracking-wide { + letter-spacing: 0.025em; +} +.tracking-wider { + letter-spacing: 0.05em; +} +.tracking-widest { + letter-spacing: 0.1em; +} +.\!text-blue-700 { + --tw-text-opacity: 1 !important; + color: rgb(26 86 219 / var(--tw-text-opacity)) !important; +} +.text-\[\#626890\] { + --tw-text-opacity: 1; + color: rgb(98 104 144 / var(--tw-text-opacity)); +} +.text-\[\#ff2d20\] { + --tw-text-opacity: 1; + color: rgb(255 45 32 / var(--tw-text-opacity)); +} +.text-blue-100 { + --tw-text-opacity: 1; + color: rgb(225 239 254 / var(--tw-text-opacity)); +} +.text-blue-400 { + --tw-text-opacity: 1; + color: rgb(118 169 250 / var(--tw-text-opacity)); +} +.text-blue-50 { + --tw-text-opacity: 1; + color: rgb(235 245 255 / var(--tw-text-opacity)); +} +.text-blue-500 { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} +.text-blue-600 { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} +.text-blue-600\/100 { + color: rgb(28 100 242 / 1); +} +.text-blue-600\/25 { + color: rgb(28 100 242 / 0.25); +} +.text-blue-600\/50 { + color: rgb(28 100 242 / 0.5); +} +.text-blue-600\/75 { + color: rgb(28 100 242 / 0.75); +} +.text-blue-700 { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); +} +.text-blue-800 { + --tw-text-opacity: 1; + color: rgb(30 66 159 / var(--tw-text-opacity)); +} +.text-blue-900 { + --tw-text-opacity: 1; + color: rgb(35 56 118 / var(--tw-text-opacity)); +} +.text-gray-200 { + --tw-text-opacity: 1; + color: rgb(229 231 235 / var(--tw-text-opacity)); +} +.text-gray-300 { + --tw-text-opacity: 1; + color: rgb(209 213 219 / var(--tw-text-opacity)); +} +.text-gray-400 { + --tw-text-opacity: 1; + color: rgb(156 163 175 / var(--tw-text-opacity)); +} +.text-gray-500 { + --tw-text-opacity: 1; + color: rgb(107 114 128 / var(--tw-text-opacity)); +} +.text-gray-600 { + --tw-text-opacity: 1; + color: rgb(75 85 99 / var(--tw-text-opacity)); +} +.text-gray-700 { + --tw-text-opacity: 1; + color: rgb(55 65 81 / var(--tw-text-opacity)); +} +.text-gray-800 { + --tw-text-opacity: 1; + color: rgb(31 41 55 / var(--tw-text-opacity)); +} +.text-gray-900 { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} +.text-green-400 { + --tw-text-opacity: 1; + color: rgb(49 196 141 / var(--tw-text-opacity)); +} +.text-green-500 { + --tw-text-opacity: 1; + color: rgb(14 159 110 / var(--tw-text-opacity)); +} +.text-green-600 { + --tw-text-opacity: 1; + color: rgb(5 122 85 / var(--tw-text-opacity)); +} +.text-green-700 { + --tw-text-opacity: 1; + color: rgb(4 108 78 / var(--tw-text-opacity)); +} +.text-green-800 { + --tw-text-opacity: 1; + color: rgb(3 84 63 / var(--tw-text-opacity)); +} +.text-green-900 { + --tw-text-opacity: 1; + color: rgb(1 71 55 / var(--tw-text-opacity)); +} +.text-indigo-400 { + --tw-text-opacity: 1; + color: rgb(141 162 251 / var(--tw-text-opacity)); +} +.text-indigo-700 { + --tw-text-opacity: 1; + color: rgb(81 69 205 / var(--tw-text-opacity)); +} +.text-indigo-800 { + --tw-text-opacity: 1; + color: rgb(66 56 157 / var(--tw-text-opacity)); +} +.text-orange-500 { + --tw-text-opacity: 1; + color: rgb(255 90 31 / var(--tw-text-opacity)); +} +.text-orange-600 { + --tw-text-opacity: 1; + color: rgb(208 56 1 / var(--tw-text-opacity)); +} +.text-orange-800 { + --tw-text-opacity: 1; + color: rgb(138 44 13 / var(--tw-text-opacity)); +} +.text-pink-400 { + --tw-text-opacity: 1; + color: rgb(241 126 184 / var(--tw-text-opacity)); +} +.text-pink-800 { + --tw-text-opacity: 1; + color: rgb(153 21 75 / var(--tw-text-opacity)); +} +.text-purple-400 { + --tw-text-opacity: 1; + color: rgb(172 148 250 / var(--tw-text-opacity)); +} +.text-purple-600 { + --tw-text-opacity: 1; + color: rgb(126 58 242 / var(--tw-text-opacity)); +} +.text-purple-700 { + --tw-text-opacity: 1; + color: rgb(108 43 217 / var(--tw-text-opacity)); +} +.text-purple-800 { + --tw-text-opacity: 1; + color: rgb(85 33 181 / var(--tw-text-opacity)); +} +.text-red-400 { + --tw-text-opacity: 1; + color: rgb(249 128 128 / var(--tw-text-opacity)); +} +.text-red-500 { + --tw-text-opacity: 1; + color: rgb(240 82 82 / var(--tw-text-opacity)); +} +.text-red-600 { + --tw-text-opacity: 1; + color: rgb(224 36 36 / var(--tw-text-opacity)); +} +.text-red-700 { + --tw-text-opacity: 1; + color: rgb(200 30 30 / var(--tw-text-opacity)); +} +.text-red-800 { + --tw-text-opacity: 1; + color: rgb(155 28 28 / var(--tw-text-opacity)); +} +.text-red-900 { + --tw-text-opacity: 1; + color: rgb(119 29 29 / var(--tw-text-opacity)); +} +.text-sky-500 { + --tw-text-opacity: 1; + color: rgb(14 165 233 / var(--tw-text-opacity)); +} +.text-teal-600 { + --tw-text-opacity: 1; + color: rgb(4 116 129 / var(--tw-text-opacity)); +} +.text-transparent { + color: transparent; +} +.text-white { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} +.text-yellow-300 { + --tw-text-opacity: 1; + color: rgb(250 202 21 / var(--tw-text-opacity)); +} +.text-yellow-400 { + --tw-text-opacity: 1; + color: rgb(227 160 8 / var(--tw-text-opacity)); +} +.text-yellow-500 { + --tw-text-opacity: 1; + color: rgb(194 120 3 / var(--tw-text-opacity)); +} +.text-yellow-700 { + --tw-text-opacity: 1; + color: rgb(142 75 16 / var(--tw-text-opacity)); +} +.text-yellow-800 { + --tw-text-opacity: 1; + color: rgb(114 59 19 / var(--tw-text-opacity)); +} +.underline { + text-decoration-line: underline; +} +.line-through { + text-decoration-line: line-through; +} +.no-underline { + text-decoration-line: none; +} +.decoration-blue-400 { + text-decoration-color: #76A9FA; +} +.decoration-blue-500 { + text-decoration-color: #3F83F8; +} +.decoration-gray-500 { + text-decoration-color: #6B7280; +} +.decoration-green-500 { + text-decoration-color: #0E9F6E; +} +.decoration-indigo-500 { + text-decoration-color: #6875F5; +} +.decoration-red-500 { + text-decoration-color: #F05252; +} +.decoration-sky-500 { + text-decoration-color: #0ea5e9; +} +.decoration-solid { + text-decoration-style: solid; +} +.decoration-double { + text-decoration-style: double; +} +.decoration-dotted { + text-decoration-style: dotted; +} +.decoration-dashed { + text-decoration-style: dashed; +} +.decoration-wavy { + text-decoration-style: wavy; +} +.decoration-8 { + text-decoration-thickness: 8px; +} +.underline-offset-2 { + text-underline-offset: 2px; +} +.antialiased { + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} +.placeholder-green-700::-moz-placeholder { + --tw-placeholder-opacity: 1; + color: rgb(4 108 78 / var(--tw-placeholder-opacity)); +} +.placeholder-green-700::placeholder { + --tw-placeholder-opacity: 1; + color: rgb(4 108 78 / var(--tw-placeholder-opacity)); +} +.placeholder-red-700::-moz-placeholder { + --tw-placeholder-opacity: 1; + color: rgb(200 30 30 / var(--tw-placeholder-opacity)); +} +.placeholder-red-700::placeholder { + --tw-placeholder-opacity: 1; + color: rgb(200 30 30 / var(--tw-placeholder-opacity)); +} +.opacity-0 { + opacity: 0; +} +.opacity-100 { + opacity: 1; +} +.opacity-20 { + opacity: 0.2; +} +.bg-blend-multiply { + background-blend-mode: multiply; +} +.shadow { + --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} +.shadow-lg { + --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} +.shadow-md { + --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} +.shadow-sm { + --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05); + --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} +.shadow-xl { + --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} +.shadow-blue-500\/50 { + --tw-shadow-color: rgb(63 131 248 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-cyan-500\/50 { + --tw-shadow-color: rgb(6 182 212 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-green-500\/50 { + --tw-shadow-color: rgb(14 159 110 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-lime-500\/50 { + --tw-shadow-color: rgb(132 204 22 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-pink-500\/50 { + --tw-shadow-color: rgb(231 70 148 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-purple-500\/50 { + --tw-shadow-color: rgb(144 97 249 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-red-500\/50 { + --tw-shadow-color: rgb(240 82 82 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.shadow-teal-500\/50 { + --tw-shadow-color: rgb(6 148 162 / 0.5); + --tw-shadow: var(--tw-shadow-colored); +} +.outline { + outline-style: solid; +} +.ring-0 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} +.ring-1 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} +.ring-2 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} +.ring-4 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} +.ring-8 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(8px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} +.ring-inset { + --tw-ring-inset: inset; +} +.ring-black { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(0 0 0 / var(--tw-ring-opacity)); +} +.ring-gray-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(209 213 219 / var(--tw-ring-opacity)); +} +.ring-white { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity)); +} +.ring-opacity-0 { + --tw-ring-opacity: 0; +} +.blur { + --tw-blur: blur(8px); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} +.blur-sm { + --tw-blur: blur(4px); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} +.grayscale { + --tw-grayscale: grayscale(100%); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} +.invert { + --tw-invert: invert(100%); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} +.filter { + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} +.transition { + transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter; + transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter; + transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} +.transition-all { + transition-property: all; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} +.transition-colors { + transition-property: color, background-color, border-color, text-decoration-color, fill, stroke; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} +.transition-opacity { + transition-property: opacity; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} +.transition-transform { + transition-property: transform; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} +.duration-200 { + transition-duration: 200ms; +} +.duration-300 { + transition-duration: 300ms; +} +.duration-700 { + transition-duration: 700ms; +} +.duration-75 { + transition-duration: 75ms; +} +.ease-in { + transition-timing-function: cubic-bezier(0.4, 0, 1, 1); +} +.ease-in-out { + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); +} +.ease-linear { + transition-timing-function: linear; +} +.ease-out { + transition-timing-function: cubic-bezier(0, 0, 0.2, 1); +} + +/* +“Have the courage to follow your heart and intuition. They somehow already know what you truly want to become. Everything else is secondary.” +― Steve Jobs +*/ + +.first-letter\:float-left::first-letter { + float: left; +} + +.first-letter\:mr-3::first-letter { + margin-right: 0.75rem; +} + +.first-letter\:text-7xl::first-letter { + font-size: 4.5rem; + line-height: 1; +} + +.first-letter\:font-bold::first-letter { + font-weight: 700; +} + +.first-letter\:text-gray-900::first-letter { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +.first-line\:uppercase::first-line { + text-transform: uppercase; +} + +.first-line\:tracking-widest::first-line { + letter-spacing: 0.1em; +} + +.after\:absolute::after { + content: var(--tw-content); + position: absolute; +} + +.after\:left-\[2px\]::after { + content: var(--tw-content); + left: 2px; +} + +.after\:left-\[4px\]::after { + content: var(--tw-content); + left: 4px; +} + +.after\:top-0::after { + content: var(--tw-content); + top: 0px; +} + +.after\:top-0\.5::after { + content: var(--tw-content); + top: 0.125rem; +} + +.after\:top-\[2px\]::after { + content: var(--tw-content); + top: 2px; +} + +.after\:mx-2::after { + content: var(--tw-content); + margin-left: 0.5rem; + margin-right: 0.5rem; +} + +.after\:mx-6::after { + content: var(--tw-content); + margin-left: 1.5rem; + margin-right: 1.5rem; +} + +.after\:inline-block::after { + content: var(--tw-content); + display: inline-block; +} + +.after\:hidden::after { + content: var(--tw-content); + display: none; +} + +.after\:h-1::after { + content: var(--tw-content); + height: 0.25rem; +} + +.after\:h-4::after { + content: var(--tw-content); + height: 1rem; +} + +.after\:h-5::after { + content: var(--tw-content); + height: 1.25rem; +} + +.after\:h-6::after { + content: var(--tw-content); + height: 1.5rem; +} + +.after\:w-4::after { + content: var(--tw-content); + width: 1rem; +} + +.after\:w-5::after { + content: var(--tw-content); + width: 1.25rem; +} + +.after\:w-6::after { + content: var(--tw-content); + width: 1.5rem; +} + +.after\:w-full::after { + content: var(--tw-content); + width: 100%; +} + +.after\:rounded-full::after { + content: var(--tw-content); + border-radius: 9999px; +} + +.after\:border::after { + content: var(--tw-content); + border-width: 1px; +} + +.after\:border-4::after { + content: var(--tw-content); + border-width: 4px; +} + +.after\:border-b::after { + content: var(--tw-content); + border-bottom-width: 1px; +} + +.after\:border-blue-100::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(225 239 254 / var(--tw-border-opacity)); +} + +.after\:border-gray-100::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(243 244 246 / var(--tw-border-opacity)); +} + +.after\:border-gray-200::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(229 231 235 / var(--tw-border-opacity)); +} + +.after\:border-gray-300::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(209 213 219 / var(--tw-border-opacity)); +} + +.after\:bg-white::after { + content: var(--tw-content); + --tw-bg-opacity: 1; + background-color: rgb(255 255 255 / var(--tw-bg-opacity)); +} + +.after\:text-gray-200::after { + content: var(--tw-content); + --tw-text-opacity: 1; + color: rgb(229 231 235 / var(--tw-text-opacity)); +} + +.after\:transition-all::after { + content: var(--tw-content); + transition-property: all; + transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + transition-duration: 150ms; +} + +.after\:content-\[\'\'\]::after { + --tw-content: ''; + content: var(--tw-content); +} + +.after\:content-\[\'\/\'\]::after { + --tw-content: '/'; + content: var(--tw-content); +} + +.hover\:border-gray-200:hover { + --tw-border-opacity: 1; + border-color: rgb(229 231 235 / var(--tw-border-opacity)); +} + +.hover\:border-gray-300:hover { + --tw-border-opacity: 1; + border-color: rgb(209 213 219 / var(--tw-border-opacity)); +} + +.hover\:bg-\[\#050708\]\/80:hover { + background-color: rgb(5 7 8 / 0.8); +} + +.hover\:bg-\[\#050708\]\/90:hover { + background-color: rgb(5 7 8 / 0.9); +} + +.hover\:bg-\[\#1da1f2\]\/90:hover { + background-color: rgb(29 161 242 / 0.9); +} + +.hover\:bg-\[\#24292F\]\/90:hover { + background-color: rgb(36 41 47 / 0.9); +} + +.hover\:bg-\[\#2557D6\]\/90:hover { + background-color: rgb(37 87 214 / 0.9); +} + +.hover\:bg-\[\#3b5998\]\/90:hover { + background-color: rgb(59 89 152 / 0.9); +} + +.hover\:bg-\[\#4285F4\]\/90:hover { + background-color: rgb(66 133 244 / 0.9); +} + +.hover\:bg-\[\#F7BE38\]\/90:hover { + background-color: rgb(247 190 56 / 0.9); +} + +.hover\:bg-\[\#FF9119\]\/80:hover { + background-color: rgb(255 145 25 / 0.8); +} + +.hover\:bg-blue-100:hover { + --tw-bg-opacity: 1; + background-color: rgb(225 239 254 / var(--tw-bg-opacity)); +} + +.hover\:bg-blue-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(195 221 253 / var(--tw-bg-opacity)); +} + +.hover\:bg-blue-500:hover { + --tw-bg-opacity: 1; + background-color: rgb(63 131 248 / var(--tw-bg-opacity)); +} + +.hover\:bg-blue-700:hover { + --tw-bg-opacity: 1; + background-color: rgb(26 86 219 / var(--tw-bg-opacity)); +} + +.hover\:bg-blue-800:hover { + --tw-bg-opacity: 1; + background-color: rgb(30 66 159 / var(--tw-bg-opacity)); +} + +.hover\:bg-blue-900:hover { + --tw-bg-opacity: 1; + background-color: rgb(35 56 118 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-100:hover { + --tw-bg-opacity: 1; + background-color: rgb(243 244 246 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(229 231 235 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-300:hover { + --tw-bg-opacity: 1; + background-color: rgb(209 213 219 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-50:hover { + --tw-bg-opacity: 1; + background-color: rgb(249 250 251 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-500:hover { + --tw-bg-opacity: 1; + background-color: rgb(107 114 128 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-600:hover { + --tw-bg-opacity: 1; + background-color: rgb(75 85 99 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-700:hover { + --tw-bg-opacity: 1; + background-color: rgb(55 65 81 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-800:hover { + --tw-bg-opacity: 1; + background-color: rgb(31 41 55 / var(--tw-bg-opacity)); +} + +.hover\:bg-gray-900:hover { + --tw-bg-opacity: 1; + background-color: rgb(17 24 39 / var(--tw-bg-opacity)); +} + +.hover\:bg-green-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(188 240 218 / var(--tw-bg-opacity)); +} + +.hover\:bg-green-800:hover { + --tw-bg-opacity: 1; + background-color: rgb(3 84 63 / var(--tw-bg-opacity)); +} + +.hover\:bg-green-900:hover { + --tw-bg-opacity: 1; + background-color: rgb(1 71 55 / var(--tw-bg-opacity)); +} + +.hover\:bg-indigo-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(205 219 254 / var(--tw-bg-opacity)); +} + +.hover\:bg-pink-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(250 209 232 / var(--tw-bg-opacity)); +} + +.hover\:bg-purple-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(220 215 254 / var(--tw-bg-opacity)); +} + +.hover\:bg-purple-800:hover { + --tw-bg-opacity: 1; + background-color: rgb(85 33 181 / var(--tw-bg-opacity)); +} + +.hover\:bg-red-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(251 213 213 / var(--tw-bg-opacity)); +} + +.hover\:bg-red-800:hover { + --tw-bg-opacity: 1; + background-color: rgb(155 28 28 / var(--tw-bg-opacity)); +} + +.hover\:bg-red-900:hover { + --tw-bg-opacity: 1; + background-color: rgb(119 29 29 / var(--tw-bg-opacity)); +} + +.hover\:bg-white:hover { + --tw-bg-opacity: 1; + background-color: rgb(255 255 255 / var(--tw-bg-opacity)); +} + +.hover\:bg-yellow-200:hover { + --tw-bg-opacity: 1; + background-color: rgb(252 233 106 / var(--tw-bg-opacity)); +} + +.hover\:bg-yellow-500:hover { + --tw-bg-opacity: 1; + background-color: rgb(194 120 3 / var(--tw-bg-opacity)); +} + +.hover\:bg-yellow-900:hover { + --tw-bg-opacity: 1; + background-color: rgb(99 49 18 / var(--tw-bg-opacity)); +} + +.hover\:bg-gradient-to-bl:hover { + background-image: linear-gradient(to bottom left, var(--tw-gradient-stops)); +} + +.hover\:bg-gradient-to-br:hover { + background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); +} + +.hover\:bg-gradient-to-l:hover { + background-image: linear-gradient(to left, var(--tw-gradient-stops)); +} + +.hover\:from-teal-200:hover { + --tw-gradient-from: #AFECEF var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(175 236 239 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.hover\:to-lime-200:hover { + --tw-gradient-to: #d9f99d var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.hover\:\!text-blue-700:hover { + --tw-text-opacity: 1 !important; + color: rgb(26 86 219 / var(--tw-text-opacity)) !important; +} + +.hover\:text-blue-600:hover { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +.hover\:text-blue-700:hover { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); +} + +.hover\:text-blue-800:hover { + --tw-text-opacity: 1; + color: rgb(30 66 159 / var(--tw-text-opacity)); +} + +.hover\:text-blue-900:hover { + --tw-text-opacity: 1; + color: rgb(35 56 118 / var(--tw-text-opacity)); +} + +.hover\:text-gray-500:hover { + --tw-text-opacity: 1; + color: rgb(107 114 128 / var(--tw-text-opacity)); +} + +.hover\:text-gray-600:hover { + --tw-text-opacity: 1; + color: rgb(75 85 99 / var(--tw-text-opacity)); +} + +.hover\:text-gray-700:hover { + --tw-text-opacity: 1; + color: rgb(55 65 81 / var(--tw-text-opacity)); +} + +.hover\:text-gray-800:hover { + --tw-text-opacity: 1; + color: rgb(31 41 55 / var(--tw-text-opacity)); +} + +.hover\:text-gray-900:hover { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +.hover\:text-green-900:hover { + --tw-text-opacity: 1; + color: rgb(1 71 55 / var(--tw-text-opacity)); +} + +.hover\:text-indigo-900:hover { + --tw-text-opacity: 1; + color: rgb(54 47 120 / var(--tw-text-opacity)); +} + +.hover\:text-pink-900:hover { + --tw-text-opacity: 1; + color: rgb(117 26 61 / var(--tw-text-opacity)); +} + +.hover\:text-purple-900:hover { + --tw-text-opacity: 1; + color: rgb(74 29 150 / var(--tw-text-opacity)); +} + +.hover\:text-red-900:hover { + --tw-text-opacity: 1; + color: rgb(119 29 29 / var(--tw-text-opacity)); +} + +.hover\:text-white:hover { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +.hover\:text-yellow-900:hover { + --tw-text-opacity: 1; + color: rgb(99 49 18 / var(--tw-text-opacity)); +} + +.hover\:underline:hover { + text-decoration-line: underline; +} + +.hover\:no-underline:hover { + text-decoration-line: none; +} + +.hover\:bg-blend-soft-light:hover { + background-blend-mode: soft-light; +} + +.hover\:shadow:hover { + --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} + +.hover\:blur-none:hover { + --tw-blur: blur(0); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} + +.hover\:grayscale-0:hover { + --tw-grayscale: grayscale(0); + filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); +} + +.focus\:z-10:focus { + z-index: 10; +} + +.focus\:border-blue-500:focus { + --tw-border-opacity: 1; + border-color: rgb(63 131 248 / var(--tw-border-opacity)); +} + +.focus\:border-blue-600:focus { + --tw-border-opacity: 1; + border-color: rgb(28 100 242 / var(--tw-border-opacity)); +} + +.focus\:border-gray-200:focus { + --tw-border-opacity: 1; + border-color: rgb(229 231 235 / var(--tw-border-opacity)); +} + +.focus\:border-green-500:focus { + --tw-border-opacity: 1; + border-color: rgb(14 159 110 / var(--tw-border-opacity)); +} + +.focus\:border-green-600:focus { + --tw-border-opacity: 1; + border-color: rgb(5 122 85 / var(--tw-border-opacity)); +} + +.focus\:border-red-500:focus { + --tw-border-opacity: 1; + border-color: rgb(240 82 82 / var(--tw-border-opacity)); +} + +.focus\:border-red-600:focus { + --tw-border-opacity: 1; + border-color: rgb(224 36 36 / var(--tw-border-opacity)); +} + +.focus\:bg-gray-100:focus { + --tw-bg-opacity: 1; + background-color: rgb(243 244 246 / var(--tw-bg-opacity)); +} + +.focus\:bg-gray-900:focus { + --tw-bg-opacity: 1; + background-color: rgb(17 24 39 / var(--tw-bg-opacity)); +} + +.focus\:text-blue-700:focus { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); +} + +.focus\:text-white:focus { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +.focus\:outline-none:focus { + outline: 2px solid transparent; + outline-offset: 2px; +} + +.focus\:ring-0:focus { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} + +.focus\:ring-2:focus { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} + +.focus\:ring-4:focus { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} + +.focus\:ring-\[\#050708\]\/50:focus { + --tw-ring-color: rgb(5 7 8 / 0.5); +} + +.focus\:ring-\[\#1da1f2\]\/50:focus { + --tw-ring-color: rgb(29 161 242 / 0.5); +} + +.focus\:ring-\[\#24292F\]\/50:focus { + --tw-ring-color: rgb(36 41 47 / 0.5); +} + +.focus\:ring-\[\#2557D6\]\/50:focus { + --tw-ring-color: rgb(37 87 214 / 0.5); +} + +.focus\:ring-\[\#3b5998\]\/50:focus { + --tw-ring-color: rgb(59 89 152 / 0.5); +} + +.focus\:ring-\[\#4285F4\]\/50:focus { + --tw-ring-color: rgb(66 133 244 / 0.5); +} + +.focus\:ring-\[\#F7BE38\]\/50:focus { + --tw-ring-color: rgb(247 190 56 / 0.5); +} + +.focus\:ring-\[\#FF9119\]\/50:focus { + --tw-ring-color: rgb(255 145 25 / 0.5); +} + +.focus\:ring-blue-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(195 221 253 / var(--tw-ring-opacity)); +} + +.focus\:ring-blue-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(164 202 254 / var(--tw-ring-opacity)); +} + +.focus\:ring-blue-400:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(118 169 250 / var(--tw-ring-opacity)); +} + +.focus\:ring-blue-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(63 131 248 / var(--tw-ring-opacity)); +} + +.focus\:ring-blue-600:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(28 100 242 / var(--tw-ring-opacity)); +} + +.focus\:ring-blue-700:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(26 86 219 / var(--tw-ring-opacity)); +} + +.focus\:ring-cyan-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(165 243 252 / var(--tw-ring-opacity)); +} + +.focus\:ring-cyan-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(103 232 249 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-100:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(243 244 246 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(229 231 235 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(209 213 219 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-400:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(156 163 175 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-50:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(249 250 251 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(107 114 128 / var(--tw-ring-opacity)); +} + +.focus\:ring-gray-700:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(55 65 81 / var(--tw-ring-opacity)); +} + +.focus\:ring-green-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(188 240 218 / var(--tw-ring-opacity)); +} + +.focus\:ring-green-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(132 225 188 / var(--tw-ring-opacity)); +} + +.focus\:ring-green-400:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(49 196 141 / var(--tw-ring-opacity)); +} + +.focus\:ring-green-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(14 159 110 / var(--tw-ring-opacity)); +} + +.focus\:ring-lime-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(217 249 157 / var(--tw-ring-opacity)); +} + +.focus\:ring-lime-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(190 242 100 / var(--tw-ring-opacity)); +} + +.focus\:ring-orange-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(255 90 31 / var(--tw-ring-opacity)); +} + +.focus\:ring-pink-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(250 209 232 / var(--tw-ring-opacity)); +} + +.focus\:ring-pink-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(248 180 217 / var(--tw-ring-opacity)); +} + +.focus\:ring-purple-200:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(220 215 254 / var(--tw-ring-opacity)); +} + +.focus\:ring-purple-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(202 191 253 / var(--tw-ring-opacity)); +} + +.focus\:ring-purple-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(144 97 249 / var(--tw-ring-opacity)); +} + +.focus\:ring-red-100:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(253 232 232 / var(--tw-ring-opacity)); +} + +.focus\:ring-red-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(248 180 180 / var(--tw-ring-opacity)); +} + +.focus\:ring-red-400:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(249 128 128 / var(--tw-ring-opacity)); +} + +.focus\:ring-red-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(240 82 82 / var(--tw-ring-opacity)); +} + +.focus\:ring-teal-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(126 220 226 / var(--tw-ring-opacity)); +} + +.focus\:ring-teal-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(6 148 162 / var(--tw-ring-opacity)); +} + +.focus\:ring-yellow-300:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(250 202 21 / var(--tw-ring-opacity)); +} + +.focus\:ring-yellow-400:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(227 160 8 / var(--tw-ring-opacity)); +} + +.focus\:ring-yellow-500:focus { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(194 120 3 / var(--tw-ring-opacity)); +} + +.group:hover .group-hover\:rotate-45 { + --tw-rotate: 45deg; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.group:hover .group-hover\:bg-white\/50 { + background-color: rgb(255 255 255 / 0.5); +} + +.group:hover .group-hover\:bg-opacity-0 { + --tw-bg-opacity: 0; +} + +.group:hover .group-hover\:from-cyan-500 { + --tw-gradient-from: #06b6d4 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(6 182 212 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-green-400 { + --tw-gradient-from: #31C48D var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(49 196 141 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-pink-500 { + --tw-gradient-from: #E74694 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(231 70 148 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-purple-500 { + --tw-gradient-from: #9061F9 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(144 97 249 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-purple-600 { + --tw-gradient-from: #7E3AF2 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(126 58 242 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-red-200 { + --tw-gradient-from: #FBD5D5 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(251 213 213 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:from-teal-300 { + --tw-gradient-from: #7EDCE2 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(126 220 226 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +.group:hover .group-hover\:via-red-300 { + --tw-gradient-via-position: ; + --tw-gradient-to: rgb(248 180 180 / 0) var(--tw-gradient-to-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), #F8B4B4 var(--tw-gradient-via-position), var(--tw-gradient-to); +} + +.group:hover .group-hover\:to-blue-500 { + --tw-gradient-to: #3F83F8 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:to-blue-600 { + --tw-gradient-to: #1C64F2 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:to-lime-300 { + --tw-gradient-to: #bef264 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:to-orange-400 { + --tw-gradient-to: #FF8A4C var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:to-pink-500 { + --tw-gradient-to: #E74694 var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:to-yellow-200 { + --tw-gradient-to: #FCE96A var(--tw-gradient-to-position); + --tw-gradient-to-position: ; +} + +.group:hover .group-hover\:text-blue-600 { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +.group:hover .group-hover\:text-gray-500 { + --tw-text-opacity: 1; + color: rgb(107 114 128 / var(--tw-text-opacity)); +} + +.group:hover .group-hover\:text-gray-900 { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +.group:hover .group-hover\:opacity-100 { + opacity: 1; +} + +.group:focus .group-focus\:text-gray-900 { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +.group:focus .group-focus\:outline-none { + outline: 2px solid transparent; + outline-offset: 2px; +} + +.group:focus .group-focus\:ring-4 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} + +.group:focus .group-focus\:ring-white { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity)); +} + +.peer:checked ~ .peer-checked\:border-blue-600 { + --tw-border-opacity: 1; + border-color: rgb(28 100 242 / var(--tw-border-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-blue-600 { + --tw-bg-opacity: 1; + background-color: rgb(28 100 242 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-green-600 { + --tw-bg-opacity: 1; + background-color: rgb(5 122 85 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-orange-500 { + --tw-bg-opacity: 1; + background-color: rgb(255 90 31 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-purple-600 { + --tw-bg-opacity: 1; + background-color: rgb(126 58 242 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-red-600 { + --tw-bg-opacity: 1; + background-color: rgb(224 36 36 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-teal-600 { + --tw-bg-opacity: 1; + background-color: rgb(4 116 129 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:bg-yellow-400 { + --tw-bg-opacity: 1; + background-color: rgb(227 160 8 / var(--tw-bg-opacity)); +} + +.peer:checked ~ .peer-checked\:text-blue-600 { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +.peer:checked ~ .peer-checked\:text-gray-600 { + --tw-text-opacity: 1; + color: rgb(75 85 99 / var(--tw-text-opacity)); +} + +.peer:checked ~ .peer-checked\:after\:translate-x-full::after { + content: var(--tw-content); + --tw-translate-x: 100%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:checked ~ .peer-checked\:after\:border-white::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(255 255 255 / var(--tw-border-opacity)); +} + +.peer:-moz-placeholder-shown ~ .peer-placeholder-shown\:top-1\/2 { + top: 50%; +} + +.peer:placeholder-shown ~ .peer-placeholder-shown\:top-1\/2 { + top: 50%; +} + +.peer:-moz-placeholder-shown ~ .peer-placeholder-shown\:-translate-y-1\/2 { + --tw-translate-y: -50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:placeholder-shown ~ .peer-placeholder-shown\:-translate-y-1\/2 { + --tw-translate-y: -50%; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:-moz-placeholder-shown ~ .peer-placeholder-shown\:translate-y-0 { + --tw-translate-y: 0px; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:placeholder-shown ~ .peer-placeholder-shown\:translate-y-0 { + --tw-translate-y: 0px; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:-moz-placeholder-shown ~ .peer-placeholder-shown\:scale-100 { + --tw-scale-x: 1; + --tw-scale-y: 1; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:placeholder-shown ~ .peer-placeholder-shown\:scale-100 { + --tw-scale-x: 1; + --tw-scale-y: 1; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:focus ~ .peer-focus\:left-0 { + left: 0px; +} + +.peer:focus ~ .peer-focus\:top-1 { + top: 0.25rem; +} + +.peer:focus ~ .peer-focus\:top-2 { + top: 0.5rem; +} + +.peer:focus ~ .peer-focus\:-translate-y-3 { + --tw-translate-y: -0.75rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:focus ~ .peer-focus\:-translate-y-4 { + --tw-translate-y: -1rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:focus ~ .peer-focus\:-translate-y-6 { + --tw-translate-y: -1.5rem; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:focus ~ .peer-focus\:scale-75 { + --tw-scale-x: .75; + --tw-scale-y: .75; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); +} + +.peer:focus ~ .peer-focus\:px-2 { + padding-left: 0.5rem; + padding-right: 0.5rem; +} + +.peer:focus ~ .peer-focus\:font-medium { + font-weight: 500; +} + +.peer:focus ~ .peer-focus\:text-blue-600 { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +.peer:focus ~ .peer-focus\:outline-none { + outline: 2px solid transparent; + outline-offset: 2px; +} + +.peer:focus ~ .peer-focus\:ring-4 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); +} + +.peer:focus ~ .peer-focus\:ring-blue-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(164 202 254 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-green-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(132 225 188 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-orange-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(253 186 140 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-purple-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(202 191 253 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-red-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(248 180 180 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-teal-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(126 220 226 / var(--tw-ring-opacity)); +} + +.peer:focus ~ .peer-focus\:ring-yellow-300 { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(250 202 21 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:block) { + display: block; +} + +:is(.dark .dark\:inline-block) { + display: inline-block; +} + +:is(.dark .dark\:hidden) { + display: none; +} + +:is(.dark .dark\:divide-gray-600) > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(75 85 99 / var(--tw-divide-opacity)); +} + +:is(.dark .dark\:divide-gray-700) > :not([hidden]) ~ :not([hidden]) { + --tw-divide-opacity: 1; + border-color: rgb(55 65 81 / var(--tw-divide-opacity)); +} + +:is(.dark .dark\:\!border-blue-500) { + --tw-border-opacity: 1 !important; + border-color: rgb(63 131 248 / var(--tw-border-opacity)) !important; +} + +:is(.dark .dark\:border-blue-400) { + --tw-border-opacity: 1; + border-color: rgb(118 169 250 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-blue-500) { + --tw-border-opacity: 1; + border-color: rgb(63 131 248 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-blue-600) { + --tw-border-opacity: 1; + border-color: rgb(28 100 242 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-blue-800) { + --tw-border-opacity: 1; + border-color: rgb(30 66 159 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-400) { + --tw-border-opacity: 1; + border-color: rgb(156 163 175 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-500) { + --tw-border-opacity: 1; + border-color: rgb(107 114 128 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-600) { + --tw-border-opacity: 1; + border-color: rgb(75 85 99 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-700) { + --tw-border-opacity: 1; + border-color: rgb(55 65 81 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-800) { + --tw-border-opacity: 1; + border-color: rgb(31 41 55 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-gray-900) { + --tw-border-opacity: 1; + border-color: rgb(17 24 39 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-green-400) { + --tw-border-opacity: 1; + border-color: rgb(49 196 141 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-green-500) { + --tw-border-opacity: 1; + border-color: rgb(14 159 110 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-green-600) { + --tw-border-opacity: 1; + border-color: rgb(5 122 85 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-green-800) { + --tw-border-opacity: 1; + border-color: rgb(3 84 63 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-purple-400) { + --tw-border-opacity: 1; + border-color: rgb(172 148 250 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-red-400) { + --tw-border-opacity: 1; + border-color: rgb(249 128 128 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-red-500) { + --tw-border-opacity: 1; + border-color: rgb(240 82 82 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-red-600) { + --tw-border-opacity: 1; + border-color: rgb(224 36 36 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-red-800) { + --tw-border-opacity: 1; + border-color: rgb(155 28 28 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-transparent) { + border-color: transparent; +} + +:is(.dark .dark\:border-white) { + --tw-border-opacity: 1; + border-color: rgb(255 255 255 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-yellow-300) { + --tw-border-opacity: 1; + border-color: rgb(250 202 21 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-yellow-800) { + --tw-border-opacity: 1; + border-color: rgb(114 59 19 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:border-l-gray-700) { + --tw-border-opacity: 1; + border-left-color: rgb(55 65 81 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:bg-blue-200) { + --tw-bg-opacity: 1; + background-color: rgb(195 221 253 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-blue-400) { + --tw-bg-opacity: 1; + background-color: rgb(118 169 250 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-blue-500) { + --tw-bg-opacity: 1; + background-color: rgb(63 131 248 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-blue-600) { + --tw-bg-opacity: 1; + background-color: rgb(28 100 242 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-blue-800) { + --tw-bg-opacity: 1; + background-color: rgb(30 66 159 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-blue-900) { + --tw-bg-opacity: 1; + background-color: rgb(35 56 118 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-300) { + --tw-bg-opacity: 1; + background-color: rgb(209 213 219 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-400) { + --tw-bg-opacity: 1; + background-color: rgb(156 163 175 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-500) { + --tw-bg-opacity: 1; + background-color: rgb(107 114 128 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-600) { + --tw-bg-opacity: 1; + background-color: rgb(75 85 99 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-700) { + --tw-bg-opacity: 1; + background-color: rgb(55 65 81 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-800) { + --tw-bg-opacity: 1; + background-color: rgb(31 41 55 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-800\/30) { + background-color: rgb(31 41 55 / 0.3); +} + +:is(.dark .dark\:bg-gray-800\/50) { + background-color: rgb(31 41 55 / 0.5); +} + +:is(.dark .dark\:bg-gray-900) { + --tw-bg-opacity: 1; + background-color: rgb(17 24 39 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-gray-900\/60) { + background-color: rgb(17 24 39 / 0.6); +} + +:is(.dark .dark\:bg-green-100) { + --tw-bg-opacity: 1; + background-color: rgb(222 247 236 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-green-500) { + --tw-bg-opacity: 1; + background-color: rgb(14 159 110 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-green-600) { + --tw-bg-opacity: 1; + background-color: rgb(5 122 85 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-green-800) { + --tw-bg-opacity: 1; + background-color: rgb(3 84 63 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-green-900) { + --tw-bg-opacity: 1; + background-color: rgb(1 71 55 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-indigo-500) { + --tw-bg-opacity: 1; + background-color: rgb(104 117 245 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-indigo-900) { + --tw-bg-opacity: 1; + background-color: rgb(54 47 120 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-orange-200) { + --tw-bg-opacity: 1; + background-color: rgb(252 217 189 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-orange-400) { + --tw-bg-opacity: 1; + background-color: rgb(255 138 76 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-orange-700) { + --tw-bg-opacity: 1; + background-color: rgb(180 52 3 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-pink-900) { + --tw-bg-opacity: 1; + background-color: rgb(117 26 61 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-purple-500) { + --tw-bg-opacity: 1; + background-color: rgb(144 97 249 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-purple-600) { + --tw-bg-opacity: 1; + background-color: rgb(126 58 242 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-purple-900) { + --tw-bg-opacity: 1; + background-color: rgb(74 29 150 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-red-100) { + --tw-bg-opacity: 1; + background-color: rgb(253 232 232 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-red-500) { + --tw-bg-opacity: 1; + background-color: rgb(240 82 82 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-red-600) { + --tw-bg-opacity: 1; + background-color: rgb(224 36 36 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-red-800) { + --tw-bg-opacity: 1; + background-color: rgb(155 28 28 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-red-900) { + --tw-bg-opacity: 1; + background-color: rgb(119 29 29 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-white) { + --tw-bg-opacity: 1; + background-color: rgb(255 255 255 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-yellow-300) { + --tw-bg-opacity: 1; + background-color: rgb(250 202 21 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-yellow-900) { + --tw-bg-opacity: 1; + background-color: rgb(99 49 18 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:bg-opacity-80) { + --tw-bg-opacity: 0.8; +} + +:is(.dark .dark\:bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/hero-pattern-dark\.svg\'\)\]) { + background-image: url('https://flowbite.s3.amazonaws.com/docs/jumbotron/hero-pattern-dark.svg'); +} + +:is(.dark .dark\:from-blue-900) { + --tw-gradient-from: #233876 var(--tw-gradient-from-position); + --tw-gradient-from-position: ; + --tw-gradient-to: rgb(35 56 118 / 0) var(--tw-gradient-from-position); + --tw-gradient-to-position: ; + --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); +} + +:is(.dark .dark\:fill-gray-300) { + fill: #D1D5DB; +} + +:is(.dark .dark\:fill-gray-400) { + fill: #9CA3AF; +} + +:is(.dark .dark\:\!text-blue-500) { + --tw-text-opacity: 1 !important; + color: rgb(63 131 248 / var(--tw-text-opacity)) !important; +} + +:is(.dark .dark\:text-blue-100) { + --tw-text-opacity: 1; + color: rgb(225 239 254 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-200) { + --tw-text-opacity: 1; + color: rgb(195 221 253 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-300) { + --tw-text-opacity: 1; + color: rgb(164 202 254 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-400) { + --tw-text-opacity: 1; + color: rgb(118 169 250 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-500) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-500\/100) { + color: rgb(63 131 248 / 1); +} + +:is(.dark .dark\:text-blue-500\/25) { + color: rgb(63 131 248 / 0.25); +} + +:is(.dark .dark\:text-blue-500\/50) { + color: rgb(63 131 248 / 0.5); +} + +:is(.dark .dark\:text-blue-500\/75) { + color: rgb(63 131 248 / 0.75); +} + +:is(.dark .dark\:text-blue-600) { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-blue-800) { + --tw-text-opacity: 1; + color: rgb(30 66 159 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-100) { + --tw-text-opacity: 1; + color: rgb(243 244 246 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-200) { + --tw-text-opacity: 1; + color: rgb(229 231 235 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-300) { + --tw-text-opacity: 1; + color: rgb(209 213 219 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-400) { + --tw-text-opacity: 1; + color: rgb(156 163 175 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-500) { + --tw-text-opacity: 1; + color: rgb(107 114 128 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-600) { + --tw-text-opacity: 1; + color: rgb(75 85 99 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-700) { + --tw-text-opacity: 1; + color: rgb(55 65 81 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-800) { + --tw-text-opacity: 1; + color: rgb(31 41 55 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-gray-900) { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-green-200) { + --tw-text-opacity: 1; + color: rgb(188 240 218 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-green-300) { + --tw-text-opacity: 1; + color: rgb(132 225 188 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-green-400) { + --tw-text-opacity: 1; + color: rgb(49 196 141 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-green-500) { + --tw-text-opacity: 1; + color: rgb(14 159 110 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-green-600) { + --tw-text-opacity: 1; + color: rgb(5 122 85 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-indigo-300) { + --tw-text-opacity: 1; + color: rgb(180 198 252 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-indigo-400) { + --tw-text-opacity: 1; + color: rgb(141 162 251 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-indigo-500) { + --tw-text-opacity: 1; + color: rgb(104 117 245 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-orange-200) { + --tw-text-opacity: 1; + color: rgb(252 217 189 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-orange-300) { + --tw-text-opacity: 1; + color: rgb(253 186 140 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-orange-900) { + --tw-text-opacity: 1; + color: rgb(119 29 29 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-pink-300) { + --tw-text-opacity: 1; + color: rgb(248 180 217 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-pink-400) { + --tw-text-opacity: 1; + color: rgb(241 126 184 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-purple-300) { + --tw-text-opacity: 1; + color: rgb(202 191 253 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-purple-400) { + --tw-text-opacity: 1; + color: rgb(172 148 250 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-purple-500) { + --tw-text-opacity: 1; + color: rgb(144 97 249 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-red-200) { + --tw-text-opacity: 1; + color: rgb(251 213 213 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-red-300) { + --tw-text-opacity: 1; + color: rgb(248 180 180 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-red-400) { + --tw-text-opacity: 1; + color: rgb(249 128 128 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-red-500) { + --tw-text-opacity: 1; + color: rgb(240 82 82 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-teal-300) { + --tw-text-opacity: 1; + color: rgb(126 220 226 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-white) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-yellow-300) { + --tw-text-opacity: 1; + color: rgb(250 202 21 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:text-yellow-500) { + --tw-text-opacity: 1; + color: rgb(194 120 3 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:decoration-blue-600) { + text-decoration-color: #1C64F2; +} + +:is(.dark .dark\:placeholder-gray-400)::-moz-placeholder { + --tw-placeholder-opacity: 1; + color: rgb(156 163 175 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:placeholder-gray-400)::placeholder { + --tw-placeholder-opacity: 1; + color: rgb(156 163 175 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:placeholder-green-500)::-moz-placeholder { + --tw-placeholder-opacity: 1; + color: rgb(14 159 110 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:placeholder-green-500)::placeholder { + --tw-placeholder-opacity: 1; + color: rgb(14 159 110 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:placeholder-red-500)::-moz-placeholder { + --tw-placeholder-opacity: 1; + color: rgb(240 82 82 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:placeholder-red-500)::placeholder { + --tw-placeholder-opacity: 1; + color: rgb(240 82 82 / var(--tw-placeholder-opacity)); +} + +:is(.dark .dark\:shadow-lg) { + --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); + --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} + +:is(.dark .dark\:shadow-sm-light) { + --tw-shadow: 0 2px 5px 0px rgba(255, 255, 255, 0.08); + --tw-shadow-colored: 0 2px 5px 0px var(--tw-shadow-color); + box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow); +} + +:is(.dark .dark\:shadow-blue-800\/80) { + --tw-shadow-color: rgb(30 66 159 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-cyan-800\/80) { + --tw-shadow-color: rgb(21 94 117 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-gray-800) { + --tw-shadow-color: #1F2937; + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-green-800\/80) { + --tw-shadow-color: rgb(3 84 63 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-lime-800\/80) { + --tw-shadow-color: rgb(63 98 18 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-pink-800\/80) { + --tw-shadow-color: rgb(153 21 75 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-purple-800\/80) { + --tw-shadow-color: rgb(85 33 181 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-red-800\/80) { + --tw-shadow-color: rgb(155 28 28 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:shadow-teal-800\/80) { + --tw-shadow-color: rgb(5 80 92 / 0.8); + --tw-shadow: var(--tw-shadow-colored); +} + +:is(.dark .dark\:ring-gray-500) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(107 114 128 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:ring-gray-900) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(17 24 39 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:ring-offset-gray-700) { + --tw-ring-offset-color: #374151; +} + +:is(.dark .dark\:ring-offset-gray-800) { + --tw-ring-offset-color: #1F2937; +} + +:is(.dark .dark\:first-letter\:text-gray-100)::first-letter { + --tw-text-opacity: 1; + color: rgb(243 244 246 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:after\:border-blue-800)::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(30 66 159 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:after\:border-gray-700)::after { + content: var(--tw-content); + --tw-border-opacity: 1; + border-color: rgb(55 65 81 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:after\:text-gray-500)::after { + content: var(--tw-content); + --tw-text-opacity: 1; + color: rgb(107 114 128 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:border-gray-500:hover) { + --tw-border-opacity: 1; + border-color: rgb(107 114 128 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:hover\:border-gray-600:hover) { + --tw-border-opacity: 1; + border-color: rgb(75 85 99 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:hover\:border-gray-700:hover) { + --tw-border-opacity: 1; + border-color: rgb(55 65 81 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:hover\:bg-\[\#050708\]\/30:hover) { + background-color: rgb(5 7 8 / 0.3); +} + +:is(.dark .dark\:hover\:bg-\[\#050708\]\/40:hover) { + background-color: rgb(5 7 8 / 0.4); +} + +:is(.dark .dark\:hover\:bg-\[\#FF9119\]\/80:hover) { + background-color: rgb(255 145 25 / 0.8); +} + +:is(.dark .dark\:hover\:bg-blue-500:hover) { + --tw-bg-opacity: 1; + background-color: rgb(63 131 248 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-blue-600:hover) { + --tw-bg-opacity: 1; + background-color: rgb(28 100 242 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-blue-700:hover) { + --tw-bg-opacity: 1; + background-color: rgb(26 86 219 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-blue-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(30 66 159 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-gray-200:hover) { + --tw-bg-opacity: 1; + background-color: rgb(229 231 235 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-gray-500:hover) { + --tw-bg-opacity: 1; + background-color: rgb(107 114 128 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-gray-600:hover) { + --tw-bg-opacity: 1; + background-color: rgb(75 85 99 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-gray-700:hover) { + --tw-bg-opacity: 1; + background-color: rgb(55 65 81 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-gray-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(31 41 55 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-green-600:hover) { + --tw-bg-opacity: 1; + background-color: rgb(5 122 85 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-green-700:hover) { + --tw-bg-opacity: 1; + background-color: rgb(4 108 78 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-green-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(3 84 63 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-indigo-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(66 56 157 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-pink-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(153 21 75 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-purple-500:hover) { + --tw-bg-opacity: 1; + background-color: rgb(144 97 249 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-purple-700:hover) { + --tw-bg-opacity: 1; + background-color: rgb(108 43 217 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-purple-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(85 33 181 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-red-600:hover) { + --tw-bg-opacity: 1; + background-color: rgb(224 36 36 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-red-700:hover) { + --tw-bg-opacity: 1; + background-color: rgb(200 30 30 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-red-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(155 28 28 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-yellow-300:hover) { + --tw-bg-opacity: 1; + background-color: rgb(250 202 21 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-yellow-400:hover) { + --tw-bg-opacity: 1; + background-color: rgb(227 160 8 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:bg-yellow-800:hover) { + --tw-bg-opacity: 1; + background-color: rgb(114 59 19 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:hover\:\!text-blue-500:hover) { + --tw-text-opacity: 1 !important; + color: rgb(63 131 248 / var(--tw-text-opacity)) !important; +} + +:is(.dark .dark\:hover\:text-blue-300:hover) { + --tw-text-opacity: 1; + color: rgb(164 202 254 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-blue-400:hover) { + --tw-text-opacity: 1; + color: rgb(118 169 250 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-blue-500:hover) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-blue-600:hover) { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-blue-700:hover) { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-gray-300:hover) { + --tw-text-opacity: 1; + color: rgb(209 213 219 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-gray-400:hover) { + --tw-text-opacity: 1; + color: rgb(156 163 175 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-gray-800:hover) { + --tw-text-opacity: 1; + color: rgb(31 41 55 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-gray-900:hover) { + --tw-text-opacity: 1; + color: rgb(17 24 39 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-green-300:hover) { + --tw-text-opacity: 1; + color: rgb(132 225 188 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-indigo-300:hover) { + --tw-text-opacity: 1; + color: rgb(180 198 252 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-pink-300:hover) { + --tw-text-opacity: 1; + color: rgb(248 180 217 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-purple-300:hover) { + --tw-text-opacity: 1; + color: rgb(202 191 253 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-red-300:hover) { + --tw-text-opacity: 1; + color: rgb(248 180 180 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-white:hover) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:text-yellow-300:hover) { + --tw-text-opacity: 1; + color: rgb(250 202 21 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:hover\:bg-blend-darken:hover) { + background-blend-mode: darken; +} + +:is(.dark .dark\:focus\:border-blue-500:focus) { + --tw-border-opacity: 1; + border-color: rgb(63 131 248 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:focus\:border-green-500:focus) { + --tw-border-opacity: 1; + border-color: rgb(14 159 110 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:focus\:border-red-500:focus) { + --tw-border-opacity: 1; + border-color: rgb(240 82 82 / var(--tw-border-opacity)); +} + +:is(.dark .dark\:focus\:bg-blue-600:focus) { + --tw-bg-opacity: 1; + background-color: rgb(28 100 242 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:focus\:bg-gray-700:focus) { + --tw-bg-opacity: 1; + background-color: rgb(55 65 81 / var(--tw-bg-opacity)); +} + +:is(.dark .dark\:focus\:text-white:focus) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +:is(.dark .dark\:focus\:ring-\[\#050708\]\/50:focus) { + --tw-ring-color: rgb(5 7 8 / 0.5); +} + +:is(.dark .dark\:focus\:ring-\[\#2557D6\]\/50:focus) { + --tw-ring-color: rgb(37 87 214 / 0.5); +} + +:is(.dark .dark\:focus\:ring-\[\#F7BE38\]\/50:focus) { + --tw-ring-color: rgb(247 190 56 / 0.5); +} + +:is(.dark .dark\:focus\:ring-\[\#FF9119\]\/40:focus) { + --tw-ring-color: rgb(255 145 25 / 0.4); +} + +:is(.dark .dark\:focus\:ring-blue-500:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(63 131 248 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-blue-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(28 100 242 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-blue-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(30 66 159 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-blue-900:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(35 56 118 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-cyan-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(21 94 117 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-gray-400:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(156 163 175 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-gray-500:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(107 114 128 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-gray-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(75 85 99 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-gray-700:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(55 65 81 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-gray-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(31 41 55 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-green-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(5 122 85 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-green-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(3 84 63 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-lime-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(63 98 18 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-orange-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(208 56 1 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-pink-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(153 21 75 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-purple-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(126 58 242 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-purple-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(85 33 181 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-purple-900:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(74 29 150 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-red-400:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(249 128 128 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-red-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(224 36 36 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-red-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(155 28 28 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-red-900:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(119 29 29 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-teal-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(4 116 129 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-teal-700:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(3 102 114 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-teal-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(5 80 92 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-yellow-600:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(159 88 10 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-yellow-800:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(114 59 19 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-yellow-900:focus) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(99 49 18 / var(--tw-ring-opacity)); +} + +:is(.dark .dark\:focus\:ring-offset-gray-700:focus) { + --tw-ring-offset-color: #374151; +} + +:is(.dark .dark\:focus\:ring-offset-gray-800:focus) { + --tw-ring-offset-color: #1F2937; +} + +:is(.dark .group:hover .dark\:group-hover\:bg-gray-800\/60) { + background-color: rgb(31 41 55 / 0.6); +} + +:is(.dark .group:hover .dark\:group-hover\:text-blue-500) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} + +:is(.dark .group:hover .dark\:group-hover\:text-gray-300) { + --tw-text-opacity: 1; + color: rgb(209 213 219 / var(--tw-text-opacity)); +} + +:is(.dark .group:hover .dark\:group-hover\:text-white) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +:is(.dark .group:focus .dark\:group-focus\:text-white) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); +} + +:is(.dark .group:focus .dark\:group-focus\:ring-gray-800\/70) { + --tw-ring-color: rgb(31 41 55 / 0.7); +} + +:is(.dark .peer:checked ~ .dark\:peer-checked\:text-blue-500) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} + +:is(.dark .peer:checked ~ .dark\:peer-checked\:text-gray-300) { + --tw-text-opacity: 1; + color: rgb(209 213 219 / var(--tw-text-opacity)); +} + +.peer:focus ~ :is(.dark .peer-focus\:dark\:text-blue-500) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-blue-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(30 66 159 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-green-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(3 84 63 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-orange-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(138 44 13 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-purple-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(85 33 181 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-red-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(155 28 28 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-teal-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(5 80 92 / var(--tw-ring-opacity)); +} + +:is(.dark .peer:focus ~ .dark\:peer-focus\:ring-yellow-800) { + --tw-ring-opacity: 1; + --tw-ring-color: rgb(114 59 19 / var(--tw-ring-opacity)); +} + +@media (min-width: 640px) { + + .sm\:order-last { + order: 9999; + } + + .sm\:col-span-1 { + grid-column: span 1 / span 1; + } + + .sm\:col-span-3 { + grid-column: span 3 / span 3; + } + + .sm\:mx-auto { + margin-left: auto; + margin-right: auto; + } + + .sm\:mb-0 { + margin-bottom: 0px; + } + + .sm\:mb-4 { + margin-bottom: 1rem; + } + + .sm\:mb-5 { + margin-bottom: 1.25rem; + } + + .sm\:ml-2 { + margin-left: 0.5rem; + } + + .sm\:ml-4 { + margin-left: 1rem; + } + + .sm\:ml-64 { + margin-left: 16rem; + } + + .sm\:ml-auto { + margin-left: auto; + } + + .sm\:mt-0 { + margin-top: 0px; + } + + .sm\:block { + display: block; + } + + .sm\:flex { + display: flex; + } + + .sm\:inline-flex { + display: inline-flex; + } + + .sm\:grid { + display: grid; + } + + .sm\:hidden { + display: none; + } + + .sm\:h-4 { + height: 1rem; + } + + .sm\:h-64 { + height: 16rem; + } + + .sm\:h-7 { + height: 1.75rem; + } + + .sm\:h-9 { + height: 2.25rem; + } + + .sm\:h-96 { + height: 24rem; + } + + .sm\:w-4 { + width: 1rem; + } + + .sm\:w-96 { + width: 24rem; + } + + .sm\:w-auto { + width: auto; + } + + .sm\:translate-x-0 { + --tw-translate-x: 0px; + transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)); + } + + .sm\:grid-cols-2 { + grid-template-columns: repeat(2, minmax(0, 1fr)); + } + + .sm\:grid-cols-3 { + grid-template-columns: repeat(3, minmax(0, 1fr)); + } + + .sm\:flex-row { + flex-direction: row; + } + + .sm\:items-center { + align-items: center; + } + + .sm\:justify-center { + justify-content: center; + } + + .sm\:justify-between { + justify-content: space-between; + } + + .sm\:gap-6 { + gap: 1.5rem; + } + + .sm\:space-x-4 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(1rem * var(--tw-space-x-reverse)); + margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse))); + } + + .sm\:space-x-8 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(2rem * var(--tw-space-x-reverse)); + margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse))); + } + + .sm\:space-y-0 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0px * var(--tw-space-y-reverse)); + } + + .sm\:divide-x > :not([hidden]) ~ :not([hidden]) { + --tw-divide-x-reverse: 0; + border-right-width: calc(1px * var(--tw-divide-x-reverse)); + border-left-width: calc(1px * calc(1 - var(--tw-divide-x-reverse))); + } + + .sm\:rounded-lg { + border-radius: 0.5rem; + } + + .sm\:border-b-0 { + border-bottom-width: 0px; + } + + .sm\:border-r { + border-right-width: 1px; + } + + .sm\:p-4 { + padding: 1rem; + } + + .sm\:p-6 { + padding: 1.5rem; + } + + .sm\:p-8 { + padding: 2rem; + } + + .sm\:px-16 { + padding-left: 4rem; + padding-right: 4rem; + } + + .sm\:px-4 { + padding-left: 1rem; + padding-right: 1rem; + } + + .sm\:px-5 { + padding-left: 1.25rem; + padding-right: 1.25rem; + } + + .sm\:py-16 { + padding-top: 4rem; + padding-bottom: 4rem; + } + + .sm\:py-4 { + padding-top: 1rem; + padding-bottom: 1rem; + } + + .sm\:pb-4 { + padding-bottom: 1rem; + } + + .sm\:pl-2 { + padding-left: 0.5rem; + } + + .sm\:pl-4 { + padding-left: 1rem; + } + + .sm\:pr-4 { + padding-right: 1rem; + } + + .sm\:pr-8 { + padding-right: 2rem; + } + + .sm\:pt-4 { + padding-top: 1rem; + } + + .sm\:text-center { + text-align: center; + } + + .sm\:text-2xl { + font-size: 1.5rem; + line-height: 2rem; + } + + .sm\:text-base { + font-size: 1rem; + line-height: 1.5rem; + } + + .sm\:text-lg { + font-size: 1.125rem; + line-height: 1.75rem; + } + + .sm\:text-xl { + font-size: 1.25rem; + line-height: 1.75rem; + } + + .sm\:text-xs { + font-size: 0.75rem; + line-height: 1rem; + } + + .sm\:ring-8 { + --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); + --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(8px + var(--tw-ring-offset-width)) var(--tw-ring-color); + box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000); + } + + .sm\:after\:inline-block::after { + content: var(--tw-content); + display: inline-block; + } + + .sm\:after\:hidden::after { + content: var(--tw-content); + display: none; + } + + .sm\:after\:content-\[\'\'\]::after { + --tw-content: ''; + content: var(--tw-content); + } +} + +@media (min-width: 768px) { + + .md\:relative { + position: relative; + } + + .md\:inset-0 { + inset: 0px; + } + + .md\:right-auto { + right: auto; + } + + .md\:top-auto { + top: auto; + } + + .md\:order-1 { + order: 1; + } + + .md\:order-2 { + order: 2; + } + + .md\:m-0 { + margin: 0px; + } + + .md\:mx-2 { + margin-left: 0.5rem; + margin-right: 0.5rem; + } + + .md\:my-0 { + margin-top: 0px; + margin-bottom: 0px; + } + + .md\:my-10 { + margin-top: 2.5rem; + margin-bottom: 2.5rem; + } + + .md\:my-12 { + margin-top: 3rem; + margin-bottom: 3rem; + } + + .md\:mb-0 { + margin-bottom: 0px; + } + + .md\:mb-12 { + margin-bottom: 3rem; + } + + .md\:ml-1 { + margin-left: 0.25rem; + } + + .md\:ml-2 { + margin-left: 0.5rem; + } + + .md\:mr-0 { + margin-right: 0px; + } + + .md\:mr-2 { + margin-right: 0.5rem; + } + + .md\:mr-24 { + margin-right: 6rem; + } + + .md\:mr-4 { + margin-right: 1rem; + } + + .md\:mr-6 { + margin-right: 1.5rem; + } + + .md\:mt-0 { + margin-top: 0px; + } + + .md\:mt-6 { + margin-top: 1.5rem; + } + + .md\:block { + display: block; + } + + .md\:inline { + display: inline; + } + + .md\:flex { + display: flex; + } + + .md\:inline-flex { + display: inline-flex; + } + + .md\:grid { + display: grid; + } + + .md\:hidden { + display: none; + } + + .md\:h-96 { + height: 24rem; + } + + .md\:h-\[21px\] { + height: 21px; + } + + .md\:h-\[262px\] { + height: 262px; + } + + .md\:h-\[278px\] { + height: 278px; + } + + .md\:h-\[294px\] { + height: 294px; + } + + .md\:h-\[42px\] { + height: 42px; + } + + .md\:h-\[654px\] { + height: 654px; + } + + .md\:h-\[682px\] { + height: 682px; + } + + .md\:h-\[8px\] { + height: 8px; + } + + .md\:h-\[95px\] { + height: 95px; + } + + .md\:h-auto { + height: auto; + } + + .md\:w-48 { + width: 12rem; + } + + .md\:w-64 { + width: 16rem; + } + + .md\:w-\[96px\] { + width: 96px; + } + + .md\:w-auto { + width: auto; + } + + .md\:w-full { + width: 100%; + } + + .md\:max-w-\[142px\] { + max-width: 142px; + } + + .md\:max-w-\[512px\] { + max-width: 512px; + } + + .md\:max-w-\[597px\] { + max-width: 597px; + } + + .md\:max-w-screen-md { + max-width: 768px; + } + + .md\:max-w-xl { + max-width: 36rem; + } + + .md\:grid-cols-2 { + grid-template-columns: repeat(2, minmax(0, 1fr)); + } + + .md\:grid-cols-3 { + grid-template-columns: repeat(3, minmax(0, 1fr)); + } + + .md\:grid-cols-4 { + grid-template-columns: repeat(4, minmax(0, 1fr)); + } + + .md\:flex-row { + flex-direction: row; + } + + .md\:items-center { + align-items: center; + } + + .md\:justify-between { + justify-content: space-between; + } + + .md\:gap-12 { + gap: 3rem; + } + + .md\:gap-6 { + gap: 1.5rem; + } + + .md\:gap-8 { + gap: 2rem; + } + + .md\:space-x-2 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.5rem * var(--tw-space-x-reverse)); + margin-left: calc(0.5rem * calc(1 - var(--tw-space-x-reverse))); + } + + .md\:space-x-3 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0.75rem * var(--tw-space-x-reverse)); + margin-left: calc(0.75rem * calc(1 - var(--tw-space-x-reverse))); + } + + .md\:space-x-4 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(1rem * var(--tw-space-x-reverse)); + margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse))); + } + + .md\:space-x-8 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(2rem * var(--tw-space-x-reverse)); + margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse))); + } + + .md\:space-y-0 > :not([hidden]) ~ :not([hidden]) { + --tw-space-y-reverse: 0; + margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse))); + margin-bottom: calc(0px * var(--tw-space-y-reverse)); + } + + .md\:rounded-none { + border-radius: 0px; + } + + .md\:rounded-l-lg { + border-top-left-radius: 0.5rem; + border-bottom-left-radius: 0.5rem; + } + + .md\:rounded-t-none { + border-top-left-radius: 0px; + border-top-right-radius: 0px; + } + + .md\:rounded-br-lg { + border-bottom-right-radius: 0.5rem; + } + + .md\:rounded-tl-lg { + border-top-left-radius: 0.5rem; + } + + .md\:border-0 { + border-width: 0px; + } + + .md\:border-b-0 { + border-bottom-width: 0px; + } + + .md\:border-r { + border-right-width: 1px; + } + + .md\:bg-transparent { + background-color: transparent; + } + + .md\:bg-white { + --tw-bg-opacity: 1; + background-color: rgb(255 255 255 / var(--tw-bg-opacity)); + } + + .md\:p-0 { + padding: 0px; + } + + .md\:p-12 { + padding: 3rem; + } + + .md\:p-6 { + padding: 1.5rem; + } + + .md\:p-8 { + padding: 2rem; + } + + .md\:px-5 { + padding-left: 1.25rem; + padding-right: 1.25rem; + } + + .md\:px-6 { + padding-left: 1.5rem; + padding-right: 1.5rem; + } + + .md\:py-2 { + padding-top: 0.5rem; + padding-bottom: 0.5rem; + } + + .md\:py-2\.5 { + padding-top: 0.625rem; + padding-bottom: 0.625rem; + } + + .md\:py-8 { + padding-top: 2rem; + padding-bottom: 2rem; + } + + .md\:pb-0 { + padding-bottom: 0px; + } + + .md\:pb-4 { + padding-bottom: 1rem; + } + + .md\:pr-4 { + padding-right: 1rem; + } + + .md\:pt-0 { + padding-top: 0px; + } + + .md\:text-4xl { + font-size: 2.25rem; + line-height: 2.5rem; + } + + .md\:text-5xl { + font-size: 3rem; + line-height: 1; + } + + .md\:text-lg { + font-size: 1.125rem; + line-height: 1.75rem; + } + + .md\:text-sm { + font-size: 0.875rem; + line-height: 1.25rem; + } + + .md\:text-xl { + font-size: 1.25rem; + line-height: 1.75rem; + } + + .md\:font-medium { + font-weight: 500; + } + + .md\:text-blue-700 { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); + } + + .md\:text-green-700 { + --tw-text-opacity: 1; + color: rgb(4 108 78 / var(--tw-text-opacity)); + } + + .md\:hover\:bg-transparent:hover { + background-color: transparent; + } + + .md\:hover\:text-blue-600:hover { + --tw-text-opacity: 1; + color: rgb(28 100 242 / var(--tw-text-opacity)); + } + + .md\:hover\:text-blue-700:hover { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); + } + + .md\:hover\:text-green-700:hover { + --tw-text-opacity: 1; + color: rgb(4 108 78 / var(--tw-text-opacity)); + } + + :is(.dark .md\:dark\:bg-gray-900) { + --tw-bg-opacity: 1; + background-color: rgb(17 24 39 / var(--tw-bg-opacity)); + } + + :is(.dark .md\:dark\:bg-transparent) { + background-color: transparent; + } + + :is(.dark .md\:dark\:text-blue-500) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); + } + + :is(.dark .md\:dark\:text-white) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); + } + + :is(.dark .md\:dark\:hover\:bg-transparent:hover) { + background-color: transparent; + } + + :is(.dark .md\:dark\:hover\:text-blue-500:hover) { + --tw-text-opacity: 1; + color: rgb(63 131 248 / var(--tw-text-opacity)); + } + + :is(.dark .md\:dark\:hover\:text-white:hover) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); + } +} + +@media (min-width: 1024px) { + + .lg\:static { + position: static; + } + + .lg\:sticky { + position: sticky; + } + + .lg\:top-28 { + top: 7rem; + } + + .lg\:order-1 { + order: 1; + } + + .lg\:order-2 { + order: 2; + } + + .lg\:col-span-5 { + grid-column: span 5 / span 5; + } + + .lg\:col-span-7 { + grid-column: span 7 / span 7; + } + + .lg\:my-12 { + margin-top: 3rem; + margin-bottom: 3rem; + } + + .lg\:my-8 { + margin-top: 2rem; + margin-bottom: 2rem; + } + + .lg\:mb-0 { + margin-bottom: 0px; + } + + .lg\:mb-16 { + margin-bottom: 4rem; + } + + .lg\:mb-8 { + margin-bottom: 2rem; + } + + .lg\:mr-0 { + margin-right: 0px; + } + + .lg\:mt-0 { + margin-top: 0px; + } + + .lg\:mt-10 { + margin-top: 2.5rem; + } + + .lg\:block { + display: block; + } + + .lg\:flex { + display: flex; + } + + .lg\:grid { + display: grid; + } + + .lg\:hidden { + display: none; + } + + .lg\:h-12 { + height: 3rem; + } + + .lg\:h-4 { + height: 1rem; + } + + .lg\:h-5 { + height: 1.25rem; + } + + .lg\:h-6 { + height: 1.5rem; + } + + .lg\:h-\[calc\(100vh-3rem\)\] { + height: calc(100vh - 3rem); + } + + .lg\:h-auto { + height: auto; + } + + .lg\:max-h-full { + max-height: 100%; + } + + .lg\:w-12 { + width: 3rem; + } + + .lg\:w-4 { + width: 1rem; + } + + .lg\:w-48 { + width: 12rem; + } + + .lg\:w-5 { + width: 1.25rem; + } + + .lg\:w-6 { + width: 1.5rem; + } + + .lg\:w-96 { + width: 24rem; + } + + .lg\:w-auto { + width: auto; + } + + .lg\:max-w-7xl { + max-width: 80rem; + } + + .lg\:max-w-screen-lg { + max-width: 1024px; + } + + .lg\:max-w-xl { + max-width: 36rem; + } + + .lg\:grid-cols-12 { + grid-template-columns: repeat(12, minmax(0, 1fr)); + } + + .lg\:grid-cols-2 { + grid-template-columns: repeat(2, minmax(0, 1fr)); + } + + .lg\:grid-cols-3 { + grid-template-columns: repeat(3, minmax(0, 1fr)); + } + + .lg\:grid-cols-4 { + grid-template-columns: repeat(4, minmax(0, 1fr)); + } + + .lg\:flex-row { + flex-direction: row; + } + + .lg\:gap-16 { + gap: 4rem; + } + + .lg\:gap-8 { + gap: 2rem; + } + + .lg\:space-x-8 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(2rem * var(--tw-space-x-reverse)); + margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse))); + } + + .lg\:self-center { + align-self: center; + } + + .lg\:overflow-visible { + overflow: visible; + } + + .lg\:overflow-y-visible { + overflow-y: visible; + } + + .lg\:border-0 { + border-width: 0px; + } + + .lg\:bg-transparent { + background-color: transparent; + } + + .lg\:p-0 { + padding: 0px; + } + + .lg\:p-8 { + padding: 2rem; + } + + .lg\:px-12 { + padding-left: 3rem; + padding-right: 3rem; + } + + .lg\:px-2 { + padding-left: 0.5rem; + padding-right: 0.5rem; + } + + .lg\:px-36 { + padding-left: 9rem; + padding-right: 9rem; + } + + .lg\:px-4 { + padding-left: 1rem; + padding-right: 1rem; + } + + .lg\:px-48 { + padding-left: 12rem; + padding-right: 12rem; + } + + .lg\:px-5 { + padding-left: 1.25rem; + padding-right: 1.25rem; + } + + .lg\:px-6 { + padding-left: 1.5rem; + padding-right: 1.5rem; + } + + .lg\:px-8 { + padding-left: 2rem; + padding-right: 2rem; + } + + .lg\:py-0 { + padding-top: 0px; + padding-bottom: 0px; + } + + .lg\:py-16 { + padding-top: 4rem; + padding-bottom: 4rem; + } + + .lg\:py-2 { + padding-top: 0.5rem; + padding-bottom: 0.5rem; + } + + .lg\:py-2\.5 { + padding-top: 0.625rem; + padding-bottom: 0.625rem; + } + + .lg\:py-4 { + padding-top: 1rem; + padding-bottom: 1rem; + } + + .lg\:py-56 { + padding-top: 14rem; + padding-bottom: 14rem; + } + + .lg\:py-8 { + padding-top: 2rem; + padding-bottom: 2rem; + } + + .lg\:pb-16 { + padding-bottom: 4rem; + } + + .lg\:pb-20 { + padding-bottom: 5rem; + } + + .lg\:pl-0 { + padding-left: 0px; + } + + .lg\:pl-3 { + padding-left: 0.75rem; + } + + .lg\:pt-0 { + padding-top: 0px; + } + + .lg\:pt-2 { + padding-top: 0.5rem; + } + + .lg\:pt-8 { + padding-top: 2rem; + } + + .lg\:text-2xl { + font-size: 1.5rem; + line-height: 2rem; + } + + .lg\:text-6xl { + font-size: 3.75rem; + line-height: 1; + } + + .lg\:text-sm { + font-size: 0.875rem; + line-height: 1.25rem; + } + + .lg\:text-xl { + font-size: 1.25rem; + line-height: 1.75rem; + } + + .lg\:text-xs { + font-size: 0.75rem; + line-height: 1rem; + } + + .lg\:text-blue-700 { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); + } + + .lg\:hover\:bg-transparent:hover { + background-color: transparent; + } + + .lg\:hover\:text-blue-700:hover { + --tw-text-opacity: 1; + color: rgb(26 86 219 / var(--tw-text-opacity)); + } + + :is(.dark .lg\:dark\:hover\:bg-transparent:hover) { + background-color: transparent; + } + + :is(.dark .lg\:dark\:hover\:text-white:hover) { + --tw-text-opacity: 1; + color: rgb(255 255 255 / var(--tw-text-opacity)); + } +} + +@media (min-width: 1280px) { + + .xl\:ml-16 { + margin-left: 4rem; + } + + .xl\:block { + display: block; + } + + .xl\:inline-flex { + display: inline-flex; + } + + .xl\:hidden { + display: none; + } + + .xl\:h-80 { + height: 20rem; + } + + .xl\:grid-cols-6 { + grid-template-columns: repeat(6, minmax(0, 1fr)); + } + + .xl\:gap-0 { + gap: 0px; + } + + .xl\:gap-16 { + gap: 4rem; + } + + .xl\:gap-24 { + gap: 6rem; + } + + .xl\:px-2 { + padding-left: 0.5rem; + padding-right: 0.5rem; + } + + .xl\:px-48 { + padding-left: 12rem; + padding-right: 12rem; + } + + .xl\:pb-24 { + padding-bottom: 6rem; + } + + .xl\:pl-4 { + padding-left: 1rem; + } + + .xl\:pt-24 { + padding-top: 6rem; + } + + .xl\:text-6xl { + font-size: 3.75rem; + line-height: 1; + } + + .xl\:text-sm { + font-size: 0.875rem; + line-height: 1.25rem; + } + + .xl\:after\:mx-10::after { + content: var(--tw-content); + margin-left: 2.5rem; + margin-right: 2.5rem; + } +} + +@media (min-width: 1536px) { + + .\32xl\:block { + display: block; + } + + .\32xl\:h-96 { + height: 24rem; + } + + .\32xl\:grid-cols-10 { + grid-template-columns: repeat(10, minmax(0, 1fr)); + } + + .\32xl\:gap-x-2 { + -moz-column-gap: 0.5rem; + column-gap: 0.5rem; + } + + .\32xl\:space-x-0 > :not([hidden]) ~ :not([hidden]) { + --tw-space-x-reverse: 0; + margin-right: calc(0px * var(--tw-space-x-reverse)); + margin-left: calc(0px * calc(1 - var(--tw-space-x-reverse))); + } +} + +.\[\&\>div\]\:mx-auto>div { + margin-left: auto; + margin-right: auto; +} diff --git a/node_modules/flowbite/dist/flowbite.js b/node_modules/flowbite/dist/flowbite.js new file mode 100644 index 0000000..e127c7a --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.js @@ -0,0 +1,4434 @@ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define("Flowbite", [], factory); + else if(typeof exports === 'object') + exports["Flowbite"] = factory(); + else + root["Flowbite"] = factory(); +})(self, function() { +return /******/ (function() { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ 647: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +__webpack_require__.r(__webpack_exports__); +// extracted by mini-css-extract-plugin + + +/***/ }), + +/***/ 853: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +// ESM COMPAT FLAG +__webpack_require__.r(__webpack_exports__); + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "afterMain": function() { return /* reexport */ afterMain; }, + "afterRead": function() { return /* reexport */ afterRead; }, + "afterWrite": function() { return /* reexport */ afterWrite; }, + "applyStyles": function() { return /* reexport */ modifiers_applyStyles; }, + "arrow": function() { return /* reexport */ modifiers_arrow; }, + "auto": function() { return /* reexport */ auto; }, + "basePlacements": function() { return /* reexport */ basePlacements; }, + "beforeMain": function() { return /* reexport */ beforeMain; }, + "beforeRead": function() { return /* reexport */ beforeRead; }, + "beforeWrite": function() { return /* reexport */ beforeWrite; }, + "bottom": function() { return /* reexport */ bottom; }, + "clippingParents": function() { return /* reexport */ clippingParents; }, + "computeStyles": function() { return /* reexport */ modifiers_computeStyles; }, + "createPopper": function() { return /* reexport */ popper_createPopper; }, + "createPopperBase": function() { return /* reexport */ createPopper; }, + "createPopperLite": function() { return /* reexport */ popper_lite_createPopper; }, + "detectOverflow": function() { return /* reexport */ detectOverflow; }, + "end": function() { return /* reexport */ end; }, + "eventListeners": function() { return /* reexport */ eventListeners; }, + "flip": function() { return /* reexport */ modifiers_flip; }, + "hide": function() { return /* reexport */ modifiers_hide; }, + "left": function() { return /* reexport */ left; }, + "main": function() { return /* reexport */ main; }, + "modifierPhases": function() { return /* reexport */ modifierPhases; }, + "offset": function() { return /* reexport */ modifiers_offset; }, + "placements": function() { return /* reexport */ enums_placements; }, + "popper": function() { return /* reexport */ popper; }, + "popperGenerator": function() { return /* reexport */ popperGenerator; }, + "popperOffsets": function() { return /* reexport */ modifiers_popperOffsets; }, + "preventOverflow": function() { return /* reexport */ modifiers_preventOverflow; }, + "read": function() { return /* reexport */ read; }, + "reference": function() { return /* reexport */ reference; }, + "right": function() { return /* reexport */ right; }, + "start": function() { return /* reexport */ start; }, + "top": function() { return /* reexport */ enums_top; }, + "variationPlacements": function() { return /* reexport */ variationPlacements; }, + "viewport": function() { return /* reexport */ viewport; }, + "write": function() { return /* reexport */ write; } +}); + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/enums.js +var enums_top = 'top'; +var bottom = 'bottom'; +var right = 'right'; +var left = 'left'; +var auto = 'auto'; +var basePlacements = [enums_top, bottom, right, left]; +var start = 'start'; +var end = 'end'; +var clippingParents = 'clippingParents'; +var viewport = 'viewport'; +var popper = 'popper'; +var reference = 'reference'; +var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) { + return acc.concat([placement + "-" + start, placement + "-" + end]); +}, []); +var enums_placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) { + return acc.concat([placement, placement + "-" + start, placement + "-" + end]); +}, []); // modifiers that need to read the DOM + +var beforeRead = 'beforeRead'; +var read = 'read'; +var afterRead = 'afterRead'; // pure-logic modifiers + +var beforeMain = 'beforeMain'; +var main = 'main'; +var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state) + +var beforeWrite = 'beforeWrite'; +var write = 'write'; +var afterWrite = 'afterWrite'; +var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite]; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js +function getNodeName(element) { + return element ? (element.nodeName || '').toLowerCase() : null; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindow.js +function getWindow(node) { + if (node == null) { + return window; + } + + if (node.toString() !== '[object Window]') { + var ownerDocument = node.ownerDocument; + return ownerDocument ? ownerDocument.defaultView || window : window; + } + + return node; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js + + +function isElement(node) { + var OwnElement = getWindow(node).Element; + return node instanceof OwnElement || node instanceof Element; +} + +function isHTMLElement(node) { + var OwnElement = getWindow(node).HTMLElement; + return node instanceof OwnElement || node instanceof HTMLElement; +} + +function isShadowRoot(node) { + // IE 11 has no ShadowRoot + if (typeof ShadowRoot === 'undefined') { + return false; + } + + var OwnElement = getWindow(node).ShadowRoot; + return node instanceof OwnElement || node instanceof ShadowRoot; +} + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/applyStyles.js + + // This modifier takes the styles prepared by the `computeStyles` modifier +// and applies them to the HTMLElements such as popper and arrow + +function applyStyles(_ref) { + var state = _ref.state; + Object.keys(state.elements).forEach(function (name) { + var style = state.styles[name] || {}; + var attributes = state.attributes[name] || {}; + var element = state.elements[name]; // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } // Flow doesn't support to extend this property, but it's the most + // effective way to apply styles to an HTMLElement + // $FlowFixMe[cannot-write] + + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (name) { + var value = attributes[name]; + + if (value === false) { + element.removeAttribute(name); + } else { + element.setAttribute(name, value === true ? '' : value); + } + }); + }); +} + +function effect(_ref2) { + var state = _ref2.state; + var initialStyles = { + popper: { + position: state.options.strategy, + left: '0', + top: '0', + margin: '0' + }, + arrow: { + position: 'absolute' + }, + reference: {} + }; + Object.assign(state.elements.popper.style, initialStyles.popper); + state.styles = initialStyles; + + if (state.elements.arrow) { + Object.assign(state.elements.arrow.style, initialStyles.arrow); + } + + return function () { + Object.keys(state.elements).forEach(function (name) { + var element = state.elements[name]; + var attributes = state.attributes[name] || {}; + var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them + + var style = styleProperties.reduce(function (style, property) { + style[property] = ''; + return style; + }, {}); // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (attribute) { + element.removeAttribute(attribute); + }); + }); + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_applyStyles = ({ + name: 'applyStyles', + enabled: true, + phase: 'write', + fn: applyStyles, + effect: effect, + requires: ['computeStyles'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getBasePlacement.js + +function getBasePlacement(placement) { + return placement.split('-')[0]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/math.js +var math_max = Math.max; +var math_min = Math.min; +var round = Math.round; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/userAgent.js +function getUAString() { + var uaData = navigator.userAgentData; + + if (uaData != null && uaData.brands) { + return uaData.brands.map(function (item) { + return item.brand + "/" + item.version; + }).join(' '); + } + + return navigator.userAgent; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js + +function isLayoutViewport() { + return !/^((?!chrome|android).)*safari/i.test(getUAString()); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js + + + + +function getBoundingClientRect(element, includeScale, isFixedStrategy) { + if (includeScale === void 0) { + includeScale = false; + } + + if (isFixedStrategy === void 0) { + isFixedStrategy = false; + } + + var clientRect = element.getBoundingClientRect(); + var scaleX = 1; + var scaleY = 1; + + if (includeScale && isHTMLElement(element)) { + scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1; + scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1; + } + + var _ref = isElement(element) ? getWindow(element) : window, + visualViewport = _ref.visualViewport; + + var addVisualOffsets = !isLayoutViewport() && isFixedStrategy; + var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX; + var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY; + var width = clientRect.width / scaleX; + var height = clientRect.height / scaleY; + return { + width: width, + height: height, + top: y, + right: x + width, + bottom: y + height, + left: x, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js + // Returns the layout rect of an element relative to its offsetParent. Layout +// means it doesn't take into account transforms. + +function getLayoutRect(element) { + var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed. + // Fixes https://github.com/popperjs/popper-core/issues/1223 + + var width = element.offsetWidth; + var height = element.offsetHeight; + + if (Math.abs(clientRect.width - width) <= 1) { + width = clientRect.width; + } + + if (Math.abs(clientRect.height - height) <= 1) { + height = clientRect.height; + } + + return { + x: element.offsetLeft, + y: element.offsetTop, + width: width, + height: height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/contains.js + +function contains(parent, child) { + var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method + + if (parent.contains(child)) { + return true; + } // then fallback to custom implementation with Shadow DOM support + else if (rootNode && isShadowRoot(rootNode)) { + var next = child; + + do { + if (next && parent.isSameNode(next)) { + return true; + } // $FlowFixMe[prop-missing]: need a better way to handle this... + + + next = next.parentNode || next.host; + } while (next); + } // Give up, the result is false + + + return false; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js + +function getComputedStyle(element) { + return getWindow(element).getComputedStyle(element); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js + +function isTableElement(element) { + return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js + +function getDocumentElement(element) { + // $FlowFixMe[incompatible-return]: assume body is always available + return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing] + element.document) || window.document).documentElement; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js + + + +function getParentNode(element) { + if (getNodeName(element) === 'html') { + return element; + } + + return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle + // $FlowFixMe[incompatible-return] + // $FlowFixMe[prop-missing] + element.assignedSlot || // step into the shadow DOM of the parent of a slotted node + element.parentNode || ( // DOM Element detected + isShadowRoot(element) ? element.host : null) || // ShadowRoot detected + // $FlowFixMe[incompatible-call]: HTMLElement is a Node + getDocumentElement(element) // fallback + + ); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js + + + + + + + + +function getTrueOffsetParent(element) { + if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837 + getComputedStyle(element).position === 'fixed') { + return null; + } + + return element.offsetParent; +} // `.offsetParent` reports `null` for fixed elements, while absolute elements +// return the containing block + + +function getContainingBlock(element) { + var isFirefox = /firefox/i.test(getUAString()); + var isIE = /Trident/i.test(getUAString()); + + if (isIE && isHTMLElement(element)) { + // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport + var elementCss = getComputedStyle(element); + + if (elementCss.position === 'fixed') { + return null; + } + } + + var currentNode = getParentNode(element); + + if (isShadowRoot(currentNode)) { + currentNode = currentNode.host; + } + + while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) { + var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that + // create a containing block. + // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block + + if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') { + return currentNode; + } else { + currentNode = currentNode.parentNode; + } + } + + return null; +} // Gets the closest ancestor positioned element. Handles some edge cases, +// such as table ancestors and cross browser bugs. + + +function getOffsetParent(element) { + var window = getWindow(element); + var offsetParent = getTrueOffsetParent(element); + + while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') { + offsetParent = getTrueOffsetParent(offsetParent); + } + + if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) { + return window; + } + + return offsetParent || getContainingBlock(element) || window; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js +function getMainAxisFromPlacement(placement) { + return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/within.js + +function within(min, value, max) { + return math_max(min, math_min(value, max)); +} +function withinMaxClamp(min, value, max) { + var v = within(min, value, max); + return v > max ? max : v; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js +function getFreshSideObject() { + return { + top: 0, + right: 0, + bottom: 0, + left: 0 + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js + +function mergePaddingObject(paddingObject) { + return Object.assign({}, getFreshSideObject(), paddingObject); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/expandToHashMap.js +function expandToHashMap(value, keys) { + return keys.reduce(function (hashMap, key) { + hashMap[key] = value; + return hashMap; + }, {}); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/arrow.js + + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var toPaddingObject = function toPaddingObject(padding, state) { + padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, { + placement: state.placement + })) : padding; + return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); +}; + +function arrow(_ref) { + var _state$modifiersData$; + + var state = _ref.state, + name = _ref.name, + options = _ref.options; + var arrowElement = state.elements.arrow; + var popperOffsets = state.modifiersData.popperOffsets; + var basePlacement = getBasePlacement(state.placement); + var axis = getMainAxisFromPlacement(basePlacement); + var isVertical = [left, right].indexOf(basePlacement) >= 0; + var len = isVertical ? 'height' : 'width'; + + if (!arrowElement || !popperOffsets) { + return; + } + + var paddingObject = toPaddingObject(options.padding, state); + var arrowRect = getLayoutRect(arrowElement); + var minProp = axis === 'y' ? enums_top : left; + var maxProp = axis === 'y' ? bottom : right; + var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len]; + var startDiff = popperOffsets[axis] - state.rects.reference[axis]; + var arrowOffsetParent = getOffsetParent(arrowElement); + var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0; + var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is + // outside of the popper bounds + + var min = paddingObject[minProp]; + var max = clientSize - arrowRect[len] - paddingObject[maxProp]; + var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference; + var offset = within(min, center, max); // Prevents breaking syntax highlighting... + + var axisProp = axis; + state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$); +} + +function arrow_effect(_ref2) { + var state = _ref2.state, + options = _ref2.options; + var _options$element = options.element, + arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element; + + if (arrowElement == null) { + return; + } // CSS selector + + + if (typeof arrowElement === 'string') { + arrowElement = state.elements.popper.querySelector(arrowElement); + + if (!arrowElement) { + return; + } + } + + if (false) {} + + if (!contains(state.elements.popper, arrowElement)) { + if (false) {} + + return; + } + + state.elements.arrow = arrowElement; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_arrow = ({ + name: 'arrow', + enabled: true, + phase: 'main', + fn: arrow, + effect: arrow_effect, + requires: ['popperOffsets'], + requiresIfExists: ['preventOverflow'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getVariation.js +function getVariation(placement) { + return placement.split('-')[1]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/computeStyles.js + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var unsetSides = { + top: 'auto', + right: 'auto', + bottom: 'auto', + left: 'auto' +}; // Round the offsets to the nearest suitable subpixel based on the DPR. +// Zooming can change the DPR, but it seems to report a value that will +// cleanly divide the values into the appropriate subpixels. + +function roundOffsetsByDPR(_ref) { + var x = _ref.x, + y = _ref.y; + var win = window; + var dpr = win.devicePixelRatio || 1; + return { + x: round(x * dpr) / dpr || 0, + y: round(y * dpr) / dpr || 0 + }; +} + +function mapToStyles(_ref2) { + var _Object$assign2; + + var popper = _ref2.popper, + popperRect = _ref2.popperRect, + placement = _ref2.placement, + variation = _ref2.variation, + offsets = _ref2.offsets, + position = _ref2.position, + gpuAcceleration = _ref2.gpuAcceleration, + adaptive = _ref2.adaptive, + roundOffsets = _ref2.roundOffsets, + isFixed = _ref2.isFixed; + var _offsets$x = offsets.x, + x = _offsets$x === void 0 ? 0 : _offsets$x, + _offsets$y = offsets.y, + y = _offsets$y === void 0 ? 0 : _offsets$y; + + var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref3.x; + y = _ref3.y; + var hasX = offsets.hasOwnProperty('x'); + var hasY = offsets.hasOwnProperty('y'); + var sideX = left; + var sideY = enums_top; + var win = window; + + if (adaptive) { + var offsetParent = getOffsetParent(popper); + var heightProp = 'clientHeight'; + var widthProp = 'clientWidth'; + + if (offsetParent === getWindow(popper)) { + offsetParent = getDocumentElement(popper); + + if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') { + heightProp = 'scrollHeight'; + widthProp = 'scrollWidth'; + } + } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it + + + offsetParent = offsetParent; + + if (placement === enums_top || (placement === left || placement === right) && variation === end) { + sideY = bottom; + var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing] + offsetParent[heightProp]; + y -= offsetY - popperRect.height; + y *= gpuAcceleration ? 1 : -1; + } + + if (placement === left || (placement === enums_top || placement === bottom) && variation === end) { + sideX = right; + var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing] + offsetParent[widthProp]; + x -= offsetX - popperRect.width; + x *= gpuAcceleration ? 1 : -1; + } + } + + var commonStyles = Object.assign({ + position: position + }, adaptive && unsetSides); + + var _ref4 = roundOffsets === true ? roundOffsetsByDPR({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref4.x; + y = _ref4.y; + + if (gpuAcceleration) { + var _Object$assign; + + return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign)); + } + + return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2)); +} + +function computeStyles(_ref5) { + var state = _ref5.state, + options = _ref5.options; + var _options$gpuAccelerat = options.gpuAcceleration, + gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, + _options$adaptive = options.adaptive, + adaptive = _options$adaptive === void 0 ? true : _options$adaptive, + _options$roundOffsets = options.roundOffsets, + roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets; + + if (false) { var transitionProperty; } + + var commonStyles = { + placement: getBasePlacement(state.placement), + variation: getVariation(state.placement), + popper: state.elements.popper, + popperRect: state.rects.popper, + gpuAcceleration: gpuAcceleration, + isFixed: state.options.strategy === 'fixed' + }; + + if (state.modifiersData.popperOffsets != null) { + state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.popperOffsets, + position: state.options.strategy, + adaptive: adaptive, + roundOffsets: roundOffsets + }))); + } + + if (state.modifiersData.arrow != null) { + state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.arrow, + position: 'absolute', + adaptive: false, + roundOffsets: roundOffsets + }))); + } + + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-placement': state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_computeStyles = ({ + name: 'computeStyles', + enabled: true, + phase: 'beforeWrite', + fn: computeStyles, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/eventListeners.js + // eslint-disable-next-line import/no-unused-modules + +var passive = { + passive: true +}; + +function eventListeners_effect(_ref) { + var state = _ref.state, + instance = _ref.instance, + options = _ref.options; + var _options$scroll = options.scroll, + scroll = _options$scroll === void 0 ? true : _options$scroll, + _options$resize = options.resize, + resize = _options$resize === void 0 ? true : _options$resize; + var window = getWindow(state.elements.popper); + var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper); + + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.addEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.addEventListener('resize', instance.update, passive); + } + + return function () { + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.removeEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.removeEventListener('resize', instance.update, passive); + } + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var eventListeners = ({ + name: 'eventListeners', + enabled: true, + phase: 'write', + fn: function fn() {}, + effect: eventListeners_effect, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js +var hash = { + left: 'right', + right: 'left', + bottom: 'top', + top: 'bottom' +}; +function getOppositePlacement(placement) { + return placement.replace(/left|right|bottom|top/g, function (matched) { + return hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js +var getOppositeVariationPlacement_hash = { + start: 'end', + end: 'start' +}; +function getOppositeVariationPlacement(placement) { + return placement.replace(/start|end/g, function (matched) { + return getOppositeVariationPlacement_hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js + +function getWindowScroll(node) { + var win = getWindow(node); + var scrollLeft = win.pageXOffset; + var scrollTop = win.pageYOffset; + return { + scrollLeft: scrollLeft, + scrollTop: scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js + + + +function getWindowScrollBarX(element) { + // If has a CSS width greater than the viewport, then this will be + // incorrect for RTL. + // Popper 1 is broken in this case and never had a bug report so let's assume + // it's not an issue. I don't think anyone ever specifies width on + // anyway. + // Browsers where the left scrollbar doesn't cause an issue report `0` for + // this (e.g. Edge 2019, IE11, Safari) + return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js + + + + +function getViewportRect(element, strategy) { + var win = getWindow(element); + var html = getDocumentElement(element); + var visualViewport = win.visualViewport; + var width = html.clientWidth; + var height = html.clientHeight; + var x = 0; + var y = 0; + + if (visualViewport) { + width = visualViewport.width; + height = visualViewport.height; + var layoutViewport = isLayoutViewport(); + + if (layoutViewport || !layoutViewport && strategy === 'fixed') { + x = visualViewport.offsetLeft; + y = visualViewport.offsetTop; + } + } + + return { + width: width, + height: height, + x: x + getWindowScrollBarX(element), + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js + + + + + // Gets the entire size of the scrollable document area, even extending outside +// of the `` and `` rect bounds if horizontally scrollable + +function getDocumentRect(element) { + var _element$ownerDocumen; + + var html = getDocumentElement(element); + var winScroll = getWindowScroll(element); + var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body; + var width = math_max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0); + var height = math_max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0); + var x = -winScroll.scrollLeft + getWindowScrollBarX(element); + var y = -winScroll.scrollTop; + + if (getComputedStyle(body || html).direction === 'rtl') { + x += math_max(html.clientWidth, body ? body.clientWidth : 0) - width; + } + + return { + width: width, + height: height, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js + +function isScrollParent(element) { + // Firefox wants us to check `-x` and `-y` variations as well + var _getComputedStyle = getComputedStyle(element), + overflow = _getComputedStyle.overflow, + overflowX = _getComputedStyle.overflowX, + overflowY = _getComputedStyle.overflowY; + + return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js + + + + +function getScrollParent(node) { + if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) { + // $FlowFixMe[incompatible-return]: assume body is always available + return node.ownerDocument.body; + } + + if (isHTMLElement(node) && isScrollParent(node)) { + return node; + } + + return getScrollParent(getParentNode(node)); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js + + + + +/* +given a DOM element, return the list of all scroll parents, up the list of ancesors +until we get to the top window object. This list is what we attach scroll listeners +to, because if any of these parent elements scroll, we'll need to re-calculate the +reference element's position. +*/ + +function listScrollParents(element, list) { + var _element$ownerDocumen; + + if (list === void 0) { + list = []; + } + + var scrollParent = getScrollParent(element); + var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body); + var win = getWindow(scrollParent); + var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent; + var updatedList = list.concat(target); + return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here + updatedList.concat(listScrollParents(getParentNode(target))); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/rectToClientRect.js +function rectToClientRect(rect) { + return Object.assign({}, rect, { + left: rect.x, + top: rect.y, + right: rect.x + rect.width, + bottom: rect.y + rect.height + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js + + + + + + + + + + + + + + + +function getInnerBoundingClientRect(element, strategy) { + var rect = getBoundingClientRect(element, false, strategy === 'fixed'); + rect.top = rect.top + element.clientTop; + rect.left = rect.left + element.clientLeft; + rect.bottom = rect.top + element.clientHeight; + rect.right = rect.left + element.clientWidth; + rect.width = element.clientWidth; + rect.height = element.clientHeight; + rect.x = rect.left; + rect.y = rect.top; + return rect; +} + +function getClientRectFromMixedType(element, clippingParent, strategy) { + return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element))); +} // A "clipping parent" is an overflowable container with the characteristic of +// clipping (or hiding) overflowing elements with a position different from +// `initial` + + +function getClippingParents(element) { + var clippingParents = listScrollParents(getParentNode(element)); + var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0; + var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element; + + if (!isElement(clipperElement)) { + return []; + } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414 + + + return clippingParents.filter(function (clippingParent) { + return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body'; + }); +} // Gets the maximum area that the element is visible in due to any number of +// clipping parents + + +function getClippingRect(element, boundary, rootBoundary, strategy) { + var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary); + var clippingParents = [].concat(mainClippingParents, [rootBoundary]); + var firstClippingParent = clippingParents[0]; + var clippingRect = clippingParents.reduce(function (accRect, clippingParent) { + var rect = getClientRectFromMixedType(element, clippingParent, strategy); + accRect.top = math_max(rect.top, accRect.top); + accRect.right = math_min(rect.right, accRect.right); + accRect.bottom = math_min(rect.bottom, accRect.bottom); + accRect.left = math_max(rect.left, accRect.left); + return accRect; + }, getClientRectFromMixedType(element, firstClippingParent, strategy)); + clippingRect.width = clippingRect.right - clippingRect.left; + clippingRect.height = clippingRect.bottom - clippingRect.top; + clippingRect.x = clippingRect.left; + clippingRect.y = clippingRect.top; + return clippingRect; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeOffsets.js + + + + +function computeOffsets(_ref) { + var reference = _ref.reference, + element = _ref.element, + placement = _ref.placement; + var basePlacement = placement ? getBasePlacement(placement) : null; + var variation = placement ? getVariation(placement) : null; + var commonX = reference.x + reference.width / 2 - element.width / 2; + var commonY = reference.y + reference.height / 2 - element.height / 2; + var offsets; + + switch (basePlacement) { + case enums_top: + offsets = { + x: commonX, + y: reference.y - element.height + }; + break; + + case bottom: + offsets = { + x: commonX, + y: reference.y + reference.height + }; + break; + + case right: + offsets = { + x: reference.x + reference.width, + y: commonY + }; + break; + + case left: + offsets = { + x: reference.x - element.width, + y: commonY + }; + break; + + default: + offsets = { + x: reference.x, + y: reference.y + }; + } + + var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null; + + if (mainAxis != null) { + var len = mainAxis === 'y' ? 'height' : 'width'; + + switch (variation) { + case start: + offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2); + break; + + case end: + offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2); + break; + + default: + } + } + + return offsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/detectOverflow.js + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function detectOverflow(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + _options$placement = _options.placement, + placement = _options$placement === void 0 ? state.placement : _options$placement, + _options$strategy = _options.strategy, + strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, + _options$boundary = _options.boundary, + boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, + _options$rootBoundary = _options.rootBoundary, + rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, + _options$elementConte = _options.elementContext, + elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, + _options$altBoundary = _options.altBoundary, + altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, + _options$padding = _options.padding, + padding = _options$padding === void 0 ? 0 : _options$padding; + var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); + var altContext = elementContext === popper ? reference : popper; + var popperRect = state.rects.popper; + var element = state.elements[altBoundary ? altContext : elementContext]; + var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy); + var referenceClientRect = getBoundingClientRect(state.elements.reference); + var popperOffsets = computeOffsets({ + reference: referenceClientRect, + element: popperRect, + strategy: 'absolute', + placement: placement + }); + var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets)); + var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect + // 0 or negative = within the clipping rect + + var overflowOffsets = { + top: clippingClientRect.top - elementClientRect.top + paddingObject.top, + bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom, + left: clippingClientRect.left - elementClientRect.left + paddingObject.left, + right: elementClientRect.right - clippingClientRect.right + paddingObject.right + }; + var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element + + if (elementContext === popper && offsetData) { + var offset = offsetData[placement]; + Object.keys(overflowOffsets).forEach(function (key) { + var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1; + var axis = [enums_top, bottom].indexOf(key) >= 0 ? 'y' : 'x'; + overflowOffsets[key] += offset[axis] * multiply; + }); + } + + return overflowOffsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js + + + + +function computeAutoPlacement(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + placement = _options.placement, + boundary = _options.boundary, + rootBoundary = _options.rootBoundary, + padding = _options.padding, + flipVariations = _options.flipVariations, + _options$allowedAutoP = _options.allowedAutoPlacements, + allowedAutoPlacements = _options$allowedAutoP === void 0 ? enums_placements : _options$allowedAutoP; + var variation = getVariation(placement); + var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) { + return getVariation(placement) === variation; + }) : basePlacements; + var allowedPlacements = placements.filter(function (placement) { + return allowedAutoPlacements.indexOf(placement) >= 0; + }); + + if (allowedPlacements.length === 0) { + allowedPlacements = placements; + + if (false) {} + } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions... + + + var overflows = allowedPlacements.reduce(function (acc, placement) { + acc[placement] = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding + })[getBasePlacement(placement)]; + return acc; + }, {}); + return Object.keys(overflows).sort(function (a, b) { + return overflows[a] - overflows[b]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/flip.js + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function getExpandedFallbackPlacements(placement) { + if (getBasePlacement(placement) === auto) { + return []; + } + + var oppositePlacement = getOppositePlacement(placement); + return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)]; +} + +function flip(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + + if (state.modifiersData[name]._skip) { + return; + } + + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, + specifiedFallbackPlacements = options.fallbackPlacements, + padding = options.padding, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + _options$flipVariatio = options.flipVariations, + flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, + allowedAutoPlacements = options.allowedAutoPlacements; + var preferredPlacement = state.options.placement; + var basePlacement = getBasePlacement(preferredPlacement); + var isBasePlacement = basePlacement === preferredPlacement; + var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement)); + var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) { + return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + flipVariations: flipVariations, + allowedAutoPlacements: allowedAutoPlacements + }) : placement); + }, []); + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var checksMap = new Map(); + var makeFallbackChecks = true; + var firstFittingPlacement = placements[0]; + + for (var i = 0; i < placements.length; i++) { + var placement = placements[i]; + + var _basePlacement = getBasePlacement(placement); + + var isStartVariation = getVariation(placement) === start; + var isVertical = [enums_top, bottom].indexOf(_basePlacement) >= 0; + var len = isVertical ? 'width' : 'height'; + var overflow = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + altBoundary: altBoundary, + padding: padding + }); + var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : enums_top; + + if (referenceRect[len] > popperRect[len]) { + mainVariationSide = getOppositePlacement(mainVariationSide); + } + + var altVariationSide = getOppositePlacement(mainVariationSide); + var checks = []; + + if (checkMainAxis) { + checks.push(overflow[_basePlacement] <= 0); + } + + if (checkAltAxis) { + checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0); + } + + if (checks.every(function (check) { + return check; + })) { + firstFittingPlacement = placement; + makeFallbackChecks = false; + break; + } + + checksMap.set(placement, checks); + } + + if (makeFallbackChecks) { + // `2` may be desired in some cases – research later + var numberOfChecks = flipVariations ? 3 : 1; + + var _loop = function _loop(_i) { + var fittingPlacement = placements.find(function (placement) { + var checks = checksMap.get(placement); + + if (checks) { + return checks.slice(0, _i).every(function (check) { + return check; + }); + } + }); + + if (fittingPlacement) { + firstFittingPlacement = fittingPlacement; + return "break"; + } + }; + + for (var _i = numberOfChecks; _i > 0; _i--) { + var _ret = _loop(_i); + + if (_ret === "break") break; + } + } + + if (state.placement !== firstFittingPlacement) { + state.modifiersData[name]._skip = true; + state.placement = firstFittingPlacement; + state.reset = true; + } +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_flip = ({ + name: 'flip', + enabled: true, + phase: 'main', + fn: flip, + requiresIfExists: ['offset'], + data: { + _skip: false + } +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/hide.js + + + +function getSideOffsets(overflow, rect, preventedOffsets) { + if (preventedOffsets === void 0) { + preventedOffsets = { + x: 0, + y: 0 + }; + } + + return { + top: overflow.top - rect.height - preventedOffsets.y, + right: overflow.right - rect.width + preventedOffsets.x, + bottom: overflow.bottom - rect.height + preventedOffsets.y, + left: overflow.left - rect.width - preventedOffsets.x + }; +} + +function isAnySideFullyClipped(overflow) { + return [enums_top, right, bottom, left].some(function (side) { + return overflow[side] >= 0; + }); +} + +function hide(_ref) { + var state = _ref.state, + name = _ref.name; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var preventedOffsets = state.modifiersData.preventOverflow; + var referenceOverflow = detectOverflow(state, { + elementContext: 'reference' + }); + var popperAltOverflow = detectOverflow(state, { + altBoundary: true + }); + var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect); + var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets); + var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets); + var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets); + state.modifiersData[name] = { + referenceClippingOffsets: referenceClippingOffsets, + popperEscapeOffsets: popperEscapeOffsets, + isReferenceHidden: isReferenceHidden, + hasPopperEscaped: hasPopperEscaped + }; + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-reference-hidden': isReferenceHidden, + 'data-popper-escaped': hasPopperEscaped + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_hide = ({ + name: 'hide', + enabled: true, + phase: 'main', + requiresIfExists: ['preventOverflow'], + fn: hide +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/offset.js + + // eslint-disable-next-line import/no-unused-modules + +function distanceAndSkiddingToXY(placement, rects, offset) { + var basePlacement = getBasePlacement(placement); + var invertDistance = [left, enums_top].indexOf(basePlacement) >= 0 ? -1 : 1; + + var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, { + placement: placement + })) : offset, + skidding = _ref[0], + distance = _ref[1]; + + skidding = skidding || 0; + distance = (distance || 0) * invertDistance; + return [left, right].indexOf(basePlacement) >= 0 ? { + x: distance, + y: skidding + } : { + x: skidding, + y: distance + }; +} + +function offset(_ref2) { + var state = _ref2.state, + options = _ref2.options, + name = _ref2.name; + var _options$offset = options.offset, + offset = _options$offset === void 0 ? [0, 0] : _options$offset; + var data = enums_placements.reduce(function (acc, placement) { + acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset); + return acc; + }, {}); + var _data$state$placement = data[state.placement], + x = _data$state$placement.x, + y = _data$state$placement.y; + + if (state.modifiersData.popperOffsets != null) { + state.modifiersData.popperOffsets.x += x; + state.modifiersData.popperOffsets.y += y; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_offset = ({ + name: 'offset', + enabled: true, + phase: 'main', + requires: ['popperOffsets'], + fn: offset +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js + + +function popperOffsets(_ref) { + var state = _ref.state, + name = _ref.name; + // Offsets are the actual position the popper needs to have to be + // properly positioned near its reference element + // This is the most basic placement, and will be adjusted by + // the modifiers in the next step + state.modifiersData[name] = computeOffsets({ + reference: state.rects.reference, + element: state.rects.popper, + strategy: 'absolute', + placement: state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_popperOffsets = ({ + name: 'popperOffsets', + enabled: true, + phase: 'read', + fn: popperOffsets, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getAltAxis.js +function getAltAxis(axis) { + return axis === 'x' ? 'y' : 'x'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js + + + + + + + + + + + + +function preventOverflow(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + padding = options.padding, + _options$tether = options.tether, + tether = _options$tether === void 0 ? true : _options$tether, + _options$tetherOffset = options.tetherOffset, + tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset; + var overflow = detectOverflow(state, { + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + altBoundary: altBoundary + }); + var basePlacement = getBasePlacement(state.placement); + var variation = getVariation(state.placement); + var isBasePlacement = !variation; + var mainAxis = getMainAxisFromPlacement(basePlacement); + var altAxis = getAltAxis(mainAxis); + var popperOffsets = state.modifiersData.popperOffsets; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, { + placement: state.placement + })) : tetherOffset; + var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? { + mainAxis: tetherOffsetValue, + altAxis: tetherOffsetValue + } : Object.assign({ + mainAxis: 0, + altAxis: 0 + }, tetherOffsetValue); + var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null; + var data = { + x: 0, + y: 0 + }; + + if (!popperOffsets) { + return; + } + + if (checkMainAxis) { + var _offsetModifierState$; + + var mainSide = mainAxis === 'y' ? enums_top : left; + var altSide = mainAxis === 'y' ? bottom : right; + var len = mainAxis === 'y' ? 'height' : 'width'; + var offset = popperOffsets[mainAxis]; + var min = offset + overflow[mainSide]; + var max = offset - overflow[altSide]; + var additive = tether ? -popperRect[len] / 2 : 0; + var minLen = variation === start ? referenceRect[len] : popperRect[len]; + var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go + // outside the reference bounds + + var arrowElement = state.elements.arrow; + var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : { + width: 0, + height: 0 + }; + var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject(); + var arrowPaddingMin = arrowPaddingObject[mainSide]; + var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want + // to include its full size in the calculation. If the reference is small + // and near the edge of a boundary, the popper can overflow even if the + // reference is not overflowing as well (e.g. virtual elements with no + // width or height) + + var arrowLen = within(0, referenceRect[len], arrowRect[len]); + var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis; + var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis; + var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow); + var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0; + var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0; + var tetherMin = offset + minOffset - offsetModifierValue - clientOffset; + var tetherMax = offset + maxOffset - offsetModifierValue; + var preventedOffset = within(tether ? math_min(min, tetherMin) : min, offset, tether ? math_max(max, tetherMax) : max); + popperOffsets[mainAxis] = preventedOffset; + data[mainAxis] = preventedOffset - offset; + } + + if (checkAltAxis) { + var _offsetModifierState$2; + + var _mainSide = mainAxis === 'x' ? enums_top : left; + + var _altSide = mainAxis === 'x' ? bottom : right; + + var _offset = popperOffsets[altAxis]; + + var _len = altAxis === 'y' ? 'height' : 'width'; + + var _min = _offset + overflow[_mainSide]; + + var _max = _offset - overflow[_altSide]; + + var isOriginSide = [enums_top, left].indexOf(basePlacement) !== -1; + + var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0; + + var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis; + + var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max; + + var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max); + + popperOffsets[altAxis] = _preventedOffset; + data[altAxis] = _preventedOffset - _offset; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_preventOverflow = ({ + name: 'preventOverflow', + enabled: true, + phase: 'main', + fn: preventOverflow, + requiresIfExists: ['offset'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/index.js + + + + + + + + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js +function getHTMLElementScroll(element) { + return { + scrollLeft: element.scrollLeft, + scrollTop: element.scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js + + + + +function getNodeScroll(node) { + if (node === getWindow(node) || !isHTMLElement(node)) { + return getWindowScroll(node); + } else { + return getHTMLElementScroll(node); + } +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js + + + + + + + + + +function isElementScaled(element) { + var rect = element.getBoundingClientRect(); + var scaleX = round(rect.width) / element.offsetWidth || 1; + var scaleY = round(rect.height) / element.offsetHeight || 1; + return scaleX !== 1 || scaleY !== 1; +} // Returns the composite rect of an element relative to its offsetParent. +// Composite means it takes into account transforms as well as layout. + + +function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) { + if (isFixed === void 0) { + isFixed = false; + } + + var isOffsetParentAnElement = isHTMLElement(offsetParent); + var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent); + var documentElement = getDocumentElement(offsetParent); + var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed); + var scroll = { + scrollLeft: 0, + scrollTop: 0 + }; + var offsets = { + x: 0, + y: 0 + }; + + if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { + if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078 + isScrollParent(documentElement)) { + scroll = getNodeScroll(offsetParent); + } + + if (isHTMLElement(offsetParent)) { + offsets = getBoundingClientRect(offsetParent, true); + offsets.x += offsetParent.clientLeft; + offsets.y += offsetParent.clientTop; + } else if (documentElement) { + offsets.x = getWindowScrollBarX(documentElement); + } + } + + return { + x: rect.left + scroll.scrollLeft - offsets.x, + y: rect.top + scroll.scrollTop - offsets.y, + width: rect.width, + height: rect.height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/orderModifiers.js + // source: https://stackoverflow.com/questions/49875255 + +function order(modifiers) { + var map = new Map(); + var visited = new Set(); + var result = []; + modifiers.forEach(function (modifier) { + map.set(modifier.name, modifier); + }); // On visiting object, check for its dependencies and visit them recursively + + function sort(modifier) { + visited.add(modifier.name); + var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []); + requires.forEach(function (dep) { + if (!visited.has(dep)) { + var depModifier = map.get(dep); + + if (depModifier) { + sort(depModifier); + } + } + }); + result.push(modifier); + } + + modifiers.forEach(function (modifier) { + if (!visited.has(modifier.name)) { + // check for visited object + sort(modifier); + } + }); + return result; +} + +function orderModifiers(modifiers) { + // order based on dependencies + var orderedModifiers = order(modifiers); // order based on phase + + return modifierPhases.reduce(function (acc, phase) { + return acc.concat(orderedModifiers.filter(function (modifier) { + return modifier.phase === phase; + })); + }, []); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/debounce.js +function debounce(fn) { + var pending; + return function () { + if (!pending) { + pending = new Promise(function (resolve) { + Promise.resolve().then(function () { + pending = undefined; + resolve(fn()); + }); + }); + } + + return pending; + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergeByName.js +function mergeByName(modifiers) { + var merged = modifiers.reduce(function (merged, current) { + var existing = merged[current.name]; + merged[current.name] = existing ? Object.assign({}, existing, current, { + options: Object.assign({}, existing.options, current.options), + data: Object.assign({}, existing.data, current.data) + }) : current; + return merged; + }, {}); // IE11 does not support Object.values + + return Object.keys(merged).map(function (key) { + return merged[key]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/createPopper.js + + + + + + + + + + + + + + +var INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.'; +var INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.'; +var DEFAULT_OPTIONS = { + placement: 'bottom', + modifiers: [], + strategy: 'absolute' +}; + +function areValidElements() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + return !args.some(function (element) { + return !(element && typeof element.getBoundingClientRect === 'function'); + }); +} + +function popperGenerator(generatorOptions) { + if (generatorOptions === void 0) { + generatorOptions = {}; + } + + var _generatorOptions = generatorOptions, + _generatorOptions$def = _generatorOptions.defaultModifiers, + defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, + _generatorOptions$def2 = _generatorOptions.defaultOptions, + defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2; + return function createPopper(reference, popper, options) { + if (options === void 0) { + options = defaultOptions; + } + + var state = { + placement: 'bottom', + orderedModifiers: [], + options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions), + modifiersData: {}, + elements: { + reference: reference, + popper: popper + }, + attributes: {}, + styles: {} + }; + var effectCleanupFns = []; + var isDestroyed = false; + var instance = { + state: state, + setOptions: function setOptions(setOptionsAction) { + var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction; + cleanupModifierEffects(); + state.options = Object.assign({}, defaultOptions, state.options, options); + state.scrollParents = { + reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [], + popper: listScrollParents(popper) + }; // Orders the modifiers based on their dependencies and `phase` + // properties + + var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers + + state.orderedModifiers = orderedModifiers.filter(function (m) { + return m.enabled; + }); // Validate the provided modifiers so that the consumer will get warned + // if one of the modifiers is invalid for any reason + + if (false) { var _getComputedStyle, marginTop, marginRight, marginBottom, marginLeft, flipModifier, modifiers; } + + runModifierEffects(); + return instance.update(); + }, + // Sync update – it will always be executed, even if not necessary. This + // is useful for low frequency updates where sync behavior simplifies the + // logic. + // For high frequency updates (e.g. `resize` and `scroll` events), always + // prefer the async Popper#update method + forceUpdate: function forceUpdate() { + if (isDestroyed) { + return; + } + + var _state$elements = state.elements, + reference = _state$elements.reference, + popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements + // anymore + + if (!areValidElements(reference, popper)) { + if (false) {} + + return; + } // Store the reference and popper rects to be read by modifiers + + + state.rects = { + reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'), + popper: getLayoutRect(popper) + }; // Modifiers have the ability to reset the current update cycle. The + // most common use case for this is the `flip` modifier changing the + // placement, which then needs to re-run all the modifiers, because the + // logic was previously ran for the previous placement and is therefore + // stale/incorrect + + state.reset = false; + state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier + // is filled with the initial data specified by the modifier. This means + // it doesn't persist and is fresh on each update. + // To ensure persistent data, use `${name}#persistent` + + state.orderedModifiers.forEach(function (modifier) { + return state.modifiersData[modifier.name] = Object.assign({}, modifier.data); + }); + var __debug_loops__ = 0; + + for (var index = 0; index < state.orderedModifiers.length; index++) { + if (false) {} + + if (state.reset === true) { + state.reset = false; + index = -1; + continue; + } + + var _state$orderedModifie = state.orderedModifiers[index], + fn = _state$orderedModifie.fn, + _state$orderedModifie2 = _state$orderedModifie.options, + _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, + name = _state$orderedModifie.name; + + if (typeof fn === 'function') { + state = fn({ + state: state, + options: _options, + name: name, + instance: instance + }) || state; + } + } + }, + // Async and optimistically optimized update – it will not be executed if + // not necessary (debounced to run at most once-per-tick) + update: debounce(function () { + return new Promise(function (resolve) { + instance.forceUpdate(); + resolve(state); + }); + }), + destroy: function destroy() { + cleanupModifierEffects(); + isDestroyed = true; + } + }; + + if (!areValidElements(reference, popper)) { + if (false) {} + + return instance; + } + + instance.setOptions(options).then(function (state) { + if (!isDestroyed && options.onFirstUpdate) { + options.onFirstUpdate(state); + } + }); // Modifiers have the ability to execute arbitrary code before the first + // update cycle runs. They will be executed in the same order as the update + // cycle. This is useful when a modifier adds some persistent data that + // other modifiers need to use, but the modifier is run after the dependent + // one. + + function runModifierEffects() { + state.orderedModifiers.forEach(function (_ref3) { + var name = _ref3.name, + _ref3$options = _ref3.options, + options = _ref3$options === void 0 ? {} : _ref3$options, + effect = _ref3.effect; + + if (typeof effect === 'function') { + var cleanupFn = effect({ + state: state, + name: name, + instance: instance, + options: options + }); + + var noopFn = function noopFn() {}; + + effectCleanupFns.push(cleanupFn || noopFn); + } + }); + } + + function cleanupModifierEffects() { + effectCleanupFns.forEach(function (fn) { + return fn(); + }); + effectCleanupFns = []; + } + + return instance; + }; +} +var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper.js + + + + + + + + + + +var defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles, modifiers_offset, modifiers_flip, modifiers_preventOverflow, modifiers_arrow, modifiers_hide]; +var popper_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper-lite.js + + + + + +var popper_lite_defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles]; +var popper_lite_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: popper_lite_defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/index.js + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + + +/***/ }), + +/***/ 902: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initAccordions = void 0; +var Default = { + alwaysOpen: false, + activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', + inactiveClasses: 'text-gray-500 dark:text-gray-400', + onOpen: function () { }, + onClose: function () { }, + onToggle: function () { }, +}; +var Accordion = /** @class */ (function () { + function Accordion(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Accordion.prototype._init = function () { + var _this = this; + if (this._items.length) { + // show accordion item based on click + this._items.map(function (item) { + if (item.active) { + _this.open(item.id); + } + item.triggerEl.addEventListener('click', function () { + _this.toggle(item.id); + }); + }); + } + }; + Accordion.prototype.getItem = function (id) { + return this._items.filter(function (item) { return item.id === id; })[0]; + }; + Accordion.prototype.open = function (id) { + var _a, _b; + var _this = this; + var item = this.getItem(id); + // don't hide other accordions if always open + if (!this._options.alwaysOpen) { + this._items.map(function (i) { + var _a, _b; + if (i !== item) { + (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + i.targetEl.classList.add('hidden'); + i.triggerEl.setAttribute('aria-expanded', 'false'); + i.active = false; + // rotate icon if set + if (i.iconEl) { + i.iconEl.classList.remove('rotate-180'); + } + } + }); + } + // show active item + (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + item.triggerEl.setAttribute('aria-expanded', 'true'); + item.targetEl.classList.remove('hidden'); + item.active = true; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.add('rotate-180'); + } + // callback function + this._options.onOpen(this, item); + }; + Accordion.prototype.toggle = function (id) { + var item = this.getItem(id); + if (item.active) { + this.close(id); + } + else { + this.open(id); + } + // callback function + this._options.onToggle(this, item); + }; + Accordion.prototype.close = function (id) { + var _a, _b; + var item = this.getItem(id); + (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); + item.targetEl.classList.add('hidden'); + item.triggerEl.setAttribute('aria-expanded', 'false'); + item.active = false; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.remove('rotate-180'); + } + // callback function + this._options.onClose(this, item); + }; + return Accordion; +}()); +function initAccordions() { + document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { + var alwaysOpen = $accordionEl.getAttribute('data-accordion'); + var activeClasses = $accordionEl.getAttribute('data-active-classes'); + var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); + var items = []; + $accordionEl + .querySelectorAll('[data-accordion-target]') + .forEach(function ($triggerEl) { + // Consider only items that directly belong to $accordionEl + // (to make nested accordions work). + if ($triggerEl.closest('[data-accordion]') === $accordionEl) { + var item = { + id: $triggerEl.getAttribute('data-accordion-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), + iconEl: $triggerEl.querySelector('[data-accordion-icon]'), + active: $triggerEl.getAttribute('aria-expanded') === 'true' + ? true + : false, + }; + items.push(item); + } + }); + new Accordion(items, { + alwaysOpen: alwaysOpen === 'open' ? true : false, + activeClasses: activeClasses + ? activeClasses + : Default.activeClasses, + inactiveClasses: inactiveClasses + ? inactiveClasses + : Default.inactiveClasses, + }); + }); +} +exports.initAccordions = initAccordions; +if (typeof window !== 'undefined') { + window.Accordion = Accordion; + window.initAccordions = initAccordions; +} +exports["default"] = Accordion; + + +/***/ }), + +/***/ 33: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCarousels = void 0; +var Default = { + defaultPosition: 0, + indicators: { + items: [], + activeClasses: 'bg-white dark:bg-gray-800', + inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', + }, + interval: 3000, + onNext: function () { }, + onPrev: function () { }, + onChange: function () { }, +}; +var Carousel = /** @class */ (function () { + function Carousel(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign(__assign({}, Default), options), { indicators: __assign(__assign({}, Default.indicators), options.indicators) }); + this._activeItem = this.getItem(this._options.defaultPosition); + this._indicators = this._options.indicators.items; + this._intervalDuration = this._options.interval; + this._intervalInstance = null; + this._init(); + } + /** + * initialize carousel and items based on active one + */ + Carousel.prototype._init = function () { + var _this = this; + this._items.map(function (item) { + item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); + }); + // if no active item is set then first position is default + if (this._getActiveItem()) { + this.slideTo(this._getActiveItem().position); + } + else { + this.slideTo(0); + } + this._indicators.map(function (indicator, position) { + indicator.el.addEventListener('click', function () { + _this.slideTo(position); + }); + }); + }; + Carousel.prototype.getItem = function (position) { + return this._items[position]; + }; + /** + * Slide to the element based on id + * @param {*} position + */ + Carousel.prototype.slideTo = function (position) { + var nextItem = this._items[position]; + var rotationItems = { + left: nextItem.position === 0 + ? this._items[this._items.length - 1] + : this._items[nextItem.position - 1], + middle: nextItem, + right: nextItem.position === this._items.length - 1 + ? this._items[0] + : this._items[nextItem.position + 1], + }; + this._rotate(rotationItems); + this._setActiveItem(nextItem); + if (this._intervalInstance) { + this.pause(); + this.cycle(); + } + this._options.onChange(this); + }; + /** + * Based on the currently active item it will go to the next position + */ + Carousel.prototype.next = function () { + var activeItem = this._getActiveItem(); + var nextItem = null; + // check if last item + if (activeItem.position === this._items.length - 1) { + nextItem = this._items[0]; + } + else { + nextItem = this._items[activeItem.position + 1]; + } + this.slideTo(nextItem.position); + // callback function + this._options.onNext(this); + }; + /** + * Based on the currently active item it will go to the previous position + */ + Carousel.prototype.prev = function () { + var activeItem = this._getActiveItem(); + var prevItem = null; + // check if first item + if (activeItem.position === 0) { + prevItem = this._items[this._items.length - 1]; + } + else { + prevItem = this._items[activeItem.position - 1]; + } + this.slideTo(prevItem.position); + // callback function + this._options.onPrev(this); + }; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + Carousel.prototype._rotate = function (rotationItems) { + // reset + this._items.map(function (item) { + item.el.classList.add('hidden'); + }); + // left item (previously active) + rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); + // currently active item + rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); + rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); + // right item (upcoming active) + rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.right.el.classList.add('translate-x-full', 'z-10'); + }; + /** + * Set an interval to cycle through the carousel items + */ + Carousel.prototype.cycle = function () { + var _this = this; + if (typeof window !== 'undefined') { + this._intervalInstance = window.setInterval(function () { + _this.next(); + }, this._intervalDuration); + } + }; + /** + * Clears the cycling interval + */ + Carousel.prototype.pause = function () { + clearInterval(this._intervalInstance); + }; + /** + * Get the currently active item + */ + Carousel.prototype._getActiveItem = function () { + return this._activeItem; + }; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + Carousel.prototype._setActiveItem = function (item) { + var _a, _b; + var _this = this; + this._activeItem = item; + var position = item.position; + // update the indicators if available + if (this._indicators.length) { + this._indicators.map(function (indicator) { + var _a, _b; + indicator.el.setAttribute('aria-current', 'false'); + (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); + (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); + }); + (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); + (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); + this._indicators[position].el.setAttribute('aria-current', 'true'); + } + }; + return Carousel; +}()); +function initCarousels() { + document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { + var interval = $carouselEl.getAttribute('data-carousel-interval'); + var slide = $carouselEl.getAttribute('data-carousel') === 'slide' + ? true + : false; + var items = []; + var defaultPosition = 0; + if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { + items.push({ + position: position, + el: $carouselItemEl, + }); + if ($carouselItemEl.getAttribute('data-carousel-item') === + 'active') { + defaultPosition = position; + } + }); + } + var indicators = []; + if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { + indicators.push({ + position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), + el: $indicatorEl, + }); + }); + } + var carousel = new Carousel(items, { + defaultPosition: defaultPosition, + indicators: { + items: indicators, + }, + interval: interval ? interval : Default.interval, + }); + if (slide) { + carousel.cycle(); + } + // check for controls + var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); + var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); + if (carouselNextEl) { + carouselNextEl.addEventListener('click', function () { + carousel.next(); + }); + } + if (carouselPrevEl) { + carouselPrevEl.addEventListener('click', function () { + carousel.prev(); + }); + } + }); +} +exports.initCarousels = initCarousels; +if (typeof window !== 'undefined') { + window.Carousel = Carousel; + window.initCarousels = initCarousels; +} +exports["default"] = Carousel; + + +/***/ }), + +/***/ 922: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCollapses = void 0; +var Default = { + onCollapse: function () { }, + onExpand: function () { }, + onToggle: function () { }, +}; +var Collapse = /** @class */ (function () { + function Collapse(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Collapse.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + if (this._triggerEl.hasAttribute('aria-expanded')) { + this._visible = + this._triggerEl.getAttribute('aria-expanded') === 'true'; + } + else { + // fix until v2 not to break previous single collapses which became dismiss + this._visible = !this._targetEl.classList.contains('hidden'); + } + this._triggerEl.addEventListener('click', function () { + _this.toggle(); + }); + } + }; + Collapse.prototype.collapse = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onCollapse(this); + }; + Collapse.prototype.expand = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onExpand(this); + }; + Collapse.prototype.toggle = function () { + if (this._visible) { + this.collapse(); + } + else { + this.expand(); + } + // callback function + this._options.onToggle(this); + }; + return Collapse; +}()); +function initCollapses() { + document + .querySelectorAll('[data-collapse-toggle]') + .forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-collapse-toggle'); + var $targetEl = document.getElementById(targetId); + // check if the target element exists + if ($targetEl) { + new Collapse($targetEl, $triggerEl); + } + else { + console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); + } + }); +} +exports.initCollapses = initCollapses; +if (typeof window !== 'undefined') { + window.Collapse = Collapse; + window.initCollapses = initCollapses; +} +exports["default"] = Collapse; + + +/***/ }), + +/***/ 556: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDials = void 0; +var Default = { + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dial = /** @class */ (function () { + function Dial(parentEl, triggerEl, targetEl, options) { + if (parentEl === void 0) { parentEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._parentEl = parentEl; + this._triggerEl = triggerEl; + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Dial.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); + triggerEventTypes.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEventTypes.hideEvents.forEach(function (ev) { + _this._parentEl.addEventListener(ev, function () { + if (!_this._parentEl.matches(':hover')) { + _this.hide(); + } + }); + }); + } + }; + Dial.prototype.hide = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Dial.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dial.prototype.toggle = function () { + if (this._visible) { + this.hide(); + } + else { + this.show(); + } + }; + Dial.prototype.isHidden = function () { + return !this._visible; + }; + Dial.prototype.isVisible = function () { + return this._visible; + }; + Dial.prototype._getTriggerEventTypes = function (triggerType) { + switch (triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + return Dial; +}()); +function initDials() { + document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { + var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); + if ($triggerEl) { + var dialId = $triggerEl.getAttribute('data-dial-toggle'); + var $dialEl = document.getElementById(dialId); + if ($dialEl) { + var triggerType = $triggerEl.getAttribute('data-dial-trigger'); + new Dial($parentEl, $triggerEl, $dialEl, { + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); + } + } + else { + console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); + } + }); +} +exports.initDials = initDials; +if (typeof window !== 'undefined') { + window.Dial = Dial; + window.initDials = initDials; +} +exports["default"] = Dial; + + +/***/ }), + +/***/ 791: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDismisses = void 0; +var Default = { + transition: 'transition-opacity', + duration: 300, + timing: 'ease-out', + onHide: function () { }, +}; +var Dismiss = /** @class */ (function () { + function Dismiss(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Dismiss.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + this._triggerEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Dismiss.prototype.hide = function () { + var _this = this; + this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); + setTimeout(function () { + _this._targetEl.classList.add('hidden'); + }, this._options.duration); + // callback function + this._options.onHide(this, this._targetEl); + }; + return Dismiss; +}()); +function initDismisses() { + document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-dismiss-target'); + var $dismissEl = document.querySelector(targetId); + if ($dismissEl) { + new Dismiss($dismissEl, $triggerEl); + } + else { + console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); + } + }); +} +exports.initDismisses = initDismisses; +if (typeof window !== 'undefined') { + window.Dismiss = Dismiss; + window.initDismisses = initDismisses; +} +exports["default"] = Dismiss; + + +/***/ }), + +/***/ 340: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDrawers = void 0; +var Default = { + placement: 'left', + bodyScrolling: false, + backdrop: true, + edge: false, + edgeOffset: 'bottom-[60px]', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Drawer = /** @class */ (function () { + function Drawer(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Drawer.prototype._init = function () { + var _this = this; + // set initial accessibility attributes + if (this._targetEl) { + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.classList.add('transition-transform'); + } + // set base placement classes + this._getPlacementClasses(this._options.placement).base.map(function (c) { + _this._targetEl.classList.add(c); + }); + // add keyboard event listener to document + document.addEventListener('keydown', function (event) { + if (event.key === 'Escape') { + // if 'Escape' key is pressed + if (_this.isVisible()) { + // if the Drawer is visible + _this.hide(); // hide the Drawer + } + } + }); + }; + Drawer.prototype.hide = function () { + var _this = this; + // based on the edge option show placement classes + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + // enable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.remove('overflow-hidden'); + } + // destroy backdrop + if (this._options.backdrop) { + this._destroyBackdropEl(); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Drawer.prototype.show = function () { + var _this = this; + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + // disable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.add('overflow-hidden'); + } + // show backdrop + if (this._options.backdrop) { + this._createBackdrop(); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Drawer.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Drawer.prototype._createBackdrop = function () { + var _a; + var _this = this; + if (!this._visible) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('drawer-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + backdropEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Drawer.prototype._destroyBackdropEl = function () { + if (this._visible) { + document.querySelector('[drawer-backdrop]').remove(); + } + }; + Drawer.prototype._getPlacementClasses = function (placement) { + switch (placement) { + case 'top': + return { + base: ['top-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['-translate-y-full'], + }; + case 'right': + return { + base: ['right-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-x-full'], + }; + case 'bottom': + return { + base: ['bottom-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['translate-y-full'], + }; + case 'left': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + case 'bottom-edge': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-y-full', this._options.edgeOffset], + }; + default: + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + } + }; + Drawer.prototype.isHidden = function () { + return !this._visible; + }; + Drawer.prototype.isVisible = function () { + return this._visible; + }; + return Drawer; +}()); +var getDrawerInstance = function (id, instances) { + if (instances.some(function (drawerInstance) { return drawerInstance.id === id; })) { + return instances.find(function (drawerInstance) { return drawerInstance.id === id; }); + } +}; +function initDrawers() { + var drawerInstances = []; + document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { + // mandatory + var drawerId = $triggerEl.getAttribute('data-drawer-target'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + // optional + var placement = $triggerEl.getAttribute('data-drawer-placement'); + var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); + var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); + var edge = $triggerEl.getAttribute('data-drawer-edge'); + var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); + if (!getDrawerInstance(drawerId, drawerInstances)) { + drawerInstances.push({ + id: drawerId, + object: new Drawer($drawerEl, { + placement: placement ? placement : Default.placement, + bodyScrolling: bodyScrolling + ? bodyScrolling === 'true' + ? true + : false + : Default.bodyScrolling, + backdrop: backdrop + ? backdrop === 'true' + ? true + : false + : Default.backdrop, + edge: edge + ? edge === 'true' + ? true + : false + : Default.edge, + edgeOffset: edgeOffset + ? edgeOffset + : Default.edgeOffset, + }), + }); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_1 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_1) { + $triggerEl.addEventListener('click', function () { + drawer_1.object.toggle(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document + .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') + .forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') + ? $triggerEl.getAttribute('data-drawer-dismiss') + : $triggerEl.getAttribute('data-drawer-hide'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_2 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_2) { + $triggerEl.addEventListener('click', function () { + drawer_2.object.hide(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); + } + }); + document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-show'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_3 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_3) { + $triggerEl.addEventListener('click', function () { + drawer_3.object.show(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); +} +exports.initDrawers = initDrawers; +if (typeof window !== 'undefined') { + window.Drawer = Drawer; + window.initDrawers = initDrawers; +} +exports["default"] = Drawer; + + +/***/ }), + +/***/ 316: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDropdowns = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'bottom', + triggerType: 'click', + offsetSkidding: 0, + offsetDistance: 10, + delay: 300, + ignoreClickOutsideClass: false, + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dropdown = /** @class */ (function () { + function Dropdown(targetElement, triggerElement, options) { + if (targetElement === void 0) { targetElement = null; } + if (triggerElement === void 0) { triggerElement = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetElement; + this._triggerEl = triggerElement; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Dropdown.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Dropdown.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + // click event handling for trigger element + if (this._options.triggerType === 'click') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.toggle(); + }); + }); + } + // hover event handling for trigger element + if (this._options.triggerType === 'hover') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + if (ev === 'click') { + _this.toggle(); + } + else { + setTimeout(function () { + _this.show(); + }, _this._options.delay); + } + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + }); + } + }; + Dropdown.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [ + this._options.offsetSkidding, + this._options.offsetDistance, + ], + }, + }, + ], + }); + }; + Dropdown.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + // Ignore clicks on the trigger element (ie. a datepicker input) + var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; + var isIgnored = false; + if (ignoreClickOutsideClass) { + var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); + ignoredClickOutsideEls.forEach(function (el) { + if (el.contains(clickedEl)) { + isIgnored = true; + return; + } + }); + } + // Ignore clicks on the target element (ie. dropdown itself) + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + !isIgnored && + this.isVisible()) { + this.hide(); + } + }; + Dropdown.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'click'], + hideEvents: ['mouseleave'], + }; + case 'click': + return { + showEvents: ['click'], + hideEvents: [], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['click'], + hideEvents: [], + }; + } + }; + Dropdown.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Dropdown.prototype.isVisible = function () { + return this._visible; + }; + Dropdown.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + this._targetEl.classList.add('block'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + this._setupClickOutsideListener(); + // Update its position + this._popperInstance.update(); + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dropdown.prototype.hide = function () { + this._targetEl.classList.remove('block'); + this._targetEl.classList.add('hidden'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + this._visible = false; + this._removeClickOutsideListener(); + // callback function + this._options.onHide(this); + }; + return Dropdown; +}()); +function initDropdowns() { + document + .querySelectorAll('[data-dropdown-toggle]') + .forEach(function ($triggerEl) { + var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); + var $dropdownEl = document.getElementById(dropdownId); + if ($dropdownEl) { + var placement = $triggerEl.getAttribute('data-dropdown-placement'); + var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); + var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); + var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); + var delay = $triggerEl.getAttribute('data-dropdown-delay'); + var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); + new Dropdown($dropdownEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + offsetSkidding: offsetSkidding + ? parseInt(offsetSkidding) + : Default.offsetSkidding, + offsetDistance: offsetDistance + ? parseInt(offsetDistance) + : Default.offsetDistance, + delay: delay ? parseInt(delay) : Default.delay, + ignoreClickOutsideClass: ignoreClickOutsideClass + ? ignoreClickOutsideClass + : Default.ignoreClickOutsideClass, + }); + } + else { + console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); + } + }); +} +exports.initDropdowns = initDropdowns; +if (typeof window !== 'undefined') { + window.Dropdown = Dropdown; + window.initDropdowns = initDropdowns; +} +exports["default"] = Dropdown; + + +/***/ }), + +/***/ 311: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initFlowbite = void 0; +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +function initFlowbite() { + (0, accordion_1.initAccordions)(); + (0, collapse_1.initCollapses)(); + (0, carousel_1.initCarousels)(); + (0, dismiss_1.initDismisses)(); + (0, dropdown_1.initDropdowns)(); + (0, modal_1.initModals)(); + (0, drawer_1.initDrawers)(); + (0, tabs_1.initTabs)(); + (0, tooltip_1.initTooltips)(); + (0, popover_1.initPopovers)(); + (0, dial_1.initDials)(); +} +exports.initFlowbite = initFlowbite; +if (typeof window !== 'undefined') { + window.initFlowbite = initFlowbite; +} + + +/***/ }), + +/***/ 16: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initModals = void 0; +var Default = { + placement: 'center', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + backdrop: 'dynamic', + closable: true, + onHide: function () { }, + onShow: function () { }, + onToggle: function () { }, +}; +var Modal = /** @class */ (function () { + function Modal(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._isHidden = true; + this._backdropEl = null; + this._init(); + } + Modal.prototype._init = function () { + var _this = this; + if (this._targetEl) { + this._getPlacementClasses().map(function (c) { + _this._targetEl.classList.add(c); + }); + } + }; + Modal.prototype._createBackdrop = function () { + var _a; + if (this._isHidden) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('modal-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + this._backdropEl = backdropEl; + } + }; + Modal.prototype._destroyBackdropEl = function () { + if (!this._isHidden) { + document.querySelector('[modal-backdrop]').remove(); + } + }; + Modal.prototype._setupModalCloseEventListeners = function () { + var _this = this; + if (this._options.backdrop === 'dynamic') { + this._clickOutsideEventListener = function (ev) { + _this._handleOutsideClick(ev.target); + }; + this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); + } + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._removeModalCloseEventListeners = function () { + if (this._options.backdrop === 'dynamic') { + this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); + } + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._handleOutsideClick = function (target) { + if (target === this._targetEl || + (target === this._backdropEl && this.isVisible())) { + this.hide(); + } + }; + Modal.prototype._getPlacementClasses = function () { + switch (this._options.placement) { + // top + case 'top-left': + return ['justify-start', 'items-start']; + case 'top-center': + return ['justify-center', 'items-start']; + case 'top-right': + return ['justify-end', 'items-start']; + // center + case 'center-left': + return ['justify-start', 'items-center']; + case 'center': + return ['justify-center', 'items-center']; + case 'center-right': + return ['justify-end', 'items-center']; + // bottom + case 'bottom-left': + return ['justify-start', 'items-end']; + case 'bottom-center': + return ['justify-center', 'items-end']; + case 'bottom-right': + return ['justify-end', 'items-end']; + default: + return ['justify-center', 'items-center']; + } + }; + Modal.prototype.toggle = function () { + if (this._isHidden) { + this.show(); + } + else { + this.hide(); + } + // callback function + this._options.onToggle(this); + }; + Modal.prototype.show = function () { + if (this.isHidden) { + this._targetEl.classList.add('flex'); + this._targetEl.classList.remove('hidden'); + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + this._createBackdrop(); + this._isHidden = false; + // prevent body scroll + document.body.classList.add('overflow-hidden'); + // Add keyboard event listener to the document + if (this._options.closable) { + this._setupModalCloseEventListeners(); + } + // callback function + this._options.onShow(this); + } + }; + Modal.prototype.hide = function () { + if (this.isVisible) { + this._targetEl.classList.add('hidden'); + this._targetEl.classList.remove('flex'); + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + this._destroyBackdropEl(); + this._isHidden = true; + // re-apply body scroll + document.body.classList.remove('overflow-hidden'); + if (this._options.closable) { + this._removeModalCloseEventListeners(); + } + // callback function + this._options.onHide(this); + } + }; + Modal.prototype.isVisible = function () { + return !this._isHidden; + }; + Modal.prototype.isHidden = function () { + return this._isHidden; + }; + return Modal; +}()); +var getModalInstance = function (id, instances) { + if (instances.some(function (modalInstance) { return modalInstance.id === id; })) { + return instances.find(function (modalInstance) { return modalInstance.id === id; }); + } + return null; +}; +function initModals() { + var modalInstances = []; + // initiate modal based on data-modal-target + document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-target'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + if (!getModalInstance(modalId, modalInstances)) { + modalInstances.push({ + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); + } + }); + // support pre v1.6.0 data-modal-toggle initialization + document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-toggle'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + var modal_1 = getModalInstance(modalId, modalInstances); + if (!modal_1) { + modal_1 = { + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }; + modalInstances.push(modal_1); + } + $triggerEl.addEventListener('click', function () { + modal_1.object.toggle(); + }); + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); + } + }); + // show modal on click if exists based on id + document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-show'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_2 = getModalInstance(modalId, modalInstances); + if (modal_2) { + $triggerEl.addEventListener('click', function () { + if (modal_2.object.isHidden) { + modal_2.object.show(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); + } + }); + // hide modal on click if exists based on id + document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-hide'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_3 = getModalInstance(modalId, modalInstances); + if (modal_3) { + $triggerEl.addEventListener('click', function () { + if (modal_3.object.isVisible) { + modal_3.object.hide(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); + } + }); +} +exports.initModals = initModals; +if (typeof window !== 'undefined') { + window.Modal = Modal; + window.initModals = initModals; +} +exports["default"] = Modal; + + +/***/ }), + +/***/ 903: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initPopovers = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + offset: 10, + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Popover = /** @class */ (function () { + function Popover(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Popover.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Popover.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + }); + }; + Popover.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, this._options.offset], + }, + }, + ], + }); + }; + Popover.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Popover.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Popover.prototype.isVisible = function () { + return this._visible; + }; + Popover.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Popover.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility to true + this._visible = true; + // callback function + this._options.onShow(this); + }; + Popover.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility to false + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Popover; +}()); +function initPopovers() { + document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { + var popoverID = $triggerEl.getAttribute('data-popover-target'); + var $popoverEl = document.getElementById(popoverID); + if ($popoverEl) { + var triggerType = $triggerEl.getAttribute('data-popover-trigger'); + var placement = $triggerEl.getAttribute('data-popover-placement'); + var offset = $triggerEl.getAttribute('data-popover-offset'); + new Popover($popoverEl, $triggerEl, { + placement: placement ? placement : Default.placement, + offset: offset ? parseInt(offset) : Default.offset, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); + } + }); +} +exports.initPopovers = initPopovers; +if (typeof window !== 'undefined') { + window.Popover = Popover; + window.initPopovers = initPopovers; +} +exports["default"] = Popover; + + +/***/ }), + +/***/ 247: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTabs = void 0; +var Default = { + defaultTabId: null, + activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', + inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', + onShow: function () { }, +}; +var Tabs = /** @class */ (function () { + function Tabs(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._activeTab = options ? this.getTab(options.defaultTabId) : null; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Tabs.prototype._init = function () { + var _this = this; + if (this._items.length) { + // set the first tab as active if not set by explicitly + if (!this._activeTab) { + this._setActiveTab(this._items[0]); + } + // force show the first default tab + this.show(this._activeTab.id, true); + // show tab content based on click + this._items.map(function (tab) { + tab.triggerEl.addEventListener('click', function () { + _this.show(tab.id); + }); + }); + } + }; + Tabs.prototype.getActiveTab = function () { + return this._activeTab; + }; + Tabs.prototype._setActiveTab = function (tab) { + this._activeTab = tab; + }; + Tabs.prototype.getTab = function (id) { + return this._items.filter(function (t) { return t.id === id; })[0]; + }; + Tabs.prototype.show = function (id, forceShow) { + var _a, _b; + var _this = this; + if (forceShow === void 0) { forceShow = false; } + var tab = this.getTab(id); + // don't do anything if already active + if (tab === this._activeTab && !forceShow) { + return; + } + // hide other tabs + this._items.map(function (t) { + var _a, _b; + if (t !== tab) { + (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + t.targetEl.classList.add('hidden'); + t.triggerEl.setAttribute('aria-selected', 'false'); + } + }); + // show active tab + (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + tab.triggerEl.setAttribute('aria-selected', 'true'); + tab.targetEl.classList.remove('hidden'); + this._setActiveTab(tab); + // callback function + this._options.onShow(this, tab); + }; + return Tabs; +}()); +function initTabs() { + document.querySelectorAll('[data-tabs-toggle]').forEach(function ($triggerEl) { + var tabItems = []; + var defaultTabId = null; + $triggerEl + .querySelectorAll('[role="tab"]') + .forEach(function ($triggerEl) { + var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; + var tab = { + id: $triggerEl.getAttribute('data-tabs-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), + }; + tabItems.push(tab); + if (isActive) { + defaultTabId = tab.id; + } + }); + new Tabs(tabItems, { + defaultTabId: defaultTabId, + }); + }); +} +exports.initTabs = initTabs; +if (typeof window !== 'undefined') { + window.Tabs = Tabs; + window.initTabs = initTabs; +} +exports["default"] = Tabs; + + +/***/ }), + +/***/ 671: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTooltips = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Tooltip = /** @class */ (function () { + function Tooltip(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Tooltip.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Tooltip.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.hide(); + }); + }); + }; + Tooltip.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, 8], + }, + }, + ], + }); + }; + Tooltip.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Tooltip.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Tooltip.prototype.isVisible = function () { + return this._visible; + }; + Tooltip.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Tooltip.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility + this._visible = true; + // callback function + this._options.onShow(this); + }; + Tooltip.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Tooltip; +}()); +function initTooltips() { + document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { + var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); + var $tooltipEl = document.getElementById(tooltipId); + if ($tooltipEl) { + var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); + var placement = $triggerEl.getAttribute('data-tooltip-placement'); + new Tooltip($tooltipEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); + } + }); +} +exports.initTooltips = initTooltips; +if (typeof window !== 'undefined') { + window.Tooltip = Tooltip; + window.initTooltips = initTooltips; +} +exports["default"] = Tooltip; + + +/***/ }), + +/***/ 947: +/***/ (function(__unused_webpack_module, exports) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +var Events = /** @class */ (function () { + function Events(eventType, eventFunctions) { + if (eventFunctions === void 0) { eventFunctions = []; } + this._eventType = eventType; + this._eventFunctions = eventFunctions; + } + Events.prototype.init = function () { + var _this = this; + this._eventFunctions.forEach(function (eventFunction) { + if (typeof window !== 'undefined') { + window.addEventListener(_this._eventType, eventFunction); + } + }); + }; + return Events; +}()); +exports["default"] = Events; + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ !function() { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = function(exports, definition) { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ }(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ !function() { +/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } +/******/ }(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ !function() { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ }(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. +!function() { +var exports = __webpack_exports__; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +__webpack_require__(647); +// core components +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +__webpack_require__(311); +var events_1 = __webpack_require__(947); +var events = new events_1.default('load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +events.init(); +exports["default"] = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; + +}(); +/******/ return __webpack_exports__; +/******/ })() +; +}); +//# sourceMappingURL=flowbite.js.map \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.js.map b/node_modules/flowbite/dist/flowbite.js.map new file mode 100644 index 0000000..478cc98 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.js.map @@ -0,0 +1 @@ +{"version":3,"file":"flowbite.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;ACVA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACAO,IAAI,SAAG;AACP;AACA;AACA;AACA;AACA,sBAAsB,SAAG;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACP;AACA,CAAC;AACM,IAAI,gBAAU;AACrB;AACA,CAAC,OAAO;;AAED;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA;AACA;;AC9BQ;AACf;AACA;;ACFe;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;ACXuC;;AAEvC;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,SAAS;AAC5B;AACA;;;;ACpBsD;AACK,CAAC;AAC5D;;AAEA;AACA;AACA;AACA;AACA;AACA,wCAAwC;;AAExC,SAAS,aAAa,cAAc,WAAW;AAC/C;AACA,MAAM;AACN;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uHAAuH;;AAEvH;AACA;AACA;AACA,OAAO,IAAI,GAAG;;AAEd,WAAW,aAAa,cAAc,WAAW;AACjD;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA,EAAE;;;AAGF,0DAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;ACnFkC;AACpB;AACf;AACA;;ACHO,IAAI,QAAG;AACP,IAAI,QAAG;AACP;;ACFQ;AACf;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;ACVgD;AACjC;AACf,gDAAgD,WAAW;AAC3D;;ACH2D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;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc,IAAI;AAClB,cAAc,SAAG;AACjB;;AAEA;AACA,uBAAuB,eAAe;AACtC;AACA;;AAEA,yBAAyB,SAAS;AAClC,qBAAqB,kBAAkB;;AAEvC,UAAU,gBAAgB;AAC1B;AACA;AACA;AACA,MAAM;;;AAGN;;AAEA,sBAAsB,SAAG,mBAAmB,IAAI,kBAAkB,KAAK,mBAAmB,GAAG;AAC7F,cAAc,MAAM;AACpB;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,IAAI,mBAAmB,SAAG,kBAAkB,MAAM,mBAAmB,GAAG;AAC9F,cAAc,KAAK;AACnB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,2BAA2B,oCAAoC;AAC/D;;AAEA,yBAAyB,qCAAqC;AAC9D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAM,KAAqC,EAAE,2BAQ1C;;AAEH;AACA,eAAe,gBAAgB;AAC/B,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C,mDAAmD;AAC7F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,yCAAyC,kDAAkD;AAC3F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,4CAA4C;AAC5C;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACpLiD,CAAC;;AAEnD;AACA;AACA;;AAEA,SAAS,qBAAM;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA,sBAAsB;AACtB,UAAU,qBAAM;AAChB;AACA,CAAC;;AChDD;AACA;AACA;AACA;AACA;AACA;AACe;AACf;AACA;AACA,GAAG;AACH;;ACVA,IAAI,kCAAI;AACR;AACA;AACA;AACe;AACf;AACA,WAAW,kCAAI;AACf,GAAG;AACH;;ACRuC;AACxB;AACf,YAAY,SAAS;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;ACT+D;AACN;AACN;AACpC;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,qBAAqB,CAAC,kBAAkB,kBAAkB,eAAe;AAClF;;ACZuC;AACkB;AACE;AACN;AACtC;AACf,YAAY,SAAS;AACrB,aAAa,kBAAkB;AAC/B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB,gBAAgB;;AAEzC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,mBAAmB;AAC9B;AACA;AACA;;AC9ByD;AACJ;AACM;AACR;AACZ,CAAC;AACxC;;AAEe;AACf;;AAEA,aAAa,kBAAkB;AAC/B,kBAAkB,eAAe;AACjC;AACA,cAAc,QAAG;AACjB,eAAe,QAAG;AAClB,kCAAkC,mBAAmB;AACrD;;AAEA,MAAM,gBAAgB;AACtB,SAAS,QAAG;AACZ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BqD;AACtC;AACf;AACA,0BAA0B,gBAAgB;AAC1C;AACA;AACA;;AAEA;AACA;;ACT+C;AACE;AACN;AACK;AACjC;AACf,4CAA4C,WAAW;AACvD;AACA;AACA;;AAEA,MAAM,aAAa,UAAU,cAAc;AAC3C;AACA;;AAEA,yBAAyB,aAAa;AACtC;;ACfmD;AACJ;AACR;AACU;AACjD;AACA;AACA;AACA;AACA;AACA;;AAEe;AACf;;AAEA;AACA;AACA;;AAEA,qBAAqB,eAAe;AACpC;AACA,YAAY,SAAS;AACrB,+DAA+D,cAAc;AAC7E;AACA;AACA,uCAAuC,aAAa;AACpD;;ACzBe;AACf,yBAAyB;AACzB;AACA;AACA;AACA;AACA,GAAG;AACH;;ACPuC;AACY;AACA;AACI;AACJ;AACM;AACJ;AACM;AACI;AAChB;AACV;AACM;AACiB;AAChB;;AAE5C;AACA,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4BAA4B,QAAQ,GAAG,gBAAgB,CAAC,eAAe,uBAAuB,SAAS,0EAA0E,gBAAgB,CAAC,eAAe,CAAC,kBAAkB;AACpO,EAAE;AACF;AACA;;;AAGA;AACA,wBAAwB,iBAAiB,CAAC,aAAa;AACvD,wDAAwD,gBAAgB;AACxE,4CAA4C,aAAa,YAAY,eAAe;;AAEpF,OAAO,SAAS;AAChB;AACA,IAAI;;;AAGJ;AACA,WAAW,SAAS,oBAAoB,QAAQ,oCAAoC,WAAW;AAC/F,GAAG;AACH,EAAE;AACF;;;AAGe;AACf;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAG;AACrB,oBAAoB,QAAG;AACvB,qBAAqB,QAAG;AACxB,mBAAmB,QAAG;AACtB;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;ACrEqD;AACR;AACwB;AACF;AACpD;AACf;AACA;AACA;AACA,kCAAkC,gBAAgB;AAClD,8BAA8B,YAAY;AAC1C;AACA;AACA;;AAEA;AACA,SAAS,SAAG;AACZ;AACA;AACA;AACA;AACA;;AAEA,SAAS,MAAM;AACf;AACA;AACA;AACA;AACA;;AAEA,SAAS,KAAK;AACd;AACA;AACA;AACA;AACA;;AAEA,SAAS,IAAI;AACb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,iCAAiC,wBAAwB;;AAEzD;AACA;;AAEA;AACA,WAAW,KAAK;AAChB;AACA;;AAEA,WAAW,GAAG;AACd;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;ACrE8D;AACM;AACM;AACzB;AACI;AAC0D;AACxD;AACE;AACN,CAAC;;AAErC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,eAAe;AAC/D;AACA,wDAAwD,QAAQ;AAChE;AACA,0DAA0D,MAAM;AAChE;AACA;AACA;AACA;AACA,sBAAsB,kBAAkB,yCAAyC,eAAe,UAAU,cAAc;AACxH,sCAAsC,MAAM,GAAG,SAAS,GAAG,MAAM;AACjE;AACA;AACA,2BAA2B,eAAe,CAAC,SAAS,gDAAgD,kBAAkB;AACtH,4BAA4B,qBAAqB;AACjD,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA,GAAG;AACH,yBAAyB,gBAAgB,iBAAiB;AAC1D,6CAA6C,MAAM,2CAA2C;AAC9F;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;;AAE/C,yBAAyB,MAAM;AAC/B;AACA;AACA,sBAAsB,KAAK,EAAE,MAAM;AACnC,kBAAkB,SAAG,EAAE,MAAM;AAC7B;AACA,KAAK;AACL;;AAEA;AACA;;AChE6C;AACkD;AAC9C;AACI;AACtC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAiE,gBAAa;AAC9E,kBAAkB,YAAY;AAC9B,gDAAgD,mBAAmB,GAAG,0BAA0B;AAChG,WAAW,YAAY;AACvB,GAAG,IAAI,cAAc;AACrB;AACA;AACA,GAAG;;AAEH;AACA;;AAEA,QAAQ,KAAqC,EAAE,EAE1C;AACL,IAAI;;;AAGJ;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA,KAAK,EAAE,gBAAgB;AACvB;AACA,GAAG,IAAI;AACP;AACA;AACA,GAAG;AACH;;AC9CoE;AACR;AAC0B;AAC9B;AACY;AACA;AAChB,CAAC;;AAErD;AACA,MAAM,gBAAgB,gBAAgB,IAAI;AAC1C;AACA;;AAEA,0BAA0B,oBAAoB;AAC9C,UAAU,6BAA6B,gCAAgC,6BAA6B;AACpG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,gBAAgB;AACtC;AACA,iGAAiG,oBAAoB;AACrH;AACA,sBAAsB,gBAAgB,gBAAgB,IAAI,GAAG,oBAAoB;AACjF;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,uBAAuB;AACzC;;AAEA,yBAAyB,gBAAgB;;AAEzC,2BAA2B,YAAY,gBAAgB,KAAK;AAC5D,sBAAsB,SAAG,EAAE,MAAM;AACjC;AACA,mBAAmB,cAAc;AACjC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,4DAA4D,KAAK,GAAG,IAAI,sBAAsB,MAAM,GAAG,SAAG;;AAE1G;AACA,0BAA0B,oBAAoB;AAC9C;;AAEA,2BAA2B,oBAAoB;AAC/C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,QAAQ;AAC1C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AClJsD;AACC;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,SAAG,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI;AAClC;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC5D2D;AACD,CAAC;;AAErD;AACP,sBAAsB,gBAAgB;AACtC,wBAAwB,IAAI,EAAE,SAAG;;AAEjC,mEAAmE;AACnE;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,UAAU,IAAI,EAAE,KAAK;AACrB;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,uBAAiB;AAC9B;AACA;AACA,GAAG,IAAI;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,qDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACrDuD;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,cAAc;AAC5C;AACA;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACxBc;AACf;AACA;;ACF8D;AACF;AACgB;AAC5B;AACY;AACF;AACI;AACN;AACJ;AACY;AACE;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA,GAAG;AACH,sBAAsB,gBAAgB;AACtC,kBAAkB,YAAY;AAC9B;AACA,iBAAiB,wBAAwB;AACzC,gBAAgB,UAAU;AAC1B;AACA;AACA;AACA,4FAA4F;AAC5F;AACA,GAAG;AACH;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,sCAAsC,SAAG,GAAG,IAAI;AAChD,qCAAqC,MAAM,GAAG,KAAK;AACnD;AACA;AACA;AACA;AACA;AACA,+BAA+B,KAAK;AACpC,+BAA+B,KAAK,2CAA2C;AAC/E;;AAEA;AACA,6CAA6C,aAAa;AAC1D;AACA;AACA;AACA,yHAAyH,kBAAkB;AAC3I;AACA,uDAAuD;AACvD;AACA;AACA;AACA;;AAEA,mBAAmB,MAAM;AACzB;AACA;AACA,oDAAoD,eAAe;AACnE;AACA;AACA;AACA;AACA,0BAA0B,MAAM,UAAU,QAAO,yCAAyC,QAAO;AACjG;AACA;AACA;;AAEA;AACA;;AAEA,uCAAuC,SAAG,GAAG,IAAI;;AAEjD,sCAAsC,MAAM,GAAG,KAAK;;AAEpD;;AAEA;;AAEA;;AAEA;;AAEA,wBAAwB,SAAG,EAAE,IAAI;;AAEjC;;AAEA;;AAEA;;AAEA,oDAAoD,cAAc,oCAAoC,MAAM;;AAE5G;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,8DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC7IyD;AACZ;AACgB;AACE;AACpB;AACA;AACI;AACc;;;ACP/C;AACf;AACA;AACA;AACA;AACA;;ACLmD;AACZ;AACS;AACa;AAC9C;AACf,eAAe,SAAS,WAAW,aAAa;AAChD,WAAW,eAAe;AAC1B,IAAI;AACJ,WAAW,oBAAoB;AAC/B;AACA;;ACV+D;AAChB;AACJ;AACK;AACW;AACF;AACR;AACR;;AAEzC;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB;AACA,EAAE;AACF;;;AAGe;AACf;AACA;AACA;;AAEA,gCAAgC,aAAa;AAC7C,6BAA6B,aAAa;AAC1C,wBAAwB,kBAAkB;AAC1C,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,QAAQ,WAAW;AACnB,IAAI,cAAc;AAClB,eAAe,aAAa;AAC5B;;AAEA,QAAQ,aAAa;AACrB,gBAAgB,qBAAqB;AACrC;AACA;AACA,MAAM;AACN,kBAAkB,mBAAmB;AACrC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzD6C,CAAC;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,GAAG;;AAEN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEe;AACf;AACA,2CAA2C;;AAE3C,SAAS,qBAAqB;AAC9B;AACA;AACA,KAAK;AACL,GAAG;AACH;;AC3Ce;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;;AAEA;AACA;AACA;;ACde;AACf;AACA;AACA,sDAAsD;AACtD,+BAA+B;AAC/B,4BAA4B;AAC5B,KAAK;AACL;AACA,GAAG,IAAI,GAAG;;AAEV;AACA;AACA,GAAG;AACH;;ACb+D;AACN;AACQ;AACJ;AACE;AACR;AACZ;AACkB;AAClB;AACgB;AACV;AACM;AACD;AACpB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,sEAAsE,aAAa;AACnF;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,+BAA+B;AAC/B,uBAAuB;AACvB;AACA;AACA;AACA,OAAO;AACP,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC;AACA,qBAAqB,SAAS,cAAc,iBAAiB,yCAAyC,iBAAiB;AACvH,kBAAkB,iBAAiB;AACnC,WAAW;AACX;;AAEA,+BAA+B,cAAc,CAAC,WAAW,yDAAyD;;AAElH;AACA;AACA,SAAS,GAAG;AACZ;;AAEA,YAAY,KAAqC,EAAE,qGA+B1C;;AAET;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,6CAA6C;AAC7C;;AAEA;AACA,cAAc,KAAqC,EAAE,EAE1C;;AAEX;AACA,UAAU;;;AAGV;AACA,qBAAqB,gBAAgB,YAAY,eAAe;AAChE,kBAAkB,aAAa;AAC/B,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA,mDAAmD;AACnD;AACA;AACA,6CAA6C,KAAK;;AAElD;AACA,sEAAsE;AACtE,SAAS;AACT;;AAEA,4BAA4B,uCAAuC;AACnE,cAAc,KAAqC,EAAE,EAO1C;;AAEX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE;AAChE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,OAAO;AACP;AACA;AACA,cAAc,QAAQ;AACtB;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,KAAqC,EAAE,EAE1C;;AAEP;AACA;;AAEA;AACA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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///./src/flowbite.css?5b3c","webpack:///./node_modules/@popperjs/core/lib/enums.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindow.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/applyStyles.js","webpack:///./node_modules/@popperjs/core/lib/utils/getBasePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/math.js","webpack:///./node_modules/@popperjs/core/lib/utils/userAgent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/contains.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","webpack:///./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/within.js","webpack:///./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/expandToHashMap.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/arrow.js","webpack:///./node_modules/@popperjs/core/lib/utils/getVariation.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/computeStyles.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/eventListeners.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","webpack:///./node_modules/@popperjs/core/lib/utils/rectToClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/detectOverflow.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/flip.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/hide.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/offset.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/getAltAxis.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/index.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/orderModifiers.js","webpack:///./node_modules/@popperjs/core/lib/utils/debounce.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergeByName.js","webpack:///./node_modules/@popperjs/core/lib/createPopper.js","webpack:///./node_modules/@popperjs/core/lib/popper.js","webpack:///./node_modules/@popperjs/core/lib/popper-lite.js","webpack:///./node_modules/@popperjs/core/lib/index.js","webpack:///./src/components/accordion/index.ts","webpack:///./src/components/carousel/index.ts","webpack:///./src/components/collapse/index.ts","webpack:///./src/components/dial/index.ts","webpack:///./src/components/dismiss/index.ts","webpack:///./src/components/drawer/index.ts","webpack:///./src/components/dropdown/index.ts","webpack:///./src/components/index.ts","webpack:///./src/components/modal/index.ts","webpack:///./src/components/popover/index.ts","webpack:///./src/components/tabs/index.ts","webpack:///./src/components/tooltip/index.ts","webpack:///./src/dom/events.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///./src/index.umd.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"Flowbite\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Flowbite\"] = factory();\n\telse\n\t\troot[\"Flowbite\"] = factory();\n})(self, function() {\nreturn ","// extracted by mini-css-extract-plugin\nexport {};","export var top = 'top';\nexport var bottom = 'bottom';\nexport var right = 'right';\nexport var left = 'left';\nexport var auto = 'auto';\nexport var basePlacements = [top, bottom, right, left];\nexport var start = 'start';\nexport var end = 'end';\nexport var clippingParents = 'clippingParents';\nexport var viewport = 'viewport';\nexport var popper = 'popper';\nexport var reference = 'reference';\nexport var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) {\n return acc.concat([placement + \"-\" + start, placement + \"-\" + end]);\n}, []);\nexport var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) {\n return acc.concat([placement, placement + \"-\" + start, placement + \"-\" + end]);\n}, []); // modifiers that need to read the DOM\n\nexport var beforeRead = 'beforeRead';\nexport var read = 'read';\nexport var afterRead = 'afterRead'; // pure-logic modifiers\n\nexport var beforeMain = 'beforeMain';\nexport var main = 'main';\nexport var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state)\n\nexport var beforeWrite = 'beforeWrite';\nexport var write = 'write';\nexport var afterWrite = 'afterWrite';\nexport var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];","export default function getNodeName(element) {\n return element ? (element.nodeName || '').toLowerCase() : null;\n}","export default function getWindow(node) {\n if (node == null) {\n return window;\n }\n\n if (node.toString() !== '[object Window]') {\n var ownerDocument = node.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView || window : window;\n }\n\n return node;\n}","import getWindow from \"./getWindow.js\";\n\nfunction isElement(node) {\n var OwnElement = getWindow(node).Element;\n return node instanceof OwnElement || node instanceof Element;\n}\n\nfunction isHTMLElement(node) {\n var OwnElement = getWindow(node).HTMLElement;\n return node instanceof OwnElement || node instanceof HTMLElement;\n}\n\nfunction isShadowRoot(node) {\n // IE 11 has no ShadowRoot\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n\n var OwnElement = getWindow(node).ShadowRoot;\n return node instanceof OwnElement || node instanceof ShadowRoot;\n}\n\nexport { isElement, isHTMLElement, isShadowRoot };","import getNodeName from \"../dom-utils/getNodeName.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // This modifier takes the styles prepared by the `computeStyles` modifier\n// and applies them to the HTMLElements such as popper and arrow\n\nfunction applyStyles(_ref) {\n var state = _ref.state;\n Object.keys(state.elements).forEach(function (name) {\n var style = state.styles[name] || {};\n var attributes = state.attributes[name] || {};\n var element = state.elements[name]; // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n } // Flow doesn't support to extend this property, but it's the most\n // effective way to apply styles to an HTMLElement\n // $FlowFixMe[cannot-write]\n\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (name) {\n var value = attributes[name];\n\n if (value === false) {\n element.removeAttribute(name);\n } else {\n element.setAttribute(name, value === true ? '' : value);\n }\n });\n });\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state;\n var initialStyles = {\n popper: {\n position: state.options.strategy,\n left: '0',\n top: '0',\n margin: '0'\n },\n arrow: {\n position: 'absolute'\n },\n reference: {}\n };\n Object.assign(state.elements.popper.style, initialStyles.popper);\n state.styles = initialStyles;\n\n if (state.elements.arrow) {\n Object.assign(state.elements.arrow.style, initialStyles.arrow);\n }\n\n return function () {\n Object.keys(state.elements).forEach(function (name) {\n var element = state.elements[name];\n var attributes = state.attributes[name] || {};\n var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them\n\n var style = styleProperties.reduce(function (style, property) {\n style[property] = '';\n return style;\n }, {}); // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n }\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (attribute) {\n element.removeAttribute(attribute);\n });\n });\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'applyStyles',\n enabled: true,\n phase: 'write',\n fn: applyStyles,\n effect: effect,\n requires: ['computeStyles']\n};","import { auto } from \"../enums.js\";\nexport default function getBasePlacement(placement) {\n return placement.split('-')[0];\n}","export var max = Math.max;\nexport var min = Math.min;\nexport var round = Math.round;","export default function getUAString() {\n var uaData = navigator.userAgentData;\n\n if (uaData != null && uaData.brands) {\n return uaData.brands.map(function (item) {\n return item.brand + \"/\" + item.version;\n }).join(' ');\n }\n\n return navigator.userAgent;\n}","import getUAString from \"../utils/userAgent.js\";\nexport default function isLayoutViewport() {\n return !/^((?!chrome|android).)*safari/i.test(getUAString());\n}","import { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport { round } from \"../utils/math.js\";\nimport getWindow from \"./getWindow.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getBoundingClientRect(element, includeScale, isFixedStrategy) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n\n var clientRect = element.getBoundingClientRect();\n var scaleX = 1;\n var scaleY = 1;\n\n if (includeScale && isHTMLElement(element)) {\n scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export { default as applyStyles } from \"./applyStyles.js\";\nexport { default as arrow } from \"./arrow.js\";\nexport { default as computeStyles } from \"./computeStyles.js\";\nexport { default as eventListeners } from \"./eventListeners.js\";\nexport { default as flip } from \"./flip.js\";\nexport { default as hide } from \"./hide.js\";\nexport { default as offset } from \"./offset.js\";\nexport { default as popperOffsets } from \"./popperOffsets.js\";\nexport { default as preventOverflow } from \"./preventOverflow.js\";","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","export * from \"./enums.js\";\nexport * from \"./modifiers/index.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { popperGenerator, detectOverflow, createPopper as createPopperBase } from \"./createPopper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper } from \"./popper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\";","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import './flowbite.css';\n\n// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst events = new Events('load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nevents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.min.css b/node_modules/flowbite/dist/flowbite.min.css new file mode 100644 index 0000000..591f2b0 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.min.css @@ -0,0 +1 @@ +/*! tailwindcss v3.3.0 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}html{-webkit-text-size-adjust:100%;font-feature-settings:normal;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]{display:none}.tooltip-arrow,.tooltip-arrow:before{background:inherit;height:8px;position:absolute;width:8px}.tooltip-arrow{visibility:hidden}.tooltip-arrow:before{content:"";transform:rotate(45deg);visibility:visible}[data-tooltip-style^=light]+.tooltip>.tooltip-arrow:before{border-color:#e5e7eb;border-style:solid}[data-tooltip-style^=light]+.tooltip[data-popper-placement^=top]>.tooltip-arrow:before{border-bottom-width:1px;border-right-width:1px}[data-tooltip-style^=light]+.tooltip[data-popper-placement^=right]>.tooltip-arrow:before{border-bottom-width:1px;border-left-width:1px}[data-tooltip-style^=light]+.tooltip[data-popper-placement^=bottom]>.tooltip-arrow:before{border-left-width:1px;border-top-width:1px}[data-tooltip-style^=light]+.tooltip[data-popper-placement^=left]>.tooltip-arrow:before{border-right-width:1px;border-top-width:1px}.tooltip[data-popper-placement^=top]>.tooltip-arrow{bottom:-4px}.tooltip[data-popper-placement^=bottom]>.tooltip-arrow{top:-4px}.tooltip[data-popper-placement^=left]>.tooltip-arrow{right:-4px}.tooltip[data-popper-placement^=right]>.tooltip-arrow{left:-4px}.tooltip.invisible>.tooltip-arrow:before{visibility:hidden}[data-popper-arrow],[data-popper-arrow]:before{background:inherit;height:8px;position:absolute;width:8px}[data-popper-arrow]{visibility:hidden}[data-popper-arrow]:after,[data-popper-arrow]:before{content:"";transform:rotate(45deg);visibility:visible}[data-popper-arrow]:after{background:inherit;height:9px;position:absolute;width:9px}[role=tooltip]>[data-popper-arrow]:before{border-color:#e5e7eb;border-style:solid}.dark [role=tooltip]>[data-popper-arrow]:before{border-color:#4b5563;border-style:solid}[role=tooltip]>[data-popper-arrow]:after{border-color:#e5e7eb;border-style:solid}.dark [role=tooltip]>[data-popper-arrow]:after{border-color:#4b5563;border-style:solid}[data-popover][role=tooltip][data-popper-placement^=top]>[data-popper-arrow]:after,[data-popover][role=tooltip][data-popper-placement^=top]>[data-popper-arrow]:before{border-bottom-width:1px;border-right-width:1px}[data-popover][role=tooltip][data-popper-placement^=right]>[data-popper-arrow]:after,[data-popover][role=tooltip][data-popper-placement^=right]>[data-popper-arrow]:before{border-bottom-width:1px;border-left-width:1px}[data-popover][role=tooltip][data-popper-placement^=bottom]>[data-popper-arrow]:after,[data-popover][role=tooltip][data-popper-placement^=bottom]>[data-popper-arrow]:before{border-left-width:1px;border-top-width:1px}[data-popover][role=tooltip][data-popper-placement^=left]>[data-popper-arrow]:after,[data-popover][role=tooltip][data-popper-placement^=left]>[data-popper-arrow]:before{border-right-width:1px;border-top-width:1px}[data-popover][role=tooltip][data-popper-placement^=top]>[data-popper-arrow]{bottom:-5px}[data-popover][role=tooltip][data-popper-placement^=bottom]>[data-popper-arrow]{top:-5px}[data-popover][role=tooltip][data-popper-placement^=left]>[data-popper-arrow]{right:-5px}[data-popover][role=tooltip][data-popper-placement^=right]>[data-popper-arrow]{left:-5px}[role=tooltip].invisible>[data-popper-arrow]:after,[role=tooltip].invisible>[data-popper-arrow]:before{visibility:hidden}[multiple],[type=date],[type=datetime-local],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],select,textarea{--tw-shadow:0 0 #0000;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-radius:0;border-width:1px;font-size:1rem;line-height:1.5rem;padding:.5rem .75rem}[multiple]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,select:focus,textarea:focus{--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#1c64f2;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);border-color:#1c64f2;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);outline:2px solid transparent;outline-offset:2px}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em}select:not([size]){background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 10 6'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 1 4 4 4-4'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:.75em .75em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple]{background-image:none;background-position:0 0;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{--tw-shadow:0 0 #0000;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;background-origin:border-box;border-color:#6b7280;border-width:1px;color:#1c64f2;display:inline-block;flex-shrink:0;height:1rem;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;-webkit-user-select:none;-moz-user-select:none;user-select:none;vertical-align:middle;width:1rem}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#1c64f2;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);outline:2px solid transparent;outline-offset:2px}.dark [type=checkbox]:checked,.dark [type=radio]:checked,[type=checkbox]:checked,[type=radio]:checked{background-color:currentColor;background-position:50%;background-repeat:no-repeat;background-size:.55em .55em;border-color:transparent}[type=checkbox]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 12'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M1 5.917 5.724 10.5 15 1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:.55em .55em;-webkit-print-color-adjust:exact;print-color-adjust:exact}.dark [type=radio]:checked,[type=radio]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E");background-size:1em 1em}[type=checkbox]:indeterminate{background-color:currentColor;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 12'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M1 5.917 5.724 10.5 15 1.5'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:.55em .55em;border-color:transparent;-webkit-print-color-adjust:exact;print-color-adjust:exact}[type=checkbox]:indeterminate:focus,[type=checkbox]:indeterminate:hover{background-color:currentColor;border-color:transparent}[type=file]{background:unset;border-color:inherit;border-radius:0;border-width:0;font-size:unset;line-height:inherit;padding:0}[type=file]:focus{outline:1px auto inherit}input[type=file]::file-selector-button{-webkit-margin-start:-1rem;-webkit-margin-end:1rem;background:#1f2937;border:0;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;margin-inline-end:1rem;margin-inline-start:-1rem;padding:.625rem 1rem .625rem 2rem}input[type=file]::file-selector-button:hover{background:#374151}.dark input[type=file]::file-selector-button{background:#4b5563;color:#fff}.dark input[type=file]::file-selector-button:hover{background:#6b7280}input[type=range]::-webkit-slider-thumb{appearance:none;-moz-appearance:none;-webkit-appearance:none;background:#1c64f2;border:0;border-radius:9999px;cursor:pointer;height:1.25rem;width:1.25rem}input[type=range]:disabled::-webkit-slider-thumb{background:#9ca3af}.dark input[type=range]:disabled::-webkit-slider-thumb{background:#6b7280}input[type=range]:focus::-webkit-slider-thumb{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);--tw-ring-opacity:1px;--tw-ring-color:rgb(164 202 254/var(--tw-ring-opacity));box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);outline:2px solid transparent;outline-offset:2px}input[type=range]::-moz-range-thumb{appearance:none;-moz-appearance:none;-webkit-appearance:none;background:#1c64f2;border:0;border-radius:9999px;cursor:pointer;height:1.25rem;width:1.25rem}input[type=range]:disabled::-moz-range-thumb{background:#9ca3af}.dark input[type=range]:disabled::-moz-range-thumb{background:#6b7280}input[type=range]::-moz-range-progress{background:#3f83f8}input[type=range]::-ms-fill-lower{background:#3f83f8}input[type=range].range-sm::-webkit-slider-thumb{height:1rem;width:1rem}input[type=range].range-lg::-webkit-slider-thumb{height:1.5rem;width:1.5rem}input[type=range].range-sm::-moz-range-thumb{height:1rem;width:1rem}input[type=range].range-lg::-moz-range-thumb{height:1.5rem;width:1.5rem}.toggle-bg:after{background:#fff;border-color:#d1d5db;border-radius:9999px;border-width:1px;box-shadow:var(--tw-ring-inset) 0 0 0 calc(var(--tw-ring-offset-width)) var(--tw-ring-color);content:"";height:1.25rem;left:.125rem;position:absolute;top:.125rem;transition-duration:.15s;transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;width:1.25rem}input:checked+.toggle-bg:after{border-color:#fff;transform:translateX(100%);}input:checked+.toggle-bg{background:#1c64f2;border-color:#1c64f2}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(63,131,248,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(63,131,248,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.apexcharts-canvas .apexcharts-tooltip{background-color:#fff;border:0!important;border-radius:.25rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);color:#6b7280}.dark .apexcharts-canvas .apexcharts-tooltip{background-color:#374151;border-color:transparent;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);color:#9ca3af}.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title{background-color:#f3f4f6;border-bottom-color:#e5e7eb;color:#6b7280;font-size:.875rem!important;font-weight:400;margin-bottom:.75rem;padding:.5rem .75rem}.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title{background-color:#4b5563;border-color:#6b7280;color:#9ca3af}.apexcharts-canvas .apexcharts-xaxistooltip{background-color:#fff;border-color:transparent;border-radius:.25rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);color:#6b7280;padding:.5rem .75rem}.dark .apexcharts-canvas .apexcharts-xaxistooltip{background-color:#374151;color:#9ca3af}.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label{color:#6b7280;font-size:.875rem}.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label{color:#9ca3af}.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value{color:#111827;font-size:.875rem}.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value{color:#fff}.apexcharts-canvas .apexcharts-xaxistooltip-text{font-size:.875rem!important;font-weight:400}.apexcharts-canvas .apexcharts-xaxistooltip:after,.apexcharts-canvas .apexcharts-xaxistooltip:before{border-bottom-color:#fff}.apexcharts-canvas .apexcharts-xaxistooltip:after{border-width:8px;margin-left:-8px}.apexcharts-canvas .apexcharts-xaxistooltip:before{border-width:10px;margin-left:-10px}.dark .apexcharts-canvas .apexcharts-xaxistooltip:after,.dark .apexcharts-canvas .apexcharts-xaxistooltip:before{border-bottom-color:#374151}.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-y-group{padding:0}.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active{background-color:#fff!important;color:#6b7280!important;padding-bottom:.75rem;padding-left:.75rem;padding-right:.75rem}.dark .apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active{background-color:#374151!important;color:#9ca3af!important}.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active:first-of-type{padding-top:.75rem}.apexcharts-canvas .apexcharts-legend{padding:0!important}.apexcharts-canvas .apexcharts-legend-text{color:#6b7280!important;font-size:.75rem;font-weight:500!important;padding-left:1.25rem}.apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover{color:#111827!important}.dark .apexcharts-canvas .apexcharts-legend-text{color:#9ca3af!important}.dark .apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover{color:#fff!important}.apexcharts-canvas .apexcharts-legend-series{align-items:center;display:flex;margin-bottom:.25rem!important;margin-left:.5rem;margin-right:.5rem}.apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value{fill:#111827!important;font-size:1.875rem;font-weight:700}.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value{fill:#fff!important}.apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label{fill:#6b7280!important;font-size:1rem;font-weight:400}.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label{fill:#9ca3af!important}.apexcharts-canvas .apexcharts-datalabels .apexcharts-text.apexcharts-pie-label{filter:none!important;font-size:.75rem!important;font-weight:600!important;text-shadow:none!important}.apexcharts-gridline,.apexcharts-xcrosshairs,.apexcharts-ycrosshairs{stroke:#e5e7eb!important}.dark .apexcharts-gridline,.dark .apexcharts-xcrosshairs,.dark .apexcharts-ycrosshairs{stroke:#374151!important}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.-left-1{left:-.25rem}.-left-1\.5{left:-.375rem}.-left-14{left:-3.5rem}.-left-3{left:-.75rem}.-left-4{left:-1rem}.-left-\[17px\]{left:-17px}.-right-2{right:-.5rem}.-right-\[16px\]{right:-16px}.-right-\[17px\]{right:-17px}.-top-2{top:-.5rem}.-top-\[140px\]{top:-140px}.bottom-0{bottom:0}.bottom-2{bottom:.5rem}.bottom-2\.5{bottom:.625rem}.bottom-4{bottom:1rem}.bottom-5{bottom:1.25rem}.bottom-6{bottom:1.5rem}.bottom-\[\*px\]{bottom:*px}.bottom-\[60px\]{bottom:60px}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-2\.5{left:.625rem}.left-5{left:1.25rem}.left-6{left:1.5rem}.left-7{left:1.75rem}.left-8{left:2rem}.left-auto{left:auto}.right-0{right:0}.right-1\/2{right:50%}.right-2{right:.5rem}.right-2\.5{right:.625rem}.right-24{right:6rem}.right-3{right:.75rem}.right-5{right:1.25rem}.right-6{right:1.5rem}.right-auto{right:auto}.top-0{top:0}.top-1{top:.25rem}.top-1\/2{top:50%}.top-2{top:.5rem}.top-2\.5{top:.625rem}.top-2\/4{top:50%}.top-28{top:7rem}.top-3{top:.75rem}.top-4{top:1rem}.top-5{top:1.25rem}.top-6{top:1.5rem}.top-\[124px\]{top:124px}.top-\[142px\]{top:142px}.top-\[178px\]{top:178px}.top-\[40px\]{top:40px}.top-\[72px\]{top:72px}.top-\[88px\]{top:88px}.-z-10{z-index:-10}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.col-span-1{grid-column:span 1/span 1}.col-span-2{grid-column:span 2/span 2}.col-span-3{grid-column:span 3/span 3}.col-span-6{grid-column:span 6/span 6}.m-2{margin:.5rem}.m-2\.5{margin:.625rem}.m-4{margin:1rem}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.-mx-1\.5{margin-left:-.375rem;margin-right:-.375rem}.-my-1{margin-bottom:-.25rem;margin-top:-.25rem}.-my-1\.5{margin-bottom:-.375rem;margin-top:-.375rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-1\.5{margin-left:.375rem;margin-right:.375rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-10{margin-bottom:2.5rem;margin-top:2.5rem}.my-12{margin-bottom:3rem;margin-top:3rem}.my-2{margin-bottom:.5rem;margin-top:.5rem}.my-3{margin-bottom:.75rem;margin-top:.75rem}.my-4{margin-bottom:1rem;margin-top:1rem}.my-6{margin-bottom:1.5rem;margin-top:1.5rem}.my-7{margin-bottom:1.75rem;margin-top:1.75rem}.my-8{margin-bottom:2rem;margin-top:2rem}.-mb-5{margin-bottom:-1.25rem}.-mb-px{margin-bottom:-1px}.-ml-0{margin-left:0}.-ml-0\.5{margin-left:-.125rem}.-ml-1{margin-left:-.25rem}.-mr-0{margin-right:0}.-mr-0\.5{margin-right:-.125rem}.-mr-1{margin-right:-.25rem}.-mt-1{margin-top:-.25rem}.-mt-5{margin-top:-1.25rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:1.75rem}.mb-8{margin-bottom:2rem}.mb-px{margin-bottom:1px}.ml-0{margin-left:0}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-2\.5{margin-left:.625rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-6{margin-left:1.5rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-2{margin-right:.5rem}.mr-2\.5{margin-right:.625rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mr-5{margin-right:1.25rem}.mr-6{margin-right:1.5rem}.mr-8{margin-right:2rem}.mr-auto{margin-right:auto}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-10{margin-top:2.5rem}.mt-14{margin-top:3.5rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.mt-8{margin-top:2rem}.mt-\[2px\]{margin-top:2px}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.flow-root{display:flow-root}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-0{height:0}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-24{height:6rem}.h-28{height:7rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-36{height:9rem}.h-4{height:1rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-72{height:18rem}.h-8{height:2rem}.h-80{height:20rem}.h-9{height:2.25rem}.h-96{height:24rem}.h-\[1\.1rem\]{height:1.1rem}.h-\[140px\]{height:140px}.h-\[156px\]{height:156px}.h-\[172px\]{height:172px}.h-\[17px\]{height:17px}.h-\[18px\]{height:18px}.h-\[193px\]{height:193px}.h-\[213px\]{height:213px}.h-\[24px\]{height:24px}.h-\[32px\]{height:32px}.h-\[41px\]{height:41px}.h-\[426px\]{height:426px}.h-\[454px\]{height:454px}.h-\[46px\]{height:46px}.h-\[48px\]{height:48px}.h-\[52px\]{height:52px}.h-\[55px\]{height:55px}.h-\[56px\]{height:56px}.h-\[572px\]{height:572px}.h-\[5px\]{height:5px}.h-\[600px\]{height:600px}.h-\[63px\]{height:63px}.h-\[64px\]{height:64px}.h-\[78px\]{height:78px}.h-\[calc\(100\%-1rem\)\]{height:calc(100% - 1rem)}.h-\[calc\(100vh-5rem\)\]{height:calc(100vh - 5rem)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-72{max-height:18rem}.max-h-\[48px\]{max-height:48px}.max-h-full{max-height:100%}.w-1{width:.25rem}.w-1\/2{width:50%}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-2\/4{width:50%}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-36{width:9rem}.w-4{width:1rem}.w-44{width:11rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-52{width:13rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-60{width:15rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-96{width:24rem}.w-\[1\.1rem\]{width:1.1rem}.w-\[148px\]{width:148px}.w-\[188px\]{width:188px}.w-\[208px\]{width:208px}.w-\[272px\]{width:272px}.w-\[300px\]{width:300px}.w-\[3px\]{width:3px}.w-\[48px\]{width:48px}.w-\[52px\]{width:52px}.w-\[56px\]{width:56px}.w-\[6px\]{width:6px}.w-\[calc\(100\%-2rem\)\]{width:calc(100% - 2rem)}.w-auto{width:auto}.w-full{width:100%}.min-w-0{min-width:0}.min-w-max{min-width:-moz-max-content;min-width:max-content}.max-w-2xl{max-width:42rem}.max-w-2xs{max-width:16rem}.max-w-4xl{max-width:56rem}.max-w-7xl{max-width:80rem}.max-w-8xl{max-width:90rem}.max-w-\[128px\]{max-width:128px}.max-w-\[133px\]{max-width:133px}.max-w-\[300px\]{max-width:300px}.max-w-\[301px\]{max-width:301px}.max-w-\[330px\]{max-width:330px}.max-w-\[341px\]{max-width:341px}.max-w-\[351px\]{max-width:351px}.max-w-\[360px\]{max-width:360px}.max-w-\[380px\]{max-width:380px}.max-w-\[400px\]{max-width:400px}.max-w-\[440px\]{max-width:440px}.max-w-\[450px\]{max-width:450px}.max-w-\[460px\]{max-width:460px}.max-w-\[480px\]{max-width:480px}.max-w-\[48px\]{max-width:48px}.max-w-\[500px\]{max-width:500px}.max-w-\[540px\]{max-width:540px}.max-w-\[640px\]{max-width:640px}.max-w-\[83px\]{max-width:83px}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-screen-md{max-width:768px}.max-w-screen-xl{max-width:1280px}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-none{flex:none}.flex-shrink-0,.shrink-0{flex-shrink:0}.grow{flex-grow:1}.origin-\[0\]{transform-origin:0}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-full{--tw-translate-x:-100%}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.-translate-y-3{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-3{--tw-translate-y:-0.75rem}.-translate-y-4{--tw-translate-y:-1rem}.-translate-y-4,.-translate-y-6{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-6{--tw-translate-y:-1.5rem}.-translate-y-full{--tw-translate-y:-100%}.-translate-y-full,.translate-x-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0{--tw-translate-x:0px}.translate-x-1\/2{--tw-translate-x:50%}.translate-x-1\/2,.translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x:100%}.translate-y-1\/2{--tw-translate-y:50%}.translate-y-1\/2,.translate-y-1\/4{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-1\/4{--tw-translate-y:25%}.translate-y-full{--tw-translate-y:100%}.rotate-180,.translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate:180deg}.rotate-45{--tw-rotate:45deg}.rotate-45,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.scale-75{--tw-scale-x:.75;--tw-scale-y:.75}.scale-75,.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform-none{transform:none}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-12{gap:3rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-x-16{-moz-column-gap:4rem;column-gap:4rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-3{row-gap:.75rem}.-space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(-.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(-.75rem*var(--tw-space-x-reverse))}.-space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(-1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(-1rem*var(--tw-space-x-reverse))}.-space-x-px>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(-1px*(1 - var(--tw-space-x-reverse)));margin-right:calc(-1px*var(--tw-space-x-reverse))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-2\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.625rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.625rem*var(--tw-space-x-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.space-x-5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.25rem*var(--tw-space-x-reverse))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.5rem*var(--tw-space-x-reverse))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.125rem*var(--tw-space-y-reverse));margin-top:calc(.125rem*(1 - var(--tw-space-y-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-2\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.625rem*var(--tw-space-y-reverse));margin-top:calc(.625rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.25rem*var(--tw-space-y-reverse));margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2rem*var(--tw-space-y-reverse));margin-top:calc(2rem*(1 - var(--tw-space-y-reverse)))}.divide-x>:not([hidden])~:not([hidden]){--tw-divide-x-reverse:0;border-left-width:calc(1px*(1 - var(--tw-divide-x-reverse)));border-right-width:calc(1px*var(--tw-divide-x-reverse))}.divide-x-2>:not([hidden])~:not([hidden]){--tw-divide-x-reverse:0;border-left-width:calc(2px*(1 - var(--tw-divide-x-reverse)));border-right-width:calc(2px*var(--tw-divide-x-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-bottom-width:calc(1px*var(--tw-divide-y-reverse));border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)))}.divide-gray-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(243 244 246/var(--tw-divide-opacity))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(229 231 235/var(--tw-divide-opacity))}.divide-gray-300>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(209 213 219/var(--tw-divide-opacity))}.divide-gray-500>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(107 114 128/var(--tw-divide-opacity))}.place-self-center{place-self:center}.self-center{align-self:center}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-scroll{overflow-y:scroll}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.rounded{border-radius:.25rem}.rounded-\[2\.5rem\]{border-radius:2.5rem}.rounded-\[2rem\]{border-radius:2rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-none{border-radius:0}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.rounded-b{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}.rounded-b-\[1rem\]{border-bottom-left-radius:1rem;border-bottom-right-radius:1rem}.rounded-b-\[2\.5rem\]{border-bottom-left-radius:2.5rem;border-bottom-right-radius:2.5rem}.rounded-b-lg{border-bottom-left-radius:.5rem;border-bottom-right-radius:.5rem}.rounded-b-xl{border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}.rounded-l{border-bottom-left-radius:.25rem;border-top-left-radius:.25rem}.rounded-l-full{border-bottom-left-radius:9999px;border-top-left-radius:9999px}.rounded-l-lg{border-bottom-left-radius:.5rem;border-top-left-radius:.5rem}.rounded-l-md{border-bottom-left-radius:.375rem;border-top-left-radius:.375rem}.rounded-r{border-bottom-right-radius:.25rem;border-top-right-radius:.25rem}.rounded-r-full{border-bottom-right-radius:9999px;border-top-right-radius:9999px}.rounded-r-lg{border-bottom-right-radius:.5rem;border-top-right-radius:.5rem}.rounded-r-md{border-bottom-right-radius:.375rem;border-top-right-radius:.375rem}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.rounded-t-\[2\.5rem\]{border-top-left-radius:2.5rem;border-top-right-radius:2.5rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.rounded-t-md{border-top-left-radius:.375rem;border-top-right-radius:.375rem}.rounded-t-sm{border-top-left-radius:.125rem;border-top-right-radius:.125rem}.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.rounded-bl-lg{border-bottom-left-radius:.5rem}.rounded-tl-lg{border-top-left-radius:.5rem}.rounded-tr-lg{border-top-right-radius:.5rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-\[10px\]{border-width:10px}.border-\[14px\]{border-width:14px}.border-\[16px\]{border-width:16px}.border-\[8px\]{border-width:8px}.border-x{border-left-width:1px;border-right-width:1px}.border-y{border-top-width:1px}.border-b,.border-y{border-bottom-width:1px}.border-b-0{border-bottom-width:0}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-2{border-left-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-r-0{border-right-width:0}.border-t{border-top-width:1px}.border-t-0{border-top-width:0}.border-t-4{border-top-width:4px}.border-dashed{border-style:dashed}.\!border-blue-700{--tw-border-opacity:1!important;border-color:rgb(26 86 219/var(--tw-border-opacity))!important}.border-blue-100{--tw-border-opacity:1;border-color:rgb(225 239 254/var(--tw-border-opacity))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(164 202 254/var(--tw-border-opacity))}.border-blue-400{--tw-border-opacity:1;border-color:rgb(118 169 250/var(--tw-border-opacity))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(28 100 242/var(--tw-border-opacity))}.border-blue-700{--tw-border-opacity:1;border-color:rgb(26 86 219/var(--tw-border-opacity))}.border-blue-800{--tw-border-opacity:1;border-color:rgb(30 66 159/var(--tw-border-opacity))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.border-gray-500{--tw-border-opacity:1;border-color:rgb(107 114 128/var(--tw-border-opacity))}.border-gray-700{--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity))}.border-gray-900{--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity))}.border-green-300{--tw-border-opacity:1;border-color:rgb(132 225 188/var(--tw-border-opacity))}.border-green-400{--tw-border-opacity:1;border-color:rgb(49 196 141/var(--tw-border-opacity))}.border-green-500{--tw-border-opacity:1;border-color:rgb(14 159 110/var(--tw-border-opacity))}.border-green-600{--tw-border-opacity:1;border-color:rgb(5 122 85/var(--tw-border-opacity))}.border-green-700{--tw-border-opacity:1;border-color:rgb(4 108 78/var(--tw-border-opacity))}.border-green-800{--tw-border-opacity:1;border-color:rgb(3 84 63/var(--tw-border-opacity))}.border-indigo-400{--tw-border-opacity:1;border-color:rgb(141 162 251/var(--tw-border-opacity))}.border-pink-400{--tw-border-opacity:1;border-color:rgb(241 126 184/var(--tw-border-opacity))}.border-purple-400{--tw-border-opacity:1;border-color:rgb(172 148 250/var(--tw-border-opacity))}.border-purple-700{--tw-border-opacity:1;border-color:rgb(108 43 217/var(--tw-border-opacity))}.border-red-300{--tw-border-opacity:1;border-color:rgb(248 180 180/var(--tw-border-opacity))}.border-red-400{--tw-border-opacity:1;border-color:rgb(249 128 128/var(--tw-border-opacity))}.border-red-500{--tw-border-opacity:1;border-color:rgb(240 82 82/var(--tw-border-opacity))}.border-red-600{--tw-border-opacity:1;border-color:rgb(224 36 36/var(--tw-border-opacity))}.border-red-700{--tw-border-opacity:1;border-color:rgb(200 30 30/var(--tw-border-opacity))}.border-red-800{--tw-border-opacity:1;border-color:rgb(155 28 28/var(--tw-border-opacity))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity))}.border-yellow-300{--tw-border-opacity:1;border-color:rgb(250 202 21/var(--tw-border-opacity))}.border-yellow-400{--tw-border-opacity:1;border-color:rgb(227 160 8/var(--tw-border-opacity))}.border-yellow-800{--tw-border-opacity:1;border-color:rgb(114 59 19/var(--tw-border-opacity))}.border-l-gray-100{--tw-border-opacity:1;border-left-color:rgb(243 244 246/var(--tw-border-opacity))}.border-l-gray-50{--tw-border-opacity:1;border-left-color:rgb(249 250 251/var(--tw-border-opacity))}.bg-\[\#050708\]{--tw-bg-opacity:1;background-color:rgb(5 7 8/var(--tw-bg-opacity))}.bg-\[\#1da1f2\]{--tw-bg-opacity:1;background-color:rgb(29 161 242/var(--tw-bg-opacity))}.bg-\[\#24292F\]{--tw-bg-opacity:1;background-color:rgb(36 41 47/var(--tw-bg-opacity))}.bg-\[\#2557D6\]{--tw-bg-opacity:1;background-color:rgb(37 87 214/var(--tw-bg-opacity))}.bg-\[\#3b5998\]{--tw-bg-opacity:1;background-color:rgb(59 89 152/var(--tw-bg-opacity))}.bg-\[\#4285F4\]{--tw-bg-opacity:1;background-color:rgb(66 133 244/var(--tw-bg-opacity))}.bg-\[\#F7BE38\]{--tw-bg-opacity:1;background-color:rgb(247 190 56/var(--tw-bg-opacity))}.bg-\[\#FF9119\]{--tw-bg-opacity:1;background-color:rgb(255 145 25/var(--tw-bg-opacity))}.bg-\[\#hex\]{background-color:#hex}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(225 239 254/var(--tw-bg-opacity))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(195 221 253/var(--tw-bg-opacity))}.bg-blue-300{--tw-bg-opacity:1;background-color:rgb(164 202 254/var(--tw-bg-opacity))}.bg-blue-400{--tw-bg-opacity:1;background-color:rgb(118 169 250/var(--tw-bg-opacity))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(235 245 255/var(--tw-bg-opacity))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(63 131 248/var(--tw-bg-opacity))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(28 100 242/var(--tw-bg-opacity))}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(26 86 219/var(--tw-bg-opacity))}.bg-blue-800{--tw-bg-opacity:1;background-color:rgb(30 66 159/var(--tw-bg-opacity))}.bg-blue-900{--tw-bg-opacity:1;background-color:rgb(35 56 118/var(--tw-bg-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}.bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}.bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}.bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}.bg-gray-900\/50{background-color:rgba(17,24,39,.5)}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(222 247 236/var(--tw-bg-opacity))}.bg-green-200{--tw-bg-opacity:1;background-color:rgb(188 240 218/var(--tw-bg-opacity))}.bg-green-300{--tw-bg-opacity:1;background-color:rgb(132 225 188/var(--tw-bg-opacity))}.bg-green-400{--tw-bg-opacity:1;background-color:rgb(49 196 141/var(--tw-bg-opacity))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(243 250 247/var(--tw-bg-opacity))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(14 159 110/var(--tw-bg-opacity))}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(5 122 85/var(--tw-bg-opacity))}.bg-green-700{--tw-bg-opacity:1;background-color:rgb(4 108 78/var(--tw-bg-opacity))}.bg-green-800{--tw-bg-opacity:1;background-color:rgb(3 84 63/var(--tw-bg-opacity))}.bg-green-900{--tw-bg-opacity:1;background-color:rgb(1 71 55/var(--tw-bg-opacity))}.bg-indigo-100{--tw-bg-opacity:1;background-color:rgb(229 237 255/var(--tw-bg-opacity))}.bg-indigo-200{--tw-bg-opacity:1;background-color:rgb(205 219 254/var(--tw-bg-opacity))}.bg-indigo-300{--tw-bg-opacity:1;background-color:rgb(180 198 252/var(--tw-bg-opacity))}.bg-indigo-400{--tw-bg-opacity:1;background-color:rgb(141 162 251/var(--tw-bg-opacity))}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(240 245 255/var(--tw-bg-opacity))}.bg-indigo-500{--tw-bg-opacity:1;background-color:rgb(104 117 245/var(--tw-bg-opacity))}.bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(88 80 236/var(--tw-bg-opacity))}.bg-indigo-700{--tw-bg-opacity:1;background-color:rgb(81 69 205/var(--tw-bg-opacity))}.bg-indigo-800{--tw-bg-opacity:1;background-color:rgb(66 56 157/var(--tw-bg-opacity))}.bg-indigo-900{--tw-bg-opacity:1;background-color:rgb(54 47 120/var(--tw-bg-opacity))}.bg-orange-100{--tw-bg-opacity:1;background-color:rgb(254 236 220/var(--tw-bg-opacity))}.bg-orange-300{--tw-bg-opacity:1;background-color:rgb(253 186 140/var(--tw-bg-opacity))}.bg-orange-50{--tw-bg-opacity:1;background-color:rgb(255 248 241/var(--tw-bg-opacity))}.bg-pink-100{--tw-bg-opacity:1;background-color:rgb(252 232 243/var(--tw-bg-opacity))}.bg-pink-200{--tw-bg-opacity:1;background-color:rgb(250 209 232/var(--tw-bg-opacity))}.bg-pink-300{--tw-bg-opacity:1;background-color:rgb(248 180 217/var(--tw-bg-opacity))}.bg-pink-400{--tw-bg-opacity:1;background-color:rgb(241 126 184/var(--tw-bg-opacity))}.bg-pink-50{--tw-bg-opacity:1;background-color:rgb(253 242 248/var(--tw-bg-opacity))}.bg-pink-500{--tw-bg-opacity:1;background-color:rgb(231 70 148/var(--tw-bg-opacity))}.bg-pink-600{--tw-bg-opacity:1;background-color:rgb(214 31 105/var(--tw-bg-opacity))}.bg-pink-700{--tw-bg-opacity:1;background-color:rgb(191 18 93/var(--tw-bg-opacity))}.bg-pink-800{--tw-bg-opacity:1;background-color:rgb(153 21 75/var(--tw-bg-opacity))}.bg-pink-900{--tw-bg-opacity:1;background-color:rgb(117 26 61/var(--tw-bg-opacity))}.bg-purple-100{--tw-bg-opacity:1;background-color:rgb(237 235 254/var(--tw-bg-opacity))}.bg-purple-200{--tw-bg-opacity:1;background-color:rgb(220 215 254/var(--tw-bg-opacity))}.bg-purple-300{--tw-bg-opacity:1;background-color:rgb(202 191 253/var(--tw-bg-opacity))}.bg-purple-400{--tw-bg-opacity:1;background-color:rgb(172 148 250/var(--tw-bg-opacity))}.bg-purple-50{--tw-bg-opacity:1;background-color:rgb(246 245 255/var(--tw-bg-opacity))}.bg-purple-500{--tw-bg-opacity:1;background-color:rgb(144 97 249/var(--tw-bg-opacity))}.bg-purple-600{--tw-bg-opacity:1;background-color:rgb(126 58 242/var(--tw-bg-opacity))}.bg-purple-700{--tw-bg-opacity:1;background-color:rgb(108 43 217/var(--tw-bg-opacity))}.bg-purple-800{--tw-bg-opacity:1;background-color:rgb(85 33 181/var(--tw-bg-opacity))}.bg-purple-900{--tw-bg-opacity:1;background-color:rgb(74 29 150/var(--tw-bg-opacity))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(253 232 232/var(--tw-bg-opacity))}.bg-red-200{--tw-bg-opacity:1;background-color:rgb(251 213 213/var(--tw-bg-opacity))}.bg-red-300{--tw-bg-opacity:1;background-color:rgb(248 180 180/var(--tw-bg-opacity))}.bg-red-400{--tw-bg-opacity:1;background-color:rgb(249 128 128/var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(253 242 242/var(--tw-bg-opacity))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(240 82 82/var(--tw-bg-opacity))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(224 36 36/var(--tw-bg-opacity))}.bg-red-700{--tw-bg-opacity:1;background-color:rgb(200 30 30/var(--tw-bg-opacity))}.bg-red-800{--tw-bg-opacity:1;background-color:rgb(155 28 28/var(--tw-bg-opacity))}.bg-red-900{--tw-bg-opacity:1;background-color:rgb(119 29 29/var(--tw-bg-opacity))}.bg-teal-100{--tw-bg-opacity:1;background-color:rgb(213 245 246/var(--tw-bg-opacity))}.bg-teal-50{--tw-bg-opacity:1;background-color:rgb(237 250 250/var(--tw-bg-opacity))}.bg-teal-500{--tw-bg-opacity:1;background-color:rgb(6 148 162/var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.bg-white\/30{background-color:hsla(0,0%,100%,.3)}.bg-white\/50{background-color:hsla(0,0%,100%,.5)}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(253 246 178/var(--tw-bg-opacity))}.bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(252 233 106/var(--tw-bg-opacity))}.bg-yellow-300{--tw-bg-opacity:1;background-color:rgb(250 202 21/var(--tw-bg-opacity))}.bg-yellow-400{--tw-bg-opacity:1;background-color:rgb(227 160 8/var(--tw-bg-opacity))}.bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(253 253 234/var(--tw-bg-opacity))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(194 120 3/var(--tw-bg-opacity))}.bg-yellow-600{--tw-bg-opacity:1;background-color:rgb(159 88 10/var(--tw-bg-opacity))}.bg-yellow-700{--tw-bg-opacity:1;background-color:rgb(142 75 16/var(--tw-bg-opacity))}.bg-yellow-800{--tw-bg-opacity:1;background-color:rgb(114 59 19/var(--tw-bg-opacity))}.bg-yellow-900{--tw-bg-opacity:1;background-color:rgb(99 49 18/var(--tw-bg-opacity))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/conference\.jpg\'\)\]{background-image:url(https://flowbite.s3.amazonaws.com/docs/jumbotron/conference.jpg)}.bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/hero-pattern\.svg\'\)\]{background-image:url(https://flowbite.s3.amazonaws.com/docs/jumbotron/hero-pattern.svg)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from:#ebf5ff var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(235,245,255,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3f83f8 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(63,131,248,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-400{--tw-gradient-from:#22d3ee var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(34,211,238,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-500{--tw-gradient-from:#06b6d4 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(6,182,212,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-400{--tw-gradient-from:#31c48d var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(49,196,141,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-lime-200{--tw-gradient-from:#d9f99d var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:hsla(81,88%,80%,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-400{--tw-gradient-from:#f17eb8 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(241,126,184,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-500{--tw-gradient-from:#e74694 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(231,70,148,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from:#9061f9 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(144,97,249,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-600{--tw-gradient-from:#7e3af2 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(126,58,242,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-200{--tw-gradient-from:#fbd5d5 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:hsla(0,83%,91%,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-400{--tw-gradient-from:#f98080 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:hsla(0,91%,74%,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-sky-400{--tw-gradient-from:#38bdf8 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(56,189,248,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-teal-200{--tw-gradient-from:#afecef var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(175,236,239,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-teal-300{--tw-gradient-from:#7edce2 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(126,220,226,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-teal-400{--tw-gradient-from:#16bdca var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(22,189,202,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-blue-600{--tw-gradient-via-position: ;--tw-gradient-to:rgba(28,100,242,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#1c64f2 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-cyan-500{--tw-gradient-via-position: ;--tw-gradient-to:rgba(6,182,212,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#06b6d4 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-green-500{--tw-gradient-via-position: ;--tw-gradient-to:rgba(14,159,110,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#0e9f6e var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-lime-400{--tw-gradient-via-position: ;--tw-gradient-to:rgba(163,230,53,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#a3e635 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-pink-500{--tw-gradient-via-position: ;--tw-gradient-to:rgba(231,70,148,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#e74694 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-purple-600{--tw-gradient-via-position: ;--tw-gradient-to:rgba(126,58,242,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#7e3af2 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-red-300{--tw-gradient-via-position: ;--tw-gradient-to:hsla(0,83%,84%,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#f8b4b4 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-red-500{--tw-gradient-via-position: ;--tw-gradient-to:rgba(240,82,82,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#f05252 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-teal-500{--tw-gradient-via-position: ;--tw-gradient-to:rgba(6,148,162,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#0694a2 var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-500{--tw-gradient-to:#3f83f8 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-blue-600{--tw-gradient-to:#1c64f2 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-blue-700{--tw-gradient-to:#1a56db var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-cyan-600{--tw-gradient-to:#0891b2 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-emerald-600{--tw-gradient-to:#059669 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-green-600{--tw-gradient-to:#057a55 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-lime-200{--tw-gradient-to:#d9f99d var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-lime-300{--tw-gradient-to:#bef264 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-lime-500{--tw-gradient-to:#84cc16 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-orange-400{--tw-gradient-to:#ff8a4c var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-pink-500{--tw-gradient-to:#e74694 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-pink-600{--tw-gradient-to:#d61f69 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-purple-700{--tw-gradient-to:#6c2bd9 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-red-600{--tw-gradient-to:#e02424 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-teal-600{--tw-gradient-to:#047481 var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-to-position: }.to-yellow-200{--tw-gradient-to:#fce96a var(--tw-gradient-to-position);--tw-gradient-to-position: }.bg-cover{background-size:cover}.bg-local{background-attachment:local}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.bg-center{background-position:50%}.bg-no-repeat{background-repeat:no-repeat}.fill-blue-600{fill:#1c64f2}.fill-gray-500{fill:#6b7280}.fill-gray-600{fill:#4b5563}.fill-green-500{fill:#0e9f6e}.fill-pink-600{fill:#d61f69}.fill-purple-600{fill:#7e3af2}.fill-red-600{fill:#e02424}.fill-yellow-400{fill:#e3a008}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-0{padding:0!important}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-0{padding-left:0;padding-right:0}.px-0\.5{padding-left:.125rem;padding-right:.125rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-bottom:0;padding-top:0}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.py-24{padding-bottom:6rem;padding-top:6rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-3\.5{padding-bottom:.875rem;padding-top:.875rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-48{padding-bottom:12rem;padding-top:12rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.py-px{padding-bottom:1px;padding-top:1px}.pb-0{padding-bottom:0}.pb-1{padding-bottom:.25rem}.pb-1\.5{padding-bottom:.375rem}.pb-10{padding-bottom:2.5rem}.pb-16{padding-bottom:4rem}.pb-2{padding-bottom:.5rem}.pb-2\.5{padding-bottom:.625rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-48{padding-bottom:12rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pb-8{padding-bottom:2rem}.pb-96{padding-bottom:24rem}.pl-0{padding-left:0}.pl-10{padding-left:2.5rem}.pl-11{padding-left:2.75rem}.pl-2{padding-left:.5rem}.pl-2\.5{padding-left:.625rem}.pl-3{padding-left:.75rem}.pl-3\.5{padding-left:.875rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-0{padding-top:0}.pt-10{padding-top:2.5rem}.pt-16{padding-top:4rem}.pt-2{padding-top:.5rem}.pt-20{padding-top:5rem}.pt-24{padding-top:6rem}.pt-3{padding-top:.75rem}.pt-32{padding-top:8rem}.pt-36{padding-top:9rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-52{padding-top:13rem}.pt-6{padding-top:1.5rem}.pt-60{padding-top:15rem}.pt-64{padding-top:16rem}.pt-8{padding-top:2rem}.pt-80{padding-top:20rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.font-sans{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.text-2xl{font-size:1.5rem;line-height:2rem}.text-2xs{font-size:.625rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-7xl{font-size:4.5rem;line-height:1}.text-8xl{font-size:6rem;line-height:1}.text-9xl{font-size:8rem;line-height:1}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-extralight{font-weight:200}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.font-thin{font-weight:100}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.leading-6{line-height:1.5rem}.leading-9{line-height:2.25rem}.leading-loose{line-height:2}.leading-none{line-height:1}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-normal{letter-spacing:0}.tracking-tight{letter-spacing:-.025em}.tracking-tighter{letter-spacing:-.05em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.\!text-blue-700{--tw-text-opacity:1!important;color:rgb(26 86 219/var(--tw-text-opacity))!important}.text-\[\#626890\]{--tw-text-opacity:1;color:rgb(98 104 144/var(--tw-text-opacity))}.text-\[\#ff2d20\]{--tw-text-opacity:1;color:rgb(255 45 32/var(--tw-text-opacity))}.text-blue-100{--tw-text-opacity:1;color:rgb(225 239 254/var(--tw-text-opacity))}.text-blue-400{--tw-text-opacity:1;color:rgb(118 169 250/var(--tw-text-opacity))}.text-blue-50{--tw-text-opacity:1;color:rgb(235 245 255/var(--tw-text-opacity))}.text-blue-500{--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.text-blue-600\/100{color:#1c64f2}.text-blue-600\/25{color:rgba(28,100,242,.25)}.text-blue-600\/50{color:rgba(28,100,242,.5)}.text-blue-600\/75{color:rgba(28,100,242,.75)}.text-blue-700{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 66 159/var(--tw-text-opacity))}.text-blue-900{--tw-text-opacity:1;color:rgb(35 56 118/var(--tw-text-opacity))}.text-gray-200{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.text-green-400{--tw-text-opacity:1;color:rgb(49 196 141/var(--tw-text-opacity))}.text-green-500{--tw-text-opacity:1;color:rgb(14 159 110/var(--tw-text-opacity))}.text-green-600{--tw-text-opacity:1;color:rgb(5 122 85/var(--tw-text-opacity))}.text-green-700{--tw-text-opacity:1;color:rgb(4 108 78/var(--tw-text-opacity))}.text-green-800{--tw-text-opacity:1;color:rgb(3 84 63/var(--tw-text-opacity))}.text-green-900{--tw-text-opacity:1;color:rgb(1 71 55/var(--tw-text-opacity))}.text-indigo-400{--tw-text-opacity:1;color:rgb(141 162 251/var(--tw-text-opacity))}.text-indigo-700{--tw-text-opacity:1;color:rgb(81 69 205/var(--tw-text-opacity))}.text-indigo-800{--tw-text-opacity:1;color:rgb(66 56 157/var(--tw-text-opacity))}.text-orange-500{--tw-text-opacity:1;color:rgb(255 90 31/var(--tw-text-opacity))}.text-orange-600{--tw-text-opacity:1;color:rgb(208 56 1/var(--tw-text-opacity))}.text-orange-800{--tw-text-opacity:1;color:rgb(138 44 13/var(--tw-text-opacity))}.text-pink-400{--tw-text-opacity:1;color:rgb(241 126 184/var(--tw-text-opacity))}.text-pink-800{--tw-text-opacity:1;color:rgb(153 21 75/var(--tw-text-opacity))}.text-purple-400{--tw-text-opacity:1;color:rgb(172 148 250/var(--tw-text-opacity))}.text-purple-600{--tw-text-opacity:1;color:rgb(126 58 242/var(--tw-text-opacity))}.text-purple-700{--tw-text-opacity:1;color:rgb(108 43 217/var(--tw-text-opacity))}.text-purple-800{--tw-text-opacity:1;color:rgb(85 33 181/var(--tw-text-opacity))}.text-red-400{--tw-text-opacity:1;color:rgb(249 128 128/var(--tw-text-opacity))}.text-red-500{--tw-text-opacity:1;color:rgb(240 82 82/var(--tw-text-opacity))}.text-red-600{--tw-text-opacity:1;color:rgb(224 36 36/var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(200 30 30/var(--tw-text-opacity))}.text-red-800{--tw-text-opacity:1;color:rgb(155 28 28/var(--tw-text-opacity))}.text-red-900{--tw-text-opacity:1;color:rgb(119 29 29/var(--tw-text-opacity))}.text-sky-500{--tw-text-opacity:1;color:rgb(14 165 233/var(--tw-text-opacity))}.text-teal-600{--tw-text-opacity:1;color:rgb(4 116 129/var(--tw-text-opacity))}.text-transparent{color:transparent}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.text-yellow-300{--tw-text-opacity:1;color:rgb(250 202 21/var(--tw-text-opacity))}.text-yellow-400{--tw-text-opacity:1;color:rgb(227 160 8/var(--tw-text-opacity))}.text-yellow-500{--tw-text-opacity:1;color:rgb(194 120 3/var(--tw-text-opacity))}.text-yellow-700{--tw-text-opacity:1;color:rgb(142 75 16/var(--tw-text-opacity))}.text-yellow-800{--tw-text-opacity:1;color:rgb(114 59 19/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.line-through{text-decoration-line:line-through}.no-underline{text-decoration-line:none}.decoration-blue-400{text-decoration-color:#76a9fa}.decoration-blue-500{text-decoration-color:#3f83f8}.decoration-gray-500{text-decoration-color:#6b7280}.decoration-green-500{text-decoration-color:#0e9f6e}.decoration-indigo-500{text-decoration-color:#6875f5}.decoration-red-500{text-decoration-color:#f05252}.decoration-sky-500{text-decoration-color:#0ea5e9}.decoration-solid{text-decoration-style:solid}.decoration-double{text-decoration-style:double}.decoration-dotted{text-decoration-style:dotted}.decoration-dashed{text-decoration-style:dashed}.decoration-wavy{text-decoration-style:wavy}.decoration-8{text-decoration-thickness:8px}.underline-offset-2{text-underline-offset:2px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-green-700::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(4 108 78/var(--tw-placeholder-opacity))}.placeholder-green-700::placeholder{--tw-placeholder-opacity:1;color:rgb(4 108 78/var(--tw-placeholder-opacity))}.placeholder-red-700::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(200 30 30/var(--tw-placeholder-opacity))}.placeholder-red-700::placeholder{--tw-placeholder-opacity:1;color:rgb(200 30 30/var(--tw-placeholder-opacity))}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-20{opacity:.2}.bg-blend-multiply{background-blend-mode:multiply}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-blue-500\/50{--tw-shadow-color:rgba(63,131,248,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-cyan-500\/50{--tw-shadow-color:rgba(6,182,212,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-green-500\/50{--tw-shadow-color:rgba(14,159,110,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-lime-500\/50{--tw-shadow-color:rgba(132,204,22,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-pink-500\/50{--tw-shadow-color:rgba(231,70,148,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-purple-500\/50{--tw-shadow-color:rgba(144,97,249,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-red-500\/50{--tw-shadow-color:rgba(240,82,82,.5);--tw-shadow:var(--tw-shadow-colored)}.shadow-teal-500\/50{--tw-shadow-color:rgba(6,148,162,.5);--tw-shadow:var(--tw-shadow-colored)}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-0,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-2,.ring-4{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-8{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(8px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-inset{--tw-ring-inset:inset}.ring-black{--tw-ring-opacity:1;--tw-ring-color:rgb(0 0 0/var(--tw-ring-opacity))}.ring-gray-300{--tw-ring-opacity:1;--tw-ring-color:rgb(209 213 219/var(--tw-ring-opacity))}.ring-white{--tw-ring-opacity:1;--tw-ring-color:rgb(255 255 255/var(--tw-ring-opacity))}.ring-opacity-0{--tw-ring-opacity:0}.blur{--tw-blur:blur(8px)}.blur,.blur-sm{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-sm{--tw-blur:blur(4px)}.grayscale{--tw-grayscale:grayscale(100%)}.grayscale,.invert{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert:invert(100%)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-700{transition-duration:.7s}.duration-75{transition-duration:75ms}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.first-letter\:float-left:first-letter{float:left}.first-letter\:mr-3:first-letter{margin-right:.75rem}.first-letter\:text-7xl:first-letter{font-size:4.5rem;line-height:1}.first-letter\:font-bold:first-letter{font-weight:700}.first-letter\:text-gray-900:first-letter{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.first-line\:uppercase:first-line{text-transform:uppercase}.first-line\:tracking-widest:first-line{letter-spacing:.1em}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:left-\[2px\]:after{content:var(--tw-content);left:2px}.after\:left-\[4px\]:after{content:var(--tw-content);left:4px}.after\:top-0:after{content:var(--tw-content);top:0}.after\:top-0\.5:after{content:var(--tw-content);top:.125rem}.after\:top-\[2px\]:after{content:var(--tw-content);top:2px}.after\:mx-2:after{content:var(--tw-content);margin-left:.5rem;margin-right:.5rem}.after\:mx-6:after{content:var(--tw-content);margin-left:1.5rem;margin-right:1.5rem}.after\:inline-block:after{content:var(--tw-content);display:inline-block}.after\:hidden:after{content:var(--tw-content);display:none}.after\:h-1:after{content:var(--tw-content);height:.25rem}.after\:h-4:after{content:var(--tw-content);height:1rem}.after\:h-5:after{content:var(--tw-content);height:1.25rem}.after\:h-6:after{content:var(--tw-content);height:1.5rem}.after\:w-4:after{content:var(--tw-content);width:1rem}.after\:w-5:after{content:var(--tw-content);width:1.25rem}.after\:w-6:after{content:var(--tw-content);width:1.5rem}.after\:w-full:after{content:var(--tw-content);width:100%}.after\:rounded-full:after{border-radius:9999px;content:var(--tw-content)}.after\:border:after{border-width:1px;content:var(--tw-content)}.after\:border-4:after{border-width:4px;content:var(--tw-content)}.after\:border-b:after{border-bottom-width:1px;content:var(--tw-content)}.after\:border-blue-100:after{--tw-border-opacity:1;border-color:rgb(225 239 254/var(--tw-border-opacity));content:var(--tw-content)}.after\:border-gray-100:after{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity));content:var(--tw-content)}.after\:border-gray-200:after{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity));content:var(--tw-content)}.after\:border-gray-300:after{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity));content:var(--tw-content)}.after\:bg-white:after{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity));content:var(--tw-content)}.after\:text-gray-200:after{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity));content:var(--tw-content)}.after\:transition-all:after{content:var(--tw-content);transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.after\:content-\[\'\'\]:after{--tw-content:"";content:var(--tw-content)}.after\:content-\[\'\/\'\]:after{--tw-content:"/";content:var(--tw-content)}.hover\:border-gray-200:hover{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.hover\:border-gray-300:hover{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.hover\:bg-\[\#050708\]\/80:hover{background-color:rgba(5,7,8,.8)}.hover\:bg-\[\#050708\]\/90:hover{background-color:rgba(5,7,8,.9)}.hover\:bg-\[\#1da1f2\]\/90:hover{background-color:rgba(29,161,242,.9)}.hover\:bg-\[\#24292F\]\/90:hover{background-color:rgba(36,41,47,.9)}.hover\:bg-\[\#2557D6\]\/90:hover{background-color:rgba(37,87,214,.9)}.hover\:bg-\[\#3b5998\]\/90:hover{background-color:rgba(59,89,152,.9)}.hover\:bg-\[\#4285F4\]\/90:hover{background-color:rgba(66,133,244,.9)}.hover\:bg-\[\#F7BE38\]\/90:hover{background-color:rgba(247,190,56,.9)}.hover\:bg-\[\#FF9119\]\/80:hover{background-color:rgba(255,145,25,.8)}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:rgb(225 239 254/var(--tw-bg-opacity))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:rgb(195 221 253/var(--tw-bg-opacity))}.hover\:bg-blue-500:hover{--tw-bg-opacity:1;background-color:rgb(63 131 248/var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(26 86 219/var(--tw-bg-opacity))}.hover\:bg-blue-800:hover{--tw-bg-opacity:1;background-color:rgb(30 66 159/var(--tw-bg-opacity))}.hover\:bg-blue-900:hover{--tw-bg-opacity:1;background-color:rgb(35 56 118/var(--tw-bg-opacity))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.hover\:bg-gray-500:hover{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}.hover\:bg-gray-600:hover{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}.hover\:bg-gray-700:hover{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.hover\:bg-gray-800:hover{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}.hover\:bg-gray-900:hover{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}.hover\:bg-green-200:hover{--tw-bg-opacity:1;background-color:rgb(188 240 218/var(--tw-bg-opacity))}.hover\:bg-green-800:hover{--tw-bg-opacity:1;background-color:rgb(3 84 63/var(--tw-bg-opacity))}.hover\:bg-green-900:hover{--tw-bg-opacity:1;background-color:rgb(1 71 55/var(--tw-bg-opacity))}.hover\:bg-indigo-200:hover{--tw-bg-opacity:1;background-color:rgb(205 219 254/var(--tw-bg-opacity))}.hover\:bg-pink-200:hover{--tw-bg-opacity:1;background-color:rgb(250 209 232/var(--tw-bg-opacity))}.hover\:bg-purple-200:hover{--tw-bg-opacity:1;background-color:rgb(220 215 254/var(--tw-bg-opacity))}.hover\:bg-purple-800:hover{--tw-bg-opacity:1;background-color:rgb(85 33 181/var(--tw-bg-opacity))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:rgb(251 213 213/var(--tw-bg-opacity))}.hover\:bg-red-800:hover{--tw-bg-opacity:1;background-color:rgb(155 28 28/var(--tw-bg-opacity))}.hover\:bg-red-900:hover{--tw-bg-opacity:1;background-color:rgb(119 29 29/var(--tw-bg-opacity))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.hover\:bg-yellow-200:hover{--tw-bg-opacity:1;background-color:rgb(252 233 106/var(--tw-bg-opacity))}.hover\:bg-yellow-500:hover{--tw-bg-opacity:1;background-color:rgb(194 120 3/var(--tw-bg-opacity))}.hover\:bg-yellow-900:hover{--tw-bg-opacity:1;background-color:rgb(99 49 18/var(--tw-bg-opacity))}.hover\:bg-gradient-to-bl:hover{background-image:linear-gradient(to bottom left,var(--tw-gradient-stops))}.hover\:bg-gradient-to-br:hover{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.hover\:bg-gradient-to-l:hover{background-image:linear-gradient(to left,var(--tw-gradient-stops))}.hover\:from-teal-200:hover{--tw-gradient-from:#afecef var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(175,236,239,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-lime-200:hover{--tw-gradient-to:#d9f99d var(--tw-gradient-to-position);--tw-gradient-to-position: }.hover\:\!text-blue-700:hover{--tw-text-opacity:1!important;color:rgb(26 86 219/var(--tw-text-opacity))!important}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.hover\:text-blue-700:hover{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 66 159/var(--tw-text-opacity))}.hover\:text-blue-900:hover{--tw-text-opacity:1;color:rgb(35 56 118/var(--tw-text-opacity))}.hover\:text-gray-500:hover{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.hover\:text-gray-800:hover{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.hover\:text-green-900:hover{--tw-text-opacity:1;color:rgb(1 71 55/var(--tw-text-opacity))}.hover\:text-indigo-900:hover{--tw-text-opacity:1;color:rgb(54 47 120/var(--tw-text-opacity))}.hover\:text-pink-900:hover{--tw-text-opacity:1;color:rgb(117 26 61/var(--tw-text-opacity))}.hover\:text-purple-900:hover{--tw-text-opacity:1;color:rgb(74 29 150/var(--tw-text-opacity))}.hover\:text-red-900:hover{--tw-text-opacity:1;color:rgb(119 29 29/var(--tw-text-opacity))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.hover\:text-yellow-900:hover{--tw-text-opacity:1;color:rgb(99 49 18/var(--tw-text-opacity))}.hover\:underline:hover{text-decoration-line:underline}.hover\:no-underline:hover{text-decoration-line:none}.hover\:bg-blend-soft-light:hover{background-blend-mode:soft-light}.hover\:shadow:hover{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:blur-none:hover{--tw-blur:blur(0)}.hover\:blur-none:hover,.hover\:grayscale-0:hover{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.hover\:grayscale-0:hover{--tw-grayscale:grayscale(0)}.focus\:z-10:focus{z-index:10}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(63 131 248/var(--tw-border-opacity))}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:rgb(28 100 242/var(--tw-border-opacity))}.focus\:border-gray-200:focus{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.focus\:border-green-500:focus{--tw-border-opacity:1;border-color:rgb(14 159 110/var(--tw-border-opacity))}.focus\:border-green-600:focus{--tw-border-opacity:1;border-color:rgb(5 122 85/var(--tw-border-opacity))}.focus\:border-red-500:focus{--tw-border-opacity:1;border-color:rgb(240 82 82/var(--tw-border-opacity))}.focus\:border-red-600:focus{--tw-border-opacity:1;border-color:rgb(224 36 36/var(--tw-border-opacity))}.focus\:bg-gray-100:focus{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.focus\:bg-gray-900:focus{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}.focus\:text-blue-700:focus{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.focus\:text-white:focus{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-0:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-4:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-\[\#050708\]\/50:focus{--tw-ring-color:rgba(5,7,8,.5)}.focus\:ring-\[\#1da1f2\]\/50:focus{--tw-ring-color:rgba(29,161,242,.5)}.focus\:ring-\[\#24292F\]\/50:focus{--tw-ring-color:rgba(36,41,47,.5)}.focus\:ring-\[\#2557D6\]\/50:focus{--tw-ring-color:rgba(37,87,214,.5)}.focus\:ring-\[\#3b5998\]\/50:focus{--tw-ring-color:rgba(59,89,152,.5)}.focus\:ring-\[\#4285F4\]\/50:focus{--tw-ring-color:rgba(66,133,244,.5)}.focus\:ring-\[\#F7BE38\]\/50:focus{--tw-ring-color:rgba(247,190,56,.5)}.focus\:ring-\[\#FF9119\]\/50:focus{--tw-ring-color:rgba(255,145,25,.5)}.focus\:ring-blue-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(195 221 253/var(--tw-ring-opacity))}.focus\:ring-blue-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(164 202 254/var(--tw-ring-opacity))}.focus\:ring-blue-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(118 169 250/var(--tw-ring-opacity))}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(63 131 248/var(--tw-ring-opacity))}.focus\:ring-blue-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(28 100 242/var(--tw-ring-opacity))}.focus\:ring-blue-700:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(26 86 219/var(--tw-ring-opacity))}.focus\:ring-cyan-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(165 243 252/var(--tw-ring-opacity))}.focus\:ring-cyan-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(103 232 249/var(--tw-ring-opacity))}.focus\:ring-gray-100:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(243 244 246/var(--tw-ring-opacity))}.focus\:ring-gray-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(229 231 235/var(--tw-ring-opacity))}.focus\:ring-gray-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(209 213 219/var(--tw-ring-opacity))}.focus\:ring-gray-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(156 163 175/var(--tw-ring-opacity))}.focus\:ring-gray-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(249 250 251/var(--tw-ring-opacity))}.focus\:ring-gray-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(107 114 128/var(--tw-ring-opacity))}.focus\:ring-gray-700:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(55 65 81/var(--tw-ring-opacity))}.focus\:ring-green-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(188 240 218/var(--tw-ring-opacity))}.focus\:ring-green-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(132 225 188/var(--tw-ring-opacity))}.focus\:ring-green-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(49 196 141/var(--tw-ring-opacity))}.focus\:ring-green-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(14 159 110/var(--tw-ring-opacity))}.focus\:ring-lime-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(217 249 157/var(--tw-ring-opacity))}.focus\:ring-lime-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(190 242 100/var(--tw-ring-opacity))}.focus\:ring-orange-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 90 31/var(--tw-ring-opacity))}.focus\:ring-pink-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(250 209 232/var(--tw-ring-opacity))}.focus\:ring-pink-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 180 217/var(--tw-ring-opacity))}.focus\:ring-purple-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(220 215 254/var(--tw-ring-opacity))}.focus\:ring-purple-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(202 191 253/var(--tw-ring-opacity))}.focus\:ring-purple-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(144 97 249/var(--tw-ring-opacity))}.focus\:ring-red-100:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(253 232 232/var(--tw-ring-opacity))}.focus\:ring-red-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 180 180/var(--tw-ring-opacity))}.focus\:ring-red-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(249 128 128/var(--tw-ring-opacity))}.focus\:ring-red-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(240 82 82/var(--tw-ring-opacity))}.focus\:ring-teal-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(126 220 226/var(--tw-ring-opacity))}.focus\:ring-teal-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(6 148 162/var(--tw-ring-opacity))}.focus\:ring-yellow-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(250 202 21/var(--tw-ring-opacity))}.focus\:ring-yellow-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(227 160 8/var(--tw-ring-opacity))}.focus\:ring-yellow-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(194 120 3/var(--tw-ring-opacity))}.group:hover .group-hover\:rotate-45{--tw-rotate:45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:bg-white\/50{background-color:hsla(0,0%,100%,.5)}.group:hover .group-hover\:bg-opacity-0{--tw-bg-opacity:0}.group:hover .group-hover\:from-cyan-500{--tw-gradient-from:#06b6d4 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(6,182,212,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-green-400{--tw-gradient-from:#31c48d var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(49,196,141,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-pink-500{--tw-gradient-from:#e74694 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(231,70,148,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-purple-500{--tw-gradient-from:#9061f9 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(144,97,249,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-purple-600{--tw-gradient-from:#7e3af2 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(126,58,242,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-red-200{--tw-gradient-from:#fbd5d5 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:hsla(0,83%,91%,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-teal-300{--tw-gradient-from:#7edce2 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(126,220,226,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:via-red-300{--tw-gradient-via-position: ;--tw-gradient-to:hsla(0,83%,84%,0) var(--tw-gradient-to-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),#f8b4b4 var(--tw-gradient-via-position),var(--tw-gradient-to)}.group:hover .group-hover\:to-blue-500{--tw-gradient-to:#3f83f8 var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:to-blue-600{--tw-gradient-to:#1c64f2 var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:to-lime-300{--tw-gradient-to:#bef264 var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:to-orange-400{--tw-gradient-to:#ff8a4c var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:to-pink-500{--tw-gradient-to:#e74694 var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:to-yellow-200{--tw-gradient-to:#fce96a var(--tw-gradient-to-position);--tw-gradient-to-position: }.group:hover .group-hover\:text-blue-600{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.group:hover .group-hover\:text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.group:hover .group-hover\:text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.group:hover .group-hover\:opacity-100{opacity:1}.group:focus .group-focus\:text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.group:focus .group-focus\:outline-none{outline:2px solid transparent;outline-offset:2px}.group:focus .group-focus\:ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.group:focus .group-focus\:ring-white{--tw-ring-opacity:1;--tw-ring-color:rgb(255 255 255/var(--tw-ring-opacity))}.peer:checked~.peer-checked\:border-blue-600{--tw-border-opacity:1;border-color:rgb(28 100 242/var(--tw-border-opacity))}.peer:checked~.peer-checked\:bg-blue-600{--tw-bg-opacity:1;background-color:rgb(28 100 242/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-green-600{--tw-bg-opacity:1;background-color:rgb(5 122 85/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-orange-500{--tw-bg-opacity:1;background-color:rgb(255 90 31/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-purple-600{--tw-bg-opacity:1;background-color:rgb(126 58 242/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-red-600{--tw-bg-opacity:1;background-color:rgb(224 36 36/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-teal-600{--tw-bg-opacity:1;background-color:rgb(4 116 129/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-yellow-400{--tw-bg-opacity:1;background-color:rgb(227 160 8/var(--tw-bg-opacity))}.peer:checked~.peer-checked\:text-blue-600{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.peer:checked~.peer-checked\:text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.peer:checked~.peer-checked\:after\:translate-x-full:after{--tw-translate-x:100%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:checked~.peer-checked\:after\:border-white:after{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity));content:var(--tw-content)}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:placeholder-shown~.peer-placeholder-shown\:-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:translate-y-0{--tw-translate-y:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:placeholder-shown~.peer-placeholder-shown\:translate-y-0{--tw-translate-y:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:scale-100{--tw-scale-x:1;--tw-scale-y:1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:placeholder-shown~.peer-placeholder-shown\:scale-100{--tw-scale-x:1;--tw-scale-y:1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:focus~.peer-focus\:left-0{left:0}.peer:focus~.peer-focus\:top-1{top:.25rem}.peer:focus~.peer-focus\:top-2{top:.5rem}.peer:focus~.peer-focus\:-translate-y-3{--tw-translate-y:-0.75rem}.peer:focus~.peer-focus\:-translate-y-3,.peer:focus~.peer-focus\:-translate-y-4{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:focus~.peer-focus\:-translate-y-4{--tw-translate-y:-1rem}.peer:focus~.peer-focus\:-translate-y-6{--tw-translate-y:-1.5rem}.peer:focus~.peer-focus\:-translate-y-6,.peer:focus~.peer-focus\:scale-75{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:focus~.peer-focus\:scale-75{--tw-scale-x:.75;--tw-scale-y:.75}.peer:focus~.peer-focus\:px-2{padding-left:.5rem;padding-right:.5rem}.peer:focus~.peer-focus\:font-medium{font-weight:500}.peer:focus~.peer-focus\:text-blue-600{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.peer:focus~.peer-focus\:outline-none{outline:2px solid transparent;outline-offset:2px}.peer:focus~.peer-focus\:ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.peer:focus~.peer-focus\:ring-blue-300{--tw-ring-opacity:1;--tw-ring-color:rgb(164 202 254/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-green-300{--tw-ring-opacity:1;--tw-ring-color:rgb(132 225 188/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-orange-300{--tw-ring-opacity:1;--tw-ring-color:rgb(253 186 140/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-purple-300{--tw-ring-opacity:1;--tw-ring-color:rgb(202 191 253/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-red-300{--tw-ring-opacity:1;--tw-ring-color:rgb(248 180 180/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-teal-300{--tw-ring-opacity:1;--tw-ring-color:rgb(126 220 226/var(--tw-ring-opacity))}.peer:focus~.peer-focus\:ring-yellow-300{--tw-ring-opacity:1;--tw-ring-color:rgb(250 202 21/var(--tw-ring-opacity))}:is(.dark .dark\:block){display:block}:is(.dark .dark\:inline-block){display:inline-block}:is(.dark .dark\:hidden){display:none}:is(.dark .dark\:divide-gray-600)>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(75 85 99/var(--tw-divide-opacity))}:is(.dark .dark\:divide-gray-700)>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(55 65 81/var(--tw-divide-opacity))}:is(.dark .dark\:\!border-blue-500){--tw-border-opacity:1!important;border-color:rgb(63 131 248/var(--tw-border-opacity))!important}:is(.dark .dark\:border-blue-400){--tw-border-opacity:1;border-color:rgb(118 169 250/var(--tw-border-opacity))}:is(.dark .dark\:border-blue-500){--tw-border-opacity:1;border-color:rgb(63 131 248/var(--tw-border-opacity))}:is(.dark .dark\:border-blue-600){--tw-border-opacity:1;border-color:rgb(28 100 242/var(--tw-border-opacity))}:is(.dark .dark\:border-blue-800){--tw-border-opacity:1;border-color:rgb(30 66 159/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-400){--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-500){--tw-border-opacity:1;border-color:rgb(107 114 128/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-600){--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-700){--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-800){--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity))}:is(.dark .dark\:border-gray-900){--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity))}:is(.dark .dark\:border-green-400){--tw-border-opacity:1;border-color:rgb(49 196 141/var(--tw-border-opacity))}:is(.dark .dark\:border-green-500){--tw-border-opacity:1;border-color:rgb(14 159 110/var(--tw-border-opacity))}:is(.dark .dark\:border-green-600){--tw-border-opacity:1;border-color:rgb(5 122 85/var(--tw-border-opacity))}:is(.dark .dark\:border-green-800){--tw-border-opacity:1;border-color:rgb(3 84 63/var(--tw-border-opacity))}:is(.dark .dark\:border-purple-400){--tw-border-opacity:1;border-color:rgb(172 148 250/var(--tw-border-opacity))}:is(.dark .dark\:border-red-400){--tw-border-opacity:1;border-color:rgb(249 128 128/var(--tw-border-opacity))}:is(.dark .dark\:border-red-500){--tw-border-opacity:1;border-color:rgb(240 82 82/var(--tw-border-opacity))}:is(.dark .dark\:border-red-600){--tw-border-opacity:1;border-color:rgb(224 36 36/var(--tw-border-opacity))}:is(.dark .dark\:border-red-800){--tw-border-opacity:1;border-color:rgb(155 28 28/var(--tw-border-opacity))}:is(.dark .dark\:border-transparent){border-color:transparent}:is(.dark .dark\:border-white){--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity))}:is(.dark .dark\:border-yellow-300){--tw-border-opacity:1;border-color:rgb(250 202 21/var(--tw-border-opacity))}:is(.dark .dark\:border-yellow-800){--tw-border-opacity:1;border-color:rgb(114 59 19/var(--tw-border-opacity))}:is(.dark .dark\:border-l-gray-700){--tw-border-opacity:1;border-left-color:rgb(55 65 81/var(--tw-border-opacity))}:is(.dark .dark\:bg-blue-200){--tw-bg-opacity:1;background-color:rgb(195 221 253/var(--tw-bg-opacity))}:is(.dark .dark\:bg-blue-400){--tw-bg-opacity:1;background-color:rgb(118 169 250/var(--tw-bg-opacity))}:is(.dark .dark\:bg-blue-500){--tw-bg-opacity:1;background-color:rgb(63 131 248/var(--tw-bg-opacity))}:is(.dark .dark\:bg-blue-600){--tw-bg-opacity:1;background-color:rgb(28 100 242/var(--tw-bg-opacity))}:is(.dark .dark\:bg-blue-800){--tw-bg-opacity:1;background-color:rgb(30 66 159/var(--tw-bg-opacity))}:is(.dark .dark\:bg-blue-900){--tw-bg-opacity:1;background-color:rgb(35 56 118/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-300){--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-400){--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-500){--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-600){--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-700){--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-800){--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-800\/30){background-color:rgba(31,41,55,.3)}:is(.dark .dark\:bg-gray-800\/50){background-color:rgba(31,41,55,.5)}:is(.dark .dark\:bg-gray-900){--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}:is(.dark .dark\:bg-gray-900\/60){background-color:rgba(17,24,39,.6)}:is(.dark .dark\:bg-green-100){--tw-bg-opacity:1;background-color:rgb(222 247 236/var(--tw-bg-opacity))}:is(.dark .dark\:bg-green-500){--tw-bg-opacity:1;background-color:rgb(14 159 110/var(--tw-bg-opacity))}:is(.dark .dark\:bg-green-600){--tw-bg-opacity:1;background-color:rgb(5 122 85/var(--tw-bg-opacity))}:is(.dark .dark\:bg-green-800){--tw-bg-opacity:1;background-color:rgb(3 84 63/var(--tw-bg-opacity))}:is(.dark .dark\:bg-green-900){--tw-bg-opacity:1;background-color:rgb(1 71 55/var(--tw-bg-opacity))}:is(.dark .dark\:bg-indigo-500){--tw-bg-opacity:1;background-color:rgb(104 117 245/var(--tw-bg-opacity))}:is(.dark .dark\:bg-indigo-900){--tw-bg-opacity:1;background-color:rgb(54 47 120/var(--tw-bg-opacity))}:is(.dark .dark\:bg-orange-200){--tw-bg-opacity:1;background-color:rgb(252 217 189/var(--tw-bg-opacity))}:is(.dark .dark\:bg-orange-400){--tw-bg-opacity:1;background-color:rgb(255 138 76/var(--tw-bg-opacity))}:is(.dark .dark\:bg-orange-700){--tw-bg-opacity:1;background-color:rgb(180 52 3/var(--tw-bg-opacity))}:is(.dark .dark\:bg-pink-900){--tw-bg-opacity:1;background-color:rgb(117 26 61/var(--tw-bg-opacity))}:is(.dark .dark\:bg-purple-500){--tw-bg-opacity:1;background-color:rgb(144 97 249/var(--tw-bg-opacity))}:is(.dark .dark\:bg-purple-600){--tw-bg-opacity:1;background-color:rgb(126 58 242/var(--tw-bg-opacity))}:is(.dark .dark\:bg-purple-900){--tw-bg-opacity:1;background-color:rgb(74 29 150/var(--tw-bg-opacity))}:is(.dark .dark\:bg-red-100){--tw-bg-opacity:1;background-color:rgb(253 232 232/var(--tw-bg-opacity))}:is(.dark .dark\:bg-red-500){--tw-bg-opacity:1;background-color:rgb(240 82 82/var(--tw-bg-opacity))}:is(.dark .dark\:bg-red-600){--tw-bg-opacity:1;background-color:rgb(224 36 36/var(--tw-bg-opacity))}:is(.dark .dark\:bg-red-800){--tw-bg-opacity:1;background-color:rgb(155 28 28/var(--tw-bg-opacity))}:is(.dark .dark\:bg-red-900){--tw-bg-opacity:1;background-color:rgb(119 29 29/var(--tw-bg-opacity))}:is(.dark .dark\:bg-white){--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}:is(.dark .dark\:bg-yellow-300){--tw-bg-opacity:1;background-color:rgb(250 202 21/var(--tw-bg-opacity))}:is(.dark .dark\:bg-yellow-900){--tw-bg-opacity:1;background-color:rgb(99 49 18/var(--tw-bg-opacity))}:is(.dark .dark\:bg-opacity-80){--tw-bg-opacity:0.8}:is(.dark .dark\:bg-\[url\(\'https\:\/\/flowbite\.s3\.amazonaws\.com\/docs\/jumbotron\/hero-pattern-dark\.svg\'\)\]){background-image:url(https://flowbite.s3.amazonaws.com/docs/jumbotron/hero-pattern-dark.svg)}:is(.dark .dark\:from-blue-900){--tw-gradient-from:#233876 var(--tw-gradient-from-position);--tw-gradient-from-position: ;--tw-gradient-to:rgba(35,56,118,0) var(--tw-gradient-from-position);--tw-gradient-to-position: ;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}:is(.dark .dark\:fill-gray-300){fill:#d1d5db}:is(.dark .dark\:fill-gray-400){fill:#9ca3af}:is(.dark .dark\:\!text-blue-500){--tw-text-opacity:1!important;color:rgb(63 131 248/var(--tw-text-opacity))!important}:is(.dark .dark\:text-blue-100){--tw-text-opacity:1;color:rgb(225 239 254/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-200){--tw-text-opacity:1;color:rgb(195 221 253/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-300){--tw-text-opacity:1;color:rgb(164 202 254/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-400){--tw-text-opacity:1;color:rgb(118 169 250/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-500){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-500\/100){color:#3f83f8}:is(.dark .dark\:text-blue-500\/25){color:rgba(63,131,248,.25)}:is(.dark .dark\:text-blue-500\/50){color:rgba(63,131,248,.5)}:is(.dark .dark\:text-blue-500\/75){color:rgba(63,131,248,.75)}:is(.dark .dark\:text-blue-600){--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}:is(.dark .dark\:text-blue-800){--tw-text-opacity:1;color:rgb(30 66 159/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-100){--tw-text-opacity:1;color:rgb(243 244 246/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-200){--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-300){--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-400){--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-500){--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-600){--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-700){--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-800){--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}:is(.dark .dark\:text-gray-900){--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}:is(.dark .dark\:text-green-200){--tw-text-opacity:1;color:rgb(188 240 218/var(--tw-text-opacity))}:is(.dark .dark\:text-green-300){--tw-text-opacity:1;color:rgb(132 225 188/var(--tw-text-opacity))}:is(.dark .dark\:text-green-400){--tw-text-opacity:1;color:rgb(49 196 141/var(--tw-text-opacity))}:is(.dark .dark\:text-green-500){--tw-text-opacity:1;color:rgb(14 159 110/var(--tw-text-opacity))}:is(.dark .dark\:text-green-600){--tw-text-opacity:1;color:rgb(5 122 85/var(--tw-text-opacity))}:is(.dark .dark\:text-indigo-300){--tw-text-opacity:1;color:rgb(180 198 252/var(--tw-text-opacity))}:is(.dark .dark\:text-indigo-400){--tw-text-opacity:1;color:rgb(141 162 251/var(--tw-text-opacity))}:is(.dark .dark\:text-indigo-500){--tw-text-opacity:1;color:rgb(104 117 245/var(--tw-text-opacity))}:is(.dark .dark\:text-orange-200){--tw-text-opacity:1;color:rgb(252 217 189/var(--tw-text-opacity))}:is(.dark .dark\:text-orange-300){--tw-text-opacity:1;color:rgb(253 186 140/var(--tw-text-opacity))}:is(.dark .dark\:text-orange-900){--tw-text-opacity:1;color:rgb(119 29 29/var(--tw-text-opacity))}:is(.dark .dark\:text-pink-300){--tw-text-opacity:1;color:rgb(248 180 217/var(--tw-text-opacity))}:is(.dark .dark\:text-pink-400){--tw-text-opacity:1;color:rgb(241 126 184/var(--tw-text-opacity))}:is(.dark .dark\:text-purple-300){--tw-text-opacity:1;color:rgb(202 191 253/var(--tw-text-opacity))}:is(.dark .dark\:text-purple-400){--tw-text-opacity:1;color:rgb(172 148 250/var(--tw-text-opacity))}:is(.dark .dark\:text-purple-500){--tw-text-opacity:1;color:rgb(144 97 249/var(--tw-text-opacity))}:is(.dark .dark\:text-red-200){--tw-text-opacity:1;color:rgb(251 213 213/var(--tw-text-opacity))}:is(.dark .dark\:text-red-300){--tw-text-opacity:1;color:rgb(248 180 180/var(--tw-text-opacity))}:is(.dark .dark\:text-red-400){--tw-text-opacity:1;color:rgb(249 128 128/var(--tw-text-opacity))}:is(.dark .dark\:text-red-500){--tw-text-opacity:1;color:rgb(240 82 82/var(--tw-text-opacity))}:is(.dark .dark\:text-teal-300){--tw-text-opacity:1;color:rgb(126 220 226/var(--tw-text-opacity))}:is(.dark .dark\:text-white){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .dark\:text-yellow-300){--tw-text-opacity:1;color:rgb(250 202 21/var(--tw-text-opacity))}:is(.dark .dark\:text-yellow-500){--tw-text-opacity:1;color:rgb(194 120 3/var(--tw-text-opacity))}:is(.dark .dark\:decoration-blue-600){text-decoration-color:#1c64f2}:is(.dark .dark\:placeholder-gray-400)::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity))}:is(.dark .dark\:placeholder-gray-400)::placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity))}:is(.dark .dark\:placeholder-green-500)::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(14 159 110/var(--tw-placeholder-opacity))}:is(.dark .dark\:placeholder-green-500)::placeholder{--tw-placeholder-opacity:1;color:rgb(14 159 110/var(--tw-placeholder-opacity))}:is(.dark .dark\:placeholder-red-500)::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(240 82 82/var(--tw-placeholder-opacity))}:is(.dark .dark\:placeholder-red-500)::placeholder{--tw-placeholder-opacity:1;color:rgb(240 82 82/var(--tw-placeholder-opacity))}:is(.dark .dark\:shadow-lg){--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}:is(.dark .dark\:shadow-sm-light){--tw-shadow:0 2px 5px 0px hsla(0,0%,100%,.08);--tw-shadow-colored:0 2px 5px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}:is(.dark .dark\:shadow-blue-800\/80){--tw-shadow-color:rgba(30,66,159,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-cyan-800\/80){--tw-shadow-color:rgba(21,94,117,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-gray-800){--tw-shadow-color:#1f2937;--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-green-800\/80){--tw-shadow-color:rgba(3,84,63,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-lime-800\/80){--tw-shadow-color:rgba(63,98,18,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-pink-800\/80){--tw-shadow-color:rgba(153,21,75,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-purple-800\/80){--tw-shadow-color:rgba(85,33,181,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-red-800\/80){--tw-shadow-color:rgba(155,28,28,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:shadow-teal-800\/80){--tw-shadow-color:rgba(5,80,92,.8);--tw-shadow:var(--tw-shadow-colored)}:is(.dark .dark\:ring-gray-500){--tw-ring-opacity:1;--tw-ring-color:rgb(107 114 128/var(--tw-ring-opacity))}:is(.dark .dark\:ring-gray-900){--tw-ring-opacity:1;--tw-ring-color:rgb(17 24 39/var(--tw-ring-opacity))}:is(.dark .dark\:ring-offset-gray-700){--tw-ring-offset-color:#374151}:is(.dark .dark\:ring-offset-gray-800){--tw-ring-offset-color:#1f2937}:is(.dark .dark\:first-letter\:text-gray-100):first-letter{--tw-text-opacity:1;color:rgb(243 244 246/var(--tw-text-opacity))}:is(.dark .dark\:after\:border-blue-800):after{--tw-border-opacity:1;border-color:rgb(30 66 159/var(--tw-border-opacity));content:var(--tw-content)}:is(.dark .dark\:after\:border-gray-700):after{--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity));content:var(--tw-content)}:is(.dark .dark\:after\:text-gray-500):after{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity));content:var(--tw-content)}:is(.dark .dark\:hover\:border-gray-500:hover){--tw-border-opacity:1;border-color:rgb(107 114 128/var(--tw-border-opacity))}:is(.dark .dark\:hover\:border-gray-600:hover){--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity))}:is(.dark .dark\:hover\:border-gray-700:hover){--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity))}:is(.dark .dark\:hover\:bg-\[\#050708\]\/30:hover){background-color:rgba(5,7,8,.3)}:is(.dark .dark\:hover\:bg-\[\#050708\]\/40:hover){background-color:rgba(5,7,8,.4)}:is(.dark .dark\:hover\:bg-\[\#FF9119\]\/80:hover){background-color:rgba(255,145,25,.8)}:is(.dark .dark\:hover\:bg-blue-500:hover){--tw-bg-opacity:1;background-color:rgb(63 131 248/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-blue-600:hover){--tw-bg-opacity:1;background-color:rgb(28 100 242/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-blue-700:hover){--tw-bg-opacity:1;background-color:rgb(26 86 219/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-blue-800:hover){--tw-bg-opacity:1;background-color:rgb(30 66 159/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-gray-200:hover){--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-gray-500:hover){--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-gray-600:hover){--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-gray-700:hover){--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-gray-800:hover){--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-green-600:hover){--tw-bg-opacity:1;background-color:rgb(5 122 85/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-green-700:hover){--tw-bg-opacity:1;background-color:rgb(4 108 78/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-green-800:hover){--tw-bg-opacity:1;background-color:rgb(3 84 63/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-indigo-800:hover){--tw-bg-opacity:1;background-color:rgb(66 56 157/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-pink-800:hover){--tw-bg-opacity:1;background-color:rgb(153 21 75/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-purple-500:hover){--tw-bg-opacity:1;background-color:rgb(144 97 249/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-purple-700:hover){--tw-bg-opacity:1;background-color:rgb(108 43 217/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-purple-800:hover){--tw-bg-opacity:1;background-color:rgb(85 33 181/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-red-600:hover){--tw-bg-opacity:1;background-color:rgb(224 36 36/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-red-700:hover){--tw-bg-opacity:1;background-color:rgb(200 30 30/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-red-800:hover){--tw-bg-opacity:1;background-color:rgb(155 28 28/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-yellow-300:hover){--tw-bg-opacity:1;background-color:rgb(250 202 21/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-yellow-400:hover){--tw-bg-opacity:1;background-color:rgb(227 160 8/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:bg-yellow-800:hover){--tw-bg-opacity:1;background-color:rgb(114 59 19/var(--tw-bg-opacity))}:is(.dark .dark\:hover\:\!text-blue-500:hover){--tw-text-opacity:1!important;color:rgb(63 131 248/var(--tw-text-opacity))!important}:is(.dark .dark\:hover\:text-blue-300:hover){--tw-text-opacity:1;color:rgb(164 202 254/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-blue-400:hover){--tw-text-opacity:1;color:rgb(118 169 250/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-blue-500:hover){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-blue-600:hover){--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-blue-700:hover){--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-gray-300:hover){--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-gray-400:hover){--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-gray-800:hover){--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-gray-900:hover){--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-green-300:hover){--tw-text-opacity:1;color:rgb(132 225 188/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-indigo-300:hover){--tw-text-opacity:1;color:rgb(180 198 252/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-pink-300:hover){--tw-text-opacity:1;color:rgb(248 180 217/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-purple-300:hover){--tw-text-opacity:1;color:rgb(202 191 253/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-red-300:hover){--tw-text-opacity:1;color:rgb(248 180 180/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-white:hover){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .dark\:hover\:text-yellow-300:hover){--tw-text-opacity:1;color:rgb(250 202 21/var(--tw-text-opacity))}:is(.dark .dark\:hover\:bg-blend-darken:hover){background-blend-mode:darken}:is(.dark .dark\:focus\:border-blue-500:focus){--tw-border-opacity:1;border-color:rgb(63 131 248/var(--tw-border-opacity))}:is(.dark .dark\:focus\:border-green-500:focus){--tw-border-opacity:1;border-color:rgb(14 159 110/var(--tw-border-opacity))}:is(.dark .dark\:focus\:border-red-500:focus){--tw-border-opacity:1;border-color:rgb(240 82 82/var(--tw-border-opacity))}:is(.dark .dark\:focus\:bg-blue-600:focus){--tw-bg-opacity:1;background-color:rgb(28 100 242/var(--tw-bg-opacity))}:is(.dark .dark\:focus\:bg-gray-700:focus){--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}:is(.dark .dark\:focus\:text-white:focus){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .dark\:focus\:ring-\[\#050708\]\/50:focus){--tw-ring-color:rgba(5,7,8,.5)}:is(.dark .dark\:focus\:ring-\[\#2557D6\]\/50:focus){--tw-ring-color:rgba(37,87,214,.5)}:is(.dark .dark\:focus\:ring-\[\#F7BE38\]\/50:focus){--tw-ring-color:rgba(247,190,56,.5)}:is(.dark .dark\:focus\:ring-\[\#FF9119\]\/40:focus){--tw-ring-color:rgba(255,145,25,.4)}:is(.dark .dark\:focus\:ring-blue-500:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(63 131 248/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-blue-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(28 100 242/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-blue-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(30 66 159/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-blue-900:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(35 56 118/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-cyan-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(21 94 117/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-gray-400:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(156 163 175/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-gray-500:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(107 114 128/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-gray-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(75 85 99/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-gray-700:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(55 65 81/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-gray-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(31 41 55/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-green-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(5 122 85/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-green-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(3 84 63/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-lime-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(63 98 18/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-orange-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(208 56 1/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-pink-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(153 21 75/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-purple-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(126 58 242/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-purple-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(85 33 181/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-purple-900:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(74 29 150/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-red-400:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(249 128 128/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-red-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(224 36 36/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-red-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(155 28 28/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-red-900:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(119 29 29/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-teal-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(4 116 129/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-teal-700:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(3 102 114/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-teal-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(5 80 92/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-yellow-600:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(159 88 10/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-yellow-800:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(114 59 19/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-yellow-900:focus){--tw-ring-opacity:1;--tw-ring-color:rgb(99 49 18/var(--tw-ring-opacity))}:is(.dark .dark\:focus\:ring-offset-gray-700:focus){--tw-ring-offset-color:#374151}:is(.dark .dark\:focus\:ring-offset-gray-800:focus){--tw-ring-offset-color:#1f2937}:is(.dark .group:hover .dark\:group-hover\:bg-gray-800\/60){background-color:rgba(31,41,55,.6)}:is(.dark .group:hover .dark\:group-hover\:text-blue-500){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .group:hover .dark\:group-hover\:text-gray-300){--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}:is(.dark .group:hover .dark\:group-hover\:text-white){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .group:focus .dark\:group-focus\:text-white){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .group:focus .dark\:group-focus\:ring-gray-800\/70){--tw-ring-color:rgba(31,41,55,.7)}:is(.dark .peer:checked~.dark\:peer-checked\:text-blue-500){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .peer:checked~.dark\:peer-checked\:text-gray-300){--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}.peer:focus~:is(.dark .peer-focus\:dark\:text-blue-500){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-blue-800){--tw-ring-opacity:1;--tw-ring-color:rgb(30 66 159/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-green-800){--tw-ring-opacity:1;--tw-ring-color:rgb(3 84 63/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-orange-800){--tw-ring-opacity:1;--tw-ring-color:rgb(138 44 13/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-purple-800){--tw-ring-opacity:1;--tw-ring-color:rgb(85 33 181/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-red-800){--tw-ring-opacity:1;--tw-ring-color:rgb(155 28 28/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-teal-800){--tw-ring-opacity:1;--tw-ring-color:rgb(5 80 92/var(--tw-ring-opacity))}:is(.dark .peer:focus~.dark\:peer-focus\:ring-yellow-800){--tw-ring-opacity:1;--tw-ring-color:rgb(114 59 19/var(--tw-ring-opacity))}@media (min-width:640px){.sm\:order-last{order:9999}.sm\:col-span-1{grid-column:span 1/span 1}.sm\:col-span-3{grid-column:span 3/span 3}.sm\:mx-auto{margin-left:auto;margin-right:auto}.sm\:mb-0{margin-bottom:0}.sm\:mb-4{margin-bottom:1rem}.sm\:mb-5{margin-bottom:1.25rem}.sm\:ml-2{margin-left:.5rem}.sm\:ml-4{margin-left:1rem}.sm\:ml-64{margin-left:16rem}.sm\:ml-auto{margin-left:auto}.sm\:mt-0{margin-top:0}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:inline-flex{display:inline-flex}.sm\:grid{display:grid}.sm\:hidden{display:none}.sm\:h-4{height:1rem}.sm\:h-64{height:16rem}.sm\:h-7{height:1.75rem}.sm\:h-9{height:2.25rem}.sm\:h-96{height:24rem}.sm\:w-4{width:1rem}.sm\:w-96{width:24rem}.sm\:w-auto{width:auto}.sm\:translate-x-0{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-center{justify-content:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-6{gap:1.5rem}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:divide-x>:not([hidden])~:not([hidden]){--tw-divide-x-reverse:0;border-left-width:calc(1px*(1 - var(--tw-divide-x-reverse)));border-right-width:calc(1px*var(--tw-divide-x-reverse))}.sm\:rounded-lg{border-radius:.5rem}.sm\:border-b-0{border-bottom-width:0}.sm\:border-r{border-right-width:1px}.sm\:p-4{padding:1rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:px-16{padding-left:4rem;padding-right:4rem}.sm\:px-4{padding-left:1rem;padding-right:1rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:py-16{padding-bottom:4rem;padding-top:4rem}.sm\:py-4{padding-top:1rem}.sm\:pb-4,.sm\:py-4{padding-bottom:1rem}.sm\:pl-2{padding-left:.5rem}.sm\:pl-4{padding-left:1rem}.sm\:pr-4{padding-right:1rem}.sm\:pr-8{padding-right:2rem}.sm\:pt-4{padding-top:1rem}.sm\:text-center{text-align:center}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}.sm\:text-xs{font-size:.75rem;line-height:1rem}.sm\:ring-8{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(8px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.sm\:after\:inline-block:after{content:var(--tw-content);display:inline-block}.sm\:after\:hidden:after{content:var(--tw-content);display:none}.sm\:after\:content-\[\'\'\]:after{--tw-content:"";content:var(--tw-content)}}@media (min-width:768px){.md\:relative{position:relative}.md\:inset-0{inset:0}.md\:right-auto{right:auto}.md\:top-auto{top:auto}.md\:order-1{order:1}.md\:order-2{order:2}.md\:m-0{margin:0}.md\:mx-2{margin-left:.5rem;margin-right:.5rem}.md\:my-0{margin-bottom:0;margin-top:0}.md\:my-10{margin-bottom:2.5rem;margin-top:2.5rem}.md\:my-12{margin-bottom:3rem;margin-top:3rem}.md\:mb-0{margin-bottom:0}.md\:mb-12{margin-bottom:3rem}.md\:ml-1{margin-left:.25rem}.md\:ml-2{margin-left:.5rem}.md\:mr-0{margin-right:0}.md\:mr-2{margin-right:.5rem}.md\:mr-24{margin-right:6rem}.md\:mr-4{margin-right:1rem}.md\:mr-6{margin-right:1.5rem}.md\:mt-0{margin-top:0}.md\:mt-6{margin-top:1.5rem}.md\:block{display:block}.md\:inline{display:inline}.md\:flex{display:flex}.md\:inline-flex{display:inline-flex}.md\:grid{display:grid}.md\:hidden{display:none}.md\:h-96{height:24rem}.md\:h-\[21px\]{height:21px}.md\:h-\[262px\]{height:262px}.md\:h-\[278px\]{height:278px}.md\:h-\[294px\]{height:294px}.md\:h-\[42px\]{height:42px}.md\:h-\[654px\]{height:654px}.md\:h-\[682px\]{height:682px}.md\:h-\[8px\]{height:8px}.md\:h-\[95px\]{height:95px}.md\:h-auto{height:auto}.md\:w-48{width:12rem}.md\:w-64{width:16rem}.md\:w-\[96px\]{width:96px}.md\:w-auto{width:auto}.md\:w-full{width:100%}.md\:max-w-\[142px\]{max-width:142px}.md\:max-w-\[512px\]{max-width:512px}.md\:max-w-\[597px\]{max-width:597px}.md\:max-w-screen-md{max-width:768px}.md\:max-w-xl{max-width:36rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:gap-12{gap:3rem}.md\:gap-6{gap:1.5rem}.md\:gap-8{gap:2rem}.md\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.md\:space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.md\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.md\:space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.md\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.md\:rounded-none{border-radius:0}.md\:rounded-l-lg{border-bottom-left-radius:.5rem;border-top-left-radius:.5rem}.md\:rounded-t-none{border-top-left-radius:0;border-top-right-radius:0}.md\:rounded-br-lg{border-bottom-right-radius:.5rem}.md\:rounded-tl-lg{border-top-left-radius:.5rem}.md\:border-0{border-width:0}.md\:border-b-0{border-bottom-width:0}.md\:border-r{border-right-width:1px}.md\:bg-transparent{background-color:transparent}.md\:bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.md\:p-0{padding:0}.md\:p-12{padding:3rem}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:px-5{padding-left:1.25rem;padding-right:1.25rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:py-2{padding-bottom:.5rem;padding-top:.5rem}.md\:py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.md\:py-8{padding-bottom:2rem;padding-top:2rem}.md\:pb-0{padding-bottom:0}.md\:pb-4{padding-bottom:1rem}.md\:pr-4{padding-right:1rem}.md\:pt-0{padding-top:0}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:font-medium{font-weight:500}.md\:text-blue-700{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.md\:text-green-700{--tw-text-opacity:1;color:rgb(4 108 78/var(--tw-text-opacity))}.md\:hover\:bg-transparent:hover{background-color:transparent}.md\:hover\:text-blue-600:hover{--tw-text-opacity:1;color:rgb(28 100 242/var(--tw-text-opacity))}.md\:hover\:text-blue-700:hover{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.md\:hover\:text-green-700:hover{--tw-text-opacity:1;color:rgb(4 108 78/var(--tw-text-opacity))}:is(.dark .md\:dark\:bg-gray-900){--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}:is(.dark .md\:dark\:bg-transparent){background-color:transparent}:is(.dark .md\:dark\:text-blue-500){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .md\:dark\:text-white){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}:is(.dark .md\:dark\:hover\:bg-transparent:hover){background-color:transparent}:is(.dark .md\:dark\:hover\:text-blue-500:hover){--tw-text-opacity:1;color:rgb(63 131 248/var(--tw-text-opacity))}:is(.dark .md\:dark\:hover\:text-white:hover){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}}@media (min-width:1024px){.lg\:static{position:static}.lg\:sticky{position:sticky}.lg\:top-28{top:7rem}.lg\:order-1{order:1}.lg\:order-2{order:2}.lg\:col-span-5{grid-column:span 5/span 5}.lg\:col-span-7{grid-column:span 7/span 7}.lg\:my-12{margin-bottom:3rem;margin-top:3rem}.lg\:my-8{margin-bottom:2rem;margin-top:2rem}.lg\:mb-0{margin-bottom:0}.lg\:mb-16{margin-bottom:4rem}.lg\:mb-8{margin-bottom:2rem}.lg\:mr-0{margin-right:0}.lg\:mt-0{margin-top:0}.lg\:mt-10{margin-top:2.5rem}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid{display:grid}.lg\:hidden{display:none}.lg\:h-12{height:3rem}.lg\:h-4{height:1rem}.lg\:h-5{height:1.25rem}.lg\:h-6{height:1.5rem}.lg\:h-\[calc\(100vh-3rem\)\]{height:calc(100vh - 3rem)}.lg\:h-auto{height:auto}.lg\:max-h-full{max-height:100%}.lg\:w-12{width:3rem}.lg\:w-4{width:1rem}.lg\:w-48{width:12rem}.lg\:w-5{width:1.25rem}.lg\:w-6{width:1.5rem}.lg\:w-96{width:24rem}.lg\:w-auto{width:auto}.lg\:max-w-7xl{max-width:80rem}.lg\:max-w-screen-lg{max-width:1024px}.lg\:max-w-xl{max-width:36rem}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:gap-16{gap:4rem}.lg\:gap-8{gap:2rem}.lg\:space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.lg\:self-center{align-self:center}.lg\:overflow-visible{overflow:visible}.lg\:overflow-y-visible{overflow-y:visible}.lg\:border-0{border-width:0}.lg\:bg-transparent{background-color:transparent}.lg\:p-0{padding:0}.lg\:p-8{padding:2rem}.lg\:px-12{padding-left:3rem;padding-right:3rem}.lg\:px-2{padding-left:.5rem;padding-right:.5rem}.lg\:px-36{padding-left:9rem;padding-right:9rem}.lg\:px-4{padding-left:1rem;padding-right:1rem}.lg\:px-48{padding-left:12rem;padding-right:12rem}.lg\:px-5{padding-left:1.25rem;padding-right:1.25rem}.lg\:px-6{padding-left:1.5rem;padding-right:1.5rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-0{padding-bottom:0;padding-top:0}.lg\:py-16{padding-bottom:4rem;padding-top:4rem}.lg\:py-2{padding-bottom:.5rem;padding-top:.5rem}.lg\:py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.lg\:py-4{padding-bottom:1rem;padding-top:1rem}.lg\:py-56{padding-bottom:14rem;padding-top:14rem}.lg\:py-8{padding-bottom:2rem;padding-top:2rem}.lg\:pb-16{padding-bottom:4rem}.lg\:pb-20{padding-bottom:5rem}.lg\:pl-0{padding-left:0}.lg\:pl-3{padding-left:.75rem}.lg\:pt-0{padding-top:0}.lg\:pt-2{padding-top:.5rem}.lg\:pt-8{padding-top:2rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-6xl{font-size:3.75rem;line-height:1}.lg\:text-sm{font-size:.875rem;line-height:1.25rem}.lg\:text-xl{font-size:1.25rem;line-height:1.75rem}.lg\:text-xs{font-size:.75rem;line-height:1rem}.lg\:text-blue-700{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}.lg\:hover\:bg-transparent:hover{background-color:transparent}.lg\:hover\:text-blue-700:hover{--tw-text-opacity:1;color:rgb(26 86 219/var(--tw-text-opacity))}:is(.dark .lg\:dark\:hover\:bg-transparent:hover){background-color:transparent}:is(.dark .lg\:dark\:hover\:text-white:hover){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}}@media (min-width:1280px){.xl\:ml-16{margin-left:4rem}.xl\:block{display:block}.xl\:inline-flex{display:inline-flex}.xl\:hidden{display:none}.xl\:h-80{height:20rem}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:gap-0{gap:0}.xl\:gap-16{gap:4rem}.xl\:gap-24{gap:6rem}.xl\:px-2{padding-left:.5rem;padding-right:.5rem}.xl\:px-48{padding-left:12rem;padding-right:12rem}.xl\:pb-24{padding-bottom:6rem}.xl\:pl-4{padding-left:1rem}.xl\:pt-24{padding-top:6rem}.xl\:text-6xl{font-size:3.75rem;line-height:1}.xl\:text-sm{font-size:.875rem;line-height:1.25rem}.xl\:after\:mx-10:after{content:var(--tw-content);margin-left:2.5rem;margin-right:2.5rem}}@media (min-width:1536px){.\32xl\:block{display:block}.\32xl\:h-96{height:24rem}.\32xl\:grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.\32xl\:gap-x-2{-moz-column-gap:.5rem;column-gap:.5rem}.\32xl\:space-x-0>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(0px*(1 - var(--tw-space-x-reverse)));margin-right:calc(0px*var(--tw-space-x-reverse))}}.\[\&\>div\]\:mx-auto>div{margin-left:auto;margin-right:auto} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.min.js b/node_modules/flowbite/dist/flowbite.min.js new file mode 100644 index 0000000..cd4e4a1 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.min.js @@ -0,0 +1,2 @@ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("Flowbite",[],e):"object"==typeof exports?exports.Flowbite=e():t.Flowbite=e()}(self,(function(){return function(){"use strict";var t={647:function(t,e,i){i.r(e)},853:function(t,e,i){i.r(e),i.d(e,{afterMain:function(){return E},afterRead:function(){return _},afterWrite:function(){return x},applyStyles:function(){return S},arrow:function(){return Z},auto:function(){return a},basePlacements:function(){return c},beforeMain:function(){return b},beforeRead:function(){return m},beforeWrite:function(){return L},bottom:function(){return o},clippingParents:function(){return u},computeStyles:function(){return it},createPopper:function(){return St},createPopperBase:function(){return Pt},createPopperLite:function(){return Dt},detectOverflow:function(){return yt},end:function(){return d},eventListeners:function(){return ot},flip:function(){return _t},hide:function(){return Et},left:function(){return s},main:function(){return w},modifierPhases:function(){return k},offset:function(){return Lt},placements:function(){return v},popper:function(){return f},popperGenerator:function(){return jt},popperOffsets:function(){return Ot},preventOverflow:function(){return xt},read:function(){return y},reference:function(){return h},right:function(){return r},start:function(){return l},top:function(){return n},variationPlacements:function(){return g},viewport:function(){return p},write:function(){return O}});var n="top",o="bottom",r="right",s="left",a="auto",c=[n,o,r,s],l="start",d="end",u="clippingParents",p="viewport",f="popper",h="reference",g=c.reduce((function(t,e){return t.concat([e+"-"+l,e+"-"+d])}),[]),v=[].concat(c,[a]).reduce((function(t,e){return t.concat([e,e+"-"+l,e+"-"+d])}),[]),m="beforeRead",y="read",_="afterRead",b="beforeMain",w="main",E="afterMain",L="beforeWrite",O="write",x="afterWrite",k=[m,y,_,b,w,E,L,O,x];function A(t){return t?(t.nodeName||"").toLowerCase():null}function T(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function C(t){return t instanceof T(t).Element||t instanceof Element}function j(t){return t instanceof T(t).HTMLElement||t instanceof HTMLElement}function P(t){return"undefined"!=typeof ShadowRoot&&(t instanceof T(t).ShadowRoot||t instanceof ShadowRoot)}var S={name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var i=e.styles[t]||{},n=e.attributes[t]||{},o=e.elements[t];j(o)&&A(o)&&(Object.assign(o.style,i),Object.keys(n).forEach((function(t){var e=n[t];!1===e?o.removeAttribute(t):o.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,i={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,i.popper),e.styles=i,e.elements.arrow&&Object.assign(e.elements.arrow.style,i.arrow),function(){Object.keys(e.elements).forEach((function(t){var n=e.elements[t],o=e.attributes[t]||{},r=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:i[t]).reduce((function(t,e){return t[e]="",t}),{});j(n)&&A(n)&&(Object.assign(n.style,r),Object.keys(o).forEach((function(t){n.removeAttribute(t)})))}))}},requires:["computeStyles"]};function D(t){return t.split("-")[0]}var I=Math.max,M=Math.min,q=Math.round;function H(){var t=navigator.userAgentData;return null!=t&&t.brands?t.brands.map((function(t){return t.brand+"/"+t.version})).join(" "):navigator.userAgent}function B(){return!/^((?!chrome|android).)*safari/i.test(H())}function V(t,e,i){void 0===e&&(e=!1),void 0===i&&(i=!1);var n=t.getBoundingClientRect(),o=1,r=1;e&&j(t)&&(o=t.offsetWidth>0&&q(n.width)/t.offsetWidth||1,r=t.offsetHeight>0&&q(n.height)/t.offsetHeight||1);var s=(C(t)?T(t):window).visualViewport,a=!B()&&i,c=(n.left+(a&&s?s.offsetLeft:0))/o,l=(n.top+(a&&s?s.offsetTop:0))/r,d=n.width/o,u=n.height/r;return{width:d,height:u,top:l,right:c+d,bottom:l+u,left:c,x:c,y:l}}function W(t){var e=V(t),i=t.offsetWidth,n=t.offsetHeight;return Math.abs(e.width-i)<=1&&(i=e.width),Math.abs(e.height-n)<=1&&(n=e.height),{x:t.offsetLeft,y:t.offsetTop,width:i,height:n}}function z(t,e){var i=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(i&&P(i)){var n=e;do{if(n&&t.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function R(t){return T(t).getComputedStyle(t)}function F(t){return["table","td","th"].indexOf(A(t))>=0}function N(t){return((C(t)?t.ownerDocument:t.document)||window.document).documentElement}function K(t){return"html"===A(t)?t:t.assignedSlot||t.parentNode||(P(t)?t.host:null)||N(t)}function U(t){return j(t)&&"fixed"!==R(t).position?t.offsetParent:null}function X(t){for(var e=T(t),i=U(t);i&&F(i)&&"static"===R(i).position;)i=U(i);return i&&("html"===A(i)||"body"===A(i)&&"static"===R(i).position)?e:i||function(t){var e=/firefox/i.test(H());if(/Trident/i.test(H())&&j(t)&&"fixed"===R(t).position)return null;var i=K(t);for(P(i)&&(i=i.host);j(i)&&["html","body"].indexOf(A(i))<0;){var n=R(i);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||e&&"filter"===n.willChange||e&&n.filter&&"none"!==n.filter)return i;i=i.parentNode}return null}(t)||e}function Y(t){return["top","bottom"].indexOf(t)>=0?"x":"y"}function G(t,e,i){return I(t,M(e,i))}function J(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function Q(t,e){return e.reduce((function(e,i){return e[i]=t,e}),{})}var Z={name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,i=t.state,a=t.name,l=t.options,d=i.elements.arrow,u=i.modifiersData.popperOffsets,p=D(i.placement),f=Y(p),h=[s,r].indexOf(p)>=0?"height":"width";if(d&&u){var g=function(t,e){return J("number"!=typeof(t="function"==typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:Q(t,c))}(l.padding,i),v=W(d),m="y"===f?n:s,y="y"===f?o:r,_=i.rects.reference[h]+i.rects.reference[f]-u[f]-i.rects.popper[h],b=u[f]-i.rects.reference[f],w=X(d),E=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,L=_/2-b/2,O=g[m],x=E-v[h]-g[y],k=E/2-v[h]/2+L,A=G(O,k,x),T=f;i.modifiersData[a]=((e={})[T]=A,e.centerOffset=A-k,e)}},effect:function(t){var e=t.state,i=t.options.element,n=void 0===i?"[data-popper-arrow]":i;null!=n&&("string"!=typeof n||(n=e.elements.popper.querySelector(n)))&&z(e.elements.popper,n)&&(e.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function $(t){return t.split("-")[1]}var tt={top:"auto",right:"auto",bottom:"auto",left:"auto"};function et(t){var e,i=t.popper,a=t.popperRect,c=t.placement,l=t.variation,u=t.offsets,p=t.position,f=t.gpuAcceleration,h=t.adaptive,g=t.roundOffsets,v=t.isFixed,m=u.x,y=void 0===m?0:m,_=u.y,b=void 0===_?0:_,w="function"==typeof g?g({x:y,y:b}):{x:y,y:b};y=w.x,b=w.y;var E=u.hasOwnProperty("x"),L=u.hasOwnProperty("y"),O=s,x=n,k=window;if(h){var A=X(i),C="clientHeight",j="clientWidth";if(A===T(i)&&"static"!==R(A=N(i)).position&&"absolute"===p&&(C="scrollHeight",j="scrollWidth"),c===n||(c===s||c===r)&&l===d)x=o,b-=(v&&A===k&&k.visualViewport?k.visualViewport.height:A[C])-a.height,b*=f?1:-1;if(c===s||(c===n||c===o)&&l===d)O=r,y-=(v&&A===k&&k.visualViewport?k.visualViewport.width:A[j])-a.width,y*=f?1:-1}var P,S=Object.assign({position:p},h&&tt),D=!0===g?function(t){var e=t.x,i=t.y,n=window.devicePixelRatio||1;return{x:q(e*n)/n||0,y:q(i*n)/n||0}}({x:y,y:b}):{x:y,y:b};return y=D.x,b=D.y,f?Object.assign({},S,((P={})[x]=L?"0":"",P[O]=E?"0":"",P.transform=(k.devicePixelRatio||1)<=1?"translate("+y+"px, "+b+"px)":"translate3d("+y+"px, "+b+"px, 0)",P)):Object.assign({},S,((e={})[x]=L?b+"px":"",e[O]=E?y+"px":"",e.transform="",e))}var it={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,i=t.options,n=i.gpuAcceleration,o=void 0===n||n,r=i.adaptive,s=void 0===r||r,a=i.roundOffsets,c=void 0===a||a,l={placement:D(e.placement),variation:$(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:o,isFixed:"fixed"===e.options.strategy};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,et(Object.assign({},l,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:s,roundOffsets:c})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,et(Object.assign({},l,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:c})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}},nt={passive:!0};var ot={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(t){var e=t.state,i=t.instance,n=t.options,o=n.scroll,r=void 0===o||o,s=n.resize,a=void 0===s||s,c=T(e.elements.popper),l=[].concat(e.scrollParents.reference,e.scrollParents.popper);return r&&l.forEach((function(t){t.addEventListener("scroll",i.update,nt)})),a&&c.addEventListener("resize",i.update,nt),function(){r&&l.forEach((function(t){t.removeEventListener("scroll",i.update,nt)})),a&&c.removeEventListener("resize",i.update,nt)}},data:{}},rt={left:"right",right:"left",bottom:"top",top:"bottom"};function st(t){return t.replace(/left|right|bottom|top/g,(function(t){return rt[t]}))}var at={start:"end",end:"start"};function ct(t){return t.replace(/start|end/g,(function(t){return at[t]}))}function lt(t){var e=T(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function dt(t){return V(N(t)).left+lt(t).scrollLeft}function ut(t){var e=R(t),i=e.overflow,n=e.overflowX,o=e.overflowY;return/auto|scroll|overlay|hidden/.test(i+o+n)}function pt(t){return["html","body","#document"].indexOf(A(t))>=0?t.ownerDocument.body:j(t)&&ut(t)?t:pt(K(t))}function ft(t,e){var i;void 0===e&&(e=[]);var n=pt(t),o=n===(null==(i=t.ownerDocument)?void 0:i.body),r=T(n),s=o?[r].concat(r.visualViewport||[],ut(n)?n:[]):n,a=e.concat(s);return o?a:a.concat(ft(K(s)))}function ht(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function gt(t,e,i){return e===p?ht(function(t,e){var i=T(t),n=N(t),o=i.visualViewport,r=n.clientWidth,s=n.clientHeight,a=0,c=0;if(o){r=o.width,s=o.height;var l=B();(l||!l&&"fixed"===e)&&(a=o.offsetLeft,c=o.offsetTop)}return{width:r,height:s,x:a+dt(t),y:c}}(t,i)):C(e)?function(t,e){var i=V(t,!1,"fixed"===e);return i.top=i.top+t.clientTop,i.left=i.left+t.clientLeft,i.bottom=i.top+t.clientHeight,i.right=i.left+t.clientWidth,i.width=t.clientWidth,i.height=t.clientHeight,i.x=i.left,i.y=i.top,i}(e,i):ht(function(t){var e,i=N(t),n=lt(t),o=null==(e=t.ownerDocument)?void 0:e.body,r=I(i.scrollWidth,i.clientWidth,o?o.scrollWidth:0,o?o.clientWidth:0),s=I(i.scrollHeight,i.clientHeight,o?o.scrollHeight:0,o?o.clientHeight:0),a=-n.scrollLeft+dt(t),c=-n.scrollTop;return"rtl"===R(o||i).direction&&(a+=I(i.clientWidth,o?o.clientWidth:0)-r),{width:r,height:s,x:a,y:c}}(N(t)))}function vt(t,e,i,n){var o="clippingParents"===e?function(t){var e=ft(K(t)),i=["absolute","fixed"].indexOf(R(t).position)>=0&&j(t)?X(t):t;return C(i)?e.filter((function(t){return C(t)&&z(t,i)&&"body"!==A(t)})):[]}(t):[].concat(e),r=[].concat(o,[i]),s=r[0],a=r.reduce((function(e,i){var o=gt(t,i,n);return e.top=I(o.top,e.top),e.right=M(o.right,e.right),e.bottom=M(o.bottom,e.bottom),e.left=I(o.left,e.left),e}),gt(t,s,n));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}function mt(t){var e,i=t.reference,a=t.element,c=t.placement,u=c?D(c):null,p=c?$(c):null,f=i.x+i.width/2-a.width/2,h=i.y+i.height/2-a.height/2;switch(u){case n:e={x:f,y:i.y-a.height};break;case o:e={x:f,y:i.y+i.height};break;case r:e={x:i.x+i.width,y:h};break;case s:e={x:i.x-a.width,y:h};break;default:e={x:i.x,y:i.y}}var g=u?Y(u):null;if(null!=g){var v="y"===g?"height":"width";switch(p){case l:e[g]=e[g]-(i[v]/2-a[v]/2);break;case d:e[g]=e[g]+(i[v]/2-a[v]/2)}}return e}function yt(t,e){void 0===e&&(e={});var i=e,s=i.placement,a=void 0===s?t.placement:s,l=i.strategy,d=void 0===l?t.strategy:l,g=i.boundary,v=void 0===g?u:g,m=i.rootBoundary,y=void 0===m?p:m,_=i.elementContext,b=void 0===_?f:_,w=i.altBoundary,E=void 0!==w&&w,L=i.padding,O=void 0===L?0:L,x=J("number"!=typeof O?O:Q(O,c)),k=b===f?h:f,A=t.rects.popper,T=t.elements[E?k:b],j=vt(C(T)?T:T.contextElement||N(t.elements.popper),v,y,d),P=V(t.elements.reference),S=mt({reference:P,element:A,strategy:"absolute",placement:a}),D=ht(Object.assign({},A,S)),I=b===f?D:P,M={top:j.top-I.top+x.top,bottom:I.bottom-j.bottom+x.bottom,left:j.left-I.left+x.left,right:I.right-j.right+x.right},q=t.modifiersData.offset;if(b===f&&q){var H=q[a];Object.keys(M).forEach((function(t){var e=[r,o].indexOf(t)>=0?1:-1,i=[n,o].indexOf(t)>=0?"y":"x";M[t]+=H[i]*e}))}return M}var _t={name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,d=t.name;if(!e.modifiersData[d]._skip){for(var u=i.mainAxis,p=void 0===u||u,f=i.altAxis,h=void 0===f||f,m=i.fallbackPlacements,y=i.padding,_=i.boundary,b=i.rootBoundary,w=i.altBoundary,E=i.flipVariations,L=void 0===E||E,O=i.allowedAutoPlacements,x=e.options.placement,k=D(x),A=m||(k===x||!L?[st(x)]:function(t){if(D(t)===a)return[];var e=st(t);return[ct(t),e,ct(e)]}(x)),T=[x].concat(A).reduce((function(t,i){return t.concat(D(i)===a?function(t,e){void 0===e&&(e={});var i=e,n=i.placement,o=i.boundary,r=i.rootBoundary,s=i.padding,a=i.flipVariations,l=i.allowedAutoPlacements,d=void 0===l?v:l,u=$(n),p=u?a?g:g.filter((function(t){return $(t)===u})):c,f=p.filter((function(t){return d.indexOf(t)>=0}));0===f.length&&(f=p);var h=f.reduce((function(e,i){return e[i]=yt(t,{placement:i,boundary:o,rootBoundary:r,padding:s})[D(i)],e}),{});return Object.keys(h).sort((function(t,e){return h[t]-h[e]}))}(e,{placement:i,boundary:_,rootBoundary:b,padding:y,flipVariations:L,allowedAutoPlacements:O}):i)}),[]),C=e.rects.reference,j=e.rects.popper,P=new Map,S=!0,I=T[0],M=0;M=0,W=V?"width":"height",z=yt(e,{placement:q,boundary:_,rootBoundary:b,altBoundary:w,padding:y}),R=V?B?r:s:B?o:n;C[W]>j[W]&&(R=st(R));var F=st(R),N=[];if(p&&N.push(z[H]<=0),h&&N.push(z[R]<=0,z[F]<=0),N.every((function(t){return t}))){I=q,S=!1;break}P.set(q,N)}if(S)for(var K=function(t){var e=T.find((function(e){var i=P.get(e);if(i)return i.slice(0,t).every((function(t){return t}))}));if(e)return I=e,"break"},U=L?3:1;U>0;U--){if("break"===K(U))break}e.placement!==I&&(e.modifiersData[d]._skip=!0,e.placement=I,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}};function bt(t,e,i){return void 0===i&&(i={x:0,y:0}),{top:t.top-e.height-i.y,right:t.right-e.width+i.x,bottom:t.bottom-e.height+i.y,left:t.left-e.width-i.x}}function wt(t){return[n,r,o,s].some((function(e){return t[e]>=0}))}var Et={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,i=t.name,n=e.rects.reference,o=e.rects.popper,r=e.modifiersData.preventOverflow,s=yt(e,{elementContext:"reference"}),a=yt(e,{altBoundary:!0}),c=bt(s,n),l=bt(a,o,r),d=wt(c),u=wt(l);e.modifiersData[i]={referenceClippingOffsets:c,popperEscapeOffsets:l,isReferenceHidden:d,hasPopperEscaped:u},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":d,"data-popper-escaped":u})}};var Lt={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,i=t.options,o=t.name,a=i.offset,c=void 0===a?[0,0]:a,l=v.reduce((function(t,i){return t[i]=function(t,e,i){var o=D(t),a=[s,n].indexOf(o)>=0?-1:1,c="function"==typeof i?i(Object.assign({},e,{placement:t})):i,l=c[0],d=c[1];return l=l||0,d=(d||0)*a,[s,r].indexOf(o)>=0?{x:d,y:l}:{x:l,y:d}}(i,e.rects,c),t}),{}),d=l[e.placement],u=d.x,p=d.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=u,e.modifiersData.popperOffsets.y+=p),e.modifiersData[o]=l}};var Ot={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,i=t.name;e.modifiersData[i]=mt({reference:e.rects.reference,element:e.rects.popper,strategy:"absolute",placement:e.placement})},data:{}};var xt={name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,a=t.name,c=i.mainAxis,d=void 0===c||c,u=i.altAxis,p=void 0!==u&&u,f=i.boundary,h=i.rootBoundary,g=i.altBoundary,v=i.padding,m=i.tether,y=void 0===m||m,_=i.tetherOffset,b=void 0===_?0:_,w=yt(e,{boundary:f,rootBoundary:h,padding:v,altBoundary:g}),E=D(e.placement),L=$(e.placement),O=!L,x=Y(E),k="x"===x?"y":"x",A=e.modifiersData.popperOffsets,T=e.rects.reference,C=e.rects.popper,j="function"==typeof b?b(Object.assign({},e.rects,{placement:e.placement})):b,P="number"==typeof j?{mainAxis:j,altAxis:j}:Object.assign({mainAxis:0,altAxis:0},j),S=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,q={x:0,y:0};if(A){if(d){var H,B="y"===x?n:s,V="y"===x?o:r,z="y"===x?"height":"width",R=A[x],F=R+w[B],N=R-w[V],K=y?-C[z]/2:0,U=L===l?T[z]:C[z],J=L===l?-C[z]:-T[z],Q=e.elements.arrow,Z=y&&Q?W(Q):{width:0,height:0},tt=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},et=tt[B],it=tt[V],nt=G(0,T[z],Z[z]),ot=O?T[z]/2-K-nt-et-P.mainAxis:U-nt-et-P.mainAxis,rt=O?-T[z]/2+K+nt+it+P.mainAxis:J+nt+it+P.mainAxis,st=e.elements.arrow&&X(e.elements.arrow),at=st?"y"===x?st.clientTop||0:st.clientLeft||0:0,ct=null!=(H=null==S?void 0:S[x])?H:0,lt=R+rt-ct,dt=G(y?M(F,R+ot-ct-at):F,R,y?I(N,lt):N);A[x]=dt,q[x]=dt-R}if(p){var ut,pt="x"===x?n:s,ft="x"===x?o:r,ht=A[k],gt="y"===k?"height":"width",vt=ht+w[pt],mt=ht-w[ft],_t=-1!==[n,s].indexOf(E),bt=null!=(ut=null==S?void 0:S[k])?ut:0,wt=_t?vt:ht-T[gt]-C[gt]-bt+P.altAxis,Et=_t?ht+T[gt]+C[gt]-bt-P.altAxis:mt,Lt=y&&_t?function(t,e,i){var n=G(t,e,i);return n>i?i:n}(wt,ht,Et):G(y?wt:vt,ht,y?Et:mt);A[k]=Lt,q[k]=Lt-ht}e.modifiersData[a]=q}},requiresIfExists:["offset"]};function kt(t,e,i){void 0===i&&(i=!1);var n,o,r=j(e),s=j(e)&&function(t){var e=t.getBoundingClientRect(),i=q(e.width)/t.offsetWidth||1,n=q(e.height)/t.offsetHeight||1;return 1!==i||1!==n}(e),a=N(e),c=V(t,s,i),l={scrollLeft:0,scrollTop:0},d={x:0,y:0};return(r||!r&&!i)&&(("body"!==A(e)||ut(a))&&(l=(n=e)!==T(n)&&j(n)?{scrollLeft:(o=n).scrollLeft,scrollTop:o.scrollTop}:lt(n)),j(e)?((d=V(e,!0)).x+=e.clientLeft,d.y+=e.clientTop):a&&(d.x=dt(a))),{x:c.left+l.scrollLeft-d.x,y:c.top+l.scrollTop-d.y,width:c.width,height:c.height}}function At(t){var e=new Map,i=new Set,n=[];function o(t){i.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!i.has(t)){var n=e.get(t);n&&o(n)}})),n.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){i.has(t.name)||o(t)})),n}var Tt={placement:"bottom",modifiers:[],strategy:"absolute"};function Ct(){for(var t=arguments.length,e=new Array(t),i=0;i 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import './flowbite.css';\n\n// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst events = new Events('load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nevents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":["root","factory","exports","module","define","amd","self","bottom","right","left","auto","basePlacements","start","end","clippingParents","viewport","popper","reference","variationPlacements","reduce","acc","placement","concat","beforeRead","read","afterRead","beforeMain","main","afterMain","beforeWrite","write","afterWrite","modifierPhases","getNodeName","element","nodeName","toLowerCase","getWindow","node","window","toString","ownerDocument","defaultView","isElement","Element","isHTMLElement","HTMLElement","isShadowRoot","ShadowRoot","name","enabled","phase","fn","_ref","state","Object","keys","elements","forEach","style","styles","attributes","assign","value","removeAttribute","setAttribute","effect","_ref2","initialStyles","position","options","strategy","top","margin","arrow","hasOwnProperty","property","attribute","requires","getBasePlacement","split","Math","max","min","round","getUAString","uaData","navigator","userAgentData","brands","map","item","brand","version","join","userAgent","isLayoutViewport","test","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scaleX","scaleY","offsetWidth","width","offsetHeight","height","visualViewport","addVisualOffsets","x","offsetLeft","y","offsetTop","getLayoutRect","abs","contains","parent","child","rootNode","getRootNode","next","isSameNode","parentNode","host","getComputedStyle","isTableElement","indexOf","getDocumentElement","document","documentElement","getParentNode","assignedSlot","getTrueOffsetParent","offsetParent","getOffsetParent","isFirefox","currentNode","css","transform","perspective","contain","willChange","filter","getContainingBlock","getMainAxisFromPlacement","within","mergePaddingObject","paddingObject","expandToHashMap","hashMap","key","_state$modifiersData$","arrowElement","popperOffsets","modifiersData","basePlacement","axis","len","padding","rects","toPaddingObject","arrowRect","minProp","maxProp","endDiff","startDiff","arrowOffsetParent","clientSize","clientHeight","clientWidth","centerToReference","center","offset","axisProp","centerOffset","_options$element","querySelector","requiresIfExists","getVariation","unsetSides","mapToStyles","_Object$assign2","popperRect","variation","offsets","gpuAcceleration","adaptive","roundOffsets","isFixed","_offsets$x","_offsets$y","_ref3","hasX","hasY","sideX","sideY","win","heightProp","widthProp","_Object$assign","commonStyles","_ref4","dpr","devicePixelRatio","roundOffsetsByDPR","_ref5","_options$gpuAccelerat","_options$adaptive","_options$roundOffsets","data","passive","instance","_options$scroll","scroll","_options$resize","resize","scrollParents","scrollParent","addEventListener","update","removeEventListener","hash","getOppositePlacement","replace","matched","getOppositeVariationPlacement","getWindowScroll","scrollLeft","pageXOffset","scrollTop","pageYOffset","getWindowScrollBarX","isScrollParent","_getComputedStyle","overflow","overflowX","overflowY","getScrollParent","body","listScrollParents","list","_element$ownerDocumen","isBody","target","updatedList","rectToClientRect","rect","getClientRectFromMixedType","clippingParent","html","layoutViewport","getViewportRect","clientTop","clientLeft","getInnerBoundingClientRect","winScroll","scrollWidth","scrollHeight","direction","getDocumentRect","getClippingRect","boundary","rootBoundary","mainClippingParents","clipperElement","getClippingParents","firstClippingParent","clippingRect","accRect","computeOffsets","commonX","commonY","mainAxis","detectOverflow","_options","_options$placement","_options$strategy","_options$boundary","_options$rootBoundary","_options$elementConte","elementContext","_options$altBoundary","altBoundary","_options$padding","altContext","clippingClientRect","contextElement","referenceClientRect","popperClientRect","elementClientRect","overflowOffsets","offsetData","multiply","_skip","_options$mainAxis","checkMainAxis","_options$altAxis","altAxis","checkAltAxis","specifiedFallbackPlacements","fallbackPlacements","_options$flipVariatio","flipVariations","allowedAutoPlacements","preferredPlacement","oppositePlacement","getExpandedFallbackPlacements","placements","_options$allowedAutoP","allowedPlacements","length","overflows","sort","a","b","computeAutoPlacement","referenceRect","checksMap","Map","makeFallbackChecks","firstFittingPlacement","i","_basePlacement","isStartVariation","isVertical","mainVariationSide","altVariationSide","checks","push","every","check","set","_loop","_i","fittingPlacement","find","get","slice","reset","getSideOffsets","preventedOffsets","isAnySideFullyClipped","some","side","preventOverflow","referenceOverflow","popperAltOverflow","referenceClippingOffsets","popperEscapeOffsets","isReferenceHidden","hasPopperEscaped","_options$offset","invertDistance","skidding","distance","distanceAndSkiddingToXY","_data$state$placement","_options$tether","tether","_options$tetherOffset","tetherOffset","isBasePlacement","tetherOffsetValue","normalizedTetherOffsetValue","offsetModifierState","_offsetModifierState$","mainSide","altSide","additive","minLen","maxLen","arrowPaddingObject","arrowPaddingMin","arrowPaddingMax","arrowLen","minOffset","maxOffset","clientOffset","offsetModifierValue","tetherMax","preventedOffset","_offsetModifierState$2","_mainSide","_altSide","_offset","_len","_min","_max","isOriginSide","_offsetModifierValue","_tetherMin","_tetherMax","_preventedOffset","v","withinMaxClamp","getCompositeRect","elementOrVirtualElement","isOffsetParentAnElement","offsetParentIsScaled","isElementScaled","order","modifiers","visited","Set","result","modifier","add","dep","has","depModifier","DEFAULT_OPTIONS","areValidElements","arguments","args","Array","_key","popperGenerator","generatorOptions","_generatorOptions","_generatorOptions$def","defaultModifiers","_generatorOptions$def2","defaultOptions","pending","orderedModifiers","effectCleanupFns","isDestroyed","setOptions","setOptionsAction","cleanupModifierEffects","orderModifiers","merged","current","existing","mergeByName","m","_ref3$options","cleanupFn","noopFn","forceUpdate","_state$elements","index","_state$orderedModifie","_state$orderedModifie2","Promise","resolve","then","undefined","destroy","onFirstUpdate","createPopper","eventListeners","Default","alwaysOpen","activeClasses","inactiveClasses","onOpen","onClose","onToggle","items","this","_items","_init","active","open","id","triggerEl","toggle","getItem","classList","remove","targetEl","iconEl","close","initAccordions","querySelectorAll","$accordionEl","getAttribute","$triggerEl","closest","Accordion","defaultPosition","indicators","interval","onNext","onPrev","onChange","_activeItem","_indicators","_intervalDuration","_intervalInstance","el","_getActiveItem","slideTo","indicator","nextItem","rotationItems","middle","_rotate","_setActiveItem","pause","cycle","activeItem","prev","prevItem","setInterval","clearInterval","initCarousels","$carouselEl","slide","from","$carouselItemEl","$indicatorEl","parseInt","carousel","Carousel","carouselNextEl","carouselPrevEl","onCollapse","onExpand","_targetEl","_triggerEl","_visible","hasAttribute","collapse","expand","initCollapses","targetId","$targetEl","getElementById","Collapse","console","error","triggerType","onShow","onHide","parentEl","_parentEl","triggerEventTypes","_getTriggerEventTypes","showEvents","ev","show","hideEvents","matches","hide","isHidden","isVisible","initDials","$parentEl","dialId","$dialEl","Dial","transition","duration","timing","setTimeout","initDismisses","$dismissEl","Dismiss","bodyScrolling","backdrop","edge","edgeOffset","backdropClasses","_getPlacementClasses","base","c","event","inactive","_destroyBackdropEl","_createBackdrop","backdropEl","createElement","append","getDrawerInstance","instances","drawerInstance","initDrawers","drawerInstances","drawerId","$drawerEl","object","Drawer","offsetSkidding","offsetDistance","delay","ignoreClickOutsideClass","targetElement","triggerElement","_popperInstance","_createPopperInstance","_setupEventListeners","triggerEvents","_getTriggerEvents","_setupClickOutsideListener","_clickOutsideEventListener","_handleClickOutside","_removeClickOutsideListener","clickedEl","isIgnored","initDropdowns","dropdownId","$dropdownEl","Dropdown","initFlowbite","initModals","initTabs","initTooltips","initPopovers","closable","_isHidden","_backdropEl","_setupModalCloseEventListeners","_handleOutsideClick","_keydownEventListener","_removeModalCloseEventListeners","getModalInstance","modalInstance","modalInstances","modalId","$modalEl","Modal","_setupKeydownListener","_removeKeydownListener","popoverID","$popoverEl","Popover","defaultTabId","_activeTab","getTab","_setActiveTab","tab","getActiveTab","t","forceShow","tabItems","isActive","Tabs","tooltipId","$tooltipEl","Tooltip","eventType","eventFunctions","_eventType","_eventFunctions","init","eventFunction","Events","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","d","definition","o","defineProperty","enumerable","obj","prop","prototype","r","Symbol","toStringTag"],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.phoenix.js b/node_modules/flowbite/dist/flowbite.phoenix.js new file mode 100644 index 0000000..4ead6dc --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.phoenix.js @@ -0,0 +1,4438 @@ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define("Flowbite", [], factory); + else if(typeof exports === 'object') + exports["Flowbite"] = factory(); + else + root["Flowbite"] = factory(); +})(self, function() { +return /******/ (function() { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ 853: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +// ESM COMPAT FLAG +__webpack_require__.r(__webpack_exports__); + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "afterMain": function() { return /* reexport */ afterMain; }, + "afterRead": function() { return /* reexport */ afterRead; }, + "afterWrite": function() { return /* reexport */ afterWrite; }, + "applyStyles": function() { return /* reexport */ modifiers_applyStyles; }, + "arrow": function() { return /* reexport */ modifiers_arrow; }, + "auto": function() { return /* reexport */ auto; }, + "basePlacements": function() { return /* reexport */ basePlacements; }, + "beforeMain": function() { return /* reexport */ beforeMain; }, + "beforeRead": function() { return /* reexport */ beforeRead; }, + "beforeWrite": function() { return /* reexport */ beforeWrite; }, + "bottom": function() { return /* reexport */ bottom; }, + "clippingParents": function() { return /* reexport */ clippingParents; }, + "computeStyles": function() { return /* reexport */ modifiers_computeStyles; }, + "createPopper": function() { return /* reexport */ popper_createPopper; }, + "createPopperBase": function() { return /* reexport */ createPopper; }, + "createPopperLite": function() { return /* reexport */ popper_lite_createPopper; }, + "detectOverflow": function() { return /* reexport */ detectOverflow; }, + "end": function() { return /* reexport */ end; }, + "eventListeners": function() { return /* reexport */ eventListeners; }, + "flip": function() { return /* reexport */ modifiers_flip; }, + "hide": function() { return /* reexport */ modifiers_hide; }, + "left": function() { return /* reexport */ left; }, + "main": function() { return /* reexport */ main; }, + "modifierPhases": function() { return /* reexport */ modifierPhases; }, + "offset": function() { return /* reexport */ modifiers_offset; }, + "placements": function() { return /* reexport */ enums_placements; }, + "popper": function() { return /* reexport */ popper; }, + "popperGenerator": function() { return /* reexport */ popperGenerator; }, + "popperOffsets": function() { return /* reexport */ modifiers_popperOffsets; }, + "preventOverflow": function() { return /* reexport */ modifiers_preventOverflow; }, + "read": function() { return /* reexport */ read; }, + "reference": function() { return /* reexport */ reference; }, + "right": function() { return /* reexport */ right; }, + "start": function() { return /* reexport */ start; }, + "top": function() { return /* reexport */ enums_top; }, + "variationPlacements": function() { return /* reexport */ variationPlacements; }, + "viewport": function() { return /* reexport */ viewport; }, + "write": function() { return /* reexport */ write; } +}); + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/enums.js +var enums_top = 'top'; +var bottom = 'bottom'; +var right = 'right'; +var left = 'left'; +var auto = 'auto'; +var basePlacements = [enums_top, bottom, right, left]; +var start = 'start'; +var end = 'end'; +var clippingParents = 'clippingParents'; +var viewport = 'viewport'; +var popper = 'popper'; +var reference = 'reference'; +var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) { + return acc.concat([placement + "-" + start, placement + "-" + end]); +}, []); +var enums_placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) { + return acc.concat([placement, placement + "-" + start, placement + "-" + end]); +}, []); // modifiers that need to read the DOM + +var beforeRead = 'beforeRead'; +var read = 'read'; +var afterRead = 'afterRead'; // pure-logic modifiers + +var beforeMain = 'beforeMain'; +var main = 'main'; +var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state) + +var beforeWrite = 'beforeWrite'; +var write = 'write'; +var afterWrite = 'afterWrite'; +var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite]; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js +function getNodeName(element) { + return element ? (element.nodeName || '').toLowerCase() : null; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindow.js +function getWindow(node) { + if (node == null) { + return window; + } + + if (node.toString() !== '[object Window]') { + var ownerDocument = node.ownerDocument; + return ownerDocument ? ownerDocument.defaultView || window : window; + } + + return node; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js + + +function isElement(node) { + var OwnElement = getWindow(node).Element; + return node instanceof OwnElement || node instanceof Element; +} + +function isHTMLElement(node) { + var OwnElement = getWindow(node).HTMLElement; + return node instanceof OwnElement || node instanceof HTMLElement; +} + +function isShadowRoot(node) { + // IE 11 has no ShadowRoot + if (typeof ShadowRoot === 'undefined') { + return false; + } + + var OwnElement = getWindow(node).ShadowRoot; + return node instanceof OwnElement || node instanceof ShadowRoot; +} + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/applyStyles.js + + // This modifier takes the styles prepared by the `computeStyles` modifier +// and applies them to the HTMLElements such as popper and arrow + +function applyStyles(_ref) { + var state = _ref.state; + Object.keys(state.elements).forEach(function (name) { + var style = state.styles[name] || {}; + var attributes = state.attributes[name] || {}; + var element = state.elements[name]; // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } // Flow doesn't support to extend this property, but it's the most + // effective way to apply styles to an HTMLElement + // $FlowFixMe[cannot-write] + + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (name) { + var value = attributes[name]; + + if (value === false) { + element.removeAttribute(name); + } else { + element.setAttribute(name, value === true ? '' : value); + } + }); + }); +} + +function effect(_ref2) { + var state = _ref2.state; + var initialStyles = { + popper: { + position: state.options.strategy, + left: '0', + top: '0', + margin: '0' + }, + arrow: { + position: 'absolute' + }, + reference: {} + }; + Object.assign(state.elements.popper.style, initialStyles.popper); + state.styles = initialStyles; + + if (state.elements.arrow) { + Object.assign(state.elements.arrow.style, initialStyles.arrow); + } + + return function () { + Object.keys(state.elements).forEach(function (name) { + var element = state.elements[name]; + var attributes = state.attributes[name] || {}; + var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them + + var style = styleProperties.reduce(function (style, property) { + style[property] = ''; + return style; + }, {}); // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (attribute) { + element.removeAttribute(attribute); + }); + }); + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_applyStyles = ({ + name: 'applyStyles', + enabled: true, + phase: 'write', + fn: applyStyles, + effect: effect, + requires: ['computeStyles'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getBasePlacement.js + +function getBasePlacement(placement) { + return placement.split('-')[0]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/math.js +var math_max = Math.max; +var math_min = Math.min; +var round = Math.round; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/userAgent.js +function getUAString() { + var uaData = navigator.userAgentData; + + if (uaData != null && uaData.brands) { + return uaData.brands.map(function (item) { + return item.brand + "/" + item.version; + }).join(' '); + } + + return navigator.userAgent; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js + +function isLayoutViewport() { + return !/^((?!chrome|android).)*safari/i.test(getUAString()); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js + + + + +function getBoundingClientRect(element, includeScale, isFixedStrategy) { + if (includeScale === void 0) { + includeScale = false; + } + + if (isFixedStrategy === void 0) { + isFixedStrategy = false; + } + + var clientRect = element.getBoundingClientRect(); + var scaleX = 1; + var scaleY = 1; + + if (includeScale && isHTMLElement(element)) { + scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1; + scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1; + } + + var _ref = isElement(element) ? getWindow(element) : window, + visualViewport = _ref.visualViewport; + + var addVisualOffsets = !isLayoutViewport() && isFixedStrategy; + var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX; + var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY; + var width = clientRect.width / scaleX; + var height = clientRect.height / scaleY; + return { + width: width, + height: height, + top: y, + right: x + width, + bottom: y + height, + left: x, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js + // Returns the layout rect of an element relative to its offsetParent. Layout +// means it doesn't take into account transforms. + +function getLayoutRect(element) { + var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed. + // Fixes https://github.com/popperjs/popper-core/issues/1223 + + var width = element.offsetWidth; + var height = element.offsetHeight; + + if (Math.abs(clientRect.width - width) <= 1) { + width = clientRect.width; + } + + if (Math.abs(clientRect.height - height) <= 1) { + height = clientRect.height; + } + + return { + x: element.offsetLeft, + y: element.offsetTop, + width: width, + height: height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/contains.js + +function contains(parent, child) { + var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method + + if (parent.contains(child)) { + return true; + } // then fallback to custom implementation with Shadow DOM support + else if (rootNode && isShadowRoot(rootNode)) { + var next = child; + + do { + if (next && parent.isSameNode(next)) { + return true; + } // $FlowFixMe[prop-missing]: need a better way to handle this... + + + next = next.parentNode || next.host; + } while (next); + } // Give up, the result is false + + + return false; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js + +function getComputedStyle(element) { + return getWindow(element).getComputedStyle(element); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js + +function isTableElement(element) { + return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js + +function getDocumentElement(element) { + // $FlowFixMe[incompatible-return]: assume body is always available + return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing] + element.document) || window.document).documentElement; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js + + + +function getParentNode(element) { + if (getNodeName(element) === 'html') { + return element; + } + + return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle + // $FlowFixMe[incompatible-return] + // $FlowFixMe[prop-missing] + element.assignedSlot || // step into the shadow DOM of the parent of a slotted node + element.parentNode || ( // DOM Element detected + isShadowRoot(element) ? element.host : null) || // ShadowRoot detected + // $FlowFixMe[incompatible-call]: HTMLElement is a Node + getDocumentElement(element) // fallback + + ); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js + + + + + + + + +function getTrueOffsetParent(element) { + if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837 + getComputedStyle(element).position === 'fixed') { + return null; + } + + return element.offsetParent; +} // `.offsetParent` reports `null` for fixed elements, while absolute elements +// return the containing block + + +function getContainingBlock(element) { + var isFirefox = /firefox/i.test(getUAString()); + var isIE = /Trident/i.test(getUAString()); + + if (isIE && isHTMLElement(element)) { + // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport + var elementCss = getComputedStyle(element); + + if (elementCss.position === 'fixed') { + return null; + } + } + + var currentNode = getParentNode(element); + + if (isShadowRoot(currentNode)) { + currentNode = currentNode.host; + } + + while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) { + var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that + // create a containing block. + // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block + + if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') { + return currentNode; + } else { + currentNode = currentNode.parentNode; + } + } + + return null; +} // Gets the closest ancestor positioned element. Handles some edge cases, +// such as table ancestors and cross browser bugs. + + +function getOffsetParent(element) { + var window = getWindow(element); + var offsetParent = getTrueOffsetParent(element); + + while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') { + offsetParent = getTrueOffsetParent(offsetParent); + } + + if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) { + return window; + } + + return offsetParent || getContainingBlock(element) || window; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js +function getMainAxisFromPlacement(placement) { + return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/within.js + +function within(min, value, max) { + return math_max(min, math_min(value, max)); +} +function withinMaxClamp(min, value, max) { + var v = within(min, value, max); + return v > max ? max : v; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js +function getFreshSideObject() { + return { + top: 0, + right: 0, + bottom: 0, + left: 0 + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js + +function mergePaddingObject(paddingObject) { + return Object.assign({}, getFreshSideObject(), paddingObject); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/expandToHashMap.js +function expandToHashMap(value, keys) { + return keys.reduce(function (hashMap, key) { + hashMap[key] = value; + return hashMap; + }, {}); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/arrow.js + + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var toPaddingObject = function toPaddingObject(padding, state) { + padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, { + placement: state.placement + })) : padding; + return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); +}; + +function arrow(_ref) { + var _state$modifiersData$; + + var state = _ref.state, + name = _ref.name, + options = _ref.options; + var arrowElement = state.elements.arrow; + var popperOffsets = state.modifiersData.popperOffsets; + var basePlacement = getBasePlacement(state.placement); + var axis = getMainAxisFromPlacement(basePlacement); + var isVertical = [left, right].indexOf(basePlacement) >= 0; + var len = isVertical ? 'height' : 'width'; + + if (!arrowElement || !popperOffsets) { + return; + } + + var paddingObject = toPaddingObject(options.padding, state); + var arrowRect = getLayoutRect(arrowElement); + var minProp = axis === 'y' ? enums_top : left; + var maxProp = axis === 'y' ? bottom : right; + var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len]; + var startDiff = popperOffsets[axis] - state.rects.reference[axis]; + var arrowOffsetParent = getOffsetParent(arrowElement); + var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0; + var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is + // outside of the popper bounds + + var min = paddingObject[minProp]; + var max = clientSize - arrowRect[len] - paddingObject[maxProp]; + var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference; + var offset = within(min, center, max); // Prevents breaking syntax highlighting... + + var axisProp = axis; + state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$); +} + +function arrow_effect(_ref2) { + var state = _ref2.state, + options = _ref2.options; + var _options$element = options.element, + arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element; + + if (arrowElement == null) { + return; + } // CSS selector + + + if (typeof arrowElement === 'string') { + arrowElement = state.elements.popper.querySelector(arrowElement); + + if (!arrowElement) { + return; + } + } + + if (false) {} + + if (!contains(state.elements.popper, arrowElement)) { + if (false) {} + + return; + } + + state.elements.arrow = arrowElement; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_arrow = ({ + name: 'arrow', + enabled: true, + phase: 'main', + fn: arrow, + effect: arrow_effect, + requires: ['popperOffsets'], + requiresIfExists: ['preventOverflow'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getVariation.js +function getVariation(placement) { + return placement.split('-')[1]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/computeStyles.js + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var unsetSides = { + top: 'auto', + right: 'auto', + bottom: 'auto', + left: 'auto' +}; // Round the offsets to the nearest suitable subpixel based on the DPR. +// Zooming can change the DPR, but it seems to report a value that will +// cleanly divide the values into the appropriate subpixels. + +function roundOffsetsByDPR(_ref) { + var x = _ref.x, + y = _ref.y; + var win = window; + var dpr = win.devicePixelRatio || 1; + return { + x: round(x * dpr) / dpr || 0, + y: round(y * dpr) / dpr || 0 + }; +} + +function mapToStyles(_ref2) { + var _Object$assign2; + + var popper = _ref2.popper, + popperRect = _ref2.popperRect, + placement = _ref2.placement, + variation = _ref2.variation, + offsets = _ref2.offsets, + position = _ref2.position, + gpuAcceleration = _ref2.gpuAcceleration, + adaptive = _ref2.adaptive, + roundOffsets = _ref2.roundOffsets, + isFixed = _ref2.isFixed; + var _offsets$x = offsets.x, + x = _offsets$x === void 0 ? 0 : _offsets$x, + _offsets$y = offsets.y, + y = _offsets$y === void 0 ? 0 : _offsets$y; + + var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref3.x; + y = _ref3.y; + var hasX = offsets.hasOwnProperty('x'); + var hasY = offsets.hasOwnProperty('y'); + var sideX = left; + var sideY = enums_top; + var win = window; + + if (adaptive) { + var offsetParent = getOffsetParent(popper); + var heightProp = 'clientHeight'; + var widthProp = 'clientWidth'; + + if (offsetParent === getWindow(popper)) { + offsetParent = getDocumentElement(popper); + + if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') { + heightProp = 'scrollHeight'; + widthProp = 'scrollWidth'; + } + } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it + + + offsetParent = offsetParent; + + if (placement === enums_top || (placement === left || placement === right) && variation === end) { + sideY = bottom; + var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing] + offsetParent[heightProp]; + y -= offsetY - popperRect.height; + y *= gpuAcceleration ? 1 : -1; + } + + if (placement === left || (placement === enums_top || placement === bottom) && variation === end) { + sideX = right; + var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing] + offsetParent[widthProp]; + x -= offsetX - popperRect.width; + x *= gpuAcceleration ? 1 : -1; + } + } + + var commonStyles = Object.assign({ + position: position + }, adaptive && unsetSides); + + var _ref4 = roundOffsets === true ? roundOffsetsByDPR({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref4.x; + y = _ref4.y; + + if (gpuAcceleration) { + var _Object$assign; + + return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign)); + } + + return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2)); +} + +function computeStyles(_ref5) { + var state = _ref5.state, + options = _ref5.options; + var _options$gpuAccelerat = options.gpuAcceleration, + gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, + _options$adaptive = options.adaptive, + adaptive = _options$adaptive === void 0 ? true : _options$adaptive, + _options$roundOffsets = options.roundOffsets, + roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets; + + if (false) { var transitionProperty; } + + var commonStyles = { + placement: getBasePlacement(state.placement), + variation: getVariation(state.placement), + popper: state.elements.popper, + popperRect: state.rects.popper, + gpuAcceleration: gpuAcceleration, + isFixed: state.options.strategy === 'fixed' + }; + + if (state.modifiersData.popperOffsets != null) { + state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.popperOffsets, + position: state.options.strategy, + adaptive: adaptive, + roundOffsets: roundOffsets + }))); + } + + if (state.modifiersData.arrow != null) { + state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.arrow, + position: 'absolute', + adaptive: false, + roundOffsets: roundOffsets + }))); + } + + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-placement': state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_computeStyles = ({ + name: 'computeStyles', + enabled: true, + phase: 'beforeWrite', + fn: computeStyles, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/eventListeners.js + // eslint-disable-next-line import/no-unused-modules + +var passive = { + passive: true +}; + +function eventListeners_effect(_ref) { + var state = _ref.state, + instance = _ref.instance, + options = _ref.options; + var _options$scroll = options.scroll, + scroll = _options$scroll === void 0 ? true : _options$scroll, + _options$resize = options.resize, + resize = _options$resize === void 0 ? true : _options$resize; + var window = getWindow(state.elements.popper); + var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper); + + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.addEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.addEventListener('resize', instance.update, passive); + } + + return function () { + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.removeEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.removeEventListener('resize', instance.update, passive); + } + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var eventListeners = ({ + name: 'eventListeners', + enabled: true, + phase: 'write', + fn: function fn() {}, + effect: eventListeners_effect, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js +var hash = { + left: 'right', + right: 'left', + bottom: 'top', + top: 'bottom' +}; +function getOppositePlacement(placement) { + return placement.replace(/left|right|bottom|top/g, function (matched) { + return hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js +var getOppositeVariationPlacement_hash = { + start: 'end', + end: 'start' +}; +function getOppositeVariationPlacement(placement) { + return placement.replace(/start|end/g, function (matched) { + return getOppositeVariationPlacement_hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js + +function getWindowScroll(node) { + var win = getWindow(node); + var scrollLeft = win.pageXOffset; + var scrollTop = win.pageYOffset; + return { + scrollLeft: scrollLeft, + scrollTop: scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js + + + +function getWindowScrollBarX(element) { + // If has a CSS width greater than the viewport, then this will be + // incorrect for RTL. + // Popper 1 is broken in this case and never had a bug report so let's assume + // it's not an issue. I don't think anyone ever specifies width on + // anyway. + // Browsers where the left scrollbar doesn't cause an issue report `0` for + // this (e.g. Edge 2019, IE11, Safari) + return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js + + + + +function getViewportRect(element, strategy) { + var win = getWindow(element); + var html = getDocumentElement(element); + var visualViewport = win.visualViewport; + var width = html.clientWidth; + var height = html.clientHeight; + var x = 0; + var y = 0; + + if (visualViewport) { + width = visualViewport.width; + height = visualViewport.height; + var layoutViewport = isLayoutViewport(); + + if (layoutViewport || !layoutViewport && strategy === 'fixed') { + x = visualViewport.offsetLeft; + y = visualViewport.offsetTop; + } + } + + return { + width: width, + height: height, + x: x + getWindowScrollBarX(element), + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js + + + + + // Gets the entire size of the scrollable document area, even extending outside +// of the `` and `` rect bounds if horizontally scrollable + +function getDocumentRect(element) { + var _element$ownerDocumen; + + var html = getDocumentElement(element); + var winScroll = getWindowScroll(element); + var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body; + var width = math_max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0); + var height = math_max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0); + var x = -winScroll.scrollLeft + getWindowScrollBarX(element); + var y = -winScroll.scrollTop; + + if (getComputedStyle(body || html).direction === 'rtl') { + x += math_max(html.clientWidth, body ? body.clientWidth : 0) - width; + } + + return { + width: width, + height: height, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js + +function isScrollParent(element) { + // Firefox wants us to check `-x` and `-y` variations as well + var _getComputedStyle = getComputedStyle(element), + overflow = _getComputedStyle.overflow, + overflowX = _getComputedStyle.overflowX, + overflowY = _getComputedStyle.overflowY; + + return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js + + + + +function getScrollParent(node) { + if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) { + // $FlowFixMe[incompatible-return]: assume body is always available + return node.ownerDocument.body; + } + + if (isHTMLElement(node) && isScrollParent(node)) { + return node; + } + + return getScrollParent(getParentNode(node)); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js + + + + +/* +given a DOM element, return the list of all scroll parents, up the list of ancesors +until we get to the top window object. This list is what we attach scroll listeners +to, because if any of these parent elements scroll, we'll need to re-calculate the +reference element's position. +*/ + +function listScrollParents(element, list) { + var _element$ownerDocumen; + + if (list === void 0) { + list = []; + } + + var scrollParent = getScrollParent(element); + var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body); + var win = getWindow(scrollParent); + var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent; + var updatedList = list.concat(target); + return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here + updatedList.concat(listScrollParents(getParentNode(target))); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/rectToClientRect.js +function rectToClientRect(rect) { + return Object.assign({}, rect, { + left: rect.x, + top: rect.y, + right: rect.x + rect.width, + bottom: rect.y + rect.height + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js + + + + + + + + + + + + + + + +function getInnerBoundingClientRect(element, strategy) { + var rect = getBoundingClientRect(element, false, strategy === 'fixed'); + rect.top = rect.top + element.clientTop; + rect.left = rect.left + element.clientLeft; + rect.bottom = rect.top + element.clientHeight; + rect.right = rect.left + element.clientWidth; + rect.width = element.clientWidth; + rect.height = element.clientHeight; + rect.x = rect.left; + rect.y = rect.top; + return rect; +} + +function getClientRectFromMixedType(element, clippingParent, strategy) { + return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element))); +} // A "clipping parent" is an overflowable container with the characteristic of +// clipping (or hiding) overflowing elements with a position different from +// `initial` + + +function getClippingParents(element) { + var clippingParents = listScrollParents(getParentNode(element)); + var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0; + var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element; + + if (!isElement(clipperElement)) { + return []; + } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414 + + + return clippingParents.filter(function (clippingParent) { + return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body'; + }); +} // Gets the maximum area that the element is visible in due to any number of +// clipping parents + + +function getClippingRect(element, boundary, rootBoundary, strategy) { + var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary); + var clippingParents = [].concat(mainClippingParents, [rootBoundary]); + var firstClippingParent = clippingParents[0]; + var clippingRect = clippingParents.reduce(function (accRect, clippingParent) { + var rect = getClientRectFromMixedType(element, clippingParent, strategy); + accRect.top = math_max(rect.top, accRect.top); + accRect.right = math_min(rect.right, accRect.right); + accRect.bottom = math_min(rect.bottom, accRect.bottom); + accRect.left = math_max(rect.left, accRect.left); + return accRect; + }, getClientRectFromMixedType(element, firstClippingParent, strategy)); + clippingRect.width = clippingRect.right - clippingRect.left; + clippingRect.height = clippingRect.bottom - clippingRect.top; + clippingRect.x = clippingRect.left; + clippingRect.y = clippingRect.top; + return clippingRect; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeOffsets.js + + + + +function computeOffsets(_ref) { + var reference = _ref.reference, + element = _ref.element, + placement = _ref.placement; + var basePlacement = placement ? getBasePlacement(placement) : null; + var variation = placement ? getVariation(placement) : null; + var commonX = reference.x + reference.width / 2 - element.width / 2; + var commonY = reference.y + reference.height / 2 - element.height / 2; + var offsets; + + switch (basePlacement) { + case enums_top: + offsets = { + x: commonX, + y: reference.y - element.height + }; + break; + + case bottom: + offsets = { + x: commonX, + y: reference.y + reference.height + }; + break; + + case right: + offsets = { + x: reference.x + reference.width, + y: commonY + }; + break; + + case left: + offsets = { + x: reference.x - element.width, + y: commonY + }; + break; + + default: + offsets = { + x: reference.x, + y: reference.y + }; + } + + var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null; + + if (mainAxis != null) { + var len = mainAxis === 'y' ? 'height' : 'width'; + + switch (variation) { + case start: + offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2); + break; + + case end: + offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2); + break; + + default: + } + } + + return offsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/detectOverflow.js + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function detectOverflow(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + _options$placement = _options.placement, + placement = _options$placement === void 0 ? state.placement : _options$placement, + _options$strategy = _options.strategy, + strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, + _options$boundary = _options.boundary, + boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, + _options$rootBoundary = _options.rootBoundary, + rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, + _options$elementConte = _options.elementContext, + elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, + _options$altBoundary = _options.altBoundary, + altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, + _options$padding = _options.padding, + padding = _options$padding === void 0 ? 0 : _options$padding; + var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); + var altContext = elementContext === popper ? reference : popper; + var popperRect = state.rects.popper; + var element = state.elements[altBoundary ? altContext : elementContext]; + var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy); + var referenceClientRect = getBoundingClientRect(state.elements.reference); + var popperOffsets = computeOffsets({ + reference: referenceClientRect, + element: popperRect, + strategy: 'absolute', + placement: placement + }); + var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets)); + var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect + // 0 or negative = within the clipping rect + + var overflowOffsets = { + top: clippingClientRect.top - elementClientRect.top + paddingObject.top, + bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom, + left: clippingClientRect.left - elementClientRect.left + paddingObject.left, + right: elementClientRect.right - clippingClientRect.right + paddingObject.right + }; + var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element + + if (elementContext === popper && offsetData) { + var offset = offsetData[placement]; + Object.keys(overflowOffsets).forEach(function (key) { + var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1; + var axis = [enums_top, bottom].indexOf(key) >= 0 ? 'y' : 'x'; + overflowOffsets[key] += offset[axis] * multiply; + }); + } + + return overflowOffsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js + + + + +function computeAutoPlacement(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + placement = _options.placement, + boundary = _options.boundary, + rootBoundary = _options.rootBoundary, + padding = _options.padding, + flipVariations = _options.flipVariations, + _options$allowedAutoP = _options.allowedAutoPlacements, + allowedAutoPlacements = _options$allowedAutoP === void 0 ? enums_placements : _options$allowedAutoP; + var variation = getVariation(placement); + var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) { + return getVariation(placement) === variation; + }) : basePlacements; + var allowedPlacements = placements.filter(function (placement) { + return allowedAutoPlacements.indexOf(placement) >= 0; + }); + + if (allowedPlacements.length === 0) { + allowedPlacements = placements; + + if (false) {} + } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions... + + + var overflows = allowedPlacements.reduce(function (acc, placement) { + acc[placement] = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding + })[getBasePlacement(placement)]; + return acc; + }, {}); + return Object.keys(overflows).sort(function (a, b) { + return overflows[a] - overflows[b]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/flip.js + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function getExpandedFallbackPlacements(placement) { + if (getBasePlacement(placement) === auto) { + return []; + } + + var oppositePlacement = getOppositePlacement(placement); + return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)]; +} + +function flip(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + + if (state.modifiersData[name]._skip) { + return; + } + + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, + specifiedFallbackPlacements = options.fallbackPlacements, + padding = options.padding, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + _options$flipVariatio = options.flipVariations, + flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, + allowedAutoPlacements = options.allowedAutoPlacements; + var preferredPlacement = state.options.placement; + var basePlacement = getBasePlacement(preferredPlacement); + var isBasePlacement = basePlacement === preferredPlacement; + var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement)); + var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) { + return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + flipVariations: flipVariations, + allowedAutoPlacements: allowedAutoPlacements + }) : placement); + }, []); + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var checksMap = new Map(); + var makeFallbackChecks = true; + var firstFittingPlacement = placements[0]; + + for (var i = 0; i < placements.length; i++) { + var placement = placements[i]; + + var _basePlacement = getBasePlacement(placement); + + var isStartVariation = getVariation(placement) === start; + var isVertical = [enums_top, bottom].indexOf(_basePlacement) >= 0; + var len = isVertical ? 'width' : 'height'; + var overflow = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + altBoundary: altBoundary, + padding: padding + }); + var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : enums_top; + + if (referenceRect[len] > popperRect[len]) { + mainVariationSide = getOppositePlacement(mainVariationSide); + } + + var altVariationSide = getOppositePlacement(mainVariationSide); + var checks = []; + + if (checkMainAxis) { + checks.push(overflow[_basePlacement] <= 0); + } + + if (checkAltAxis) { + checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0); + } + + if (checks.every(function (check) { + return check; + })) { + firstFittingPlacement = placement; + makeFallbackChecks = false; + break; + } + + checksMap.set(placement, checks); + } + + if (makeFallbackChecks) { + // `2` may be desired in some cases – research later + var numberOfChecks = flipVariations ? 3 : 1; + + var _loop = function _loop(_i) { + var fittingPlacement = placements.find(function (placement) { + var checks = checksMap.get(placement); + + if (checks) { + return checks.slice(0, _i).every(function (check) { + return check; + }); + } + }); + + if (fittingPlacement) { + firstFittingPlacement = fittingPlacement; + return "break"; + } + }; + + for (var _i = numberOfChecks; _i > 0; _i--) { + var _ret = _loop(_i); + + if (_ret === "break") break; + } + } + + if (state.placement !== firstFittingPlacement) { + state.modifiersData[name]._skip = true; + state.placement = firstFittingPlacement; + state.reset = true; + } +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_flip = ({ + name: 'flip', + enabled: true, + phase: 'main', + fn: flip, + requiresIfExists: ['offset'], + data: { + _skip: false + } +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/hide.js + + + +function getSideOffsets(overflow, rect, preventedOffsets) { + if (preventedOffsets === void 0) { + preventedOffsets = { + x: 0, + y: 0 + }; + } + + return { + top: overflow.top - rect.height - preventedOffsets.y, + right: overflow.right - rect.width + preventedOffsets.x, + bottom: overflow.bottom - rect.height + preventedOffsets.y, + left: overflow.left - rect.width - preventedOffsets.x + }; +} + +function isAnySideFullyClipped(overflow) { + return [enums_top, right, bottom, left].some(function (side) { + return overflow[side] >= 0; + }); +} + +function hide(_ref) { + var state = _ref.state, + name = _ref.name; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var preventedOffsets = state.modifiersData.preventOverflow; + var referenceOverflow = detectOverflow(state, { + elementContext: 'reference' + }); + var popperAltOverflow = detectOverflow(state, { + altBoundary: true + }); + var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect); + var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets); + var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets); + var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets); + state.modifiersData[name] = { + referenceClippingOffsets: referenceClippingOffsets, + popperEscapeOffsets: popperEscapeOffsets, + isReferenceHidden: isReferenceHidden, + hasPopperEscaped: hasPopperEscaped + }; + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-reference-hidden': isReferenceHidden, + 'data-popper-escaped': hasPopperEscaped + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_hide = ({ + name: 'hide', + enabled: true, + phase: 'main', + requiresIfExists: ['preventOverflow'], + fn: hide +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/offset.js + + // eslint-disable-next-line import/no-unused-modules + +function distanceAndSkiddingToXY(placement, rects, offset) { + var basePlacement = getBasePlacement(placement); + var invertDistance = [left, enums_top].indexOf(basePlacement) >= 0 ? -1 : 1; + + var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, { + placement: placement + })) : offset, + skidding = _ref[0], + distance = _ref[1]; + + skidding = skidding || 0; + distance = (distance || 0) * invertDistance; + return [left, right].indexOf(basePlacement) >= 0 ? { + x: distance, + y: skidding + } : { + x: skidding, + y: distance + }; +} + +function offset(_ref2) { + var state = _ref2.state, + options = _ref2.options, + name = _ref2.name; + var _options$offset = options.offset, + offset = _options$offset === void 0 ? [0, 0] : _options$offset; + var data = enums_placements.reduce(function (acc, placement) { + acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset); + return acc; + }, {}); + var _data$state$placement = data[state.placement], + x = _data$state$placement.x, + y = _data$state$placement.y; + + if (state.modifiersData.popperOffsets != null) { + state.modifiersData.popperOffsets.x += x; + state.modifiersData.popperOffsets.y += y; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_offset = ({ + name: 'offset', + enabled: true, + phase: 'main', + requires: ['popperOffsets'], + fn: offset +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js + + +function popperOffsets(_ref) { + var state = _ref.state, + name = _ref.name; + // Offsets are the actual position the popper needs to have to be + // properly positioned near its reference element + // This is the most basic placement, and will be adjusted by + // the modifiers in the next step + state.modifiersData[name] = computeOffsets({ + reference: state.rects.reference, + element: state.rects.popper, + strategy: 'absolute', + placement: state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_popperOffsets = ({ + name: 'popperOffsets', + enabled: true, + phase: 'read', + fn: popperOffsets, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getAltAxis.js +function getAltAxis(axis) { + return axis === 'x' ? 'y' : 'x'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js + + + + + + + + + + + + +function preventOverflow(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + padding = options.padding, + _options$tether = options.tether, + tether = _options$tether === void 0 ? true : _options$tether, + _options$tetherOffset = options.tetherOffset, + tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset; + var overflow = detectOverflow(state, { + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + altBoundary: altBoundary + }); + var basePlacement = getBasePlacement(state.placement); + var variation = getVariation(state.placement); + var isBasePlacement = !variation; + var mainAxis = getMainAxisFromPlacement(basePlacement); + var altAxis = getAltAxis(mainAxis); + var popperOffsets = state.modifiersData.popperOffsets; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, { + placement: state.placement + })) : tetherOffset; + var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? { + mainAxis: tetherOffsetValue, + altAxis: tetherOffsetValue + } : Object.assign({ + mainAxis: 0, + altAxis: 0 + }, tetherOffsetValue); + var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null; + var data = { + x: 0, + y: 0 + }; + + if (!popperOffsets) { + return; + } + + if (checkMainAxis) { + var _offsetModifierState$; + + var mainSide = mainAxis === 'y' ? enums_top : left; + var altSide = mainAxis === 'y' ? bottom : right; + var len = mainAxis === 'y' ? 'height' : 'width'; + var offset = popperOffsets[mainAxis]; + var min = offset + overflow[mainSide]; + var max = offset - overflow[altSide]; + var additive = tether ? -popperRect[len] / 2 : 0; + var minLen = variation === start ? referenceRect[len] : popperRect[len]; + var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go + // outside the reference bounds + + var arrowElement = state.elements.arrow; + var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : { + width: 0, + height: 0 + }; + var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject(); + var arrowPaddingMin = arrowPaddingObject[mainSide]; + var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want + // to include its full size in the calculation. If the reference is small + // and near the edge of a boundary, the popper can overflow even if the + // reference is not overflowing as well (e.g. virtual elements with no + // width or height) + + var arrowLen = within(0, referenceRect[len], arrowRect[len]); + var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis; + var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis; + var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow); + var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0; + var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0; + var tetherMin = offset + minOffset - offsetModifierValue - clientOffset; + var tetherMax = offset + maxOffset - offsetModifierValue; + var preventedOffset = within(tether ? math_min(min, tetherMin) : min, offset, tether ? math_max(max, tetherMax) : max); + popperOffsets[mainAxis] = preventedOffset; + data[mainAxis] = preventedOffset - offset; + } + + if (checkAltAxis) { + var _offsetModifierState$2; + + var _mainSide = mainAxis === 'x' ? enums_top : left; + + var _altSide = mainAxis === 'x' ? bottom : right; + + var _offset = popperOffsets[altAxis]; + + var _len = altAxis === 'y' ? 'height' : 'width'; + + var _min = _offset + overflow[_mainSide]; + + var _max = _offset - overflow[_altSide]; + + var isOriginSide = [enums_top, left].indexOf(basePlacement) !== -1; + + var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0; + + var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis; + + var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max; + + var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max); + + popperOffsets[altAxis] = _preventedOffset; + data[altAxis] = _preventedOffset - _offset; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_preventOverflow = ({ + name: 'preventOverflow', + enabled: true, + phase: 'main', + fn: preventOverflow, + requiresIfExists: ['offset'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/index.js + + + + + + + + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js +function getHTMLElementScroll(element) { + return { + scrollLeft: element.scrollLeft, + scrollTop: element.scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js + + + + +function getNodeScroll(node) { + if (node === getWindow(node) || !isHTMLElement(node)) { + return getWindowScroll(node); + } else { + return getHTMLElementScroll(node); + } +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js + + + + + + + + + +function isElementScaled(element) { + var rect = element.getBoundingClientRect(); + var scaleX = round(rect.width) / element.offsetWidth || 1; + var scaleY = round(rect.height) / element.offsetHeight || 1; + return scaleX !== 1 || scaleY !== 1; +} // Returns the composite rect of an element relative to its offsetParent. +// Composite means it takes into account transforms as well as layout. + + +function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) { + if (isFixed === void 0) { + isFixed = false; + } + + var isOffsetParentAnElement = isHTMLElement(offsetParent); + var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent); + var documentElement = getDocumentElement(offsetParent); + var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed); + var scroll = { + scrollLeft: 0, + scrollTop: 0 + }; + var offsets = { + x: 0, + y: 0 + }; + + if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { + if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078 + isScrollParent(documentElement)) { + scroll = getNodeScroll(offsetParent); + } + + if (isHTMLElement(offsetParent)) { + offsets = getBoundingClientRect(offsetParent, true); + offsets.x += offsetParent.clientLeft; + offsets.y += offsetParent.clientTop; + } else if (documentElement) { + offsets.x = getWindowScrollBarX(documentElement); + } + } + + return { + x: rect.left + scroll.scrollLeft - offsets.x, + y: rect.top + scroll.scrollTop - offsets.y, + width: rect.width, + height: rect.height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/orderModifiers.js + // source: https://stackoverflow.com/questions/49875255 + +function order(modifiers) { + var map = new Map(); + var visited = new Set(); + var result = []; + modifiers.forEach(function (modifier) { + map.set(modifier.name, modifier); + }); // On visiting object, check for its dependencies and visit them recursively + + function sort(modifier) { + visited.add(modifier.name); + var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []); + requires.forEach(function (dep) { + if (!visited.has(dep)) { + var depModifier = map.get(dep); + + if (depModifier) { + sort(depModifier); + } + } + }); + result.push(modifier); + } + + modifiers.forEach(function (modifier) { + if (!visited.has(modifier.name)) { + // check for visited object + sort(modifier); + } + }); + return result; +} + +function orderModifiers(modifiers) { + // order based on dependencies + var orderedModifiers = order(modifiers); // order based on phase + + return modifierPhases.reduce(function (acc, phase) { + return acc.concat(orderedModifiers.filter(function (modifier) { + return modifier.phase === phase; + })); + }, []); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/debounce.js +function debounce(fn) { + var pending; + return function () { + if (!pending) { + pending = new Promise(function (resolve) { + Promise.resolve().then(function () { + pending = undefined; + resolve(fn()); + }); + }); + } + + return pending; + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergeByName.js +function mergeByName(modifiers) { + var merged = modifiers.reduce(function (merged, current) { + var existing = merged[current.name]; + merged[current.name] = existing ? Object.assign({}, existing, current, { + options: Object.assign({}, existing.options, current.options), + data: Object.assign({}, existing.data, current.data) + }) : current; + return merged; + }, {}); // IE11 does not support Object.values + + return Object.keys(merged).map(function (key) { + return merged[key]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/createPopper.js + + + + + + + + + + + + + + +var INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.'; +var INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.'; +var DEFAULT_OPTIONS = { + placement: 'bottom', + modifiers: [], + strategy: 'absolute' +}; + +function areValidElements() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + return !args.some(function (element) { + return !(element && typeof element.getBoundingClientRect === 'function'); + }); +} + +function popperGenerator(generatorOptions) { + if (generatorOptions === void 0) { + generatorOptions = {}; + } + + var _generatorOptions = generatorOptions, + _generatorOptions$def = _generatorOptions.defaultModifiers, + defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, + _generatorOptions$def2 = _generatorOptions.defaultOptions, + defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2; + return function createPopper(reference, popper, options) { + if (options === void 0) { + options = defaultOptions; + } + + var state = { + placement: 'bottom', + orderedModifiers: [], + options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions), + modifiersData: {}, + elements: { + reference: reference, + popper: popper + }, + attributes: {}, + styles: {} + }; + var effectCleanupFns = []; + var isDestroyed = false; + var instance = { + state: state, + setOptions: function setOptions(setOptionsAction) { + var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction; + cleanupModifierEffects(); + state.options = Object.assign({}, defaultOptions, state.options, options); + state.scrollParents = { + reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [], + popper: listScrollParents(popper) + }; // Orders the modifiers based on their dependencies and `phase` + // properties + + var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers + + state.orderedModifiers = orderedModifiers.filter(function (m) { + return m.enabled; + }); // Validate the provided modifiers so that the consumer will get warned + // if one of the modifiers is invalid for any reason + + if (false) { var _getComputedStyle, marginTop, marginRight, marginBottom, marginLeft, flipModifier, modifiers; } + + runModifierEffects(); + return instance.update(); + }, + // Sync update – it will always be executed, even if not necessary. This + // is useful for low frequency updates where sync behavior simplifies the + // logic. + // For high frequency updates (e.g. `resize` and `scroll` events), always + // prefer the async Popper#update method + forceUpdate: function forceUpdate() { + if (isDestroyed) { + return; + } + + var _state$elements = state.elements, + reference = _state$elements.reference, + popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements + // anymore + + if (!areValidElements(reference, popper)) { + if (false) {} + + return; + } // Store the reference and popper rects to be read by modifiers + + + state.rects = { + reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'), + popper: getLayoutRect(popper) + }; // Modifiers have the ability to reset the current update cycle. The + // most common use case for this is the `flip` modifier changing the + // placement, which then needs to re-run all the modifiers, because the + // logic was previously ran for the previous placement and is therefore + // stale/incorrect + + state.reset = false; + state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier + // is filled with the initial data specified by the modifier. This means + // it doesn't persist and is fresh on each update. + // To ensure persistent data, use `${name}#persistent` + + state.orderedModifiers.forEach(function (modifier) { + return state.modifiersData[modifier.name] = Object.assign({}, modifier.data); + }); + var __debug_loops__ = 0; + + for (var index = 0; index < state.orderedModifiers.length; index++) { + if (false) {} + + if (state.reset === true) { + state.reset = false; + index = -1; + continue; + } + + var _state$orderedModifie = state.orderedModifiers[index], + fn = _state$orderedModifie.fn, + _state$orderedModifie2 = _state$orderedModifie.options, + _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, + name = _state$orderedModifie.name; + + if (typeof fn === 'function') { + state = fn({ + state: state, + options: _options, + name: name, + instance: instance + }) || state; + } + } + }, + // Async and optimistically optimized update – it will not be executed if + // not necessary (debounced to run at most once-per-tick) + update: debounce(function () { + return new Promise(function (resolve) { + instance.forceUpdate(); + resolve(state); + }); + }), + destroy: function destroy() { + cleanupModifierEffects(); + isDestroyed = true; + } + }; + + if (!areValidElements(reference, popper)) { + if (false) {} + + return instance; + } + + instance.setOptions(options).then(function (state) { + if (!isDestroyed && options.onFirstUpdate) { + options.onFirstUpdate(state); + } + }); // Modifiers have the ability to execute arbitrary code before the first + // update cycle runs. They will be executed in the same order as the update + // cycle. This is useful when a modifier adds some persistent data that + // other modifiers need to use, but the modifier is run after the dependent + // one. + + function runModifierEffects() { + state.orderedModifiers.forEach(function (_ref3) { + var name = _ref3.name, + _ref3$options = _ref3.options, + options = _ref3$options === void 0 ? {} : _ref3$options, + effect = _ref3.effect; + + if (typeof effect === 'function') { + var cleanupFn = effect({ + state: state, + name: name, + instance: instance, + options: options + }); + + var noopFn = function noopFn() {}; + + effectCleanupFns.push(cleanupFn || noopFn); + } + }); + } + + function cleanupModifierEffects() { + effectCleanupFns.forEach(function (fn) { + return fn(); + }); + effectCleanupFns = []; + } + + return instance; + }; +} +var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper.js + + + + + + + + + + +var defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles, modifiers_offset, modifiers_flip, modifiers_preventOverflow, modifiers_arrow, modifiers_hide]; +var popper_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper-lite.js + + + + + +var popper_lite_defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles]; +var popper_lite_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: popper_lite_defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/index.js + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + + +/***/ }), + +/***/ 902: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initAccordions = void 0; +var Default = { + alwaysOpen: false, + activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', + inactiveClasses: 'text-gray-500 dark:text-gray-400', + onOpen: function () { }, + onClose: function () { }, + onToggle: function () { }, +}; +var Accordion = /** @class */ (function () { + function Accordion(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Accordion.prototype._init = function () { + var _this = this; + if (this._items.length) { + // show accordion item based on click + this._items.map(function (item) { + if (item.active) { + _this.open(item.id); + } + item.triggerEl.addEventListener('click', function () { + _this.toggle(item.id); + }); + }); + } + }; + Accordion.prototype.getItem = function (id) { + return this._items.filter(function (item) { return item.id === id; })[0]; + }; + Accordion.prototype.open = function (id) { + var _a, _b; + var _this = this; + var item = this.getItem(id); + // don't hide other accordions if always open + if (!this._options.alwaysOpen) { + this._items.map(function (i) { + var _a, _b; + if (i !== item) { + (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + i.targetEl.classList.add('hidden'); + i.triggerEl.setAttribute('aria-expanded', 'false'); + i.active = false; + // rotate icon if set + if (i.iconEl) { + i.iconEl.classList.remove('rotate-180'); + } + } + }); + } + // show active item + (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + item.triggerEl.setAttribute('aria-expanded', 'true'); + item.targetEl.classList.remove('hidden'); + item.active = true; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.add('rotate-180'); + } + // callback function + this._options.onOpen(this, item); + }; + Accordion.prototype.toggle = function (id) { + var item = this.getItem(id); + if (item.active) { + this.close(id); + } + else { + this.open(id); + } + // callback function + this._options.onToggle(this, item); + }; + Accordion.prototype.close = function (id) { + var _a, _b; + var item = this.getItem(id); + (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); + item.targetEl.classList.add('hidden'); + item.triggerEl.setAttribute('aria-expanded', 'false'); + item.active = false; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.remove('rotate-180'); + } + // callback function + this._options.onClose(this, item); + }; + return Accordion; +}()); +function initAccordions() { + document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { + var alwaysOpen = $accordionEl.getAttribute('data-accordion'); + var activeClasses = $accordionEl.getAttribute('data-active-classes'); + var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); + var items = []; + $accordionEl + .querySelectorAll('[data-accordion-target]') + .forEach(function ($triggerEl) { + // Consider only items that directly belong to $accordionEl + // (to make nested accordions work). + if ($triggerEl.closest('[data-accordion]') === $accordionEl) { + var item = { + id: $triggerEl.getAttribute('data-accordion-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), + iconEl: $triggerEl.querySelector('[data-accordion-icon]'), + active: $triggerEl.getAttribute('aria-expanded') === 'true' + ? true + : false, + }; + items.push(item); + } + }); + new Accordion(items, { + alwaysOpen: alwaysOpen === 'open' ? true : false, + activeClasses: activeClasses + ? activeClasses + : Default.activeClasses, + inactiveClasses: inactiveClasses + ? inactiveClasses + : Default.inactiveClasses, + }); + }); +} +exports.initAccordions = initAccordions; +if (typeof window !== 'undefined') { + window.Accordion = Accordion; + window.initAccordions = initAccordions; +} +exports["default"] = Accordion; + + +/***/ }), + +/***/ 33: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCarousels = void 0; +var Default = { + defaultPosition: 0, + indicators: { + items: [], + activeClasses: 'bg-white dark:bg-gray-800', + inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', + }, + interval: 3000, + onNext: function () { }, + onPrev: function () { }, + onChange: function () { }, +}; +var Carousel = /** @class */ (function () { + function Carousel(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign(__assign({}, Default), options), { indicators: __assign(__assign({}, Default.indicators), options.indicators) }); + this._activeItem = this.getItem(this._options.defaultPosition); + this._indicators = this._options.indicators.items; + this._intervalDuration = this._options.interval; + this._intervalInstance = null; + this._init(); + } + /** + * initialize carousel and items based on active one + */ + Carousel.prototype._init = function () { + var _this = this; + this._items.map(function (item) { + item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); + }); + // if no active item is set then first position is default + if (this._getActiveItem()) { + this.slideTo(this._getActiveItem().position); + } + else { + this.slideTo(0); + } + this._indicators.map(function (indicator, position) { + indicator.el.addEventListener('click', function () { + _this.slideTo(position); + }); + }); + }; + Carousel.prototype.getItem = function (position) { + return this._items[position]; + }; + /** + * Slide to the element based on id + * @param {*} position + */ + Carousel.prototype.slideTo = function (position) { + var nextItem = this._items[position]; + var rotationItems = { + left: nextItem.position === 0 + ? this._items[this._items.length - 1] + : this._items[nextItem.position - 1], + middle: nextItem, + right: nextItem.position === this._items.length - 1 + ? this._items[0] + : this._items[nextItem.position + 1], + }; + this._rotate(rotationItems); + this._setActiveItem(nextItem); + if (this._intervalInstance) { + this.pause(); + this.cycle(); + } + this._options.onChange(this); + }; + /** + * Based on the currently active item it will go to the next position + */ + Carousel.prototype.next = function () { + var activeItem = this._getActiveItem(); + var nextItem = null; + // check if last item + if (activeItem.position === this._items.length - 1) { + nextItem = this._items[0]; + } + else { + nextItem = this._items[activeItem.position + 1]; + } + this.slideTo(nextItem.position); + // callback function + this._options.onNext(this); + }; + /** + * Based on the currently active item it will go to the previous position + */ + Carousel.prototype.prev = function () { + var activeItem = this._getActiveItem(); + var prevItem = null; + // check if first item + if (activeItem.position === 0) { + prevItem = this._items[this._items.length - 1]; + } + else { + prevItem = this._items[activeItem.position - 1]; + } + this.slideTo(prevItem.position); + // callback function + this._options.onPrev(this); + }; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + Carousel.prototype._rotate = function (rotationItems) { + // reset + this._items.map(function (item) { + item.el.classList.add('hidden'); + }); + // left item (previously active) + rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); + // currently active item + rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); + rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); + // right item (upcoming active) + rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.right.el.classList.add('translate-x-full', 'z-10'); + }; + /** + * Set an interval to cycle through the carousel items + */ + Carousel.prototype.cycle = function () { + var _this = this; + if (typeof window !== 'undefined') { + this._intervalInstance = window.setInterval(function () { + _this.next(); + }, this._intervalDuration); + } + }; + /** + * Clears the cycling interval + */ + Carousel.prototype.pause = function () { + clearInterval(this._intervalInstance); + }; + /** + * Get the currently active item + */ + Carousel.prototype._getActiveItem = function () { + return this._activeItem; + }; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + Carousel.prototype._setActiveItem = function (item) { + var _a, _b; + var _this = this; + this._activeItem = item; + var position = item.position; + // update the indicators if available + if (this._indicators.length) { + this._indicators.map(function (indicator) { + var _a, _b; + indicator.el.setAttribute('aria-current', 'false'); + (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); + (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); + }); + (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); + (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); + this._indicators[position].el.setAttribute('aria-current', 'true'); + } + }; + return Carousel; +}()); +function initCarousels() { + document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { + var interval = $carouselEl.getAttribute('data-carousel-interval'); + var slide = $carouselEl.getAttribute('data-carousel') === 'slide' + ? true + : false; + var items = []; + var defaultPosition = 0; + if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { + items.push({ + position: position, + el: $carouselItemEl, + }); + if ($carouselItemEl.getAttribute('data-carousel-item') === + 'active') { + defaultPosition = position; + } + }); + } + var indicators = []; + if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { + indicators.push({ + position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), + el: $indicatorEl, + }); + }); + } + var carousel = new Carousel(items, { + defaultPosition: defaultPosition, + indicators: { + items: indicators, + }, + interval: interval ? interval : Default.interval, + }); + if (slide) { + carousel.cycle(); + } + // check for controls + var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); + var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); + if (carouselNextEl) { + carouselNextEl.addEventListener('click', function () { + carousel.next(); + }); + } + if (carouselPrevEl) { + carouselPrevEl.addEventListener('click', function () { + carousel.prev(); + }); + } + }); +} +exports.initCarousels = initCarousels; +if (typeof window !== 'undefined') { + window.Carousel = Carousel; + window.initCarousels = initCarousels; +} +exports["default"] = Carousel; + + +/***/ }), + +/***/ 922: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCollapses = void 0; +var Default = { + onCollapse: function () { }, + onExpand: function () { }, + onToggle: function () { }, +}; +var Collapse = /** @class */ (function () { + function Collapse(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Collapse.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + if (this._triggerEl.hasAttribute('aria-expanded')) { + this._visible = + this._triggerEl.getAttribute('aria-expanded') === 'true'; + } + else { + // fix until v2 not to break previous single collapses which became dismiss + this._visible = !this._targetEl.classList.contains('hidden'); + } + this._triggerEl.addEventListener('click', function () { + _this.toggle(); + }); + } + }; + Collapse.prototype.collapse = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onCollapse(this); + }; + Collapse.prototype.expand = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onExpand(this); + }; + Collapse.prototype.toggle = function () { + if (this._visible) { + this.collapse(); + } + else { + this.expand(); + } + // callback function + this._options.onToggle(this); + }; + return Collapse; +}()); +function initCollapses() { + document + .querySelectorAll('[data-collapse-toggle]') + .forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-collapse-toggle'); + var $targetEl = document.getElementById(targetId); + // check if the target element exists + if ($targetEl) { + new Collapse($targetEl, $triggerEl); + } + else { + console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); + } + }); +} +exports.initCollapses = initCollapses; +if (typeof window !== 'undefined') { + window.Collapse = Collapse; + window.initCollapses = initCollapses; +} +exports["default"] = Collapse; + + +/***/ }), + +/***/ 556: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDials = void 0; +var Default = { + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dial = /** @class */ (function () { + function Dial(parentEl, triggerEl, targetEl, options) { + if (parentEl === void 0) { parentEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._parentEl = parentEl; + this._triggerEl = triggerEl; + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Dial.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); + triggerEventTypes.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEventTypes.hideEvents.forEach(function (ev) { + _this._parentEl.addEventListener(ev, function () { + if (!_this._parentEl.matches(':hover')) { + _this.hide(); + } + }); + }); + } + }; + Dial.prototype.hide = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Dial.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dial.prototype.toggle = function () { + if (this._visible) { + this.hide(); + } + else { + this.show(); + } + }; + Dial.prototype.isHidden = function () { + return !this._visible; + }; + Dial.prototype.isVisible = function () { + return this._visible; + }; + Dial.prototype._getTriggerEventTypes = function (triggerType) { + switch (triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + return Dial; +}()); +function initDials() { + document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { + var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); + if ($triggerEl) { + var dialId = $triggerEl.getAttribute('data-dial-toggle'); + var $dialEl = document.getElementById(dialId); + if ($dialEl) { + var triggerType = $triggerEl.getAttribute('data-dial-trigger'); + new Dial($parentEl, $triggerEl, $dialEl, { + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); + } + } + else { + console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); + } + }); +} +exports.initDials = initDials; +if (typeof window !== 'undefined') { + window.Dial = Dial; + window.initDials = initDials; +} +exports["default"] = Dial; + + +/***/ }), + +/***/ 791: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDismisses = void 0; +var Default = { + transition: 'transition-opacity', + duration: 300, + timing: 'ease-out', + onHide: function () { }, +}; +var Dismiss = /** @class */ (function () { + function Dismiss(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Dismiss.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + this._triggerEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Dismiss.prototype.hide = function () { + var _this = this; + this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); + setTimeout(function () { + _this._targetEl.classList.add('hidden'); + }, this._options.duration); + // callback function + this._options.onHide(this, this._targetEl); + }; + return Dismiss; +}()); +function initDismisses() { + document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-dismiss-target'); + var $dismissEl = document.querySelector(targetId); + if ($dismissEl) { + new Dismiss($dismissEl, $triggerEl); + } + else { + console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); + } + }); +} +exports.initDismisses = initDismisses; +if (typeof window !== 'undefined') { + window.Dismiss = Dismiss; + window.initDismisses = initDismisses; +} +exports["default"] = Dismiss; + + +/***/ }), + +/***/ 340: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDrawers = void 0; +var Default = { + placement: 'left', + bodyScrolling: false, + backdrop: true, + edge: false, + edgeOffset: 'bottom-[60px]', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Drawer = /** @class */ (function () { + function Drawer(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Drawer.prototype._init = function () { + var _this = this; + // set initial accessibility attributes + if (this._targetEl) { + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.classList.add('transition-transform'); + } + // set base placement classes + this._getPlacementClasses(this._options.placement).base.map(function (c) { + _this._targetEl.classList.add(c); + }); + // add keyboard event listener to document + document.addEventListener('keydown', function (event) { + if (event.key === 'Escape') { + // if 'Escape' key is pressed + if (_this.isVisible()) { + // if the Drawer is visible + _this.hide(); // hide the Drawer + } + } + }); + }; + Drawer.prototype.hide = function () { + var _this = this; + // based on the edge option show placement classes + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + // enable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.remove('overflow-hidden'); + } + // destroy backdrop + if (this._options.backdrop) { + this._destroyBackdropEl(); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Drawer.prototype.show = function () { + var _this = this; + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + // disable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.add('overflow-hidden'); + } + // show backdrop + if (this._options.backdrop) { + this._createBackdrop(); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Drawer.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Drawer.prototype._createBackdrop = function () { + var _a; + var _this = this; + if (!this._visible) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('drawer-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + backdropEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Drawer.prototype._destroyBackdropEl = function () { + if (this._visible) { + document.querySelector('[drawer-backdrop]').remove(); + } + }; + Drawer.prototype._getPlacementClasses = function (placement) { + switch (placement) { + case 'top': + return { + base: ['top-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['-translate-y-full'], + }; + case 'right': + return { + base: ['right-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-x-full'], + }; + case 'bottom': + return { + base: ['bottom-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['translate-y-full'], + }; + case 'left': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + case 'bottom-edge': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-y-full', this._options.edgeOffset], + }; + default: + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + } + }; + Drawer.prototype.isHidden = function () { + return !this._visible; + }; + Drawer.prototype.isVisible = function () { + return this._visible; + }; + return Drawer; +}()); +var getDrawerInstance = function (id, instances) { + if (instances.some(function (drawerInstance) { return drawerInstance.id === id; })) { + return instances.find(function (drawerInstance) { return drawerInstance.id === id; }); + } +}; +function initDrawers() { + var drawerInstances = []; + document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { + // mandatory + var drawerId = $triggerEl.getAttribute('data-drawer-target'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + // optional + var placement = $triggerEl.getAttribute('data-drawer-placement'); + var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); + var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); + var edge = $triggerEl.getAttribute('data-drawer-edge'); + var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); + if (!getDrawerInstance(drawerId, drawerInstances)) { + drawerInstances.push({ + id: drawerId, + object: new Drawer($drawerEl, { + placement: placement ? placement : Default.placement, + bodyScrolling: bodyScrolling + ? bodyScrolling === 'true' + ? true + : false + : Default.bodyScrolling, + backdrop: backdrop + ? backdrop === 'true' + ? true + : false + : Default.backdrop, + edge: edge + ? edge === 'true' + ? true + : false + : Default.edge, + edgeOffset: edgeOffset + ? edgeOffset + : Default.edgeOffset, + }), + }); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_1 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_1) { + $triggerEl.addEventListener('click', function () { + drawer_1.object.toggle(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document + .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') + .forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') + ? $triggerEl.getAttribute('data-drawer-dismiss') + : $triggerEl.getAttribute('data-drawer-hide'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_2 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_2) { + $triggerEl.addEventListener('click', function () { + drawer_2.object.hide(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); + } + }); + document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-show'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_3 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_3) { + $triggerEl.addEventListener('click', function () { + drawer_3.object.show(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); +} +exports.initDrawers = initDrawers; +if (typeof window !== 'undefined') { + window.Drawer = Drawer; + window.initDrawers = initDrawers; +} +exports["default"] = Drawer; + + +/***/ }), + +/***/ 316: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDropdowns = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'bottom', + triggerType: 'click', + offsetSkidding: 0, + offsetDistance: 10, + delay: 300, + ignoreClickOutsideClass: false, + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dropdown = /** @class */ (function () { + function Dropdown(targetElement, triggerElement, options) { + if (targetElement === void 0) { targetElement = null; } + if (triggerElement === void 0) { triggerElement = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetElement; + this._triggerEl = triggerElement; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Dropdown.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Dropdown.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + // click event handling for trigger element + if (this._options.triggerType === 'click') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.toggle(); + }); + }); + } + // hover event handling for trigger element + if (this._options.triggerType === 'hover') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + if (ev === 'click') { + _this.toggle(); + } + else { + setTimeout(function () { + _this.show(); + }, _this._options.delay); + } + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + }); + } + }; + Dropdown.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [ + this._options.offsetSkidding, + this._options.offsetDistance, + ], + }, + }, + ], + }); + }; + Dropdown.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + // Ignore clicks on the trigger element (ie. a datepicker input) + var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; + var isIgnored = false; + if (ignoreClickOutsideClass) { + var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); + ignoredClickOutsideEls.forEach(function (el) { + if (el.contains(clickedEl)) { + isIgnored = true; + return; + } + }); + } + // Ignore clicks on the target element (ie. dropdown itself) + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + !isIgnored && + this.isVisible()) { + this.hide(); + } + }; + Dropdown.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'click'], + hideEvents: ['mouseleave'], + }; + case 'click': + return { + showEvents: ['click'], + hideEvents: [], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['click'], + hideEvents: [], + }; + } + }; + Dropdown.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Dropdown.prototype.isVisible = function () { + return this._visible; + }; + Dropdown.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + this._targetEl.classList.add('block'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + this._setupClickOutsideListener(); + // Update its position + this._popperInstance.update(); + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dropdown.prototype.hide = function () { + this._targetEl.classList.remove('block'); + this._targetEl.classList.add('hidden'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + this._visible = false; + this._removeClickOutsideListener(); + // callback function + this._options.onHide(this); + }; + return Dropdown; +}()); +function initDropdowns() { + document + .querySelectorAll('[data-dropdown-toggle]') + .forEach(function ($triggerEl) { + var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); + var $dropdownEl = document.getElementById(dropdownId); + if ($dropdownEl) { + var placement = $triggerEl.getAttribute('data-dropdown-placement'); + var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); + var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); + var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); + var delay = $triggerEl.getAttribute('data-dropdown-delay'); + var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); + new Dropdown($dropdownEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + offsetSkidding: offsetSkidding + ? parseInt(offsetSkidding) + : Default.offsetSkidding, + offsetDistance: offsetDistance + ? parseInt(offsetDistance) + : Default.offsetDistance, + delay: delay ? parseInt(delay) : Default.delay, + ignoreClickOutsideClass: ignoreClickOutsideClass + ? ignoreClickOutsideClass + : Default.ignoreClickOutsideClass, + }); + } + else { + console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); + } + }); +} +exports.initDropdowns = initDropdowns; +if (typeof window !== 'undefined') { + window.Dropdown = Dropdown; + window.initDropdowns = initDropdowns; +} +exports["default"] = Dropdown; + + +/***/ }), + +/***/ 311: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initFlowbite = void 0; +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +function initFlowbite() { + (0, accordion_1.initAccordions)(); + (0, collapse_1.initCollapses)(); + (0, carousel_1.initCarousels)(); + (0, dismiss_1.initDismisses)(); + (0, dropdown_1.initDropdowns)(); + (0, modal_1.initModals)(); + (0, drawer_1.initDrawers)(); + (0, tabs_1.initTabs)(); + (0, tooltip_1.initTooltips)(); + (0, popover_1.initPopovers)(); + (0, dial_1.initDials)(); +} +exports.initFlowbite = initFlowbite; +if (typeof window !== 'undefined') { + window.initFlowbite = initFlowbite; +} + + +/***/ }), + +/***/ 16: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initModals = void 0; +var Default = { + placement: 'center', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + backdrop: 'dynamic', + closable: true, + onHide: function () { }, + onShow: function () { }, + onToggle: function () { }, +}; +var Modal = /** @class */ (function () { + function Modal(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._isHidden = true; + this._backdropEl = null; + this._init(); + } + Modal.prototype._init = function () { + var _this = this; + if (this._targetEl) { + this._getPlacementClasses().map(function (c) { + _this._targetEl.classList.add(c); + }); + } + }; + Modal.prototype._createBackdrop = function () { + var _a; + if (this._isHidden) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('modal-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + this._backdropEl = backdropEl; + } + }; + Modal.prototype._destroyBackdropEl = function () { + if (!this._isHidden) { + document.querySelector('[modal-backdrop]').remove(); + } + }; + Modal.prototype._setupModalCloseEventListeners = function () { + var _this = this; + if (this._options.backdrop === 'dynamic') { + this._clickOutsideEventListener = function (ev) { + _this._handleOutsideClick(ev.target); + }; + this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); + } + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._removeModalCloseEventListeners = function () { + if (this._options.backdrop === 'dynamic') { + this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); + } + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._handleOutsideClick = function (target) { + if (target === this._targetEl || + (target === this._backdropEl && this.isVisible())) { + this.hide(); + } + }; + Modal.prototype._getPlacementClasses = function () { + switch (this._options.placement) { + // top + case 'top-left': + return ['justify-start', 'items-start']; + case 'top-center': + return ['justify-center', 'items-start']; + case 'top-right': + return ['justify-end', 'items-start']; + // center + case 'center-left': + return ['justify-start', 'items-center']; + case 'center': + return ['justify-center', 'items-center']; + case 'center-right': + return ['justify-end', 'items-center']; + // bottom + case 'bottom-left': + return ['justify-start', 'items-end']; + case 'bottom-center': + return ['justify-center', 'items-end']; + case 'bottom-right': + return ['justify-end', 'items-end']; + default: + return ['justify-center', 'items-center']; + } + }; + Modal.prototype.toggle = function () { + if (this._isHidden) { + this.show(); + } + else { + this.hide(); + } + // callback function + this._options.onToggle(this); + }; + Modal.prototype.show = function () { + if (this.isHidden) { + this._targetEl.classList.add('flex'); + this._targetEl.classList.remove('hidden'); + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + this._createBackdrop(); + this._isHidden = false; + // prevent body scroll + document.body.classList.add('overflow-hidden'); + // Add keyboard event listener to the document + if (this._options.closable) { + this._setupModalCloseEventListeners(); + } + // callback function + this._options.onShow(this); + } + }; + Modal.prototype.hide = function () { + if (this.isVisible) { + this._targetEl.classList.add('hidden'); + this._targetEl.classList.remove('flex'); + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + this._destroyBackdropEl(); + this._isHidden = true; + // re-apply body scroll + document.body.classList.remove('overflow-hidden'); + if (this._options.closable) { + this._removeModalCloseEventListeners(); + } + // callback function + this._options.onHide(this); + } + }; + Modal.prototype.isVisible = function () { + return !this._isHidden; + }; + Modal.prototype.isHidden = function () { + return this._isHidden; + }; + return Modal; +}()); +var getModalInstance = function (id, instances) { + if (instances.some(function (modalInstance) { return modalInstance.id === id; })) { + return instances.find(function (modalInstance) { return modalInstance.id === id; }); + } + return null; +}; +function initModals() { + var modalInstances = []; + // initiate modal based on data-modal-target + document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-target'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + if (!getModalInstance(modalId, modalInstances)) { + modalInstances.push({ + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); + } + }); + // support pre v1.6.0 data-modal-toggle initialization + document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-toggle'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + var modal_1 = getModalInstance(modalId, modalInstances); + if (!modal_1) { + modal_1 = { + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }; + modalInstances.push(modal_1); + } + $triggerEl.addEventListener('click', function () { + modal_1.object.toggle(); + }); + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); + } + }); + // show modal on click if exists based on id + document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-show'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_2 = getModalInstance(modalId, modalInstances); + if (modal_2) { + $triggerEl.addEventListener('click', function () { + if (modal_2.object.isHidden) { + modal_2.object.show(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); + } + }); + // hide modal on click if exists based on id + document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-hide'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_3 = getModalInstance(modalId, modalInstances); + if (modal_3) { + $triggerEl.addEventListener('click', function () { + if (modal_3.object.isVisible) { + modal_3.object.hide(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); + } + }); +} +exports.initModals = initModals; +if (typeof window !== 'undefined') { + window.Modal = Modal; + window.initModals = initModals; +} +exports["default"] = Modal; + + +/***/ }), + +/***/ 903: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initPopovers = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + offset: 10, + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Popover = /** @class */ (function () { + function Popover(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Popover.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Popover.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + }); + }; + Popover.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, this._options.offset], + }, + }, + ], + }); + }; + Popover.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Popover.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Popover.prototype.isVisible = function () { + return this._visible; + }; + Popover.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Popover.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility to true + this._visible = true; + // callback function + this._options.onShow(this); + }; + Popover.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility to false + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Popover; +}()); +function initPopovers() { + document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { + var popoverID = $triggerEl.getAttribute('data-popover-target'); + var $popoverEl = document.getElementById(popoverID); + if ($popoverEl) { + var triggerType = $triggerEl.getAttribute('data-popover-trigger'); + var placement = $triggerEl.getAttribute('data-popover-placement'); + var offset = $triggerEl.getAttribute('data-popover-offset'); + new Popover($popoverEl, $triggerEl, { + placement: placement ? placement : Default.placement, + offset: offset ? parseInt(offset) : Default.offset, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); + } + }); +} +exports.initPopovers = initPopovers; +if (typeof window !== 'undefined') { + window.Popover = Popover; + window.initPopovers = initPopovers; +} +exports["default"] = Popover; + + +/***/ }), + +/***/ 247: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTabs = void 0; +var Default = { + defaultTabId: null, + activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', + inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', + onShow: function () { }, +}; +var Tabs = /** @class */ (function () { + function Tabs(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._activeTab = options ? this.getTab(options.defaultTabId) : null; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Tabs.prototype._init = function () { + var _this = this; + if (this._items.length) { + // set the first tab as active if not set by explicitly + if (!this._activeTab) { + this._setActiveTab(this._items[0]); + } + // force show the first default tab + this.show(this._activeTab.id, true); + // show tab content based on click + this._items.map(function (tab) { + tab.triggerEl.addEventListener('click', function () { + _this.show(tab.id); + }); + }); + } + }; + Tabs.prototype.getActiveTab = function () { + return this._activeTab; + }; + Tabs.prototype._setActiveTab = function (tab) { + this._activeTab = tab; + }; + Tabs.prototype.getTab = function (id) { + return this._items.filter(function (t) { return t.id === id; })[0]; + }; + Tabs.prototype.show = function (id, forceShow) { + var _a, _b; + var _this = this; + if (forceShow === void 0) { forceShow = false; } + var tab = this.getTab(id); + // don't do anything if already active + if (tab === this._activeTab && !forceShow) { + return; + } + // hide other tabs + this._items.map(function (t) { + var _a, _b; + if (t !== tab) { + (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + t.targetEl.classList.add('hidden'); + t.triggerEl.setAttribute('aria-selected', 'false'); + } + }); + // show active tab + (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + tab.triggerEl.setAttribute('aria-selected', 'true'); + tab.targetEl.classList.remove('hidden'); + this._setActiveTab(tab); + // callback function + this._options.onShow(this, tab); + }; + return Tabs; +}()); +function initTabs() { + document.querySelectorAll('[data-tabs-toggle]').forEach(function ($triggerEl) { + var tabItems = []; + var defaultTabId = null; + $triggerEl + .querySelectorAll('[role="tab"]') + .forEach(function ($triggerEl) { + var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; + var tab = { + id: $triggerEl.getAttribute('data-tabs-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), + }; + tabItems.push(tab); + if (isActive) { + defaultTabId = tab.id; + } + }); + new Tabs(tabItems, { + defaultTabId: defaultTabId, + }); + }); +} +exports.initTabs = initTabs; +if (typeof window !== 'undefined') { + window.Tabs = Tabs; + window.initTabs = initTabs; +} +exports["default"] = Tabs; + + +/***/ }), + +/***/ 671: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTooltips = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Tooltip = /** @class */ (function () { + function Tooltip(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Tooltip.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Tooltip.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.hide(); + }); + }); + }; + Tooltip.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, 8], + }, + }, + ], + }); + }; + Tooltip.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Tooltip.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Tooltip.prototype.isVisible = function () { + return this._visible; + }; + Tooltip.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Tooltip.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility + this._visible = true; + // callback function + this._options.onShow(this); + }; + Tooltip.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Tooltip; +}()); +function initTooltips() { + document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { + var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); + var $tooltipEl = document.getElementById(tooltipId); + if ($tooltipEl) { + var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); + var placement = $triggerEl.getAttribute('data-tooltip-placement'); + new Tooltip($tooltipEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); + } + }); +} +exports.initTooltips = initTooltips; +if (typeof window !== 'undefined') { + window.Tooltip = Tooltip; + window.initTooltips = initTooltips; +} +exports["default"] = Tooltip; + + +/***/ }), + +/***/ 947: +/***/ (function(__unused_webpack_module, exports) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +var Events = /** @class */ (function () { + function Events(eventType, eventFunctions) { + if (eventFunctions === void 0) { eventFunctions = []; } + this._eventType = eventType; + this._eventFunctions = eventFunctions; + } + Events.prototype.init = function () { + var _this = this; + this._eventFunctions.forEach(function (eventFunction) { + if (typeof window !== 'undefined') { + window.addEventListener(_this._eventType, eventFunction); + } + }); + }; + return Events; +}()); +exports["default"] = Events; + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ !function() { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = function(exports, definition) { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ }(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ !function() { +/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } +/******/ }(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ !function() { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ }(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. +!function() { +var exports = __webpack_exports__; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +// core components +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +__webpack_require__(311); +var events_1 = __webpack_require__(947); +var liveViewLoadEvents = new events_1.default('phx:page-loading-stop', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +liveViewLoadEvents.init(); +var regularViewLoadEvents = new events_1.default('load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +regularViewLoadEvents.init(); +exports["default"] = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; + +}(); +/******/ return __webpack_exports__; +/******/ })() +; +}); +//# sourceMappingURL=flowbite.phoenix.js.map \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.phoenix.js.map b/node_modules/flowbite/dist/flowbite.phoenix.js.map new file mode 100644 index 0000000..4896d72 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.phoenix.js.map @@ -0,0 +1 @@ +{"version":3,"file":"flowbite.phoenix.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACVO,IAAI,SAAG;AACP;AACA;AACA;AACA;AACA,sBAAsB,SAAG;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACP;AACA,CAAC;AACM,IAAI,gBAAU;AACrB;AACA,CAAC,OAAO;;AAED;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA;AACA;;AC9BQ;AACf;AACA;;ACFe;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;ACXuC;;AAEvC;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,SAAS;AAC5B;AACA;;;;ACpBsD;AACK,CAAC;AAC5D;;AAEA;AACA;AACA;AACA;AACA;AACA,wCAAwC;;AAExC,SAAS,aAAa,cAAc,WAAW;AAC/C;AACA,MAAM;AACN;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uHAAuH;;AAEvH;AACA;AACA;AACA,OAAO,IAAI,GAAG;;AAEd,WAAW,aAAa,cAAc,WAAW;AACjD;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA,EAAE;;;AAGF,0DAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;ACnFkC;AACpB;AACf;AACA;;ACHO,IAAI,QAAG;AACP,IAAI,QAAG;AACP;;ACFQ;AACf;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;ACVgD;AACjC;AACf,gDAAgD,WAAW;AAC3D;;ACH2D;AAClB;AACF;A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CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc,IAAI;AAClB,cAAc,SAAG;AACjB;;AAEA;AACA,uBAAuB,eAAe;AACtC;AACA;;AAEA,yBAAyB,SAAS;AAClC,qBAAqB,kBAAkB;;AAEvC,UAAU,gBAAgB;AAC1B;AACA;AACA;AACA,MAAM;;;AAGN;;AAEA,sBAAsB,SAAG,mBAAmB,IAAI,kBAAkB,KAAK,mBAAmB,GAAG;AAC7F,cAAc,MAAM;AACpB;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,IAAI,mBAAmB,SAAG,kBAAkB,MAAM,mBAAmB,GAAG;AAC9F,cAAc,KAAK;AACnB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,2BAA2B,oCAAoC;AAC/D;;AAEA,yBAAyB,qCAAqC;AAC9D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAM,KAAqC,EAAE,2BAQ1C;;AAEH;AACA,eAAe,gBAAgB;AAC/B,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C,mDAAmD;AAC7F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,yCAAyC,kDAAkD;AAC3F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,4CAA4C;AAC5C;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACpLiD,CAAC;;AAEnD;AACA;AACA;;AAEA,SAAS,qBAAM;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA,sBAAsB;AACtB,UAAU,qBAAM;AAChB;AACA,CAAC;;AChDD;AACA;AACA;AACA;AACA;AACA;AACe;AACf;AACA;AACA,GAAG;AACH;;ACVA,IAAI,kCAAI;AACR;AACA;AACA;AACe;AACf;AACA,WAAW,kCAAI;AACf,GAAG;AACH;;ACRuC;AACxB;AACf,YAAY,SAAS;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;ACT+D;AACN;AACN;AACpC;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,qBAAqB,CAAC,kBAAkB,kBAAkB,eAAe;AAClF;;ACZuC;AACkB;AACE;AACN;AACtC;AACf,YAAY,SAAS;AACrB,aAAa,kBAAkB;AAC/B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB,gBAAgB;;AAEzC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,mBAAmB;AAC9B;AACA;AACA;;AC9ByD;AACJ;AACM;AACR;AACZ,CAAC;AACxC;;AAEe;AACf;;AAEA,aAAa,kBAAkB;AAC/B,kBAAkB,eAAe;AACjC;AACA,cAAc,QAAG;AACjB,eAAe,QAAG;AAClB,kCAAkC,mBAAmB;AACrD;;AAEA,MAAM,gBAAgB;AACtB,SAAS,QAAG;AACZ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BqD;AACtC;AACf;AACA,0BAA0B,gBAAgB;AAC1C;AACA;AACA;;AAEA;AACA;;ACT+C;AACE;AACN;AACK;AACjC;AACf,4CAA4C,WAAW;AACvD;AACA;AACA;;AAEA,MAAM,aAAa,UAAU,cAAc;AAC3C;AACA;;AAEA,yBAAyB,aAAa;AACtC;;ACfmD;AACJ;AACR;AACU;AACjD;AACA;AACA;AACA;AACA;AACA;;AAEe;AACf;;AAEA;AACA;AACA;;AAEA,qBAAqB,eAAe;AACpC;AACA,YAAY,SAAS;AACrB,+DAA+D,cAAc;AAC7E;AACA;AACA,uCAAuC,aAAa;AACpD;;ACzBe;AACf,yBAAyB;AACzB;AACA;AACA;AACA;AACA,GAAG;AACH;;ACPuC;AACY;AACA;AACI;AACJ;AACM;AACJ;AACM;AACI;AAChB;AACV;AACM;AACiB;AAChB;;AAE5C;AACA,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4BAA4B,QAAQ,GAAG,gBAAgB,CAAC,eAAe,uBAAuB,SAAS,0EAA0E,gBAAgB,CAAC,eAAe,CAAC,kBAAkB;AACpO,EAAE;AACF;AACA;;;AAGA;AACA,wBAAwB,iBAAiB,CAAC,aAAa;AACvD,wDAAwD,gBAAgB;AACxE,4CAA4C,aAAa,YAAY,eAAe;;AAEpF,OAAO,SAAS;AAChB;AACA,IAAI;;;AAGJ;AACA,WAAW,SAAS,oBAAoB,QAAQ,oCAAoC,WAAW;AAC/F,GAAG;AACH,EAAE;AACF;;;AAGe;AACf;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAG;AACrB,oBAAoB,QAAG;AACvB,qBAAqB,QAAG;AACxB,mBAAmB,QAAG;AACtB;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;ACrEqD;AACR;AACwB;AACF;AACpD;AACf;AACA;AACA;AACA,kCAAkC,gBAAgB;AAClD,8BAA8B,YAAY;AAC1C;AACA;AACA;;AAEA;AACA,SAAS,SAAG;AACZ;AACA;AACA;AACA;AACA;;AAEA,SAAS,MAAM;AACf;AACA;AACA;AACA;AACA;;AAEA,SAAS,KAAK;AACd;AACA;AACA;AACA;AACA;;AAEA,SAAS,IAAI;AACb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,iCAAiC,wBAAwB;;AAEzD;AACA;;AAEA;AACA,WAAW,KAAK;AAChB;AACA;;AAEA,WAAW,GAAG;AACd;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;ACrE8D;AACM;AACM;AACzB;AACI;AAC0D;AACxD;AACE;AACN,CAAC;;AAErC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,eAAe;AAC/D;AACA,wDAAwD,QAAQ;AAChE;AACA,0DAA0D,MAAM;AAChE;AACA;AACA;AACA;AACA,sBAAsB,kBAAkB,yCAAyC,eAAe,UAAU,cAAc;AACxH,sCAAsC,MAAM,GAAG,SAAS,GAAG,MAAM;AACjE;AACA;AACA,2BAA2B,eAAe,CAAC,SAAS,gDAAgD,kBAAkB;AACtH,4BAA4B,qBAAqB;AACjD,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA,GAAG;AACH,yBAAyB,gBAAgB,iBAAiB;AAC1D,6CAA6C,MAAM,2CAA2C;AAC9F;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;;AAE/C,yBAAyB,MAAM;AAC/B;AACA;AACA,sBAAsB,KAAK,EAAE,MAAM;AACnC,kBAAkB,SAAG,EAAE,MAAM;AAC7B;AACA,KAAK;AACL;;AAEA;AACA;;AChE6C;AACkD;AAC9C;AACI;AACtC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAiE,gBAAa;AAC9E,kBAAkB,YAAY;AAC9B,gDAAgD,mBAAmB,GAAG,0BAA0B;AAChG,WAAW,YAAY;AACvB,GAAG,IAAI,cAAc;AACrB;AACA;AACA,GAAG;;AAEH;AACA;;AAEA,QAAQ,KAAqC,EAAE,EAE1C;AACL,IAAI;;;AAGJ;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA,KAAK,EAAE,gBAAgB;AACvB;AACA,GAAG,IAAI;AACP;AACA;AACA,GAAG;AACH;;AC9CoE;AACR;AAC0B;AAC9B;AACY;AACA;AAChB,CAAC;;AAErD;AACA,MAAM,gBAAgB,gBAAgB,IAAI;AAC1C;AACA;;AAEA,0BAA0B,oBAAoB;AAC9C,UAAU,6BAA6B,gCAAgC,6BAA6B;AACpG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,gBAAgB;AACtC;AACA,iGAAiG,oBAAoB;AACrH;AACA,sBAAsB,gBAAgB,gBAAgB,IAAI,GAAG,oBAAoB;AACjF;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,uBAAuB;AACzC;;AAEA,yBAAyB,gBAAgB;;AAEzC,2BAA2B,YAAY,gBAAgB,KAAK;AAC5D,sBAAsB,SAAG,EAAE,MAAM;AACjC;AACA,mBAAmB,cAAc;AACjC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,4DAA4D,KAAK,GAAG,IAAI,sBAAsB,MAAM,GAAG,SAAG;;AAE1G;AACA,0BAA0B,oBAAoB;AAC9C;;AAEA,2BAA2B,oBAAoB;AAC/C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,QAAQ;AAC1C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AClJsD;AACC;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,SAAG,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI;AAClC;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC5D2D;AACD,CAAC;;AAErD;AACP,sBAAsB,gBAAgB;AACtC,wBAAwB,IAAI,EAAE,SAAG;;AAEjC,mEAAmE;AACnE;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,UAAU,IAAI,EAAE,KAAK;AACrB;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,uBAAiB;AAC9B;AACA;AACA,GAAG,IAAI;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,qDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACrDuD;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,cAAc;AAC5C;AACA;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACxBc;AACf;AACA;;ACF8D;AACF;AACgB;AAC5B;AACY;AACF;AACI;AACN;AACJ;AACY;AACE;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA,GAAG;AACH,sBAAsB,gBAAgB;AACtC,kBAAkB,YAAY;AAC9B;AACA,iBAAiB,wBAAwB;AACzC,gBAAgB,UAAU;AAC1B;AACA;AACA;AACA,4FAA4F;AAC5F;AACA,GAAG;AACH;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,sCAAsC,SAAG,GAAG,IAAI;AAChD,qCAAqC,MAAM,GAAG,KAAK;AACnD;AACA;AACA;AACA;AACA;AACA,+BAA+B,KAAK;AACpC,+BAA+B,KAAK,2CAA2C;AAC/E;;AAEA;AACA,6CAA6C,aAAa;AAC1D;AACA;AACA;AACA,yHAAyH,kBAAkB;AAC3I;AACA,uDAAuD;AACvD;AACA;AACA;AACA;;AAEA,mBAAmB,MAAM;AACzB;AACA;AACA,oDAAoD,eAAe;AACnE;AACA;AACA;AACA;AACA,0BAA0B,MAAM,UAAU,QAAO,yCAAyC,QAAO;AACjG;AACA;AACA;;AAEA;AACA;;AAEA,uCAAuC,SAAG,GAAG,IAAI;;AAEjD,sCAAsC,MAAM,GAAG,KAAK;;AAEpD;;AAEA;;AAEA;;AAEA;;AAEA,wBAAwB,SAAG,EAAE,IAAI;;AAEjC;;AAEA;;AAEA;;AAEA,oDAAoD,cAAc,oCAAoC,MAAM;;AAE5G;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,8DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC7IyD;AACZ;AACgB;AACE;AACpB;AACA;AACI;AACc;;;ACP/C;AACf;AACA;AACA;AACA;AACA;;ACLmD;AACZ;AACS;AACa;AAC9C;AACf,eAAe,SAAS,WAAW,aAAa;AAChD,WAAW,eAAe;AAC1B,IAAI;AACJ,WAAW,oBAAoB;AAC/B;AACA;;ACV+D;AAChB;AACJ;AACK;AACW;AACF;AACR;AACR;;AAEzC;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB;AACA,EAAE;AACF;;;AAGe;AACf;AACA;AACA;;AAEA,gCAAgC,aAAa;AAC7C,6BAA6B,aAAa;AAC1C,wBAAwB,kBAAkB;AAC1C,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,QAAQ,WAAW;AACnB,IAAI,cAAc;AAClB,eAAe,aAAa;AAC5B;;AAEA,QAAQ,aAAa;AACrB,gBAAgB,qBAAqB;AACrC;AACA;AACA,MAAM;AACN,kBAAkB,mBAAmB;AACrC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzD6C,CAAC;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,GAAG;;AAEN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEe;AACf;AACA,2CAA2C;;AAE3C,SAAS,qBAAqB;AAC9B;AACA;AACA,KAAK;AACL,GAAG;AACH;;AC3Ce;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;;AAEA;AACA;AACA;;ACde;AACf;AACA;AACA,sDAAsD;AACtD,+BAA+B;AAC/B,4BAA4B;AAC5B,KAAK;AACL;AACA,GAAG,IAAI,GAAG;;AAEV;AACA;AACA,GAAG;AACH;;ACb+D;AACN;AACQ;AACJ;AACE;AACR;AACZ;AACkB;AAClB;AACgB;AACV;AACM;AACD;AACpB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,sEAAsE,aAAa;AACnF;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,+BAA+B;AAC/B,uBAAuB;AACvB;AACA;AACA;AACA,OAAO;AACP,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC;AACA,qBAAqB,SAAS,cAAc,iBAAiB,yCAAyC,iBAAiB;AACvH,kBAAkB,iBAAiB;AACnC,WAAW;AACX;;AAEA,+BAA+B,cAAc,CAAC,WAAW,yDAAyD;;AAElH;AACA;AACA,SAAS,GAAG;AACZ;;AAEA,YAAY,KAAqC,EAAE,qGA+B1C;;AAET;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,6CAA6C;AAC7C;;AAEA;AACA,cAAc,KAAqC,EAAE,EAE1C;;AAEX;AACA,UAAU;;;AAGV;AACA,qBAAqB,gBAAgB,YAAY,eAAe;AAChE,kBAAkB,aAAa;AAC/B,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA,mDAAmD;AACnD;AACA;AACA,6CAA6C,KAAK;;AAElD;AACA,sEAAsE;AACtE,SAAS;AACT;;AAEA,4BAA4B,uCAAuC;AACnE,cAAc,KAAqC,EAAE,EAO1C;;AAEX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE;AAChE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,OAAO;AACP;AACA;AACA,cAAc,QAAQ;AACtB;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,KAAqC,EAAE,EAE1C;;AAEP;AACA;;AAEA;AACA;AACA;AACA;AA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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///./node_modules/@popperjs/core/lib/enums.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindow.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/applyStyles.js","webpack:///./node_modules/@popperjs/core/lib/utils/getBasePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/math.js","webpack:///./node_modules/@popperjs/core/lib/utils/userAgent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/contains.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","webpack:///./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/within.js","webpack:///./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/expandToHashMap.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/arrow.js","webpack:///./node_modules/@popperjs/core/lib/utils/getVariation.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/computeStyles.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/eventListeners.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","webpack:///./node_modules/@popperjs/core/lib/utils/rectToClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/detectOverflow.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/flip.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/hide.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/offset.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/getAltAxis.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/index.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/orderModifiers.js","webpack:///./node_modules/@popperjs/core/lib/utils/debounce.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergeByName.js","webpack:///./node_modules/@popperjs/core/lib/createPopper.js","webpack:///./node_modules/@popperjs/core/lib/popper.js","webpack:///./node_modules/@popperjs/core/lib/popper-lite.js","webpack:///./node_modules/@popperjs/core/lib/index.js","webpack:///./src/components/accordion/index.ts","webpack:///./src/components/carousel/index.ts","webpack:///./src/components/collapse/index.ts","webpack:///./src/components/dial/index.ts","webpack:///./src/components/dismiss/index.ts","webpack:///./src/components/drawer/index.ts","webpack:///./src/components/dropdown/index.ts","webpack:///./src/components/index.ts","webpack:///./src/components/modal/index.ts","webpack:///./src/components/popover/index.ts","webpack:///./src/components/tabs/index.ts","webpack:///./src/components/tooltip/index.ts","webpack:///./src/dom/events.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///./src/index.phoenix.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"Flowbite\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Flowbite\"] = factory();\n\telse\n\t\troot[\"Flowbite\"] = factory();\n})(self, function() {\nreturn ","export var top = 'top';\nexport var bottom = 'bottom';\nexport var right = 'right';\nexport var left = 'left';\nexport var auto = 'auto';\nexport var basePlacements = [top, bottom, right, left];\nexport var start = 'start';\nexport var end = 'end';\nexport var clippingParents = 'clippingParents';\nexport var viewport = 'viewport';\nexport var popper = 'popper';\nexport var reference = 'reference';\nexport var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) {\n return acc.concat([placement + \"-\" + start, placement + \"-\" + end]);\n}, []);\nexport var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) {\n return acc.concat([placement, placement + \"-\" + start, placement + \"-\" + end]);\n}, []); // modifiers that need to read the DOM\n\nexport var beforeRead = 'beforeRead';\nexport var read = 'read';\nexport var afterRead = 'afterRead'; // pure-logic modifiers\n\nexport var beforeMain = 'beforeMain';\nexport var main = 'main';\nexport var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state)\n\nexport var beforeWrite = 'beforeWrite';\nexport var write = 'write';\nexport var afterWrite = 'afterWrite';\nexport var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];","export default function getNodeName(element) {\n return element ? (element.nodeName || '').toLowerCase() : null;\n}","export default function getWindow(node) {\n if (node == null) {\n return window;\n }\n\n if (node.toString() !== '[object Window]') {\n var ownerDocument = node.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView || window : window;\n }\n\n return node;\n}","import getWindow from \"./getWindow.js\";\n\nfunction isElement(node) {\n var OwnElement = getWindow(node).Element;\n return node instanceof OwnElement || node instanceof Element;\n}\n\nfunction isHTMLElement(node) {\n var OwnElement = getWindow(node).HTMLElement;\n return node instanceof OwnElement || node instanceof HTMLElement;\n}\n\nfunction isShadowRoot(node) {\n // IE 11 has no ShadowRoot\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n\n var OwnElement = getWindow(node).ShadowRoot;\n return node instanceof OwnElement || node instanceof ShadowRoot;\n}\n\nexport { isElement, isHTMLElement, isShadowRoot };","import getNodeName from \"../dom-utils/getNodeName.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // This modifier takes the styles prepared by the `computeStyles` modifier\n// and applies them to the HTMLElements such as popper and arrow\n\nfunction applyStyles(_ref) {\n var state = _ref.state;\n Object.keys(state.elements).forEach(function (name) {\n var style = state.styles[name] || {};\n var attributes = state.attributes[name] || {};\n var element = state.elements[name]; // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n } // Flow doesn't support to extend this property, but it's the most\n // effective way to apply styles to an HTMLElement\n // $FlowFixMe[cannot-write]\n\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (name) {\n var value = attributes[name];\n\n if (value === false) {\n element.removeAttribute(name);\n } else {\n element.setAttribute(name, value === true ? '' : value);\n }\n });\n });\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state;\n var initialStyles = {\n popper: {\n position: state.options.strategy,\n left: '0',\n top: '0',\n margin: '0'\n },\n arrow: {\n position: 'absolute'\n },\n reference: {}\n };\n Object.assign(state.elements.popper.style, initialStyles.popper);\n state.styles = initialStyles;\n\n if (state.elements.arrow) {\n Object.assign(state.elements.arrow.style, initialStyles.arrow);\n }\n\n return function () {\n Object.keys(state.elements).forEach(function (name) {\n var element = state.elements[name];\n var attributes = state.attributes[name] || {};\n var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them\n\n var style = styleProperties.reduce(function (style, property) {\n style[property] = '';\n return style;\n }, {}); // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n }\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (attribute) {\n element.removeAttribute(attribute);\n });\n });\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'applyStyles',\n enabled: true,\n phase: 'write',\n fn: applyStyles,\n effect: effect,\n requires: ['computeStyles']\n};","import { auto } from \"../enums.js\";\nexport default function getBasePlacement(placement) {\n return placement.split('-')[0];\n}","export var max = Math.max;\nexport var min = Math.min;\nexport var round = Math.round;","export default function getUAString() {\n var uaData = navigator.userAgentData;\n\n if (uaData != null && uaData.brands) {\n return uaData.brands.map(function (item) {\n return item.brand + \"/\" + item.version;\n }).join(' ');\n }\n\n return navigator.userAgent;\n}","import getUAString from \"../utils/userAgent.js\";\nexport default function isLayoutViewport() {\n return !/^((?!chrome|android).)*safari/i.test(getUAString());\n}","import { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport { round } from \"../utils/math.js\";\nimport getWindow from \"./getWindow.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getBoundingClientRect(element, includeScale, isFixedStrategy) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n\n var clientRect = element.getBoundingClientRect();\n var scaleX = 1;\n var scaleY = 1;\n\n if (includeScale && isHTMLElement(element)) {\n scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export { default as applyStyles } from \"./applyStyles.js\";\nexport { default as arrow } from \"./arrow.js\";\nexport { default as computeStyles } from \"./computeStyles.js\";\nexport { default as eventListeners } from \"./eventListeners.js\";\nexport { default as flip } from \"./flip.js\";\nexport { default as hide } from \"./hide.js\";\nexport { default as offset } from \"./offset.js\";\nexport { default as popperOffsets } from \"./popperOffsets.js\";\nexport { default as preventOverflow } from \"./preventOverflow.js\";","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","export * from \"./enums.js\";\nexport * from \"./modifiers/index.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { popperGenerator, detectOverflow, createPopper as createPopperBase } from \"./createPopper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper } from \"./popper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\";","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst liveViewLoadEvents = new Events('phx:page-loading-stop', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nliveViewLoadEvents.init();\n\nconst regularViewLoadEvents = new Events('load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nregularViewLoadEvents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.phoenix.min.js b/node_modules/flowbite/dist/flowbite.phoenix.min.js new file mode 100644 index 0000000..7a06472 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.phoenix.min.js @@ -0,0 +1,2 @@ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("Flowbite",[],e):"object"==typeof exports?exports.Flowbite=e():t.Flowbite=e()}(self,(function(){return function(){"use strict";var t={853:function(t,e,i){i.r(e),i.d(e,{afterMain:function(){return E},afterRead:function(){return _},afterWrite:function(){return x},applyStyles:function(){return D},arrow:function(){return Z},auto:function(){return a},basePlacements:function(){return c},beforeMain:function(){return b},beforeRead:function(){return m},beforeWrite:function(){return L},bottom:function(){return o},clippingParents:function(){return u},computeStyles:function(){return it},createPopper:function(){return Dt},createPopperBase:function(){return Pt},createPopperLite:function(){return St},detectOverflow:function(){return yt},end:function(){return d},eventListeners:function(){return ot},flip:function(){return _t},hide:function(){return Et},left:function(){return s},main:function(){return w},modifierPhases:function(){return k},offset:function(){return Lt},placements:function(){return v},popper:function(){return f},popperGenerator:function(){return jt},popperOffsets:function(){return Ot},preventOverflow:function(){return xt},read:function(){return y},reference:function(){return h},right:function(){return r},start:function(){return l},top:function(){return n},variationPlacements:function(){return g},viewport:function(){return p},write:function(){return O}});var n="top",o="bottom",r="right",s="left",a="auto",c=[n,o,r,s],l="start",d="end",u="clippingParents",p="viewport",f="popper",h="reference",g=c.reduce((function(t,e){return t.concat([e+"-"+l,e+"-"+d])}),[]),v=[].concat(c,[a]).reduce((function(t,e){return t.concat([e,e+"-"+l,e+"-"+d])}),[]),m="beforeRead",y="read",_="afterRead",b="beforeMain",w="main",E="afterMain",L="beforeWrite",O="write",x="afterWrite",k=[m,y,_,b,w,E,L,O,x];function A(t){return t?(t.nodeName||"").toLowerCase():null}function T(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function C(t){return t instanceof T(t).Element||t instanceof Element}function j(t){return t instanceof T(t).HTMLElement||t instanceof HTMLElement}function P(t){return"undefined"!=typeof ShadowRoot&&(t instanceof T(t).ShadowRoot||t instanceof ShadowRoot)}var D={name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var i=e.styles[t]||{},n=e.attributes[t]||{},o=e.elements[t];j(o)&&A(o)&&(Object.assign(o.style,i),Object.keys(n).forEach((function(t){var e=n[t];!1===e?o.removeAttribute(t):o.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,i={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,i.popper),e.styles=i,e.elements.arrow&&Object.assign(e.elements.arrow.style,i.arrow),function(){Object.keys(e.elements).forEach((function(t){var n=e.elements[t],o=e.attributes[t]||{},r=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:i[t]).reduce((function(t,e){return t[e]="",t}),{});j(n)&&A(n)&&(Object.assign(n.style,r),Object.keys(o).forEach((function(t){n.removeAttribute(t)})))}))}},requires:["computeStyles"]};function S(t){return t.split("-")[0]}var I=Math.max,M=Math.min,q=Math.round;function H(){var t=navigator.userAgentData;return null!=t&&t.brands?t.brands.map((function(t){return t.brand+"/"+t.version})).join(" "):navigator.userAgent}function B(){return!/^((?!chrome|android).)*safari/i.test(H())}function V(t,e,i){void 0===e&&(e=!1),void 0===i&&(i=!1);var n=t.getBoundingClientRect(),o=1,r=1;e&&j(t)&&(o=t.offsetWidth>0&&q(n.width)/t.offsetWidth||1,r=t.offsetHeight>0&&q(n.height)/t.offsetHeight||1);var s=(C(t)?T(t):window).visualViewport,a=!B()&&i,c=(n.left+(a&&s?s.offsetLeft:0))/o,l=(n.top+(a&&s?s.offsetTop:0))/r,d=n.width/o,u=n.height/r;return{width:d,height:u,top:l,right:c+d,bottom:l+u,left:c,x:c,y:l}}function W(t){var e=V(t),i=t.offsetWidth,n=t.offsetHeight;return Math.abs(e.width-i)<=1&&(i=e.width),Math.abs(e.height-n)<=1&&(n=e.height),{x:t.offsetLeft,y:t.offsetTop,width:i,height:n}}function z(t,e){var i=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(i&&P(i)){var n=e;do{if(n&&t.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function R(t){return T(t).getComputedStyle(t)}function F(t){return["table","td","th"].indexOf(A(t))>=0}function N(t){return((C(t)?t.ownerDocument:t.document)||window.document).documentElement}function K(t){return"html"===A(t)?t:t.assignedSlot||t.parentNode||(P(t)?t.host:null)||N(t)}function U(t){return j(t)&&"fixed"!==R(t).position?t.offsetParent:null}function X(t){for(var e=T(t),i=U(t);i&&F(i)&&"static"===R(i).position;)i=U(i);return i&&("html"===A(i)||"body"===A(i)&&"static"===R(i).position)?e:i||function(t){var e=/firefox/i.test(H());if(/Trident/i.test(H())&&j(t)&&"fixed"===R(t).position)return null;var i=K(t);for(P(i)&&(i=i.host);j(i)&&["html","body"].indexOf(A(i))<0;){var n=R(i);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||e&&"filter"===n.willChange||e&&n.filter&&"none"!==n.filter)return i;i=i.parentNode}return null}(t)||e}function Y(t){return["top","bottom"].indexOf(t)>=0?"x":"y"}function G(t,e,i){return I(t,M(e,i))}function J(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function Q(t,e){return e.reduce((function(e,i){return e[i]=t,e}),{})}var Z={name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,i=t.state,a=t.name,l=t.options,d=i.elements.arrow,u=i.modifiersData.popperOffsets,p=S(i.placement),f=Y(p),h=[s,r].indexOf(p)>=0?"height":"width";if(d&&u){var g=function(t,e){return J("number"!=typeof(t="function"==typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:Q(t,c))}(l.padding,i),v=W(d),m="y"===f?n:s,y="y"===f?o:r,_=i.rects.reference[h]+i.rects.reference[f]-u[f]-i.rects.popper[h],b=u[f]-i.rects.reference[f],w=X(d),E=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,L=_/2-b/2,O=g[m],x=E-v[h]-g[y],k=E/2-v[h]/2+L,A=G(O,k,x),T=f;i.modifiersData[a]=((e={})[T]=A,e.centerOffset=A-k,e)}},effect:function(t){var e=t.state,i=t.options.element,n=void 0===i?"[data-popper-arrow]":i;null!=n&&("string"!=typeof n||(n=e.elements.popper.querySelector(n)))&&z(e.elements.popper,n)&&(e.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function $(t){return t.split("-")[1]}var tt={top:"auto",right:"auto",bottom:"auto",left:"auto"};function et(t){var e,i=t.popper,a=t.popperRect,c=t.placement,l=t.variation,u=t.offsets,p=t.position,f=t.gpuAcceleration,h=t.adaptive,g=t.roundOffsets,v=t.isFixed,m=u.x,y=void 0===m?0:m,_=u.y,b=void 0===_?0:_,w="function"==typeof g?g({x:y,y:b}):{x:y,y:b};y=w.x,b=w.y;var E=u.hasOwnProperty("x"),L=u.hasOwnProperty("y"),O=s,x=n,k=window;if(h){var A=X(i),C="clientHeight",j="clientWidth";if(A===T(i)&&"static"!==R(A=N(i)).position&&"absolute"===p&&(C="scrollHeight",j="scrollWidth"),c===n||(c===s||c===r)&&l===d)x=o,b-=(v&&A===k&&k.visualViewport?k.visualViewport.height:A[C])-a.height,b*=f?1:-1;if(c===s||(c===n||c===o)&&l===d)O=r,y-=(v&&A===k&&k.visualViewport?k.visualViewport.width:A[j])-a.width,y*=f?1:-1}var P,D=Object.assign({position:p},h&&tt),S=!0===g?function(t){var e=t.x,i=t.y,n=window.devicePixelRatio||1;return{x:q(e*n)/n||0,y:q(i*n)/n||0}}({x:y,y:b}):{x:y,y:b};return y=S.x,b=S.y,f?Object.assign({},D,((P={})[x]=L?"0":"",P[O]=E?"0":"",P.transform=(k.devicePixelRatio||1)<=1?"translate("+y+"px, "+b+"px)":"translate3d("+y+"px, "+b+"px, 0)",P)):Object.assign({},D,((e={})[x]=L?b+"px":"",e[O]=E?y+"px":"",e.transform="",e))}var it={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,i=t.options,n=i.gpuAcceleration,o=void 0===n||n,r=i.adaptive,s=void 0===r||r,a=i.roundOffsets,c=void 0===a||a,l={placement:S(e.placement),variation:$(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:o,isFixed:"fixed"===e.options.strategy};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,et(Object.assign({},l,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:s,roundOffsets:c})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,et(Object.assign({},l,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:c})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}},nt={passive:!0};var ot={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(t){var e=t.state,i=t.instance,n=t.options,o=n.scroll,r=void 0===o||o,s=n.resize,a=void 0===s||s,c=T(e.elements.popper),l=[].concat(e.scrollParents.reference,e.scrollParents.popper);return r&&l.forEach((function(t){t.addEventListener("scroll",i.update,nt)})),a&&c.addEventListener("resize",i.update,nt),function(){r&&l.forEach((function(t){t.removeEventListener("scroll",i.update,nt)})),a&&c.removeEventListener("resize",i.update,nt)}},data:{}},rt={left:"right",right:"left",bottom:"top",top:"bottom"};function st(t){return t.replace(/left|right|bottom|top/g,(function(t){return rt[t]}))}var at={start:"end",end:"start"};function ct(t){return t.replace(/start|end/g,(function(t){return at[t]}))}function lt(t){var e=T(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function dt(t){return V(N(t)).left+lt(t).scrollLeft}function ut(t){var e=R(t),i=e.overflow,n=e.overflowX,o=e.overflowY;return/auto|scroll|overlay|hidden/.test(i+o+n)}function pt(t){return["html","body","#document"].indexOf(A(t))>=0?t.ownerDocument.body:j(t)&&ut(t)?t:pt(K(t))}function ft(t,e){var i;void 0===e&&(e=[]);var n=pt(t),o=n===(null==(i=t.ownerDocument)?void 0:i.body),r=T(n),s=o?[r].concat(r.visualViewport||[],ut(n)?n:[]):n,a=e.concat(s);return o?a:a.concat(ft(K(s)))}function ht(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function gt(t,e,i){return e===p?ht(function(t,e){var i=T(t),n=N(t),o=i.visualViewport,r=n.clientWidth,s=n.clientHeight,a=0,c=0;if(o){r=o.width,s=o.height;var l=B();(l||!l&&"fixed"===e)&&(a=o.offsetLeft,c=o.offsetTop)}return{width:r,height:s,x:a+dt(t),y:c}}(t,i)):C(e)?function(t,e){var i=V(t,!1,"fixed"===e);return i.top=i.top+t.clientTop,i.left=i.left+t.clientLeft,i.bottom=i.top+t.clientHeight,i.right=i.left+t.clientWidth,i.width=t.clientWidth,i.height=t.clientHeight,i.x=i.left,i.y=i.top,i}(e,i):ht(function(t){var e,i=N(t),n=lt(t),o=null==(e=t.ownerDocument)?void 0:e.body,r=I(i.scrollWidth,i.clientWidth,o?o.scrollWidth:0,o?o.clientWidth:0),s=I(i.scrollHeight,i.clientHeight,o?o.scrollHeight:0,o?o.clientHeight:0),a=-n.scrollLeft+dt(t),c=-n.scrollTop;return"rtl"===R(o||i).direction&&(a+=I(i.clientWidth,o?o.clientWidth:0)-r),{width:r,height:s,x:a,y:c}}(N(t)))}function vt(t,e,i,n){var o="clippingParents"===e?function(t){var e=ft(K(t)),i=["absolute","fixed"].indexOf(R(t).position)>=0&&j(t)?X(t):t;return C(i)?e.filter((function(t){return C(t)&&z(t,i)&&"body"!==A(t)})):[]}(t):[].concat(e),r=[].concat(o,[i]),s=r[0],a=r.reduce((function(e,i){var o=gt(t,i,n);return e.top=I(o.top,e.top),e.right=M(o.right,e.right),e.bottom=M(o.bottom,e.bottom),e.left=I(o.left,e.left),e}),gt(t,s,n));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}function mt(t){var e,i=t.reference,a=t.element,c=t.placement,u=c?S(c):null,p=c?$(c):null,f=i.x+i.width/2-a.width/2,h=i.y+i.height/2-a.height/2;switch(u){case n:e={x:f,y:i.y-a.height};break;case o:e={x:f,y:i.y+i.height};break;case r:e={x:i.x+i.width,y:h};break;case s:e={x:i.x-a.width,y:h};break;default:e={x:i.x,y:i.y}}var g=u?Y(u):null;if(null!=g){var v="y"===g?"height":"width";switch(p){case l:e[g]=e[g]-(i[v]/2-a[v]/2);break;case d:e[g]=e[g]+(i[v]/2-a[v]/2)}}return e}function yt(t,e){void 0===e&&(e={});var i=e,s=i.placement,a=void 0===s?t.placement:s,l=i.strategy,d=void 0===l?t.strategy:l,g=i.boundary,v=void 0===g?u:g,m=i.rootBoundary,y=void 0===m?p:m,_=i.elementContext,b=void 0===_?f:_,w=i.altBoundary,E=void 0!==w&&w,L=i.padding,O=void 0===L?0:L,x=J("number"!=typeof O?O:Q(O,c)),k=b===f?h:f,A=t.rects.popper,T=t.elements[E?k:b],j=vt(C(T)?T:T.contextElement||N(t.elements.popper),v,y,d),P=V(t.elements.reference),D=mt({reference:P,element:A,strategy:"absolute",placement:a}),S=ht(Object.assign({},A,D)),I=b===f?S:P,M={top:j.top-I.top+x.top,bottom:I.bottom-j.bottom+x.bottom,left:j.left-I.left+x.left,right:I.right-j.right+x.right},q=t.modifiersData.offset;if(b===f&&q){var H=q[a];Object.keys(M).forEach((function(t){var e=[r,o].indexOf(t)>=0?1:-1,i=[n,o].indexOf(t)>=0?"y":"x";M[t]+=H[i]*e}))}return M}var _t={name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,d=t.name;if(!e.modifiersData[d]._skip){for(var u=i.mainAxis,p=void 0===u||u,f=i.altAxis,h=void 0===f||f,m=i.fallbackPlacements,y=i.padding,_=i.boundary,b=i.rootBoundary,w=i.altBoundary,E=i.flipVariations,L=void 0===E||E,O=i.allowedAutoPlacements,x=e.options.placement,k=S(x),A=m||(k===x||!L?[st(x)]:function(t){if(S(t)===a)return[];var e=st(t);return[ct(t),e,ct(e)]}(x)),T=[x].concat(A).reduce((function(t,i){return t.concat(S(i)===a?function(t,e){void 0===e&&(e={});var i=e,n=i.placement,o=i.boundary,r=i.rootBoundary,s=i.padding,a=i.flipVariations,l=i.allowedAutoPlacements,d=void 0===l?v:l,u=$(n),p=u?a?g:g.filter((function(t){return $(t)===u})):c,f=p.filter((function(t){return d.indexOf(t)>=0}));0===f.length&&(f=p);var h=f.reduce((function(e,i){return e[i]=yt(t,{placement:i,boundary:o,rootBoundary:r,padding:s})[S(i)],e}),{});return Object.keys(h).sort((function(t,e){return h[t]-h[e]}))}(e,{placement:i,boundary:_,rootBoundary:b,padding:y,flipVariations:L,allowedAutoPlacements:O}):i)}),[]),C=e.rects.reference,j=e.rects.popper,P=new Map,D=!0,I=T[0],M=0;M=0,W=V?"width":"height",z=yt(e,{placement:q,boundary:_,rootBoundary:b,altBoundary:w,padding:y}),R=V?B?r:s:B?o:n;C[W]>j[W]&&(R=st(R));var F=st(R),N=[];if(p&&N.push(z[H]<=0),h&&N.push(z[R]<=0,z[F]<=0),N.every((function(t){return t}))){I=q,D=!1;break}P.set(q,N)}if(D)for(var K=function(t){var e=T.find((function(e){var i=P.get(e);if(i)return i.slice(0,t).every((function(t){return t}))}));if(e)return I=e,"break"},U=L?3:1;U>0;U--){if("break"===K(U))break}e.placement!==I&&(e.modifiersData[d]._skip=!0,e.placement=I,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}};function bt(t,e,i){return void 0===i&&(i={x:0,y:0}),{top:t.top-e.height-i.y,right:t.right-e.width+i.x,bottom:t.bottom-e.height+i.y,left:t.left-e.width-i.x}}function wt(t){return[n,r,o,s].some((function(e){return t[e]>=0}))}var Et={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,i=t.name,n=e.rects.reference,o=e.rects.popper,r=e.modifiersData.preventOverflow,s=yt(e,{elementContext:"reference"}),a=yt(e,{altBoundary:!0}),c=bt(s,n),l=bt(a,o,r),d=wt(c),u=wt(l);e.modifiersData[i]={referenceClippingOffsets:c,popperEscapeOffsets:l,isReferenceHidden:d,hasPopperEscaped:u},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":d,"data-popper-escaped":u})}};var Lt={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,i=t.options,o=t.name,a=i.offset,c=void 0===a?[0,0]:a,l=v.reduce((function(t,i){return t[i]=function(t,e,i){var o=S(t),a=[s,n].indexOf(o)>=0?-1:1,c="function"==typeof i?i(Object.assign({},e,{placement:t})):i,l=c[0],d=c[1];return l=l||0,d=(d||0)*a,[s,r].indexOf(o)>=0?{x:d,y:l}:{x:l,y:d}}(i,e.rects,c),t}),{}),d=l[e.placement],u=d.x,p=d.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=u,e.modifiersData.popperOffsets.y+=p),e.modifiersData[o]=l}};var Ot={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,i=t.name;e.modifiersData[i]=mt({reference:e.rects.reference,element:e.rects.popper,strategy:"absolute",placement:e.placement})},data:{}};var xt={name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,a=t.name,c=i.mainAxis,d=void 0===c||c,u=i.altAxis,p=void 0!==u&&u,f=i.boundary,h=i.rootBoundary,g=i.altBoundary,v=i.padding,m=i.tether,y=void 0===m||m,_=i.tetherOffset,b=void 0===_?0:_,w=yt(e,{boundary:f,rootBoundary:h,padding:v,altBoundary:g}),E=S(e.placement),L=$(e.placement),O=!L,x=Y(E),k="x"===x?"y":"x",A=e.modifiersData.popperOffsets,T=e.rects.reference,C=e.rects.popper,j="function"==typeof b?b(Object.assign({},e.rects,{placement:e.placement})):b,P="number"==typeof j?{mainAxis:j,altAxis:j}:Object.assign({mainAxis:0,altAxis:0},j),D=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,q={x:0,y:0};if(A){if(d){var H,B="y"===x?n:s,V="y"===x?o:r,z="y"===x?"height":"width",R=A[x],F=R+w[B],N=R-w[V],K=y?-C[z]/2:0,U=L===l?T[z]:C[z],J=L===l?-C[z]:-T[z],Q=e.elements.arrow,Z=y&&Q?W(Q):{width:0,height:0},tt=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},et=tt[B],it=tt[V],nt=G(0,T[z],Z[z]),ot=O?T[z]/2-K-nt-et-P.mainAxis:U-nt-et-P.mainAxis,rt=O?-T[z]/2+K+nt+it+P.mainAxis:J+nt+it+P.mainAxis,st=e.elements.arrow&&X(e.elements.arrow),at=st?"y"===x?st.clientTop||0:st.clientLeft||0:0,ct=null!=(H=null==D?void 0:D[x])?H:0,lt=R+rt-ct,dt=G(y?M(F,R+ot-ct-at):F,R,y?I(N,lt):N);A[x]=dt,q[x]=dt-R}if(p){var ut,pt="x"===x?n:s,ft="x"===x?o:r,ht=A[k],gt="y"===k?"height":"width",vt=ht+w[pt],mt=ht-w[ft],_t=-1!==[n,s].indexOf(E),bt=null!=(ut=null==D?void 0:D[k])?ut:0,wt=_t?vt:ht-T[gt]-C[gt]-bt+P.altAxis,Et=_t?ht+T[gt]+C[gt]-bt-P.altAxis:mt,Lt=y&&_t?function(t,e,i){var n=G(t,e,i);return n>i?i:n}(wt,ht,Et):G(y?wt:vt,ht,y?Et:mt);A[k]=Lt,q[k]=Lt-ht}e.modifiersData[a]=q}},requiresIfExists:["offset"]};function kt(t,e,i){void 0===i&&(i=!1);var n,o,r=j(e),s=j(e)&&function(t){var e=t.getBoundingClientRect(),i=q(e.width)/t.offsetWidth||1,n=q(e.height)/t.offsetHeight||1;return 1!==i||1!==n}(e),a=N(e),c=V(t,s,i),l={scrollLeft:0,scrollTop:0},d={x:0,y:0};return(r||!r&&!i)&&(("body"!==A(e)||ut(a))&&(l=(n=e)!==T(n)&&j(n)?{scrollLeft:(o=n).scrollLeft,scrollTop:o.scrollTop}:lt(n)),j(e)?((d=V(e,!0)).x+=e.clientLeft,d.y+=e.clientTop):a&&(d.x=dt(a))),{x:c.left+l.scrollLeft-d.x,y:c.top+l.scrollTop-d.y,width:c.width,height:c.height}}function At(t){var e=new Map,i=new Set,n=[];function o(t){i.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!i.has(t)){var n=e.get(t);n&&o(n)}})),n.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){i.has(t.name)||o(t)})),n}var Tt={placement:"bottom",modifiers:[],strategy:"absolute"};function Ct(){for(var t=arguments.length,e=new Array(t),i=0;i 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst liveViewLoadEvents = new Events('phx:page-loading-stop', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nliveViewLoadEvents.init();\n\nconst regularViewLoadEvents = new Events('load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nregularViewLoadEvents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":["root","factory","exports","module","define","amd","self","bottom","right","left","auto","basePlacements","start","end","clippingParents","viewport","popper","reference","variationPlacements","reduce","acc","placement","concat","beforeRead","read","afterRead","beforeMain","main","afterMain","beforeWrite","write","afterWrite","modifierPhases","getNodeName","element","nodeName","toLowerCase","getWindow","node","window","toString","ownerDocument","defaultView","isElement","Element","isHTMLElement","HTMLElement","isShadowRoot","ShadowRoot","name","enabled","phase","fn","_ref","state","Object","keys","elements","forEach","style","styles","attributes","assign","value","removeAttribute","setAttribute","effect","_ref2","initialStyles","position","options","strategy","top","margin","arrow","hasOwnProperty","property","attribute","requires","getBasePlacement","split","Math","max","min","round","getUAString","uaData","navigator","userAgentData","brands","map","item","brand","version","join","userAgent","isLayoutViewport","test","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scaleX","scaleY","offsetWidth","width","offsetHeight","height","visualViewport","addVisualOffsets","x","offsetLeft","y","offsetTop","getLayoutRect","abs","contains","parent","child","rootNode","getRootNode","next","isSameNode","parentNode","host","getComputedStyle","isTableElement","indexOf","getDocumentElement","document","documentElement","getParentNode","assignedSlot","getTrueOffsetParent","offsetParent","getOffsetParent","isFirefox","currentNode","css","transform","perspective","contain","willChange","filter","getContainingBlock","getMainAxisFromPlacement","within","mergePaddingObject","paddingObject","expandToHashMap","hashMap","key","_state$modifiersData$","arrowElement","popperOffsets","modifiersData","basePlacement","axis","len","padding","rects","toPaddingObject","arrowRect","minProp","maxProp","endDiff","startDiff","arrowOffsetParent","clientSize","clientHeight","clientWidth","centerToReference","center","offset","axisProp","centerOffset","_options$element","querySelector","requiresIfExists","getVariation","unsetSides","mapToStyles","_Object$assign2","popperRect","variation","offsets","gpuAcceleration","adaptive","roundOffsets","isFixed","_offsets$x","_offsets$y","_ref3","hasX","hasY","sideX","sideY","win","heightProp","widthProp","_Object$assign","commonStyles","_ref4","dpr","devicePixelRatio","roundOffsetsByDPR","_ref5","_options$gpuAccelerat","_options$adaptive","_options$roundOffsets","data","passive","instance","_options$scroll","scroll","_options$resize","resize","scrollParents","scrollParent","addEventListener","update","removeEventListener","hash","getOppositePlacement","replace","matched","getOppositeVariationPlacement","getWindowScroll","scrollLeft","pageXOffset","scrollTop","pageYOffset","getWindowScrollBarX","isScrollParent","_getComputedStyle","overflow","overflowX","overflowY","getScrollParent","body","listScrollParents","list","_element$ownerDocumen","isBody","target","updatedList","rectToClientRect","rect","getClientRectFromMixedType","clippingParent","html","layoutViewport","getViewportRect","clientTop","clientLeft","getInnerBoundingClientRect","winScroll","scrollWidth","scrollHeight","direction","getDocumentRect","getClippingRect","boundary","rootBoundary","mainClippingParents","clipperElement","getClippingParents","firstClippingParent","clippingRect","accRect","computeOffsets","commonX","commonY","mainAxis","detectOverflow","_options","_options$placement","_options$strategy","_options$boundary","_options$rootBoundary","_options$elementConte","elementContext","_options$altBoundary","altBoundary","_options$padding","altContext","clippingClientRect","contextElement","referenceClientRect","popperClientRect","elementClientRect","overflowOffsets","offsetData","multiply","_skip","_options$mainAxis","checkMainAxis","_options$altAxis","altAxis","checkAltAxis","specifiedFallbackPlacements","fallbackPlacements","_options$flipVariatio","flipVariations","allowedAutoPlacements","preferredPlacement","oppositePlacement","getExpandedFallbackPlacements","placements","_options$allowedAutoP","allowedPlacements","length","overflows","sort","a","b","computeAutoPlacement","referenceRect","checksMap","Map","makeFallbackChecks","firstFittingPlacement","i","_basePlacement","isStartVariation","isVertical","mainVariationSide","altVariationSide","checks","push","every","check","set","_loop","_i","fittingPlacement","find","get","slice","reset","getSideOffsets","preventedOffsets","isAnySideFullyClipped","some","side","preventOverflow","referenceOverflow","popperAltOverflow","referenceClippingOffsets","popperEscapeOffsets","isReferenceHidden","hasPopperEscaped","_options$offset","invertDistance","skidding","distance","distanceAndSkiddingToXY","_data$state$placement","_options$tether","tether","_options$tetherOffset","tetherOffset","isBasePlacement","tetherOffsetValue","normalizedTetherOffsetValue","offsetModifierState","_offsetModifierState$","mainSide","altSide","additive","minLen","maxLen","arrowPaddingObject","arrowPaddingMin","arrowPaddingMax","arrowLen","minOffset","maxOffset","clientOffset","offsetModifierValue","tetherMax","preventedOffset","_offsetModifierState$2","_mainSide","_altSide","_offset","_len","_min","_max","isOriginSide","_offsetModifierValue","_tetherMin","_tetherMax","_preventedOffset","v","withinMaxClamp","getCompositeRect","elementOrVirtualElement","isOffsetParentAnElement","offsetParentIsScaled","isElementScaled","order","modifiers","visited","Set","result","modifier","add","dep","has","depModifier","DEFAULT_OPTIONS","areValidElements","arguments","args","Array","_key","popperGenerator","generatorOptions","_generatorOptions","_generatorOptions$def","defaultModifiers","_generatorOptions$def2","defaultOptions","pending","orderedModifiers","effectCleanupFns","isDestroyed","setOptions","setOptionsAction","cleanupModifierEffects","orderModifiers","merged","current","existing","mergeByName","m","_ref3$options","cleanupFn","noopFn","forceUpdate","_state$elements","index","_state$orderedModifie","_state$orderedModifie2","Promise","resolve","then","undefined","destroy","onFirstUpdate","createPopper","eventListeners","Default","alwaysOpen","activeClasses","inactiveClasses","onOpen","onClose","onToggle","items","this","_items","_init","active","open","id","triggerEl","toggle","getItem","classList","remove","targetEl","iconEl","close","initAccordions","querySelectorAll","$accordionEl","getAttribute","$triggerEl","closest","Accordion","defaultPosition","indicators","interval","onNext","onPrev","onChange","_activeItem","_indicators","_intervalDuration","_intervalInstance","el","_getActiveItem","slideTo","indicator","nextItem","rotationItems","middle","_rotate","_setActiveItem","pause","cycle","activeItem","prev","prevItem","setInterval","clearInterval","initCarousels","$carouselEl","slide","from","$carouselItemEl","$indicatorEl","parseInt","carousel","Carousel","carouselNextEl","carouselPrevEl","onCollapse","onExpand","_targetEl","_triggerEl","_visible","hasAttribute","collapse","expand","initCollapses","targetId","$targetEl","getElementById","Collapse","console","error","triggerType","onShow","onHide","parentEl","_parentEl","triggerEventTypes","_getTriggerEventTypes","showEvents","ev","show","hideEvents","matches","hide","isHidden","isVisible","initDials","$parentEl","dialId","$dialEl","Dial","transition","duration","timing","setTimeout","initDismisses","$dismissEl","Dismiss","bodyScrolling","backdrop","edge","edgeOffset","backdropClasses","_getPlacementClasses","base","c","event","inactive","_destroyBackdropEl","_createBackdrop","backdropEl","createElement","append","getDrawerInstance","instances","drawerInstance","initDrawers","drawerInstances","drawerId","$drawerEl","object","Drawer","offsetSkidding","offsetDistance","delay","ignoreClickOutsideClass","targetElement","triggerElement","_popperInstance","_createPopperInstance","_setupEventListeners","triggerEvents","_getTriggerEvents","_setupClickOutsideListener","_clickOutsideEventListener","_handleClickOutside","_removeClickOutsideListener","clickedEl","isIgnored","initDropdowns","dropdownId","$dropdownEl","Dropdown","initFlowbite","initModals","initTabs","initTooltips","initPopovers","closable","_isHidden","_backdropEl","_setupModalCloseEventListeners","_handleOutsideClick","_keydownEventListener","_removeModalCloseEventListeners","getModalInstance","modalInstance","modalInstances","modalId","$modalEl","Modal","_setupKeydownListener","_removeKeydownListener","popoverID","$popoverEl","Popover","defaultTabId","_activeTab","getTab","_setActiveTab","tab","getActiveTab","t","forceShow","tabItems","isActive","Tabs","tooltipId","$tooltipEl","Tooltip","eventType","eventFunctions","_eventType","_eventFunctions","init","eventFunction","Events","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","d","definition","o","defineProperty","enumerable","obj","prop","prototype","r","Symbol","toStringTag"],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.turbo.js b/node_modules/flowbite/dist/flowbite.turbo.js new file mode 100644 index 0000000..ac78acb --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.turbo.js @@ -0,0 +1,4438 @@ +(function webpackUniversalModuleDefinition(root, factory) { + if(typeof exports === 'object' && typeof module === 'object') + module.exports = factory(); + else if(typeof define === 'function' && define.amd) + define("Flowbite", [], factory); + else if(typeof exports === 'object') + exports["Flowbite"] = factory(); + else + root["Flowbite"] = factory(); +})(self, function() { +return /******/ (function() { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ 853: +/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { + +// ESM COMPAT FLAG +__webpack_require__.r(__webpack_exports__); + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "afterMain": function() { return /* reexport */ afterMain; }, + "afterRead": function() { return /* reexport */ afterRead; }, + "afterWrite": function() { return /* reexport */ afterWrite; }, + "applyStyles": function() { return /* reexport */ modifiers_applyStyles; }, + "arrow": function() { return /* reexport */ modifiers_arrow; }, + "auto": function() { return /* reexport */ auto; }, + "basePlacements": function() { return /* reexport */ basePlacements; }, + "beforeMain": function() { return /* reexport */ beforeMain; }, + "beforeRead": function() { return /* reexport */ beforeRead; }, + "beforeWrite": function() { return /* reexport */ beforeWrite; }, + "bottom": function() { return /* reexport */ bottom; }, + "clippingParents": function() { return /* reexport */ clippingParents; }, + "computeStyles": function() { return /* reexport */ modifiers_computeStyles; }, + "createPopper": function() { return /* reexport */ popper_createPopper; }, + "createPopperBase": function() { return /* reexport */ createPopper; }, + "createPopperLite": function() { return /* reexport */ popper_lite_createPopper; }, + "detectOverflow": function() { return /* reexport */ detectOverflow; }, + "end": function() { return /* reexport */ end; }, + "eventListeners": function() { return /* reexport */ eventListeners; }, + "flip": function() { return /* reexport */ modifiers_flip; }, + "hide": function() { return /* reexport */ modifiers_hide; }, + "left": function() { return /* reexport */ left; }, + "main": function() { return /* reexport */ main; }, + "modifierPhases": function() { return /* reexport */ modifierPhases; }, + "offset": function() { return /* reexport */ modifiers_offset; }, + "placements": function() { return /* reexport */ enums_placements; }, + "popper": function() { return /* reexport */ popper; }, + "popperGenerator": function() { return /* reexport */ popperGenerator; }, + "popperOffsets": function() { return /* reexport */ modifiers_popperOffsets; }, + "preventOverflow": function() { return /* reexport */ modifiers_preventOverflow; }, + "read": function() { return /* reexport */ read; }, + "reference": function() { return /* reexport */ reference; }, + "right": function() { return /* reexport */ right; }, + "start": function() { return /* reexport */ start; }, + "top": function() { return /* reexport */ enums_top; }, + "variationPlacements": function() { return /* reexport */ variationPlacements; }, + "viewport": function() { return /* reexport */ viewport; }, + "write": function() { return /* reexport */ write; } +}); + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/enums.js +var enums_top = 'top'; +var bottom = 'bottom'; +var right = 'right'; +var left = 'left'; +var auto = 'auto'; +var basePlacements = [enums_top, bottom, right, left]; +var start = 'start'; +var end = 'end'; +var clippingParents = 'clippingParents'; +var viewport = 'viewport'; +var popper = 'popper'; +var reference = 'reference'; +var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) { + return acc.concat([placement + "-" + start, placement + "-" + end]); +}, []); +var enums_placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) { + return acc.concat([placement, placement + "-" + start, placement + "-" + end]); +}, []); // modifiers that need to read the DOM + +var beforeRead = 'beforeRead'; +var read = 'read'; +var afterRead = 'afterRead'; // pure-logic modifiers + +var beforeMain = 'beforeMain'; +var main = 'main'; +var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state) + +var beforeWrite = 'beforeWrite'; +var write = 'write'; +var afterWrite = 'afterWrite'; +var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite]; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js +function getNodeName(element) { + return element ? (element.nodeName || '').toLowerCase() : null; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindow.js +function getWindow(node) { + if (node == null) { + return window; + } + + if (node.toString() !== '[object Window]') { + var ownerDocument = node.ownerDocument; + return ownerDocument ? ownerDocument.defaultView || window : window; + } + + return node; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js + + +function isElement(node) { + var OwnElement = getWindow(node).Element; + return node instanceof OwnElement || node instanceof Element; +} + +function isHTMLElement(node) { + var OwnElement = getWindow(node).HTMLElement; + return node instanceof OwnElement || node instanceof HTMLElement; +} + +function isShadowRoot(node) { + // IE 11 has no ShadowRoot + if (typeof ShadowRoot === 'undefined') { + return false; + } + + var OwnElement = getWindow(node).ShadowRoot; + return node instanceof OwnElement || node instanceof ShadowRoot; +} + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/applyStyles.js + + // This modifier takes the styles prepared by the `computeStyles` modifier +// and applies them to the HTMLElements such as popper and arrow + +function applyStyles(_ref) { + var state = _ref.state; + Object.keys(state.elements).forEach(function (name) { + var style = state.styles[name] || {}; + var attributes = state.attributes[name] || {}; + var element = state.elements[name]; // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } // Flow doesn't support to extend this property, but it's the most + // effective way to apply styles to an HTMLElement + // $FlowFixMe[cannot-write] + + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (name) { + var value = attributes[name]; + + if (value === false) { + element.removeAttribute(name); + } else { + element.setAttribute(name, value === true ? '' : value); + } + }); + }); +} + +function effect(_ref2) { + var state = _ref2.state; + var initialStyles = { + popper: { + position: state.options.strategy, + left: '0', + top: '0', + margin: '0' + }, + arrow: { + position: 'absolute' + }, + reference: {} + }; + Object.assign(state.elements.popper.style, initialStyles.popper); + state.styles = initialStyles; + + if (state.elements.arrow) { + Object.assign(state.elements.arrow.style, initialStyles.arrow); + } + + return function () { + Object.keys(state.elements).forEach(function (name) { + var element = state.elements[name]; + var attributes = state.attributes[name] || {}; + var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them + + var style = styleProperties.reduce(function (style, property) { + style[property] = ''; + return style; + }, {}); // arrow is optional + virtual elements + + if (!isHTMLElement(element) || !getNodeName(element)) { + return; + } + + Object.assign(element.style, style); + Object.keys(attributes).forEach(function (attribute) { + element.removeAttribute(attribute); + }); + }); + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_applyStyles = ({ + name: 'applyStyles', + enabled: true, + phase: 'write', + fn: applyStyles, + effect: effect, + requires: ['computeStyles'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getBasePlacement.js + +function getBasePlacement(placement) { + return placement.split('-')[0]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/math.js +var math_max = Math.max; +var math_min = Math.min; +var round = Math.round; +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/userAgent.js +function getUAString() { + var uaData = navigator.userAgentData; + + if (uaData != null && uaData.brands) { + return uaData.brands.map(function (item) { + return item.brand + "/" + item.version; + }).join(' '); + } + + return navigator.userAgent; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js + +function isLayoutViewport() { + return !/^((?!chrome|android).)*safari/i.test(getUAString()); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js + + + + +function getBoundingClientRect(element, includeScale, isFixedStrategy) { + if (includeScale === void 0) { + includeScale = false; + } + + if (isFixedStrategy === void 0) { + isFixedStrategy = false; + } + + var clientRect = element.getBoundingClientRect(); + var scaleX = 1; + var scaleY = 1; + + if (includeScale && isHTMLElement(element)) { + scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1; + scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1; + } + + var _ref = isElement(element) ? getWindow(element) : window, + visualViewport = _ref.visualViewport; + + var addVisualOffsets = !isLayoutViewport() && isFixedStrategy; + var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX; + var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY; + var width = clientRect.width / scaleX; + var height = clientRect.height / scaleY; + return { + width: width, + height: height, + top: y, + right: x + width, + bottom: y + height, + left: x, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js + // Returns the layout rect of an element relative to its offsetParent. Layout +// means it doesn't take into account transforms. + +function getLayoutRect(element) { + var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed. + // Fixes https://github.com/popperjs/popper-core/issues/1223 + + var width = element.offsetWidth; + var height = element.offsetHeight; + + if (Math.abs(clientRect.width - width) <= 1) { + width = clientRect.width; + } + + if (Math.abs(clientRect.height - height) <= 1) { + height = clientRect.height; + } + + return { + x: element.offsetLeft, + y: element.offsetTop, + width: width, + height: height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/contains.js + +function contains(parent, child) { + var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method + + if (parent.contains(child)) { + return true; + } // then fallback to custom implementation with Shadow DOM support + else if (rootNode && isShadowRoot(rootNode)) { + var next = child; + + do { + if (next && parent.isSameNode(next)) { + return true; + } // $FlowFixMe[prop-missing]: need a better way to handle this... + + + next = next.parentNode || next.host; + } while (next); + } // Give up, the result is false + + + return false; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js + +function getComputedStyle(element) { + return getWindow(element).getComputedStyle(element); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js + +function isTableElement(element) { + return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js + +function getDocumentElement(element) { + // $FlowFixMe[incompatible-return]: assume body is always available + return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing] + element.document) || window.document).documentElement; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js + + + +function getParentNode(element) { + if (getNodeName(element) === 'html') { + return element; + } + + return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle + // $FlowFixMe[incompatible-return] + // $FlowFixMe[prop-missing] + element.assignedSlot || // step into the shadow DOM of the parent of a slotted node + element.parentNode || ( // DOM Element detected + isShadowRoot(element) ? element.host : null) || // ShadowRoot detected + // $FlowFixMe[incompatible-call]: HTMLElement is a Node + getDocumentElement(element) // fallback + + ); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js + + + + + + + + +function getTrueOffsetParent(element) { + if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837 + getComputedStyle(element).position === 'fixed') { + return null; + } + + return element.offsetParent; +} // `.offsetParent` reports `null` for fixed elements, while absolute elements +// return the containing block + + +function getContainingBlock(element) { + var isFirefox = /firefox/i.test(getUAString()); + var isIE = /Trident/i.test(getUAString()); + + if (isIE && isHTMLElement(element)) { + // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport + var elementCss = getComputedStyle(element); + + if (elementCss.position === 'fixed') { + return null; + } + } + + var currentNode = getParentNode(element); + + if (isShadowRoot(currentNode)) { + currentNode = currentNode.host; + } + + while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) { + var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that + // create a containing block. + // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block + + if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') { + return currentNode; + } else { + currentNode = currentNode.parentNode; + } + } + + return null; +} // Gets the closest ancestor positioned element. Handles some edge cases, +// such as table ancestors and cross browser bugs. + + +function getOffsetParent(element) { + var window = getWindow(element); + var offsetParent = getTrueOffsetParent(element); + + while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') { + offsetParent = getTrueOffsetParent(offsetParent); + } + + if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) { + return window; + } + + return offsetParent || getContainingBlock(element) || window; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js +function getMainAxisFromPlacement(placement) { + return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/within.js + +function within(min, value, max) { + return math_max(min, math_min(value, max)); +} +function withinMaxClamp(min, value, max) { + var v = within(min, value, max); + return v > max ? max : v; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js +function getFreshSideObject() { + return { + top: 0, + right: 0, + bottom: 0, + left: 0 + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js + +function mergePaddingObject(paddingObject) { + return Object.assign({}, getFreshSideObject(), paddingObject); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/expandToHashMap.js +function expandToHashMap(value, keys) { + return keys.reduce(function (hashMap, key) { + hashMap[key] = value; + return hashMap; + }, {}); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/arrow.js + + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var toPaddingObject = function toPaddingObject(padding, state) { + padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, { + placement: state.placement + })) : padding; + return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); +}; + +function arrow(_ref) { + var _state$modifiersData$; + + var state = _ref.state, + name = _ref.name, + options = _ref.options; + var arrowElement = state.elements.arrow; + var popperOffsets = state.modifiersData.popperOffsets; + var basePlacement = getBasePlacement(state.placement); + var axis = getMainAxisFromPlacement(basePlacement); + var isVertical = [left, right].indexOf(basePlacement) >= 0; + var len = isVertical ? 'height' : 'width'; + + if (!arrowElement || !popperOffsets) { + return; + } + + var paddingObject = toPaddingObject(options.padding, state); + var arrowRect = getLayoutRect(arrowElement); + var minProp = axis === 'y' ? enums_top : left; + var maxProp = axis === 'y' ? bottom : right; + var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len]; + var startDiff = popperOffsets[axis] - state.rects.reference[axis]; + var arrowOffsetParent = getOffsetParent(arrowElement); + var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0; + var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is + // outside of the popper bounds + + var min = paddingObject[minProp]; + var max = clientSize - arrowRect[len] - paddingObject[maxProp]; + var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference; + var offset = within(min, center, max); // Prevents breaking syntax highlighting... + + var axisProp = axis; + state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$); +} + +function arrow_effect(_ref2) { + var state = _ref2.state, + options = _ref2.options; + var _options$element = options.element, + arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element; + + if (arrowElement == null) { + return; + } // CSS selector + + + if (typeof arrowElement === 'string') { + arrowElement = state.elements.popper.querySelector(arrowElement); + + if (!arrowElement) { + return; + } + } + + if (false) {} + + if (!contains(state.elements.popper, arrowElement)) { + if (false) {} + + return; + } + + state.elements.arrow = arrowElement; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_arrow = ({ + name: 'arrow', + enabled: true, + phase: 'main', + fn: arrow, + effect: arrow_effect, + requires: ['popperOffsets'], + requiresIfExists: ['preventOverflow'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getVariation.js +function getVariation(placement) { + return placement.split('-')[1]; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/computeStyles.js + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +var unsetSides = { + top: 'auto', + right: 'auto', + bottom: 'auto', + left: 'auto' +}; // Round the offsets to the nearest suitable subpixel based on the DPR. +// Zooming can change the DPR, but it seems to report a value that will +// cleanly divide the values into the appropriate subpixels. + +function roundOffsetsByDPR(_ref) { + var x = _ref.x, + y = _ref.y; + var win = window; + var dpr = win.devicePixelRatio || 1; + return { + x: round(x * dpr) / dpr || 0, + y: round(y * dpr) / dpr || 0 + }; +} + +function mapToStyles(_ref2) { + var _Object$assign2; + + var popper = _ref2.popper, + popperRect = _ref2.popperRect, + placement = _ref2.placement, + variation = _ref2.variation, + offsets = _ref2.offsets, + position = _ref2.position, + gpuAcceleration = _ref2.gpuAcceleration, + adaptive = _ref2.adaptive, + roundOffsets = _ref2.roundOffsets, + isFixed = _ref2.isFixed; + var _offsets$x = offsets.x, + x = _offsets$x === void 0 ? 0 : _offsets$x, + _offsets$y = offsets.y, + y = _offsets$y === void 0 ? 0 : _offsets$y; + + var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref3.x; + y = _ref3.y; + var hasX = offsets.hasOwnProperty('x'); + var hasY = offsets.hasOwnProperty('y'); + var sideX = left; + var sideY = enums_top; + var win = window; + + if (adaptive) { + var offsetParent = getOffsetParent(popper); + var heightProp = 'clientHeight'; + var widthProp = 'clientWidth'; + + if (offsetParent === getWindow(popper)) { + offsetParent = getDocumentElement(popper); + + if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') { + heightProp = 'scrollHeight'; + widthProp = 'scrollWidth'; + } + } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it + + + offsetParent = offsetParent; + + if (placement === enums_top || (placement === left || placement === right) && variation === end) { + sideY = bottom; + var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing] + offsetParent[heightProp]; + y -= offsetY - popperRect.height; + y *= gpuAcceleration ? 1 : -1; + } + + if (placement === left || (placement === enums_top || placement === bottom) && variation === end) { + sideX = right; + var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing] + offsetParent[widthProp]; + x -= offsetX - popperRect.width; + x *= gpuAcceleration ? 1 : -1; + } + } + + var commonStyles = Object.assign({ + position: position + }, adaptive && unsetSides); + + var _ref4 = roundOffsets === true ? roundOffsetsByDPR({ + x: x, + y: y + }) : { + x: x, + y: y + }; + + x = _ref4.x; + y = _ref4.y; + + if (gpuAcceleration) { + var _Object$assign; + + return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign)); + } + + return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2)); +} + +function computeStyles(_ref5) { + var state = _ref5.state, + options = _ref5.options; + var _options$gpuAccelerat = options.gpuAcceleration, + gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, + _options$adaptive = options.adaptive, + adaptive = _options$adaptive === void 0 ? true : _options$adaptive, + _options$roundOffsets = options.roundOffsets, + roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets; + + if (false) { var transitionProperty; } + + var commonStyles = { + placement: getBasePlacement(state.placement), + variation: getVariation(state.placement), + popper: state.elements.popper, + popperRect: state.rects.popper, + gpuAcceleration: gpuAcceleration, + isFixed: state.options.strategy === 'fixed' + }; + + if (state.modifiersData.popperOffsets != null) { + state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.popperOffsets, + position: state.options.strategy, + adaptive: adaptive, + roundOffsets: roundOffsets + }))); + } + + if (state.modifiersData.arrow != null) { + state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, { + offsets: state.modifiersData.arrow, + position: 'absolute', + adaptive: false, + roundOffsets: roundOffsets + }))); + } + + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-placement': state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_computeStyles = ({ + name: 'computeStyles', + enabled: true, + phase: 'beforeWrite', + fn: computeStyles, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/eventListeners.js + // eslint-disable-next-line import/no-unused-modules + +var passive = { + passive: true +}; + +function eventListeners_effect(_ref) { + var state = _ref.state, + instance = _ref.instance, + options = _ref.options; + var _options$scroll = options.scroll, + scroll = _options$scroll === void 0 ? true : _options$scroll, + _options$resize = options.resize, + resize = _options$resize === void 0 ? true : _options$resize; + var window = getWindow(state.elements.popper); + var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper); + + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.addEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.addEventListener('resize', instance.update, passive); + } + + return function () { + if (scroll) { + scrollParents.forEach(function (scrollParent) { + scrollParent.removeEventListener('scroll', instance.update, passive); + }); + } + + if (resize) { + window.removeEventListener('resize', instance.update, passive); + } + }; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var eventListeners = ({ + name: 'eventListeners', + enabled: true, + phase: 'write', + fn: function fn() {}, + effect: eventListeners_effect, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js +var hash = { + left: 'right', + right: 'left', + bottom: 'top', + top: 'bottom' +}; +function getOppositePlacement(placement) { + return placement.replace(/left|right|bottom|top/g, function (matched) { + return hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js +var getOppositeVariationPlacement_hash = { + start: 'end', + end: 'start' +}; +function getOppositeVariationPlacement(placement) { + return placement.replace(/start|end/g, function (matched) { + return getOppositeVariationPlacement_hash[matched]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js + +function getWindowScroll(node) { + var win = getWindow(node); + var scrollLeft = win.pageXOffset; + var scrollTop = win.pageYOffset; + return { + scrollLeft: scrollLeft, + scrollTop: scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js + + + +function getWindowScrollBarX(element) { + // If has a CSS width greater than the viewport, then this will be + // incorrect for RTL. + // Popper 1 is broken in this case and never had a bug report so let's assume + // it's not an issue. I don't think anyone ever specifies width on + // anyway. + // Browsers where the left scrollbar doesn't cause an issue report `0` for + // this (e.g. Edge 2019, IE11, Safari) + return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js + + + + +function getViewportRect(element, strategy) { + var win = getWindow(element); + var html = getDocumentElement(element); + var visualViewport = win.visualViewport; + var width = html.clientWidth; + var height = html.clientHeight; + var x = 0; + var y = 0; + + if (visualViewport) { + width = visualViewport.width; + height = visualViewport.height; + var layoutViewport = isLayoutViewport(); + + if (layoutViewport || !layoutViewport && strategy === 'fixed') { + x = visualViewport.offsetLeft; + y = visualViewport.offsetTop; + } + } + + return { + width: width, + height: height, + x: x + getWindowScrollBarX(element), + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js + + + + + // Gets the entire size of the scrollable document area, even extending outside +// of the `` and `` rect bounds if horizontally scrollable + +function getDocumentRect(element) { + var _element$ownerDocumen; + + var html = getDocumentElement(element); + var winScroll = getWindowScroll(element); + var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body; + var width = math_max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0); + var height = math_max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0); + var x = -winScroll.scrollLeft + getWindowScrollBarX(element); + var y = -winScroll.scrollTop; + + if (getComputedStyle(body || html).direction === 'rtl') { + x += math_max(html.clientWidth, body ? body.clientWidth : 0) - width; + } + + return { + width: width, + height: height, + x: x, + y: y + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js + +function isScrollParent(element) { + // Firefox wants us to check `-x` and `-y` variations as well + var _getComputedStyle = getComputedStyle(element), + overflow = _getComputedStyle.overflow, + overflowX = _getComputedStyle.overflowX, + overflowY = _getComputedStyle.overflowY; + + return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js + + + + +function getScrollParent(node) { + if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) { + // $FlowFixMe[incompatible-return]: assume body is always available + return node.ownerDocument.body; + } + + if (isHTMLElement(node) && isScrollParent(node)) { + return node; + } + + return getScrollParent(getParentNode(node)); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js + + + + +/* +given a DOM element, return the list of all scroll parents, up the list of ancesors +until we get to the top window object. This list is what we attach scroll listeners +to, because if any of these parent elements scroll, we'll need to re-calculate the +reference element's position. +*/ + +function listScrollParents(element, list) { + var _element$ownerDocumen; + + if (list === void 0) { + list = []; + } + + var scrollParent = getScrollParent(element); + var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body); + var win = getWindow(scrollParent); + var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent; + var updatedList = list.concat(target); + return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here + updatedList.concat(listScrollParents(getParentNode(target))); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/rectToClientRect.js +function rectToClientRect(rect) { + return Object.assign({}, rect, { + left: rect.x, + top: rect.y, + right: rect.x + rect.width, + bottom: rect.y + rect.height + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js + + + + + + + + + + + + + + + +function getInnerBoundingClientRect(element, strategy) { + var rect = getBoundingClientRect(element, false, strategy === 'fixed'); + rect.top = rect.top + element.clientTop; + rect.left = rect.left + element.clientLeft; + rect.bottom = rect.top + element.clientHeight; + rect.right = rect.left + element.clientWidth; + rect.width = element.clientWidth; + rect.height = element.clientHeight; + rect.x = rect.left; + rect.y = rect.top; + return rect; +} + +function getClientRectFromMixedType(element, clippingParent, strategy) { + return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element))); +} // A "clipping parent" is an overflowable container with the characteristic of +// clipping (or hiding) overflowing elements with a position different from +// `initial` + + +function getClippingParents(element) { + var clippingParents = listScrollParents(getParentNode(element)); + var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0; + var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element; + + if (!isElement(clipperElement)) { + return []; + } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414 + + + return clippingParents.filter(function (clippingParent) { + return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body'; + }); +} // Gets the maximum area that the element is visible in due to any number of +// clipping parents + + +function getClippingRect(element, boundary, rootBoundary, strategy) { + var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary); + var clippingParents = [].concat(mainClippingParents, [rootBoundary]); + var firstClippingParent = clippingParents[0]; + var clippingRect = clippingParents.reduce(function (accRect, clippingParent) { + var rect = getClientRectFromMixedType(element, clippingParent, strategy); + accRect.top = math_max(rect.top, accRect.top); + accRect.right = math_min(rect.right, accRect.right); + accRect.bottom = math_min(rect.bottom, accRect.bottom); + accRect.left = math_max(rect.left, accRect.left); + return accRect; + }, getClientRectFromMixedType(element, firstClippingParent, strategy)); + clippingRect.width = clippingRect.right - clippingRect.left; + clippingRect.height = clippingRect.bottom - clippingRect.top; + clippingRect.x = clippingRect.left; + clippingRect.y = clippingRect.top; + return clippingRect; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeOffsets.js + + + + +function computeOffsets(_ref) { + var reference = _ref.reference, + element = _ref.element, + placement = _ref.placement; + var basePlacement = placement ? getBasePlacement(placement) : null; + var variation = placement ? getVariation(placement) : null; + var commonX = reference.x + reference.width / 2 - element.width / 2; + var commonY = reference.y + reference.height / 2 - element.height / 2; + var offsets; + + switch (basePlacement) { + case enums_top: + offsets = { + x: commonX, + y: reference.y - element.height + }; + break; + + case bottom: + offsets = { + x: commonX, + y: reference.y + reference.height + }; + break; + + case right: + offsets = { + x: reference.x + reference.width, + y: commonY + }; + break; + + case left: + offsets = { + x: reference.x - element.width, + y: commonY + }; + break; + + default: + offsets = { + x: reference.x, + y: reference.y + }; + } + + var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null; + + if (mainAxis != null) { + var len = mainAxis === 'y' ? 'height' : 'width'; + + switch (variation) { + case start: + offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2); + break; + + case end: + offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2); + break; + + default: + } + } + + return offsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/detectOverflow.js + + + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function detectOverflow(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + _options$placement = _options.placement, + placement = _options$placement === void 0 ? state.placement : _options$placement, + _options$strategy = _options.strategy, + strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, + _options$boundary = _options.boundary, + boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, + _options$rootBoundary = _options.rootBoundary, + rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, + _options$elementConte = _options.elementContext, + elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, + _options$altBoundary = _options.altBoundary, + altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, + _options$padding = _options.padding, + padding = _options$padding === void 0 ? 0 : _options$padding; + var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); + var altContext = elementContext === popper ? reference : popper; + var popperRect = state.rects.popper; + var element = state.elements[altBoundary ? altContext : elementContext]; + var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy); + var referenceClientRect = getBoundingClientRect(state.elements.reference); + var popperOffsets = computeOffsets({ + reference: referenceClientRect, + element: popperRect, + strategy: 'absolute', + placement: placement + }); + var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets)); + var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect + // 0 or negative = within the clipping rect + + var overflowOffsets = { + top: clippingClientRect.top - elementClientRect.top + paddingObject.top, + bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom, + left: clippingClientRect.left - elementClientRect.left + paddingObject.left, + right: elementClientRect.right - clippingClientRect.right + paddingObject.right + }; + var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element + + if (elementContext === popper && offsetData) { + var offset = offsetData[placement]; + Object.keys(overflowOffsets).forEach(function (key) { + var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1; + var axis = [enums_top, bottom].indexOf(key) >= 0 ? 'y' : 'x'; + overflowOffsets[key] += offset[axis] * multiply; + }); + } + + return overflowOffsets; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js + + + + +function computeAutoPlacement(state, options) { + if (options === void 0) { + options = {}; + } + + var _options = options, + placement = _options.placement, + boundary = _options.boundary, + rootBoundary = _options.rootBoundary, + padding = _options.padding, + flipVariations = _options.flipVariations, + _options$allowedAutoP = _options.allowedAutoPlacements, + allowedAutoPlacements = _options$allowedAutoP === void 0 ? enums_placements : _options$allowedAutoP; + var variation = getVariation(placement); + var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) { + return getVariation(placement) === variation; + }) : basePlacements; + var allowedPlacements = placements.filter(function (placement) { + return allowedAutoPlacements.indexOf(placement) >= 0; + }); + + if (allowedPlacements.length === 0) { + allowedPlacements = placements; + + if (false) {} + } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions... + + + var overflows = allowedPlacements.reduce(function (acc, placement) { + acc[placement] = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding + })[getBasePlacement(placement)]; + return acc; + }, {}); + return Object.keys(overflows).sort(function (a, b) { + return overflows[a] - overflows[b]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/flip.js + + + + + + + // eslint-disable-next-line import/no-unused-modules + +function getExpandedFallbackPlacements(placement) { + if (getBasePlacement(placement) === auto) { + return []; + } + + var oppositePlacement = getOppositePlacement(placement); + return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)]; +} + +function flip(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + + if (state.modifiersData[name]._skip) { + return; + } + + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, + specifiedFallbackPlacements = options.fallbackPlacements, + padding = options.padding, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + _options$flipVariatio = options.flipVariations, + flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, + allowedAutoPlacements = options.allowedAutoPlacements; + var preferredPlacement = state.options.placement; + var basePlacement = getBasePlacement(preferredPlacement); + var isBasePlacement = basePlacement === preferredPlacement; + var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement)); + var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) { + return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + flipVariations: flipVariations, + allowedAutoPlacements: allowedAutoPlacements + }) : placement); + }, []); + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var checksMap = new Map(); + var makeFallbackChecks = true; + var firstFittingPlacement = placements[0]; + + for (var i = 0; i < placements.length; i++) { + var placement = placements[i]; + + var _basePlacement = getBasePlacement(placement); + + var isStartVariation = getVariation(placement) === start; + var isVertical = [enums_top, bottom].indexOf(_basePlacement) >= 0; + var len = isVertical ? 'width' : 'height'; + var overflow = detectOverflow(state, { + placement: placement, + boundary: boundary, + rootBoundary: rootBoundary, + altBoundary: altBoundary, + padding: padding + }); + var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : enums_top; + + if (referenceRect[len] > popperRect[len]) { + mainVariationSide = getOppositePlacement(mainVariationSide); + } + + var altVariationSide = getOppositePlacement(mainVariationSide); + var checks = []; + + if (checkMainAxis) { + checks.push(overflow[_basePlacement] <= 0); + } + + if (checkAltAxis) { + checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0); + } + + if (checks.every(function (check) { + return check; + })) { + firstFittingPlacement = placement; + makeFallbackChecks = false; + break; + } + + checksMap.set(placement, checks); + } + + if (makeFallbackChecks) { + // `2` may be desired in some cases – research later + var numberOfChecks = flipVariations ? 3 : 1; + + var _loop = function _loop(_i) { + var fittingPlacement = placements.find(function (placement) { + var checks = checksMap.get(placement); + + if (checks) { + return checks.slice(0, _i).every(function (check) { + return check; + }); + } + }); + + if (fittingPlacement) { + firstFittingPlacement = fittingPlacement; + return "break"; + } + }; + + for (var _i = numberOfChecks; _i > 0; _i--) { + var _ret = _loop(_i); + + if (_ret === "break") break; + } + } + + if (state.placement !== firstFittingPlacement) { + state.modifiersData[name]._skip = true; + state.placement = firstFittingPlacement; + state.reset = true; + } +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_flip = ({ + name: 'flip', + enabled: true, + phase: 'main', + fn: flip, + requiresIfExists: ['offset'], + data: { + _skip: false + } +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/hide.js + + + +function getSideOffsets(overflow, rect, preventedOffsets) { + if (preventedOffsets === void 0) { + preventedOffsets = { + x: 0, + y: 0 + }; + } + + return { + top: overflow.top - rect.height - preventedOffsets.y, + right: overflow.right - rect.width + preventedOffsets.x, + bottom: overflow.bottom - rect.height + preventedOffsets.y, + left: overflow.left - rect.width - preventedOffsets.x + }; +} + +function isAnySideFullyClipped(overflow) { + return [enums_top, right, bottom, left].some(function (side) { + return overflow[side] >= 0; + }); +} + +function hide(_ref) { + var state = _ref.state, + name = _ref.name; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var preventedOffsets = state.modifiersData.preventOverflow; + var referenceOverflow = detectOverflow(state, { + elementContext: 'reference' + }); + var popperAltOverflow = detectOverflow(state, { + altBoundary: true + }); + var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect); + var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets); + var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets); + var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets); + state.modifiersData[name] = { + referenceClippingOffsets: referenceClippingOffsets, + popperEscapeOffsets: popperEscapeOffsets, + isReferenceHidden: isReferenceHidden, + hasPopperEscaped: hasPopperEscaped + }; + state.attributes.popper = Object.assign({}, state.attributes.popper, { + 'data-popper-reference-hidden': isReferenceHidden, + 'data-popper-escaped': hasPopperEscaped + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_hide = ({ + name: 'hide', + enabled: true, + phase: 'main', + requiresIfExists: ['preventOverflow'], + fn: hide +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/offset.js + + // eslint-disable-next-line import/no-unused-modules + +function distanceAndSkiddingToXY(placement, rects, offset) { + var basePlacement = getBasePlacement(placement); + var invertDistance = [left, enums_top].indexOf(basePlacement) >= 0 ? -1 : 1; + + var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, { + placement: placement + })) : offset, + skidding = _ref[0], + distance = _ref[1]; + + skidding = skidding || 0; + distance = (distance || 0) * invertDistance; + return [left, right].indexOf(basePlacement) >= 0 ? { + x: distance, + y: skidding + } : { + x: skidding, + y: distance + }; +} + +function offset(_ref2) { + var state = _ref2.state, + options = _ref2.options, + name = _ref2.name; + var _options$offset = options.offset, + offset = _options$offset === void 0 ? [0, 0] : _options$offset; + var data = enums_placements.reduce(function (acc, placement) { + acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset); + return acc; + }, {}); + var _data$state$placement = data[state.placement], + x = _data$state$placement.x, + y = _data$state$placement.y; + + if (state.modifiersData.popperOffsets != null) { + state.modifiersData.popperOffsets.x += x; + state.modifiersData.popperOffsets.y += y; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_offset = ({ + name: 'offset', + enabled: true, + phase: 'main', + requires: ['popperOffsets'], + fn: offset +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js + + +function popperOffsets(_ref) { + var state = _ref.state, + name = _ref.name; + // Offsets are the actual position the popper needs to have to be + // properly positioned near its reference element + // This is the most basic placement, and will be adjusted by + // the modifiers in the next step + state.modifiersData[name] = computeOffsets({ + reference: state.rects.reference, + element: state.rects.popper, + strategy: 'absolute', + placement: state.placement + }); +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_popperOffsets = ({ + name: 'popperOffsets', + enabled: true, + phase: 'read', + fn: popperOffsets, + data: {} +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/getAltAxis.js +function getAltAxis(axis) { + return axis === 'x' ? 'y' : 'x'; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js + + + + + + + + + + + + +function preventOverflow(_ref) { + var state = _ref.state, + options = _ref.options, + name = _ref.name; + var _options$mainAxis = options.mainAxis, + checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, + _options$altAxis = options.altAxis, + checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, + boundary = options.boundary, + rootBoundary = options.rootBoundary, + altBoundary = options.altBoundary, + padding = options.padding, + _options$tether = options.tether, + tether = _options$tether === void 0 ? true : _options$tether, + _options$tetherOffset = options.tetherOffset, + tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset; + var overflow = detectOverflow(state, { + boundary: boundary, + rootBoundary: rootBoundary, + padding: padding, + altBoundary: altBoundary + }); + var basePlacement = getBasePlacement(state.placement); + var variation = getVariation(state.placement); + var isBasePlacement = !variation; + var mainAxis = getMainAxisFromPlacement(basePlacement); + var altAxis = getAltAxis(mainAxis); + var popperOffsets = state.modifiersData.popperOffsets; + var referenceRect = state.rects.reference; + var popperRect = state.rects.popper; + var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, { + placement: state.placement + })) : tetherOffset; + var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? { + mainAxis: tetherOffsetValue, + altAxis: tetherOffsetValue + } : Object.assign({ + mainAxis: 0, + altAxis: 0 + }, tetherOffsetValue); + var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null; + var data = { + x: 0, + y: 0 + }; + + if (!popperOffsets) { + return; + } + + if (checkMainAxis) { + var _offsetModifierState$; + + var mainSide = mainAxis === 'y' ? enums_top : left; + var altSide = mainAxis === 'y' ? bottom : right; + var len = mainAxis === 'y' ? 'height' : 'width'; + var offset = popperOffsets[mainAxis]; + var min = offset + overflow[mainSide]; + var max = offset - overflow[altSide]; + var additive = tether ? -popperRect[len] / 2 : 0; + var minLen = variation === start ? referenceRect[len] : popperRect[len]; + var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go + // outside the reference bounds + + var arrowElement = state.elements.arrow; + var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : { + width: 0, + height: 0 + }; + var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject(); + var arrowPaddingMin = arrowPaddingObject[mainSide]; + var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want + // to include its full size in the calculation. If the reference is small + // and near the edge of a boundary, the popper can overflow even if the + // reference is not overflowing as well (e.g. virtual elements with no + // width or height) + + var arrowLen = within(0, referenceRect[len], arrowRect[len]); + var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis; + var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis; + var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow); + var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0; + var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0; + var tetherMin = offset + minOffset - offsetModifierValue - clientOffset; + var tetherMax = offset + maxOffset - offsetModifierValue; + var preventedOffset = within(tether ? math_min(min, tetherMin) : min, offset, tether ? math_max(max, tetherMax) : max); + popperOffsets[mainAxis] = preventedOffset; + data[mainAxis] = preventedOffset - offset; + } + + if (checkAltAxis) { + var _offsetModifierState$2; + + var _mainSide = mainAxis === 'x' ? enums_top : left; + + var _altSide = mainAxis === 'x' ? bottom : right; + + var _offset = popperOffsets[altAxis]; + + var _len = altAxis === 'y' ? 'height' : 'width'; + + var _min = _offset + overflow[_mainSide]; + + var _max = _offset - overflow[_altSide]; + + var isOriginSide = [enums_top, left].indexOf(basePlacement) !== -1; + + var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0; + + var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis; + + var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max; + + var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max); + + popperOffsets[altAxis] = _preventedOffset; + data[altAxis] = _preventedOffset - _offset; + } + + state.modifiersData[name] = data; +} // eslint-disable-next-line import/no-unused-modules + + +/* harmony default export */ var modifiers_preventOverflow = ({ + name: 'preventOverflow', + enabled: true, + phase: 'main', + fn: preventOverflow, + requiresIfExists: ['offset'] +}); +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/modifiers/index.js + + + + + + + + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js +function getHTMLElementScroll(element) { + return { + scrollLeft: element.scrollLeft, + scrollTop: element.scrollTop + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js + + + + +function getNodeScroll(node) { + if (node === getWindow(node) || !isHTMLElement(node)) { + return getWindowScroll(node); + } else { + return getHTMLElementScroll(node); + } +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js + + + + + + + + + +function isElementScaled(element) { + var rect = element.getBoundingClientRect(); + var scaleX = round(rect.width) / element.offsetWidth || 1; + var scaleY = round(rect.height) / element.offsetHeight || 1; + return scaleX !== 1 || scaleY !== 1; +} // Returns the composite rect of an element relative to its offsetParent. +// Composite means it takes into account transforms as well as layout. + + +function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) { + if (isFixed === void 0) { + isFixed = false; + } + + var isOffsetParentAnElement = isHTMLElement(offsetParent); + var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent); + var documentElement = getDocumentElement(offsetParent); + var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed); + var scroll = { + scrollLeft: 0, + scrollTop: 0 + }; + var offsets = { + x: 0, + y: 0 + }; + + if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { + if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078 + isScrollParent(documentElement)) { + scroll = getNodeScroll(offsetParent); + } + + if (isHTMLElement(offsetParent)) { + offsets = getBoundingClientRect(offsetParent, true); + offsets.x += offsetParent.clientLeft; + offsets.y += offsetParent.clientTop; + } else if (documentElement) { + offsets.x = getWindowScrollBarX(documentElement); + } + } + + return { + x: rect.left + scroll.scrollLeft - offsets.x, + y: rect.top + scroll.scrollTop - offsets.y, + width: rect.width, + height: rect.height + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/orderModifiers.js + // source: https://stackoverflow.com/questions/49875255 + +function order(modifiers) { + var map = new Map(); + var visited = new Set(); + var result = []; + modifiers.forEach(function (modifier) { + map.set(modifier.name, modifier); + }); // On visiting object, check for its dependencies and visit them recursively + + function sort(modifier) { + visited.add(modifier.name); + var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []); + requires.forEach(function (dep) { + if (!visited.has(dep)) { + var depModifier = map.get(dep); + + if (depModifier) { + sort(depModifier); + } + } + }); + result.push(modifier); + } + + modifiers.forEach(function (modifier) { + if (!visited.has(modifier.name)) { + // check for visited object + sort(modifier); + } + }); + return result; +} + +function orderModifiers(modifiers) { + // order based on dependencies + var orderedModifiers = order(modifiers); // order based on phase + + return modifierPhases.reduce(function (acc, phase) { + return acc.concat(orderedModifiers.filter(function (modifier) { + return modifier.phase === phase; + })); + }, []); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/debounce.js +function debounce(fn) { + var pending; + return function () { + if (!pending) { + pending = new Promise(function (resolve) { + Promise.resolve().then(function () { + pending = undefined; + resolve(fn()); + }); + }); + } + + return pending; + }; +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/utils/mergeByName.js +function mergeByName(modifiers) { + var merged = modifiers.reduce(function (merged, current) { + var existing = merged[current.name]; + merged[current.name] = existing ? Object.assign({}, existing, current, { + options: Object.assign({}, existing.options, current.options), + data: Object.assign({}, existing.data, current.data) + }) : current; + return merged; + }, {}); // IE11 does not support Object.values + + return Object.keys(merged).map(function (key) { + return merged[key]; + }); +} +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/createPopper.js + + + + + + + + + + + + + + +var INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.'; +var INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.'; +var DEFAULT_OPTIONS = { + placement: 'bottom', + modifiers: [], + strategy: 'absolute' +}; + +function areValidElements() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + return !args.some(function (element) { + return !(element && typeof element.getBoundingClientRect === 'function'); + }); +} + +function popperGenerator(generatorOptions) { + if (generatorOptions === void 0) { + generatorOptions = {}; + } + + var _generatorOptions = generatorOptions, + _generatorOptions$def = _generatorOptions.defaultModifiers, + defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, + _generatorOptions$def2 = _generatorOptions.defaultOptions, + defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2; + return function createPopper(reference, popper, options) { + if (options === void 0) { + options = defaultOptions; + } + + var state = { + placement: 'bottom', + orderedModifiers: [], + options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions), + modifiersData: {}, + elements: { + reference: reference, + popper: popper + }, + attributes: {}, + styles: {} + }; + var effectCleanupFns = []; + var isDestroyed = false; + var instance = { + state: state, + setOptions: function setOptions(setOptionsAction) { + var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction; + cleanupModifierEffects(); + state.options = Object.assign({}, defaultOptions, state.options, options); + state.scrollParents = { + reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [], + popper: listScrollParents(popper) + }; // Orders the modifiers based on their dependencies and `phase` + // properties + + var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers + + state.orderedModifiers = orderedModifiers.filter(function (m) { + return m.enabled; + }); // Validate the provided modifiers so that the consumer will get warned + // if one of the modifiers is invalid for any reason + + if (false) { var _getComputedStyle, marginTop, marginRight, marginBottom, marginLeft, flipModifier, modifiers; } + + runModifierEffects(); + return instance.update(); + }, + // Sync update – it will always be executed, even if not necessary. This + // is useful for low frequency updates where sync behavior simplifies the + // logic. + // For high frequency updates (e.g. `resize` and `scroll` events), always + // prefer the async Popper#update method + forceUpdate: function forceUpdate() { + if (isDestroyed) { + return; + } + + var _state$elements = state.elements, + reference = _state$elements.reference, + popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements + // anymore + + if (!areValidElements(reference, popper)) { + if (false) {} + + return; + } // Store the reference and popper rects to be read by modifiers + + + state.rects = { + reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'), + popper: getLayoutRect(popper) + }; // Modifiers have the ability to reset the current update cycle. The + // most common use case for this is the `flip` modifier changing the + // placement, which then needs to re-run all the modifiers, because the + // logic was previously ran for the previous placement and is therefore + // stale/incorrect + + state.reset = false; + state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier + // is filled with the initial data specified by the modifier. This means + // it doesn't persist and is fresh on each update. + // To ensure persistent data, use `${name}#persistent` + + state.orderedModifiers.forEach(function (modifier) { + return state.modifiersData[modifier.name] = Object.assign({}, modifier.data); + }); + var __debug_loops__ = 0; + + for (var index = 0; index < state.orderedModifiers.length; index++) { + if (false) {} + + if (state.reset === true) { + state.reset = false; + index = -1; + continue; + } + + var _state$orderedModifie = state.orderedModifiers[index], + fn = _state$orderedModifie.fn, + _state$orderedModifie2 = _state$orderedModifie.options, + _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, + name = _state$orderedModifie.name; + + if (typeof fn === 'function') { + state = fn({ + state: state, + options: _options, + name: name, + instance: instance + }) || state; + } + } + }, + // Async and optimistically optimized update – it will not be executed if + // not necessary (debounced to run at most once-per-tick) + update: debounce(function () { + return new Promise(function (resolve) { + instance.forceUpdate(); + resolve(state); + }); + }), + destroy: function destroy() { + cleanupModifierEffects(); + isDestroyed = true; + } + }; + + if (!areValidElements(reference, popper)) { + if (false) {} + + return instance; + } + + instance.setOptions(options).then(function (state) { + if (!isDestroyed && options.onFirstUpdate) { + options.onFirstUpdate(state); + } + }); // Modifiers have the ability to execute arbitrary code before the first + // update cycle runs. They will be executed in the same order as the update + // cycle. This is useful when a modifier adds some persistent data that + // other modifiers need to use, but the modifier is run after the dependent + // one. + + function runModifierEffects() { + state.orderedModifiers.forEach(function (_ref3) { + var name = _ref3.name, + _ref3$options = _ref3.options, + options = _ref3$options === void 0 ? {} : _ref3$options, + effect = _ref3.effect; + + if (typeof effect === 'function') { + var cleanupFn = effect({ + state: state, + name: name, + instance: instance, + options: options + }); + + var noopFn = function noopFn() {}; + + effectCleanupFns.push(cleanupFn || noopFn); + } + }); + } + + function cleanupModifierEffects() { + effectCleanupFns.forEach(function (fn) { + return fn(); + }); + effectCleanupFns = []; + } + + return instance; + }; +} +var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper.js + + + + + + + + + + +var defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles, modifiers_offset, modifiers_flip, modifiers_preventOverflow, modifiers_arrow, modifiers_hide]; +var popper_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/popper-lite.js + + + + + +var popper_lite_defaultModifiers = [eventListeners, modifiers_popperOffsets, modifiers_computeStyles, modifiers_applyStyles]; +var popper_lite_createPopper = /*#__PURE__*/popperGenerator({ + defaultModifiers: popper_lite_defaultModifiers +}); // eslint-disable-next-line import/no-unused-modules + + +;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/index.js + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + // eslint-disable-next-line import/no-unused-modules + + + +/***/ }), + +/***/ 902: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initAccordions = void 0; +var Default = { + alwaysOpen: false, + activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', + inactiveClasses: 'text-gray-500 dark:text-gray-400', + onOpen: function () { }, + onClose: function () { }, + onToggle: function () { }, +}; +var Accordion = /** @class */ (function () { + function Accordion(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Accordion.prototype._init = function () { + var _this = this; + if (this._items.length) { + // show accordion item based on click + this._items.map(function (item) { + if (item.active) { + _this.open(item.id); + } + item.triggerEl.addEventListener('click', function () { + _this.toggle(item.id); + }); + }); + } + }; + Accordion.prototype.getItem = function (id) { + return this._items.filter(function (item) { return item.id === id; })[0]; + }; + Accordion.prototype.open = function (id) { + var _a, _b; + var _this = this; + var item = this.getItem(id); + // don't hide other accordions if always open + if (!this._options.alwaysOpen) { + this._items.map(function (i) { + var _a, _b; + if (i !== item) { + (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + i.targetEl.classList.add('hidden'); + i.triggerEl.setAttribute('aria-expanded', 'false'); + i.active = false; + // rotate icon if set + if (i.iconEl) { + i.iconEl.classList.remove('rotate-180'); + } + } + }); + } + // show active item + (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + item.triggerEl.setAttribute('aria-expanded', 'true'); + item.targetEl.classList.remove('hidden'); + item.active = true; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.add('rotate-180'); + } + // callback function + this._options.onOpen(this, item); + }; + Accordion.prototype.toggle = function (id) { + var item = this.getItem(id); + if (item.active) { + this.close(id); + } + else { + this.open(id); + } + // callback function + this._options.onToggle(this, item); + }; + Accordion.prototype.close = function (id) { + var _a, _b; + var item = this.getItem(id); + (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); + item.targetEl.classList.add('hidden'); + item.triggerEl.setAttribute('aria-expanded', 'false'); + item.active = false; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.remove('rotate-180'); + } + // callback function + this._options.onClose(this, item); + }; + return Accordion; +}()); +function initAccordions() { + document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { + var alwaysOpen = $accordionEl.getAttribute('data-accordion'); + var activeClasses = $accordionEl.getAttribute('data-active-classes'); + var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); + var items = []; + $accordionEl + .querySelectorAll('[data-accordion-target]') + .forEach(function ($triggerEl) { + // Consider only items that directly belong to $accordionEl + // (to make nested accordions work). + if ($triggerEl.closest('[data-accordion]') === $accordionEl) { + var item = { + id: $triggerEl.getAttribute('data-accordion-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), + iconEl: $triggerEl.querySelector('[data-accordion-icon]'), + active: $triggerEl.getAttribute('aria-expanded') === 'true' + ? true + : false, + }; + items.push(item); + } + }); + new Accordion(items, { + alwaysOpen: alwaysOpen === 'open' ? true : false, + activeClasses: activeClasses + ? activeClasses + : Default.activeClasses, + inactiveClasses: inactiveClasses + ? inactiveClasses + : Default.inactiveClasses, + }); + }); +} +exports.initAccordions = initAccordions; +if (typeof window !== 'undefined') { + window.Accordion = Accordion; + window.initAccordions = initAccordions; +} +exports["default"] = Accordion; + + +/***/ }), + +/***/ 33: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCarousels = void 0; +var Default = { + defaultPosition: 0, + indicators: { + items: [], + activeClasses: 'bg-white dark:bg-gray-800', + inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', + }, + interval: 3000, + onNext: function () { }, + onPrev: function () { }, + onChange: function () { }, +}; +var Carousel = /** @class */ (function () { + function Carousel(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign(__assign({}, Default), options), { indicators: __assign(__assign({}, Default.indicators), options.indicators) }); + this._activeItem = this.getItem(this._options.defaultPosition); + this._indicators = this._options.indicators.items; + this._intervalDuration = this._options.interval; + this._intervalInstance = null; + this._init(); + } + /** + * initialize carousel and items based on active one + */ + Carousel.prototype._init = function () { + var _this = this; + this._items.map(function (item) { + item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); + }); + // if no active item is set then first position is default + if (this._getActiveItem()) { + this.slideTo(this._getActiveItem().position); + } + else { + this.slideTo(0); + } + this._indicators.map(function (indicator, position) { + indicator.el.addEventListener('click', function () { + _this.slideTo(position); + }); + }); + }; + Carousel.prototype.getItem = function (position) { + return this._items[position]; + }; + /** + * Slide to the element based on id + * @param {*} position + */ + Carousel.prototype.slideTo = function (position) { + var nextItem = this._items[position]; + var rotationItems = { + left: nextItem.position === 0 + ? this._items[this._items.length - 1] + : this._items[nextItem.position - 1], + middle: nextItem, + right: nextItem.position === this._items.length - 1 + ? this._items[0] + : this._items[nextItem.position + 1], + }; + this._rotate(rotationItems); + this._setActiveItem(nextItem); + if (this._intervalInstance) { + this.pause(); + this.cycle(); + } + this._options.onChange(this); + }; + /** + * Based on the currently active item it will go to the next position + */ + Carousel.prototype.next = function () { + var activeItem = this._getActiveItem(); + var nextItem = null; + // check if last item + if (activeItem.position === this._items.length - 1) { + nextItem = this._items[0]; + } + else { + nextItem = this._items[activeItem.position + 1]; + } + this.slideTo(nextItem.position); + // callback function + this._options.onNext(this); + }; + /** + * Based on the currently active item it will go to the previous position + */ + Carousel.prototype.prev = function () { + var activeItem = this._getActiveItem(); + var prevItem = null; + // check if first item + if (activeItem.position === 0) { + prevItem = this._items[this._items.length - 1]; + } + else { + prevItem = this._items[activeItem.position - 1]; + } + this.slideTo(prevItem.position); + // callback function + this._options.onPrev(this); + }; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + Carousel.prototype._rotate = function (rotationItems) { + // reset + this._items.map(function (item) { + item.el.classList.add('hidden'); + }); + // left item (previously active) + rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); + // currently active item + rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); + rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); + // right item (upcoming active) + rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.right.el.classList.add('translate-x-full', 'z-10'); + }; + /** + * Set an interval to cycle through the carousel items + */ + Carousel.prototype.cycle = function () { + var _this = this; + if (typeof window !== 'undefined') { + this._intervalInstance = window.setInterval(function () { + _this.next(); + }, this._intervalDuration); + } + }; + /** + * Clears the cycling interval + */ + Carousel.prototype.pause = function () { + clearInterval(this._intervalInstance); + }; + /** + * Get the currently active item + */ + Carousel.prototype._getActiveItem = function () { + return this._activeItem; + }; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + Carousel.prototype._setActiveItem = function (item) { + var _a, _b; + var _this = this; + this._activeItem = item; + var position = item.position; + // update the indicators if available + if (this._indicators.length) { + this._indicators.map(function (indicator) { + var _a, _b; + indicator.el.setAttribute('aria-current', 'false'); + (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); + (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); + }); + (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); + (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); + this._indicators[position].el.setAttribute('aria-current', 'true'); + } + }; + return Carousel; +}()); +function initCarousels() { + document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { + var interval = $carouselEl.getAttribute('data-carousel-interval'); + var slide = $carouselEl.getAttribute('data-carousel') === 'slide' + ? true + : false; + var items = []; + var defaultPosition = 0; + if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { + items.push({ + position: position, + el: $carouselItemEl, + }); + if ($carouselItemEl.getAttribute('data-carousel-item') === + 'active') { + defaultPosition = position; + } + }); + } + var indicators = []; + if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { + indicators.push({ + position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), + el: $indicatorEl, + }); + }); + } + var carousel = new Carousel(items, { + defaultPosition: defaultPosition, + indicators: { + items: indicators, + }, + interval: interval ? interval : Default.interval, + }); + if (slide) { + carousel.cycle(); + } + // check for controls + var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); + var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); + if (carouselNextEl) { + carouselNextEl.addEventListener('click', function () { + carousel.next(); + }); + } + if (carouselPrevEl) { + carouselPrevEl.addEventListener('click', function () { + carousel.prev(); + }); + } + }); +} +exports.initCarousels = initCarousels; +if (typeof window !== 'undefined') { + window.Carousel = Carousel; + window.initCarousels = initCarousels; +} +exports["default"] = Carousel; + + +/***/ }), + +/***/ 922: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initCollapses = void 0; +var Default = { + onCollapse: function () { }, + onExpand: function () { }, + onToggle: function () { }, +}; +var Collapse = /** @class */ (function () { + function Collapse(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Collapse.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + if (this._triggerEl.hasAttribute('aria-expanded')) { + this._visible = + this._triggerEl.getAttribute('aria-expanded') === 'true'; + } + else { + // fix until v2 not to break previous single collapses which became dismiss + this._visible = !this._targetEl.classList.contains('hidden'); + } + this._triggerEl.addEventListener('click', function () { + _this.toggle(); + }); + } + }; + Collapse.prototype.collapse = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onCollapse(this); + }; + Collapse.prototype.expand = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onExpand(this); + }; + Collapse.prototype.toggle = function () { + if (this._visible) { + this.collapse(); + } + else { + this.expand(); + } + // callback function + this._options.onToggle(this); + }; + return Collapse; +}()); +function initCollapses() { + document + .querySelectorAll('[data-collapse-toggle]') + .forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-collapse-toggle'); + var $targetEl = document.getElementById(targetId); + // check if the target element exists + if ($targetEl) { + new Collapse($targetEl, $triggerEl); + } + else { + console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); + } + }); +} +exports.initCollapses = initCollapses; +if (typeof window !== 'undefined') { + window.Collapse = Collapse; + window.initCollapses = initCollapses; +} +exports["default"] = Collapse; + + +/***/ }), + +/***/ 556: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDials = void 0; +var Default = { + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dial = /** @class */ (function () { + function Dial(parentEl, triggerEl, targetEl, options) { + if (parentEl === void 0) { parentEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._parentEl = parentEl; + this._triggerEl = triggerEl; + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Dial.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); + triggerEventTypes.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEventTypes.hideEvents.forEach(function (ev) { + _this._parentEl.addEventListener(ev, function () { + if (!_this._parentEl.matches(':hover')) { + _this.hide(); + } + }); + }); + } + }; + Dial.prototype.hide = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Dial.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dial.prototype.toggle = function () { + if (this._visible) { + this.hide(); + } + else { + this.show(); + } + }; + Dial.prototype.isHidden = function () { + return !this._visible; + }; + Dial.prototype.isVisible = function () { + return this._visible; + }; + Dial.prototype._getTriggerEventTypes = function (triggerType) { + switch (triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + return Dial; +}()); +function initDials() { + document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { + var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); + if ($triggerEl) { + var dialId = $triggerEl.getAttribute('data-dial-toggle'); + var $dialEl = document.getElementById(dialId); + if ($dialEl) { + var triggerType = $triggerEl.getAttribute('data-dial-trigger'); + new Dial($parentEl, $triggerEl, $dialEl, { + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); + } + } + else { + console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); + } + }); +} +exports.initDials = initDials; +if (typeof window !== 'undefined') { + window.Dial = Dial; + window.initDials = initDials; +} +exports["default"] = Dial; + + +/***/ }), + +/***/ 791: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDismisses = void 0; +var Default = { + transition: 'transition-opacity', + duration: 300, + timing: 'ease-out', + onHide: function () { }, +}; +var Dismiss = /** @class */ (function () { + function Dismiss(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Dismiss.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + this._triggerEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Dismiss.prototype.hide = function () { + var _this = this; + this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); + setTimeout(function () { + _this._targetEl.classList.add('hidden'); + }, this._options.duration); + // callback function + this._options.onHide(this, this._targetEl); + }; + return Dismiss; +}()); +function initDismisses() { + document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-dismiss-target'); + var $dismissEl = document.querySelector(targetId); + if ($dismissEl) { + new Dismiss($dismissEl, $triggerEl); + } + else { + console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); + } + }); +} +exports.initDismisses = initDismisses; +if (typeof window !== 'undefined') { + window.Dismiss = Dismiss; + window.initDismisses = initDismisses; +} +exports["default"] = Dismiss; + + +/***/ }), + +/***/ 340: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDrawers = void 0; +var Default = { + placement: 'left', + bodyScrolling: false, + backdrop: true, + edge: false, + edgeOffset: 'bottom-[60px]', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Drawer = /** @class */ (function () { + function Drawer(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Drawer.prototype._init = function () { + var _this = this; + // set initial accessibility attributes + if (this._targetEl) { + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.classList.add('transition-transform'); + } + // set base placement classes + this._getPlacementClasses(this._options.placement).base.map(function (c) { + _this._targetEl.classList.add(c); + }); + // add keyboard event listener to document + document.addEventListener('keydown', function (event) { + if (event.key === 'Escape') { + // if 'Escape' key is pressed + if (_this.isVisible()) { + // if the Drawer is visible + _this.hide(); // hide the Drawer + } + } + }); + }; + Drawer.prototype.hide = function () { + var _this = this; + // based on the edge option show placement classes + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + // enable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.remove('overflow-hidden'); + } + // destroy backdrop + if (this._options.backdrop) { + this._destroyBackdropEl(); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Drawer.prototype.show = function () { + var _this = this; + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + // disable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.add('overflow-hidden'); + } + // show backdrop + if (this._options.backdrop) { + this._createBackdrop(); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Drawer.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Drawer.prototype._createBackdrop = function () { + var _a; + var _this = this; + if (!this._visible) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('drawer-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + backdropEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Drawer.prototype._destroyBackdropEl = function () { + if (this._visible) { + document.querySelector('[drawer-backdrop]').remove(); + } + }; + Drawer.prototype._getPlacementClasses = function (placement) { + switch (placement) { + case 'top': + return { + base: ['top-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['-translate-y-full'], + }; + case 'right': + return { + base: ['right-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-x-full'], + }; + case 'bottom': + return { + base: ['bottom-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['translate-y-full'], + }; + case 'left': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + case 'bottom-edge': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-y-full', this._options.edgeOffset], + }; + default: + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + } + }; + Drawer.prototype.isHidden = function () { + return !this._visible; + }; + Drawer.prototype.isVisible = function () { + return this._visible; + }; + return Drawer; +}()); +var getDrawerInstance = function (id, instances) { + if (instances.some(function (drawerInstance) { return drawerInstance.id === id; })) { + return instances.find(function (drawerInstance) { return drawerInstance.id === id; }); + } +}; +function initDrawers() { + var drawerInstances = []; + document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { + // mandatory + var drawerId = $triggerEl.getAttribute('data-drawer-target'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + // optional + var placement = $triggerEl.getAttribute('data-drawer-placement'); + var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); + var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); + var edge = $triggerEl.getAttribute('data-drawer-edge'); + var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); + if (!getDrawerInstance(drawerId, drawerInstances)) { + drawerInstances.push({ + id: drawerId, + object: new Drawer($drawerEl, { + placement: placement ? placement : Default.placement, + bodyScrolling: bodyScrolling + ? bodyScrolling === 'true' + ? true + : false + : Default.bodyScrolling, + backdrop: backdrop + ? backdrop === 'true' + ? true + : false + : Default.backdrop, + edge: edge + ? edge === 'true' + ? true + : false + : Default.edge, + edgeOffset: edgeOffset + ? edgeOffset + : Default.edgeOffset, + }), + }); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_1 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_1) { + $triggerEl.addEventListener('click', function () { + drawer_1.object.toggle(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document + .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') + .forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') + ? $triggerEl.getAttribute('data-drawer-dismiss') + : $triggerEl.getAttribute('data-drawer-hide'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_2 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_2) { + $triggerEl.addEventListener('click', function () { + drawer_2.object.hide(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); + } + }); + document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-show'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_3 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_3) { + $triggerEl.addEventListener('click', function () { + drawer_3.object.show(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); +} +exports.initDrawers = initDrawers; +if (typeof window !== 'undefined') { + window.Drawer = Drawer; + window.initDrawers = initDrawers; +} +exports["default"] = Drawer; + + +/***/ }), + +/***/ 316: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initDropdowns = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'bottom', + triggerType: 'click', + offsetSkidding: 0, + offsetDistance: 10, + delay: 300, + ignoreClickOutsideClass: false, + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dropdown = /** @class */ (function () { + function Dropdown(targetElement, triggerElement, options) { + if (targetElement === void 0) { targetElement = null; } + if (triggerElement === void 0) { triggerElement = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetElement; + this._triggerEl = triggerElement; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Dropdown.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Dropdown.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + // click event handling for trigger element + if (this._options.triggerType === 'click') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.toggle(); + }); + }); + } + // hover event handling for trigger element + if (this._options.triggerType === 'hover') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + if (ev === 'click') { + _this.toggle(); + } + else { + setTimeout(function () { + _this.show(); + }, _this._options.delay); + } + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + }); + } + }; + Dropdown.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [ + this._options.offsetSkidding, + this._options.offsetDistance, + ], + }, + }, + ], + }); + }; + Dropdown.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + // Ignore clicks on the trigger element (ie. a datepicker input) + var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; + var isIgnored = false; + if (ignoreClickOutsideClass) { + var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); + ignoredClickOutsideEls.forEach(function (el) { + if (el.contains(clickedEl)) { + isIgnored = true; + return; + } + }); + } + // Ignore clicks on the target element (ie. dropdown itself) + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + !isIgnored && + this.isVisible()) { + this.hide(); + } + }; + Dropdown.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'click'], + hideEvents: ['mouseleave'], + }; + case 'click': + return { + showEvents: ['click'], + hideEvents: [], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['click'], + hideEvents: [], + }; + } + }; + Dropdown.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Dropdown.prototype.isVisible = function () { + return this._visible; + }; + Dropdown.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + this._targetEl.classList.add('block'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + this._setupClickOutsideListener(); + // Update its position + this._popperInstance.update(); + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dropdown.prototype.hide = function () { + this._targetEl.classList.remove('block'); + this._targetEl.classList.add('hidden'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + this._visible = false; + this._removeClickOutsideListener(); + // callback function + this._options.onHide(this); + }; + return Dropdown; +}()); +function initDropdowns() { + document + .querySelectorAll('[data-dropdown-toggle]') + .forEach(function ($triggerEl) { + var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); + var $dropdownEl = document.getElementById(dropdownId); + if ($dropdownEl) { + var placement = $triggerEl.getAttribute('data-dropdown-placement'); + var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); + var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); + var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); + var delay = $triggerEl.getAttribute('data-dropdown-delay'); + var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); + new Dropdown($dropdownEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + offsetSkidding: offsetSkidding + ? parseInt(offsetSkidding) + : Default.offsetSkidding, + offsetDistance: offsetDistance + ? parseInt(offsetDistance) + : Default.offsetDistance, + delay: delay ? parseInt(delay) : Default.delay, + ignoreClickOutsideClass: ignoreClickOutsideClass + ? ignoreClickOutsideClass + : Default.ignoreClickOutsideClass, + }); + } + else { + console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); + } + }); +} +exports.initDropdowns = initDropdowns; +if (typeof window !== 'undefined') { + window.Dropdown = Dropdown; + window.initDropdowns = initDropdowns; +} +exports["default"] = Dropdown; + + +/***/ }), + +/***/ 311: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initFlowbite = void 0; +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +function initFlowbite() { + (0, accordion_1.initAccordions)(); + (0, collapse_1.initCollapses)(); + (0, carousel_1.initCarousels)(); + (0, dismiss_1.initDismisses)(); + (0, dropdown_1.initDropdowns)(); + (0, modal_1.initModals)(); + (0, drawer_1.initDrawers)(); + (0, tabs_1.initTabs)(); + (0, tooltip_1.initTooltips)(); + (0, popover_1.initPopovers)(); + (0, dial_1.initDials)(); +} +exports.initFlowbite = initFlowbite; +if (typeof window !== 'undefined') { + window.initFlowbite = initFlowbite; +} + + +/***/ }), + +/***/ 16: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initModals = void 0; +var Default = { + placement: 'center', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + backdrop: 'dynamic', + closable: true, + onHide: function () { }, + onShow: function () { }, + onToggle: function () { }, +}; +var Modal = /** @class */ (function () { + function Modal(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._isHidden = true; + this._backdropEl = null; + this._init(); + } + Modal.prototype._init = function () { + var _this = this; + if (this._targetEl) { + this._getPlacementClasses().map(function (c) { + _this._targetEl.classList.add(c); + }); + } + }; + Modal.prototype._createBackdrop = function () { + var _a; + if (this._isHidden) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('modal-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + this._backdropEl = backdropEl; + } + }; + Modal.prototype._destroyBackdropEl = function () { + if (!this._isHidden) { + document.querySelector('[modal-backdrop]').remove(); + } + }; + Modal.prototype._setupModalCloseEventListeners = function () { + var _this = this; + if (this._options.backdrop === 'dynamic') { + this._clickOutsideEventListener = function (ev) { + _this._handleOutsideClick(ev.target); + }; + this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); + } + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._removeModalCloseEventListeners = function () { + if (this._options.backdrop === 'dynamic') { + this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); + } + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._handleOutsideClick = function (target) { + if (target === this._targetEl || + (target === this._backdropEl && this.isVisible())) { + this.hide(); + } + }; + Modal.prototype._getPlacementClasses = function () { + switch (this._options.placement) { + // top + case 'top-left': + return ['justify-start', 'items-start']; + case 'top-center': + return ['justify-center', 'items-start']; + case 'top-right': + return ['justify-end', 'items-start']; + // center + case 'center-left': + return ['justify-start', 'items-center']; + case 'center': + return ['justify-center', 'items-center']; + case 'center-right': + return ['justify-end', 'items-center']; + // bottom + case 'bottom-left': + return ['justify-start', 'items-end']; + case 'bottom-center': + return ['justify-center', 'items-end']; + case 'bottom-right': + return ['justify-end', 'items-end']; + default: + return ['justify-center', 'items-center']; + } + }; + Modal.prototype.toggle = function () { + if (this._isHidden) { + this.show(); + } + else { + this.hide(); + } + // callback function + this._options.onToggle(this); + }; + Modal.prototype.show = function () { + if (this.isHidden) { + this._targetEl.classList.add('flex'); + this._targetEl.classList.remove('hidden'); + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + this._createBackdrop(); + this._isHidden = false; + // prevent body scroll + document.body.classList.add('overflow-hidden'); + // Add keyboard event listener to the document + if (this._options.closable) { + this._setupModalCloseEventListeners(); + } + // callback function + this._options.onShow(this); + } + }; + Modal.prototype.hide = function () { + if (this.isVisible) { + this._targetEl.classList.add('hidden'); + this._targetEl.classList.remove('flex'); + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + this._destroyBackdropEl(); + this._isHidden = true; + // re-apply body scroll + document.body.classList.remove('overflow-hidden'); + if (this._options.closable) { + this._removeModalCloseEventListeners(); + } + // callback function + this._options.onHide(this); + } + }; + Modal.prototype.isVisible = function () { + return !this._isHidden; + }; + Modal.prototype.isHidden = function () { + return this._isHidden; + }; + return Modal; +}()); +var getModalInstance = function (id, instances) { + if (instances.some(function (modalInstance) { return modalInstance.id === id; })) { + return instances.find(function (modalInstance) { return modalInstance.id === id; }); + } + return null; +}; +function initModals() { + var modalInstances = []; + // initiate modal based on data-modal-target + document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-target'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + if (!getModalInstance(modalId, modalInstances)) { + modalInstances.push({ + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); + } + }); + // support pre v1.6.0 data-modal-toggle initialization + document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-toggle'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + var modal_1 = getModalInstance(modalId, modalInstances); + if (!modal_1) { + modal_1 = { + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }; + modalInstances.push(modal_1); + } + $triggerEl.addEventListener('click', function () { + modal_1.object.toggle(); + }); + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); + } + }); + // show modal on click if exists based on id + document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-show'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_2 = getModalInstance(modalId, modalInstances); + if (modal_2) { + $triggerEl.addEventListener('click', function () { + if (modal_2.object.isHidden) { + modal_2.object.show(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); + } + }); + // hide modal on click if exists based on id + document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-hide'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_3 = getModalInstance(modalId, modalInstances); + if (modal_3) { + $triggerEl.addEventListener('click', function () { + if (modal_3.object.isVisible) { + modal_3.object.hide(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); + } + }); +} +exports.initModals = initModals; +if (typeof window !== 'undefined') { + window.Modal = Modal; + window.initModals = initModals; +} +exports["default"] = Modal; + + +/***/ }), + +/***/ 903: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initPopovers = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + offset: 10, + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Popover = /** @class */ (function () { + function Popover(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Popover.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Popover.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + }); + }; + Popover.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, this._options.offset], + }, + }, + ], + }); + }; + Popover.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Popover.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Popover.prototype.isVisible = function () { + return this._visible; + }; + Popover.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Popover.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility to true + this._visible = true; + // callback function + this._options.onShow(this); + }; + Popover.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility to false + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Popover; +}()); +function initPopovers() { + document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { + var popoverID = $triggerEl.getAttribute('data-popover-target'); + var $popoverEl = document.getElementById(popoverID); + if ($popoverEl) { + var triggerType = $triggerEl.getAttribute('data-popover-trigger'); + var placement = $triggerEl.getAttribute('data-popover-placement'); + var offset = $triggerEl.getAttribute('data-popover-offset'); + new Popover($popoverEl, $triggerEl, { + placement: placement ? placement : Default.placement, + offset: offset ? parseInt(offset) : Default.offset, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); + } + }); +} +exports.initPopovers = initPopovers; +if (typeof window !== 'undefined') { + window.Popover = Popover; + window.initPopovers = initPopovers; +} +exports["default"] = Popover; + + +/***/ }), + +/***/ 247: +/***/ (function(__unused_webpack_module, exports) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTabs = void 0; +var Default = { + defaultTabId: null, + activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', + inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', + onShow: function () { }, +}; +var Tabs = /** @class */ (function () { + function Tabs(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._activeTab = options ? this.getTab(options.defaultTabId) : null; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Tabs.prototype._init = function () { + var _this = this; + if (this._items.length) { + // set the first tab as active if not set by explicitly + if (!this._activeTab) { + this._setActiveTab(this._items[0]); + } + // force show the first default tab + this.show(this._activeTab.id, true); + // show tab content based on click + this._items.map(function (tab) { + tab.triggerEl.addEventListener('click', function () { + _this.show(tab.id); + }); + }); + } + }; + Tabs.prototype.getActiveTab = function () { + return this._activeTab; + }; + Tabs.prototype._setActiveTab = function (tab) { + this._activeTab = tab; + }; + Tabs.prototype.getTab = function (id) { + return this._items.filter(function (t) { return t.id === id; })[0]; + }; + Tabs.prototype.show = function (id, forceShow) { + var _a, _b; + var _this = this; + if (forceShow === void 0) { forceShow = false; } + var tab = this.getTab(id); + // don't do anything if already active + if (tab === this._activeTab && !forceShow) { + return; + } + // hide other tabs + this._items.map(function (t) { + var _a, _b; + if (t !== tab) { + (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + t.targetEl.classList.add('hidden'); + t.triggerEl.setAttribute('aria-selected', 'false'); + } + }); + // show active tab + (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + tab.triggerEl.setAttribute('aria-selected', 'true'); + tab.targetEl.classList.remove('hidden'); + this._setActiveTab(tab); + // callback function + this._options.onShow(this, tab); + }; + return Tabs; +}()); +function initTabs() { + document.querySelectorAll('[data-tabs-toggle]').forEach(function ($triggerEl) { + var tabItems = []; + var defaultTabId = null; + $triggerEl + .querySelectorAll('[role="tab"]') + .forEach(function ($triggerEl) { + var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; + var tab = { + id: $triggerEl.getAttribute('data-tabs-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), + }; + tabItems.push(tab); + if (isActive) { + defaultTabId = tab.id; + } + }); + new Tabs(tabItems, { + defaultTabId: defaultTabId, + }); + }); +} +exports.initTabs = initTabs; +if (typeof window !== 'undefined') { + window.Tabs = Tabs; + window.initTabs = initTabs; +} +exports["default"] = Tabs; + + +/***/ }), + +/***/ 671: +/***/ (function(__unused_webpack_module, exports, __webpack_require__) { + + +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.initTooltips = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = __webpack_require__(853); +var Default = { + placement: 'top', + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Tooltip = /** @class */ (function () { + function Tooltip(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Tooltip.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Tooltip.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.hide(); + }); + }); + }; + Tooltip.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, 8], + }, + }, + ], + }); + }; + Tooltip.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Tooltip.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Tooltip.prototype.isVisible = function () { + return this._visible; + }; + Tooltip.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Tooltip.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility + this._visible = true; + // callback function + this._options.onShow(this); + }; + Tooltip.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Tooltip; +}()); +function initTooltips() { + document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { + var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); + var $tooltipEl = document.getElementById(tooltipId); + if ($tooltipEl) { + var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); + var placement = $triggerEl.getAttribute('data-tooltip-placement'); + new Tooltip($tooltipEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); + } + }); +} +exports.initTooltips = initTooltips; +if (typeof window !== 'undefined') { + window.Tooltip = Tooltip; + window.initTooltips = initTooltips; +} +exports["default"] = Tooltip; + + +/***/ }), + +/***/ 947: +/***/ (function(__unused_webpack_module, exports) { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +var Events = /** @class */ (function () { + function Events(eventType, eventFunctions) { + if (eventFunctions === void 0) { eventFunctions = []; } + this._eventType = eventType; + this._eventFunctions = eventFunctions; + } + Events.prototype.init = function () { + var _this = this; + this._eventFunctions.forEach(function (eventFunction) { + if (typeof window !== 'undefined') { + window.addEventListener(_this._eventType, eventFunction); + } + }); + }; + return Events; +}()); +exports["default"] = Events; + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ !function() { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = function(exports, definition) { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ }(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ !function() { +/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } +/******/ }(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ !function() { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ }(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. +!function() { +var exports = __webpack_exports__; + +Object.defineProperty(exports, "__esModule", ({ value: true })); +// core components +var accordion_1 = __webpack_require__(902); +var carousel_1 = __webpack_require__(33); +var collapse_1 = __webpack_require__(922); +var dial_1 = __webpack_require__(556); +var dismiss_1 = __webpack_require__(791); +var drawer_1 = __webpack_require__(340); +var dropdown_1 = __webpack_require__(316); +var modal_1 = __webpack_require__(16); +var popover_1 = __webpack_require__(903); +var tabs_1 = __webpack_require__(247); +var tooltip_1 = __webpack_require__(671); +__webpack_require__(311); +var events_1 = __webpack_require__(947); +var turboLoadEvents = new events_1.default('turbo:load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +turboLoadEvents.init(); +var turboFrameLoadEvents = new events_1.default('turbo:frame-load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +turboFrameLoadEvents.init(); +exports["default"] = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; + +}(); +/******/ return __webpack_exports__; +/******/ })() +; +}); +//# sourceMappingURL=flowbite.turbo.js.map \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.turbo.js.map b/node_modules/flowbite/dist/flowbite.turbo.js.map new file mode 100644 index 0000000..1d25895 --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.turbo.js.map @@ -0,0 +1 @@ +{"version":3,"file":"flowbite.turbo.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACVO,IAAI,SAAG;AACP;AACA;AACA;AACA;AACA,sBAAsB,SAAG;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACP;AACA,CAAC;AACM,IAAI,gBAAU;AACrB;AACA,CAAC,OAAO;;AAED;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA;AACA;;AC9BQ;AACf;AACA;;ACFe;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;ACXuC;;AAEvC;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA,mBAAmB,SAAS;AAC5B;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,SAAS;AAC5B;AACA;;;;ACpBsD;AACK,CAAC;AAC5D;;AAEA;AACA;AACA;AACA;AACA;AACA,wCAAwC;;AAExC,SAAS,aAAa,cAAc,WAAW;AAC/C;AACA,MAAM;AACN;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uHAAuH;;AAEvH;AACA;AACA;AACA,OAAO,IAAI,GAAG;;AAEd,WAAW,aAAa,cAAc,WAAW;AACjD;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA,EAAE;;;AAGF,0DAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;ACnFkC;AACpB;AACf;AACA;;ACHO,IAAI,QAAG;AACP,IAAI,QAAG;AACP;;ACFQ;AACf;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;ACVgD;AACjC;AACf,gDAAgD,WAAW;AAC3D;;ACH2D;AAClB;AACF;A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CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc,IAAI;AAClB,cAAc,SAAG;AACjB;;AAEA;AACA,uBAAuB,eAAe;AACtC;AACA;;AAEA,yBAAyB,SAAS;AAClC,qBAAqB,kBAAkB;;AAEvC,UAAU,gBAAgB;AAC1B;AACA;AACA;AACA,MAAM;;;AAGN;;AAEA,sBAAsB,SAAG,mBAAmB,IAAI,kBAAkB,KAAK,mBAAmB,GAAG;AAC7F,cAAc,MAAM;AACpB;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,IAAI,mBAAmB,SAAG,kBAAkB,MAAM,mBAAmB,GAAG;AAC9F,cAAc,KAAK;AACnB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,2BAA2B,oCAAoC;AAC/D;;AAEA,yBAAyB,qCAAqC;AAC9D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,MAAM,KAAqC,EAAE,2BAQ1C;;AAEH;AACA,eAAe,gBAAgB;AAC/B,eAAe,YAAY;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA,0CAA0C,mDAAmD;AAC7F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,yCAAyC,kDAAkD;AAC3F;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,4CAA4C;AAC5C;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACpLiD,CAAC;;AAEnD;AACA;AACA;;AAEA,SAAS,qBAAM;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,SAAS;AACxB;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA,sBAAsB;AACtB,UAAU,qBAAM;AAChB;AACA,CAAC;;AChDD;AACA;AACA;AACA;AACA;AACA;AACe;AACf;AACA;AACA,GAAG;AACH;;ACVA,IAAI,kCAAI;AACR;AACA;AACA;AACe;AACf;AACA,WAAW,kCAAI;AACf,GAAG;AACH;;ACRuC;AACxB;AACf,YAAY,SAAS;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;;ACT+D;AACN;AACN;AACpC;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,qBAAqB,CAAC,kBAAkB,kBAAkB,eAAe;AAClF;;ACZuC;AACkB;AACE;AACN;AACtC;AACf,YAAY,SAAS;AACrB,aAAa,kBAAkB;AAC/B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB,gBAAgB;;AAEzC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,mBAAmB;AAC9B;AACA;AACA;;AC9ByD;AACJ;AACM;AACR;AACZ,CAAC;AACxC;;AAEe;AACf;;AAEA,aAAa,kBAAkB;AAC/B,kBAAkB,eAAe;AACjC;AACA,cAAc,QAAG;AACjB,eAAe,QAAG;AAClB,kCAAkC,mBAAmB;AACrD;;AAEA,MAAM,gBAAgB;AACtB,SAAS,QAAG;AACZ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BqD;AACtC;AACf;AACA,0BAA0B,gBAAgB;AAC1C;AACA;AACA;;AAEA;AACA;;ACT+C;AACE;AACN;AACK;AACjC;AACf,4CAA4C,WAAW;AACvD;AACA;AACA;;AAEA,MAAM,aAAa,UAAU,cAAc;AAC3C;AACA;;AAEA,yBAAyB,aAAa;AACtC;;ACfmD;AACJ;AACR;AACU;AACjD;AACA;AACA;AACA;AACA;AACA;;AAEe;AACf;;AAEA;AACA;AACA;;AAEA,qBAAqB,eAAe;AACpC;AACA,YAAY,SAAS;AACrB,+DAA+D,cAAc;AAC7E;AACA;AACA,uCAAuC,aAAa;AACpD;;ACzBe;AACf,yBAAyB;AACzB;AACA;AACA;AACA;AACA,GAAG;AACH;;ACPuC;AACY;AACA;AACI;AACJ;AACM;AACJ;AACM;AACI;AAChB;AACV;AACM;AACiB;AAChB;;AAE5C;AACA,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4BAA4B,QAAQ,GAAG,gBAAgB,CAAC,eAAe,uBAAuB,SAAS,0EAA0E,gBAAgB,CAAC,eAAe,CAAC,kBAAkB;AACpO,EAAE;AACF;AACA;;;AAGA;AACA,wBAAwB,iBAAiB,CAAC,aAAa;AACvD,wDAAwD,gBAAgB;AACxE,4CAA4C,aAAa,YAAY,eAAe;;AAEpF,OAAO,SAAS;AAChB;AACA,IAAI;;;AAGJ;AACA,WAAW,SAAS,oBAAoB,QAAQ,oCAAoC,WAAW;AAC/F,GAAG;AACH,EAAE;AACF;;;AAGe;AACf;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAG;AACrB,oBAAoB,QAAG;AACvB,qBAAqB,QAAG;AACxB,mBAAmB,QAAG;AACtB;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;ACrEqD;AACR;AACwB;AACF;AACpD;AACf;AACA;AACA;AACA,kCAAkC,gBAAgB;AAClD,8BAA8B,YAAY;AAC1C;AACA;AACA;;AAEA;AACA,SAAS,SAAG;AACZ;AACA;AACA;AACA;AACA;;AAEA,SAAS,MAAM;AACf;AACA;AACA;AACA;AACA;;AAEA,SAAS,KAAK;AACd;AACA;AACA;AACA;AACA;;AAEA,SAAS,IAAI;AACb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,iCAAiC,wBAAwB;;AAEzD;AACA;;AAEA;AACA,WAAW,KAAK;AAChB;AACA;;AAEA,WAAW,GAAG;AACd;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;ACrE8D;AACM;AACM;AACzB;AACI;AAC0D;AACxD;AACE;AACN,CAAC;;AAErC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,eAAe;AAC/D;AACA,wDAAwD,QAAQ;AAChE;AACA,0DAA0D,MAAM;AAChE;AACA;AACA;AACA;AACA,sBAAsB,kBAAkB,yCAAyC,eAAe,UAAU,cAAc;AACxH,sCAAsC,MAAM,GAAG,SAAS,GAAG,MAAM;AACjE;AACA;AACA,2BAA2B,eAAe,CAAC,SAAS,gDAAgD,kBAAkB;AACtH,4BAA4B,qBAAqB;AACjD,sBAAsB,cAAc;AACpC;AACA;AACA;AACA;AACA,GAAG;AACH,yBAAyB,gBAAgB,iBAAiB;AAC1D,6CAA6C,MAAM,2CAA2C;AAC9F;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;;AAE/C,yBAAyB,MAAM;AAC/B;AACA;AACA,sBAAsB,KAAK,EAAE,MAAM;AACnC,kBAAkB,SAAG,EAAE,MAAM;AAC7B;AACA,KAAK;AACL;;AAEA;AACA;;AChE6C;AACkD;AAC9C;AACI;AACtC;AACf;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAiE,gBAAa;AAC9E,kBAAkB,YAAY;AAC9B,gDAAgD,mBAAmB,GAAG,0BAA0B;AAChG,WAAW,YAAY;AACvB,GAAG,IAAI,cAAc;AACrB;AACA;AACA,GAAG;;AAEH;AACA;;AAEA,QAAQ,KAAqC,EAAE,EAE1C;AACL,IAAI;;;AAGJ;AACA,qBAAqB,cAAc;AACnC;AACA;AACA;AACA;AACA,KAAK,EAAE,gBAAgB;AACvB;AACA,GAAG,IAAI;AACP;AACA;AACA,GAAG;AACH;;AC9CoE;AACR;AAC0B;AAC9B;AACY;AACA;AAChB,CAAC;;AAErD;AACA,MAAM,gBAAgB,gBAAgB,IAAI;AAC1C;AACA;;AAEA,0BAA0B,oBAAoB;AAC9C,UAAU,6BAA6B,gCAAgC,6BAA6B;AACpG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,gBAAgB;AACtC;AACA,iGAAiG,oBAAoB;AACrH;AACA,sBAAsB,gBAAgB,gBAAgB,IAAI,GAAG,oBAAoB;AACjF;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,uBAAuB;AACzC;;AAEA,yBAAyB,gBAAgB;;AAEzC,2BAA2B,YAAY,gBAAgB,KAAK;AAC5D,sBAAsB,SAAG,EAAE,MAAM;AACjC;AACA,mBAAmB,cAAc;AACjC;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,4DAA4D,KAAK,GAAG,IAAI,sBAAsB,MAAM,GAAG,SAAG;;AAE1G;AACA,0BAA0B,oBAAoB;AAC9C;;AAEA,2BAA2B,oBAAoB;AAC/C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,QAAQ;AAC1C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AClJsD;AACC;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,SAAG,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI;AAClC;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH,0BAA0B,cAAc;AACxC;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,mDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC5D2D;AACD,CAAC;;AAErD;AACP,sBAAsB,gBAAgB;AACtC,wBAAwB,IAAI,EAAE,SAAG;;AAEjC,mEAAmE;AACnE;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,UAAU,IAAI,EAAE,KAAK;AACrB;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,uBAAiB;AAC9B;AACA;AACA,GAAG,IAAI;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,qDAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACrDuD;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,cAAc;AAC5C;AACA;AACA;AACA;AACA,GAAG;AACH,EAAE;;;AAGF,4DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;ACxBc;AACf;AACA;;ACF8D;AACF;AACgB;AAC5B;AACY;AACF;AACI;AACN;AACJ;AACY;AACE;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B;AACA;AACA;AACA;AACA,GAAG;AACH,sBAAsB,gBAAgB;AACtC,kBAAkB,YAAY;AAC9B;AACA,iBAAiB,wBAAwB;AACzC,gBAAgB,UAAU;AAC1B;AACA;AACA;AACA,4FAA4F;AAC5F;AACA,GAAG;AACH;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,sCAAsC,SAAG,GAAG,IAAI;AAChD,qCAAqC,MAAM,GAAG,KAAK;AACnD;AACA;AACA;AACA;AACA;AACA,+BAA+B,KAAK;AACpC,+BAA+B,KAAK,2CAA2C;AAC/E;;AAEA;AACA,6CAA6C,aAAa;AAC1D;AACA;AACA;AACA,yHAAyH,kBAAkB;AAC3I;AACA,uDAAuD;AACvD;AACA;AACA;AACA;;AAEA,mBAAmB,MAAM;AACzB;AACA;AACA,oDAAoD,eAAe;AACnE;AACA;AACA;AACA;AACA,0BAA0B,MAAM,UAAU,QAAO,yCAAyC,QAAO;AACjG;AACA;AACA;;AAEA;AACA;;AAEA,uCAAuC,SAAG,GAAG,IAAI;;AAEjD,sCAAsC,MAAM,GAAG,KAAK;;AAEpD;;AAEA;;AAEA;;AAEA;;AAEA,wBAAwB,SAAG,EAAE,IAAI;;AAEjC;;AAEA;;AAEA;;AAEA,oDAAoD,cAAc,oCAAoC,MAAM;;AAE5G;AACA;AACA;;AAEA;AACA,EAAE;;;AAGF,8DAAe;AACf;AACA;AACA;AACA;AACA;AACA,CAAC;;AC7IyD;AACZ;AACgB;AACE;AACpB;AACA;AACI;AACc;;;ACP/C;AACf;AACA;AACA;AACA;AACA;;ACLmD;AACZ;AACS;AACa;AAC9C;AACf,eAAe,SAAS,WAAW,aAAa;AAChD,WAAW,eAAe;AAC1B,IAAI;AACJ,WAAW,oBAAoB;AAC/B;AACA;;ACV+D;AAChB;AACJ;AACK;AACW;AACF;AACR;AACR;;AAEzC;AACA;AACA,eAAe,KAAK;AACpB,eAAe,KAAK;AACpB;AACA,EAAE;AACF;;;AAGe;AACf;AACA;AACA;;AAEA,gCAAgC,aAAa;AAC7C,6BAA6B,aAAa;AAC1C,wBAAwB,kBAAkB;AAC1C,aAAa,qBAAqB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,QAAQ,WAAW;AACnB,IAAI,cAAc;AAClB,eAAe,aAAa;AAC5B;;AAEA,QAAQ,aAAa;AACrB,gBAAgB,qBAAqB;AACrC;AACA;AACA,MAAM;AACN,kBAAkB,mBAAmB;AACrC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzD6C,CAAC;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,GAAG;;AAEN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEe;AACf;AACA,2CAA2C;;AAE3C,SAAS,qBAAqB;AAC9B;AACA;AACA,KAAK;AACL,GAAG;AACH;;AC3Ce;AACf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;;AAEA;AACA;AACA;;ACde;AACf;AACA;AACA,sDAAsD;AACtD,+BAA+B;AAC/B,4BAA4B;AAC5B,KAAK;AACL;AACA,GAAG,IAAI,GAAG;;AAEV;AACA;AACA,GAAG;AACH;;ACb+D;AACN;AACQ;AACJ;AACE;AACR;AACZ;AACkB;AAClB;AACgB;AACV;AACM;AACD;AACpB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,sEAAsE,aAAa;AACnF;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,+BAA+B;AAC/B,uBAAuB;AACvB;AACA;AACA;AACA,OAAO;AACP,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC;AACA,qBAAqB,SAAS,cAAc,iBAAiB,yCAAyC,iBAAiB;AACvH,kBAAkB,iBAAiB;AACnC,WAAW;AACX;;AAEA,+BAA+B,cAAc,CAAC,WAAW,yDAAyD;;AAElH;AACA;AACA,SAAS,GAAG;AACZ;;AAEA,YAAY,KAAqC,EAAE,qGA+B1C;;AAET;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,6CAA6C;AAC7C;;AAEA;AACA,cAAc,KAAqC,EAAE,EAE1C;;AAEX;AACA,UAAU;;;AAGV;AACA,qBAAqB,gBAAgB,YAAY,eAAe;AAChE,kBAAkB,aAAa;AAC/B,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA,mDAAmD;AACnD;AACA;AACA,6CAA6C,KAAK;;AAElD;AACA,sEAAsE;AACtE,SAAS;AACT;;AAEA,4BAA4B,uCAAuC;AACnE,cAAc,KAAqC,EAAE,EAO1C;;AAEX;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE;AAChE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,OAAO;AACP;AACA;AACA,cAAc,QAAQ;AACtB;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,KAAqC,EAAE,EAE1C;;AAEP;AACA;;AAEA;AACA;AACA;AACA;AA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","sources":["webpack:///webpack/universalModuleDefinition","webpack:///./node_modules/@popperjs/core/lib/enums.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeName.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindow.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/instanceOf.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/applyStyles.js","webpack:///./node_modules/@popperjs/core/lib/utils/getBasePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/math.js","webpack:///./node_modules/@popperjs/core/lib/utils/userAgent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isLayoutViewport.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getBoundingClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getLayoutRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/contains.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getComputedStyle.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isTableElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentElement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getParentNode.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getOffsetParent.js","webpack:///./node_modules/@popperjs/core/lib/utils/getMainAxisFromPlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/within.js","webpack:///./node_modules/@popperjs/core/lib/utils/getFreshSideObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergePaddingObject.js","webpack:///./node_modules/@popperjs/core/lib/utils/expandToHashMap.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/arrow.js","webpack:///./node_modules/@popperjs/core/lib/utils/getVariation.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/computeStyles.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/eventListeners.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositePlacement.js","webpack:///./node_modules/@popperjs/core/lib/utils/getOppositeVariationPlacement.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getWindowScrollBarX.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getViewportRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getDocumentRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/isScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getScrollParent.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/listScrollParents.js","webpack:///./node_modules/@popperjs/core/lib/utils/rectToClientRect.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getClippingRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/detectOverflow.js","webpack:///./node_modules/@popperjs/core/lib/utils/computeAutoPlacement.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/flip.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/hide.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/offset.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/popperOffsets.js","webpack:///./node_modules/@popperjs/core/lib/utils/getAltAxis.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/preventOverflow.js","webpack:///./node_modules/@popperjs/core/lib/modifiers/index.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getHTMLElementScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getNodeScroll.js","webpack:///./node_modules/@popperjs/core/lib/dom-utils/getCompositeRect.js","webpack:///./node_modules/@popperjs/core/lib/utils/orderModifiers.js","webpack:///./node_modules/@popperjs/core/lib/utils/debounce.js","webpack:///./node_modules/@popperjs/core/lib/utils/mergeByName.js","webpack:///./node_modules/@popperjs/core/lib/createPopper.js","webpack:///./node_modules/@popperjs/core/lib/popper.js","webpack:///./node_modules/@popperjs/core/lib/popper-lite.js","webpack:///./node_modules/@popperjs/core/lib/index.js","webpack:///./src/components/accordion/index.ts","webpack:///./src/components/carousel/index.ts","webpack:///./src/components/collapse/index.ts","webpack:///./src/components/dial/index.ts","webpack:///./src/components/dismiss/index.ts","webpack:///./src/components/drawer/index.ts","webpack:///./src/components/dropdown/index.ts","webpack:///./src/components/index.ts","webpack:///./src/components/modal/index.ts","webpack:///./src/components/popover/index.ts","webpack:///./src/components/tabs/index.ts","webpack:///./src/components/tooltip/index.ts","webpack:///./src/dom/events.ts","webpack:///webpack/bootstrap","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///./src/index.turbo.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"Flowbite\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Flowbite\"] = factory();\n\telse\n\t\troot[\"Flowbite\"] = factory();\n})(self, function() {\nreturn ","export var top = 'top';\nexport var bottom = 'bottom';\nexport var right = 'right';\nexport var left = 'left';\nexport var auto = 'auto';\nexport var basePlacements = [top, bottom, right, left];\nexport var start = 'start';\nexport var end = 'end';\nexport var clippingParents = 'clippingParents';\nexport var viewport = 'viewport';\nexport var popper = 'popper';\nexport var reference = 'reference';\nexport var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) {\n return acc.concat([placement + \"-\" + start, placement + \"-\" + end]);\n}, []);\nexport var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) {\n return acc.concat([placement, placement + \"-\" + start, placement + \"-\" + end]);\n}, []); // modifiers that need to read the DOM\n\nexport var beforeRead = 'beforeRead';\nexport var read = 'read';\nexport var afterRead = 'afterRead'; // pure-logic modifiers\n\nexport var beforeMain = 'beforeMain';\nexport var main = 'main';\nexport var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state)\n\nexport var beforeWrite = 'beforeWrite';\nexport var write = 'write';\nexport var afterWrite = 'afterWrite';\nexport var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite];","export default function getNodeName(element) {\n return element ? (element.nodeName || '').toLowerCase() : null;\n}","export default function getWindow(node) {\n if (node == null) {\n return window;\n }\n\n if (node.toString() !== '[object Window]') {\n var ownerDocument = node.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView || window : window;\n }\n\n return node;\n}","import getWindow from \"./getWindow.js\";\n\nfunction isElement(node) {\n var OwnElement = getWindow(node).Element;\n return node instanceof OwnElement || node instanceof Element;\n}\n\nfunction isHTMLElement(node) {\n var OwnElement = getWindow(node).HTMLElement;\n return node instanceof OwnElement || node instanceof HTMLElement;\n}\n\nfunction isShadowRoot(node) {\n // IE 11 has no ShadowRoot\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n\n var OwnElement = getWindow(node).ShadowRoot;\n return node instanceof OwnElement || node instanceof ShadowRoot;\n}\n\nexport { isElement, isHTMLElement, isShadowRoot };","import getNodeName from \"../dom-utils/getNodeName.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // This modifier takes the styles prepared by the `computeStyles` modifier\n// and applies them to the HTMLElements such as popper and arrow\n\nfunction applyStyles(_ref) {\n var state = _ref.state;\n Object.keys(state.elements).forEach(function (name) {\n var style = state.styles[name] || {};\n var attributes = state.attributes[name] || {};\n var element = state.elements[name]; // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n } // Flow doesn't support to extend this property, but it's the most\n // effective way to apply styles to an HTMLElement\n // $FlowFixMe[cannot-write]\n\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (name) {\n var value = attributes[name];\n\n if (value === false) {\n element.removeAttribute(name);\n } else {\n element.setAttribute(name, value === true ? '' : value);\n }\n });\n });\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state;\n var initialStyles = {\n popper: {\n position: state.options.strategy,\n left: '0',\n top: '0',\n margin: '0'\n },\n arrow: {\n position: 'absolute'\n },\n reference: {}\n };\n Object.assign(state.elements.popper.style, initialStyles.popper);\n state.styles = initialStyles;\n\n if (state.elements.arrow) {\n Object.assign(state.elements.arrow.style, initialStyles.arrow);\n }\n\n return function () {\n Object.keys(state.elements).forEach(function (name) {\n var element = state.elements[name];\n var attributes = state.attributes[name] || {};\n var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them\n\n var style = styleProperties.reduce(function (style, property) {\n style[property] = '';\n return style;\n }, {}); // arrow is optional + virtual elements\n\n if (!isHTMLElement(element) || !getNodeName(element)) {\n return;\n }\n\n Object.assign(element.style, style);\n Object.keys(attributes).forEach(function (attribute) {\n element.removeAttribute(attribute);\n });\n });\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'applyStyles',\n enabled: true,\n phase: 'write',\n fn: applyStyles,\n effect: effect,\n requires: ['computeStyles']\n};","import { auto } from \"../enums.js\";\nexport default function getBasePlacement(placement) {\n return placement.split('-')[0];\n}","export var max = Math.max;\nexport var min = Math.min;\nexport var round = Math.round;","export default function getUAString() {\n var uaData = navigator.userAgentData;\n\n if (uaData != null && uaData.brands) {\n return uaData.brands.map(function (item) {\n return item.brand + \"/\" + item.version;\n }).join(' ');\n }\n\n return navigator.userAgent;\n}","import getUAString from \"../utils/userAgent.js\";\nexport default function isLayoutViewport() {\n return !/^((?!chrome|android).)*safari/i.test(getUAString());\n}","import { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport { round } from \"../utils/math.js\";\nimport getWindow from \"./getWindow.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getBoundingClientRect(element, includeScale, isFixedStrategy) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n\n var clientRect = element.getBoundingClientRect();\n var scaleX = 1;\n var scaleY = 1;\n\n if (includeScale && isHTMLElement(element)) {\n scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export { default as applyStyles } from \"./applyStyles.js\";\nexport { default as arrow } from \"./arrow.js\";\nexport { default as computeStyles } from \"./computeStyles.js\";\nexport { default as eventListeners } from \"./eventListeners.js\";\nexport { default as flip } from \"./flip.js\";\nexport { default as hide } from \"./hide.js\";\nexport { default as offset } from \"./offset.js\";\nexport { default as popperOffsets } from \"./popperOffsets.js\";\nexport { default as preventOverflow } from \"./preventOverflow.js\";","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","export * from \"./enums.js\";\nexport * from \"./modifiers/index.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { popperGenerator, detectOverflow, createPopper as createPopperBase } from \"./createPopper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper } from \"./popper.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\";","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst turboLoadEvents = new Events('turbo:load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nturboLoadEvents.init();\n\nconst turboFrameLoadEvents = new Events('turbo:frame-load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nturboFrameLoadEvents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/dist/flowbite.turbo.min.js b/node_modules/flowbite/dist/flowbite.turbo.min.js new file mode 100644 index 0000000..65c47ff --- /dev/null +++ b/node_modules/flowbite/dist/flowbite.turbo.min.js @@ -0,0 +1,2 @@ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("Flowbite",[],e):"object"==typeof exports?exports.Flowbite=e():t.Flowbite=e()}(self,(function(){return function(){"use strict";var t={853:function(t,e,i){i.r(e),i.d(e,{afterMain:function(){return E},afterRead:function(){return _},afterWrite:function(){return x},applyStyles:function(){return D},arrow:function(){return Z},auto:function(){return a},basePlacements:function(){return c},beforeMain:function(){return b},beforeRead:function(){return m},beforeWrite:function(){return L},bottom:function(){return o},clippingParents:function(){return u},computeStyles:function(){return it},createPopper:function(){return Dt},createPopperBase:function(){return Pt},createPopperLite:function(){return St},detectOverflow:function(){return yt},end:function(){return d},eventListeners:function(){return ot},flip:function(){return _t},hide:function(){return Et},left:function(){return s},main:function(){return w},modifierPhases:function(){return k},offset:function(){return Lt},placements:function(){return v},popper:function(){return f},popperGenerator:function(){return jt},popperOffsets:function(){return Ot},preventOverflow:function(){return xt},read:function(){return y},reference:function(){return h},right:function(){return r},start:function(){return l},top:function(){return n},variationPlacements:function(){return g},viewport:function(){return p},write:function(){return O}});var n="top",o="bottom",r="right",s="left",a="auto",c=[n,o,r,s],l="start",d="end",u="clippingParents",p="viewport",f="popper",h="reference",g=c.reduce((function(t,e){return t.concat([e+"-"+l,e+"-"+d])}),[]),v=[].concat(c,[a]).reduce((function(t,e){return t.concat([e,e+"-"+l,e+"-"+d])}),[]),m="beforeRead",y="read",_="afterRead",b="beforeMain",w="main",E="afterMain",L="beforeWrite",O="write",x="afterWrite",k=[m,y,_,b,w,E,L,O,x];function A(t){return t?(t.nodeName||"").toLowerCase():null}function T(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function C(t){return t instanceof T(t).Element||t instanceof Element}function j(t){return t instanceof T(t).HTMLElement||t instanceof HTMLElement}function P(t){return"undefined"!=typeof ShadowRoot&&(t instanceof T(t).ShadowRoot||t instanceof ShadowRoot)}var D={name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var i=e.styles[t]||{},n=e.attributes[t]||{},o=e.elements[t];j(o)&&A(o)&&(Object.assign(o.style,i),Object.keys(n).forEach((function(t){var e=n[t];!1===e?o.removeAttribute(t):o.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,i={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,i.popper),e.styles=i,e.elements.arrow&&Object.assign(e.elements.arrow.style,i.arrow),function(){Object.keys(e.elements).forEach((function(t){var n=e.elements[t],o=e.attributes[t]||{},r=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:i[t]).reduce((function(t,e){return t[e]="",t}),{});j(n)&&A(n)&&(Object.assign(n.style,r),Object.keys(o).forEach((function(t){n.removeAttribute(t)})))}))}},requires:["computeStyles"]};function S(t){return t.split("-")[0]}var I=Math.max,M=Math.min,q=Math.round;function H(){var t=navigator.userAgentData;return null!=t&&t.brands?t.brands.map((function(t){return t.brand+"/"+t.version})).join(" "):navigator.userAgent}function B(){return!/^((?!chrome|android).)*safari/i.test(H())}function V(t,e,i){void 0===e&&(e=!1),void 0===i&&(i=!1);var n=t.getBoundingClientRect(),o=1,r=1;e&&j(t)&&(o=t.offsetWidth>0&&q(n.width)/t.offsetWidth||1,r=t.offsetHeight>0&&q(n.height)/t.offsetHeight||1);var s=(C(t)?T(t):window).visualViewport,a=!B()&&i,c=(n.left+(a&&s?s.offsetLeft:0))/o,l=(n.top+(a&&s?s.offsetTop:0))/r,d=n.width/o,u=n.height/r;return{width:d,height:u,top:l,right:c+d,bottom:l+u,left:c,x:c,y:l}}function W(t){var e=V(t),i=t.offsetWidth,n=t.offsetHeight;return Math.abs(e.width-i)<=1&&(i=e.width),Math.abs(e.height-n)<=1&&(n=e.height),{x:t.offsetLeft,y:t.offsetTop,width:i,height:n}}function z(t,e){var i=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(i&&P(i)){var n=e;do{if(n&&t.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function R(t){return T(t).getComputedStyle(t)}function F(t){return["table","td","th"].indexOf(A(t))>=0}function N(t){return((C(t)?t.ownerDocument:t.document)||window.document).documentElement}function K(t){return"html"===A(t)?t:t.assignedSlot||t.parentNode||(P(t)?t.host:null)||N(t)}function U(t){return j(t)&&"fixed"!==R(t).position?t.offsetParent:null}function X(t){for(var e=T(t),i=U(t);i&&F(i)&&"static"===R(i).position;)i=U(i);return i&&("html"===A(i)||"body"===A(i)&&"static"===R(i).position)?e:i||function(t){var e=/firefox/i.test(H());if(/Trident/i.test(H())&&j(t)&&"fixed"===R(t).position)return null;var i=K(t);for(P(i)&&(i=i.host);j(i)&&["html","body"].indexOf(A(i))<0;){var n=R(i);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||e&&"filter"===n.willChange||e&&n.filter&&"none"!==n.filter)return i;i=i.parentNode}return null}(t)||e}function Y(t){return["top","bottom"].indexOf(t)>=0?"x":"y"}function G(t,e,i){return I(t,M(e,i))}function J(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function Q(t,e){return e.reduce((function(e,i){return e[i]=t,e}),{})}var Z={name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,i=t.state,a=t.name,l=t.options,d=i.elements.arrow,u=i.modifiersData.popperOffsets,p=S(i.placement),f=Y(p),h=[s,r].indexOf(p)>=0?"height":"width";if(d&&u){var g=function(t,e){return J("number"!=typeof(t="function"==typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:Q(t,c))}(l.padding,i),v=W(d),m="y"===f?n:s,y="y"===f?o:r,_=i.rects.reference[h]+i.rects.reference[f]-u[f]-i.rects.popper[h],b=u[f]-i.rects.reference[f],w=X(d),E=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,L=_/2-b/2,O=g[m],x=E-v[h]-g[y],k=E/2-v[h]/2+L,A=G(O,k,x),T=f;i.modifiersData[a]=((e={})[T]=A,e.centerOffset=A-k,e)}},effect:function(t){var e=t.state,i=t.options.element,n=void 0===i?"[data-popper-arrow]":i;null!=n&&("string"!=typeof n||(n=e.elements.popper.querySelector(n)))&&z(e.elements.popper,n)&&(e.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function $(t){return t.split("-")[1]}var tt={top:"auto",right:"auto",bottom:"auto",left:"auto"};function et(t){var e,i=t.popper,a=t.popperRect,c=t.placement,l=t.variation,u=t.offsets,p=t.position,f=t.gpuAcceleration,h=t.adaptive,g=t.roundOffsets,v=t.isFixed,m=u.x,y=void 0===m?0:m,_=u.y,b=void 0===_?0:_,w="function"==typeof g?g({x:y,y:b}):{x:y,y:b};y=w.x,b=w.y;var E=u.hasOwnProperty("x"),L=u.hasOwnProperty("y"),O=s,x=n,k=window;if(h){var A=X(i),C="clientHeight",j="clientWidth";if(A===T(i)&&"static"!==R(A=N(i)).position&&"absolute"===p&&(C="scrollHeight",j="scrollWidth"),c===n||(c===s||c===r)&&l===d)x=o,b-=(v&&A===k&&k.visualViewport?k.visualViewport.height:A[C])-a.height,b*=f?1:-1;if(c===s||(c===n||c===o)&&l===d)O=r,y-=(v&&A===k&&k.visualViewport?k.visualViewport.width:A[j])-a.width,y*=f?1:-1}var P,D=Object.assign({position:p},h&&tt),S=!0===g?function(t){var e=t.x,i=t.y,n=window.devicePixelRatio||1;return{x:q(e*n)/n||0,y:q(i*n)/n||0}}({x:y,y:b}):{x:y,y:b};return y=S.x,b=S.y,f?Object.assign({},D,((P={})[x]=L?"0":"",P[O]=E?"0":"",P.transform=(k.devicePixelRatio||1)<=1?"translate("+y+"px, "+b+"px)":"translate3d("+y+"px, "+b+"px, 0)",P)):Object.assign({},D,((e={})[x]=L?b+"px":"",e[O]=E?y+"px":"",e.transform="",e))}var it={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,i=t.options,n=i.gpuAcceleration,o=void 0===n||n,r=i.adaptive,s=void 0===r||r,a=i.roundOffsets,c=void 0===a||a,l={placement:S(e.placement),variation:$(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:o,isFixed:"fixed"===e.options.strategy};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,et(Object.assign({},l,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:s,roundOffsets:c})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,et(Object.assign({},l,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:c})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}},nt={passive:!0};var ot={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(t){var e=t.state,i=t.instance,n=t.options,o=n.scroll,r=void 0===o||o,s=n.resize,a=void 0===s||s,c=T(e.elements.popper),l=[].concat(e.scrollParents.reference,e.scrollParents.popper);return r&&l.forEach((function(t){t.addEventListener("scroll",i.update,nt)})),a&&c.addEventListener("resize",i.update,nt),function(){r&&l.forEach((function(t){t.removeEventListener("scroll",i.update,nt)})),a&&c.removeEventListener("resize",i.update,nt)}},data:{}},rt={left:"right",right:"left",bottom:"top",top:"bottom"};function st(t){return t.replace(/left|right|bottom|top/g,(function(t){return rt[t]}))}var at={start:"end",end:"start"};function ct(t){return t.replace(/start|end/g,(function(t){return at[t]}))}function lt(t){var e=T(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function dt(t){return V(N(t)).left+lt(t).scrollLeft}function ut(t){var e=R(t),i=e.overflow,n=e.overflowX,o=e.overflowY;return/auto|scroll|overlay|hidden/.test(i+o+n)}function pt(t){return["html","body","#document"].indexOf(A(t))>=0?t.ownerDocument.body:j(t)&&ut(t)?t:pt(K(t))}function ft(t,e){var i;void 0===e&&(e=[]);var n=pt(t),o=n===(null==(i=t.ownerDocument)?void 0:i.body),r=T(n),s=o?[r].concat(r.visualViewport||[],ut(n)?n:[]):n,a=e.concat(s);return o?a:a.concat(ft(K(s)))}function ht(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function gt(t,e,i){return e===p?ht(function(t,e){var i=T(t),n=N(t),o=i.visualViewport,r=n.clientWidth,s=n.clientHeight,a=0,c=0;if(o){r=o.width,s=o.height;var l=B();(l||!l&&"fixed"===e)&&(a=o.offsetLeft,c=o.offsetTop)}return{width:r,height:s,x:a+dt(t),y:c}}(t,i)):C(e)?function(t,e){var i=V(t,!1,"fixed"===e);return i.top=i.top+t.clientTop,i.left=i.left+t.clientLeft,i.bottom=i.top+t.clientHeight,i.right=i.left+t.clientWidth,i.width=t.clientWidth,i.height=t.clientHeight,i.x=i.left,i.y=i.top,i}(e,i):ht(function(t){var e,i=N(t),n=lt(t),o=null==(e=t.ownerDocument)?void 0:e.body,r=I(i.scrollWidth,i.clientWidth,o?o.scrollWidth:0,o?o.clientWidth:0),s=I(i.scrollHeight,i.clientHeight,o?o.scrollHeight:0,o?o.clientHeight:0),a=-n.scrollLeft+dt(t),c=-n.scrollTop;return"rtl"===R(o||i).direction&&(a+=I(i.clientWidth,o?o.clientWidth:0)-r),{width:r,height:s,x:a,y:c}}(N(t)))}function vt(t,e,i,n){var o="clippingParents"===e?function(t){var e=ft(K(t)),i=["absolute","fixed"].indexOf(R(t).position)>=0&&j(t)?X(t):t;return C(i)?e.filter((function(t){return C(t)&&z(t,i)&&"body"!==A(t)})):[]}(t):[].concat(e),r=[].concat(o,[i]),s=r[0],a=r.reduce((function(e,i){var o=gt(t,i,n);return e.top=I(o.top,e.top),e.right=M(o.right,e.right),e.bottom=M(o.bottom,e.bottom),e.left=I(o.left,e.left),e}),gt(t,s,n));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}function mt(t){var e,i=t.reference,a=t.element,c=t.placement,u=c?S(c):null,p=c?$(c):null,f=i.x+i.width/2-a.width/2,h=i.y+i.height/2-a.height/2;switch(u){case n:e={x:f,y:i.y-a.height};break;case o:e={x:f,y:i.y+i.height};break;case r:e={x:i.x+i.width,y:h};break;case s:e={x:i.x-a.width,y:h};break;default:e={x:i.x,y:i.y}}var g=u?Y(u):null;if(null!=g){var v="y"===g?"height":"width";switch(p){case l:e[g]=e[g]-(i[v]/2-a[v]/2);break;case d:e[g]=e[g]+(i[v]/2-a[v]/2)}}return e}function yt(t,e){void 0===e&&(e={});var i=e,s=i.placement,a=void 0===s?t.placement:s,l=i.strategy,d=void 0===l?t.strategy:l,g=i.boundary,v=void 0===g?u:g,m=i.rootBoundary,y=void 0===m?p:m,_=i.elementContext,b=void 0===_?f:_,w=i.altBoundary,E=void 0!==w&&w,L=i.padding,O=void 0===L?0:L,x=J("number"!=typeof O?O:Q(O,c)),k=b===f?h:f,A=t.rects.popper,T=t.elements[E?k:b],j=vt(C(T)?T:T.contextElement||N(t.elements.popper),v,y,d),P=V(t.elements.reference),D=mt({reference:P,element:A,strategy:"absolute",placement:a}),S=ht(Object.assign({},A,D)),I=b===f?S:P,M={top:j.top-I.top+x.top,bottom:I.bottom-j.bottom+x.bottom,left:j.left-I.left+x.left,right:I.right-j.right+x.right},q=t.modifiersData.offset;if(b===f&&q){var H=q[a];Object.keys(M).forEach((function(t){var e=[r,o].indexOf(t)>=0?1:-1,i=[n,o].indexOf(t)>=0?"y":"x";M[t]+=H[i]*e}))}return M}var _t={name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,d=t.name;if(!e.modifiersData[d]._skip){for(var u=i.mainAxis,p=void 0===u||u,f=i.altAxis,h=void 0===f||f,m=i.fallbackPlacements,y=i.padding,_=i.boundary,b=i.rootBoundary,w=i.altBoundary,E=i.flipVariations,L=void 0===E||E,O=i.allowedAutoPlacements,x=e.options.placement,k=S(x),A=m||(k===x||!L?[st(x)]:function(t){if(S(t)===a)return[];var e=st(t);return[ct(t),e,ct(e)]}(x)),T=[x].concat(A).reduce((function(t,i){return t.concat(S(i)===a?function(t,e){void 0===e&&(e={});var i=e,n=i.placement,o=i.boundary,r=i.rootBoundary,s=i.padding,a=i.flipVariations,l=i.allowedAutoPlacements,d=void 0===l?v:l,u=$(n),p=u?a?g:g.filter((function(t){return $(t)===u})):c,f=p.filter((function(t){return d.indexOf(t)>=0}));0===f.length&&(f=p);var h=f.reduce((function(e,i){return e[i]=yt(t,{placement:i,boundary:o,rootBoundary:r,padding:s})[S(i)],e}),{});return Object.keys(h).sort((function(t,e){return h[t]-h[e]}))}(e,{placement:i,boundary:_,rootBoundary:b,padding:y,flipVariations:L,allowedAutoPlacements:O}):i)}),[]),C=e.rects.reference,j=e.rects.popper,P=new Map,D=!0,I=T[0],M=0;M=0,W=V?"width":"height",z=yt(e,{placement:q,boundary:_,rootBoundary:b,altBoundary:w,padding:y}),R=V?B?r:s:B?o:n;C[W]>j[W]&&(R=st(R));var F=st(R),N=[];if(p&&N.push(z[H]<=0),h&&N.push(z[R]<=0,z[F]<=0),N.every((function(t){return t}))){I=q,D=!1;break}P.set(q,N)}if(D)for(var K=function(t){var e=T.find((function(e){var i=P.get(e);if(i)return i.slice(0,t).every((function(t){return t}))}));if(e)return I=e,"break"},U=L?3:1;U>0;U--){if("break"===K(U))break}e.placement!==I&&(e.modifiersData[d]._skip=!0,e.placement=I,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}};function bt(t,e,i){return void 0===i&&(i={x:0,y:0}),{top:t.top-e.height-i.y,right:t.right-e.width+i.x,bottom:t.bottom-e.height+i.y,left:t.left-e.width-i.x}}function wt(t){return[n,r,o,s].some((function(e){return t[e]>=0}))}var Et={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,i=t.name,n=e.rects.reference,o=e.rects.popper,r=e.modifiersData.preventOverflow,s=yt(e,{elementContext:"reference"}),a=yt(e,{altBoundary:!0}),c=bt(s,n),l=bt(a,o,r),d=wt(c),u=wt(l);e.modifiersData[i]={referenceClippingOffsets:c,popperEscapeOffsets:l,isReferenceHidden:d,hasPopperEscaped:u},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":d,"data-popper-escaped":u})}};var Lt={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,i=t.options,o=t.name,a=i.offset,c=void 0===a?[0,0]:a,l=v.reduce((function(t,i){return t[i]=function(t,e,i){var o=S(t),a=[s,n].indexOf(o)>=0?-1:1,c="function"==typeof i?i(Object.assign({},e,{placement:t})):i,l=c[0],d=c[1];return l=l||0,d=(d||0)*a,[s,r].indexOf(o)>=0?{x:d,y:l}:{x:l,y:d}}(i,e.rects,c),t}),{}),d=l[e.placement],u=d.x,p=d.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=u,e.modifiersData.popperOffsets.y+=p),e.modifiersData[o]=l}};var Ot={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,i=t.name;e.modifiersData[i]=mt({reference:e.rects.reference,element:e.rects.popper,strategy:"absolute",placement:e.placement})},data:{}};var xt={name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,a=t.name,c=i.mainAxis,d=void 0===c||c,u=i.altAxis,p=void 0!==u&&u,f=i.boundary,h=i.rootBoundary,g=i.altBoundary,v=i.padding,m=i.tether,y=void 0===m||m,_=i.tetherOffset,b=void 0===_?0:_,w=yt(e,{boundary:f,rootBoundary:h,padding:v,altBoundary:g}),E=S(e.placement),L=$(e.placement),O=!L,x=Y(E),k="x"===x?"y":"x",A=e.modifiersData.popperOffsets,T=e.rects.reference,C=e.rects.popper,j="function"==typeof b?b(Object.assign({},e.rects,{placement:e.placement})):b,P="number"==typeof j?{mainAxis:j,altAxis:j}:Object.assign({mainAxis:0,altAxis:0},j),D=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,q={x:0,y:0};if(A){if(d){var H,B="y"===x?n:s,V="y"===x?o:r,z="y"===x?"height":"width",R=A[x],F=R+w[B],N=R-w[V],K=y?-C[z]/2:0,U=L===l?T[z]:C[z],J=L===l?-C[z]:-T[z],Q=e.elements.arrow,Z=y&&Q?W(Q):{width:0,height:0},tt=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},et=tt[B],it=tt[V],nt=G(0,T[z],Z[z]),ot=O?T[z]/2-K-nt-et-P.mainAxis:U-nt-et-P.mainAxis,rt=O?-T[z]/2+K+nt+it+P.mainAxis:J+nt+it+P.mainAxis,st=e.elements.arrow&&X(e.elements.arrow),at=st?"y"===x?st.clientTop||0:st.clientLeft||0:0,ct=null!=(H=null==D?void 0:D[x])?H:0,lt=R+rt-ct,dt=G(y?M(F,R+ot-ct-at):F,R,y?I(N,lt):N);A[x]=dt,q[x]=dt-R}if(p){var ut,pt="x"===x?n:s,ft="x"===x?o:r,ht=A[k],gt="y"===k?"height":"width",vt=ht+w[pt],mt=ht-w[ft],_t=-1!==[n,s].indexOf(E),bt=null!=(ut=null==D?void 0:D[k])?ut:0,wt=_t?vt:ht-T[gt]-C[gt]-bt+P.altAxis,Et=_t?ht+T[gt]+C[gt]-bt-P.altAxis:mt,Lt=y&&_t?function(t,e,i){var n=G(t,e,i);return n>i?i:n}(wt,ht,Et):G(y?wt:vt,ht,y?Et:mt);A[k]=Lt,q[k]=Lt-ht}e.modifiersData[a]=q}},requiresIfExists:["offset"]};function kt(t,e,i){void 0===i&&(i=!1);var n,o,r=j(e),s=j(e)&&function(t){var e=t.getBoundingClientRect(),i=q(e.width)/t.offsetWidth||1,n=q(e.height)/t.offsetHeight||1;return 1!==i||1!==n}(e),a=N(e),c=V(t,s,i),l={scrollLeft:0,scrollTop:0},d={x:0,y:0};return(r||!r&&!i)&&(("body"!==A(e)||ut(a))&&(l=(n=e)!==T(n)&&j(n)?{scrollLeft:(o=n).scrollLeft,scrollTop:o.scrollTop}:lt(n)),j(e)?((d=V(e,!0)).x+=e.clientLeft,d.y+=e.clientTop):a&&(d.x=dt(a))),{x:c.left+l.scrollLeft-d.x,y:c.top+l.scrollTop-d.y,width:c.width,height:c.height}}function At(t){var e=new Map,i=new Set,n=[];function o(t){i.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!i.has(t)){var n=e.get(t);n&&o(n)}})),n.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){i.has(t.name)||o(t)})),n}var Tt={placement:"bottom",modifiers:[],strategy:"absolute"};function Ct(){for(var t=arguments.length,e=new Array(t),i=0;i 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n var _ref = isElement(element) ? getWindow(element) : window,\n visualViewport = _ref.visualViewport;\n\n var addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX;\n var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY;\n var width = clientRect.width / scaleX;\n var height = clientRect.height / scaleY;\n return {\n width: width,\n height: height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x: x,\n y: y\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\"; // Returns the layout rect of an element relative to its offsetParent. Layout\n// means it doesn't take into account transforms.\n\nexport default function getLayoutRect(element) {\n var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed.\n // Fixes https://github.com/popperjs/popper-core/issues/1223\n\n var width = element.offsetWidth;\n var height = element.offsetHeight;\n\n if (Math.abs(clientRect.width - width) <= 1) {\n width = clientRect.width;\n }\n\n if (Math.abs(clientRect.height - height) <= 1) {\n height = clientRect.height;\n }\n\n return {\n x: element.offsetLeft,\n y: element.offsetTop,\n width: width,\n height: height\n };\n}","import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","import getWindow from \"./getWindow.js\";\nexport default function getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}","import getNodeName from \"./getNodeName.js\";\nexport default function isTableElement(element) {\n return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0;\n}","import { isElement } from \"./instanceOf.js\";\nexport default function getDocumentElement(element) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing]\n element.document) || window.document).documentElement;\n}","import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","import getWindow from \"./getWindow.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isHTMLElement, isShadowRoot } from \"./instanceOf.js\";\nimport isTableElement from \"./isTableElement.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getUAString from \"../utils/userAgent.js\";\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837\n getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n} // `.offsetParent` reports `null` for fixed elements, while absolute elements\n// return the containing block\n\n\nfunction getContainingBlock(element) {\n var isFirefox = /firefox/i.test(getUAString());\n var isIE = /Trident/i.test(getUAString());\n\n if (isIE && isHTMLElement(element)) {\n // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport\n var elementCss = getComputedStyle(element);\n\n if (elementCss.position === 'fixed') {\n return null;\n }\n }\n\n var currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) {\n var css = getComputedStyle(currentNode); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nexport default function getOffsetParent(element) {\n var window = getWindow(element);\n var offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static')) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}","export default function getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y';\n}","import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","export default function getFreshSideObject() {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n };\n}","export default function expandToHashMap(value, keys) {\n return keys.reduce(function (hashMap, key) {\n hashMap[key] = value;\n return hashMap;\n }, {});\n}","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport contains from \"../dom-utils/contains.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport { within } from \"../utils/within.js\";\nimport mergePaddingObject from \"../utils/mergePaddingObject.js\";\nimport expandToHashMap from \"../utils/expandToHashMap.js\";\nimport { left, right, basePlacements, top, bottom } from \"../enums.js\";\nimport { isHTMLElement } from \"../dom-utils/instanceOf.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar toPaddingObject = function toPaddingObject(padding, state) {\n padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, {\n placement: state.placement\n })) : padding;\n return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n};\n\nfunction arrow(_ref) {\n var _state$modifiersData$;\n\n var state = _ref.state,\n name = _ref.name,\n options = _ref.options;\n var arrowElement = state.elements.arrow;\n var popperOffsets = state.modifiersData.popperOffsets;\n var basePlacement = getBasePlacement(state.placement);\n var axis = getMainAxisFromPlacement(basePlacement);\n var isVertical = [left, right].indexOf(basePlacement) >= 0;\n var len = isVertical ? 'height' : 'width';\n\n if (!arrowElement || !popperOffsets) {\n return;\n }\n\n var paddingObject = toPaddingObject(options.padding, state);\n var arrowRect = getLayoutRect(arrowElement);\n var minProp = axis === 'y' ? top : left;\n var maxProp = axis === 'y' ? bottom : right;\n var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len];\n var startDiff = popperOffsets[axis] - state.rects.reference[axis];\n var arrowOffsetParent = getOffsetParent(arrowElement);\n var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is\n // outside of the popper bounds\n\n var min = paddingObject[minProp];\n var max = clientSize - arrowRect[len] - paddingObject[maxProp];\n var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference;\n var offset = within(min, center, max); // Prevents breaking syntax highlighting...\n\n var axisProp = axis;\n state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$);\n}\n\nfunction effect(_ref2) {\n var state = _ref2.state,\n options = _ref2.options;\n var _options$element = options.element,\n arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element;\n\n if (arrowElement == null) {\n return;\n } // CSS selector\n\n\n if (typeof arrowElement === 'string') {\n arrowElement = state.elements.popper.querySelector(arrowElement);\n\n if (!arrowElement) {\n return;\n }\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n if (!isHTMLElement(arrowElement)) {\n console.error(['Popper: \"arrow\" element must be an HTMLElement (not an SVGElement).', 'To use an SVG arrow, wrap it in an HTMLElement that will be used as', 'the arrow.'].join(' '));\n }\n }\n\n if (!contains(state.elements.popper, arrowElement)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: \"arrow\" modifier\\'s `element` must be a child of the popper', 'element.'].join(' '));\n }\n\n return;\n }\n\n state.elements.arrow = arrowElement;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'arrow',\n enabled: true,\n phase: 'main',\n fn: arrow,\n effect: effect,\n requires: ['popperOffsets'],\n requiresIfExists: ['preventOverflow']\n};","export default function getVariation(placement) {\n return placement.split('-')[1];\n}","import { top, left, right, bottom, end } from \"../enums.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport getWindow from \"../dom-utils/getWindow.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getComputedStyle from \"../dom-utils/getComputedStyle.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport { round } from \"../utils/math.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar unsetSides = {\n top: 'auto',\n right: 'auto',\n bottom: 'auto',\n left: 'auto'\n}; // Round the offsets to the nearest suitable subpixel based on the DPR.\n// Zooming can change the DPR, but it seems to report a value that will\n// cleanly divide the values into the appropriate subpixels.\n\nfunction roundOffsetsByDPR(_ref) {\n var x = _ref.x,\n y = _ref.y;\n var win = window;\n var dpr = win.devicePixelRatio || 1;\n return {\n x: round(x * dpr) / dpr || 0,\n y: round(y * dpr) / dpr || 0\n };\n}\n\nexport function mapToStyles(_ref2) {\n var _Object$assign2;\n\n var popper = _ref2.popper,\n popperRect = _ref2.popperRect,\n placement = _ref2.placement,\n variation = _ref2.variation,\n offsets = _ref2.offsets,\n position = _ref2.position,\n gpuAcceleration = _ref2.gpuAcceleration,\n adaptive = _ref2.adaptive,\n roundOffsets = _ref2.roundOffsets,\n isFixed = _ref2.isFixed;\n var _offsets$x = offsets.x,\n x = _offsets$x === void 0 ? 0 : _offsets$x,\n _offsets$y = offsets.y,\n y = _offsets$y === void 0 ? 0 : _offsets$y;\n\n var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref3.x;\n y = _ref3.y;\n var hasX = offsets.hasOwnProperty('x');\n var hasY = offsets.hasOwnProperty('y');\n var sideX = left;\n var sideY = top;\n var win = window;\n\n if (adaptive) {\n var offsetParent = getOffsetParent(popper);\n var heightProp = 'clientHeight';\n var widthProp = 'clientWidth';\n\n if (offsetParent === getWindow(popper)) {\n offsetParent = getDocumentElement(popper);\n\n if (getComputedStyle(offsetParent).position !== 'static' && position === 'absolute') {\n heightProp = 'scrollHeight';\n widthProp = 'scrollWidth';\n }\n } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it\n\n\n offsetParent = offsetParent;\n\n if (placement === top || (placement === left || placement === right) && variation === end) {\n sideY = bottom;\n var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing]\n offsetParent[heightProp];\n y -= offsetY - popperRect.height;\n y *= gpuAcceleration ? 1 : -1;\n }\n\n if (placement === left || (placement === top || placement === bottom) && variation === end) {\n sideX = right;\n var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing]\n offsetParent[widthProp];\n x -= offsetX - popperRect.width;\n x *= gpuAcceleration ? 1 : -1;\n }\n }\n\n var commonStyles = Object.assign({\n position: position\n }, adaptive && unsetSides);\n\n var _ref4 = roundOffsets === true ? roundOffsetsByDPR({\n x: x,\n y: y\n }) : {\n x: x,\n y: y\n };\n\n x = _ref4.x;\n y = _ref4.y;\n\n if (gpuAcceleration) {\n var _Object$assign;\n\n return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? \"translate(\" + x + \"px, \" + y + \"px)\" : \"translate3d(\" + x + \"px, \" + y + \"px, 0)\", _Object$assign));\n }\n\n return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + \"px\" : '', _Object$assign2[sideX] = hasX ? x + \"px\" : '', _Object$assign2.transform = '', _Object$assign2));\n}\n\nfunction computeStyles(_ref5) {\n var state = _ref5.state,\n options = _ref5.options;\n var _options$gpuAccelerat = options.gpuAcceleration,\n gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat,\n _options$adaptive = options.adaptive,\n adaptive = _options$adaptive === void 0 ? true : _options$adaptive,\n _options$roundOffsets = options.roundOffsets,\n roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets;\n\n if (process.env.NODE_ENV !== \"production\") {\n var transitionProperty = getComputedStyle(state.elements.popper).transitionProperty || '';\n\n if (adaptive && ['transform', 'top', 'right', 'bottom', 'left'].some(function (property) {\n return transitionProperty.indexOf(property) >= 0;\n })) {\n console.warn(['Popper: Detected CSS transitions on at least one of the following', 'CSS properties: \"transform\", \"top\", \"right\", \"bottom\", \"left\".', '\\n\\n', 'Disable the \"computeStyles\" modifier\\'s `adaptive` option to allow', 'for smooth transitions, or remove these properties from the CSS', 'transition declaration on the popper element if only transitioning', 'opacity or background-color for example.', '\\n\\n', 'We recommend using the popper element as a wrapper around an inner', 'element that can have any CSS property transitioned for animations.'].join(' '));\n }\n }\n\n var commonStyles = {\n placement: getBasePlacement(state.placement),\n variation: getVariation(state.placement),\n popper: state.elements.popper,\n popperRect: state.rects.popper,\n gpuAcceleration: gpuAcceleration,\n isFixed: state.options.strategy === 'fixed'\n };\n\n if (state.modifiersData.popperOffsets != null) {\n state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.popperOffsets,\n position: state.options.strategy,\n adaptive: adaptive,\n roundOffsets: roundOffsets\n })));\n }\n\n if (state.modifiersData.arrow != null) {\n state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, {\n offsets: state.modifiersData.arrow,\n position: 'absolute',\n adaptive: false,\n roundOffsets: roundOffsets\n })));\n }\n\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-placement': state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'computeStyles',\n enabled: true,\n phase: 'beforeWrite',\n fn: computeStyles,\n data: {}\n};","import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","var hash = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nexport default function getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}","var hash = {\n start: 'end',\n end: 'start'\n};\nexport default function getOppositeVariationPlacement(placement) {\n return placement.replace(/start|end/g, function (matched) {\n return hash[matched];\n });\n}","import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nexport default function getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n // Popper 1 is broken in this case and never had a bug report so let's assume\n // it's not an issue. I don't think anyone ever specifies width on \n // anyway.\n // Browsers where the left scrollbar doesn't cause an issue report `0` for\n // this (e.g. Edge 2019, IE11, Safari)\n return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft;\n}","import getComputedStyle from \"./getComputedStyle.js\";\nexport default function isScrollParent(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n var _getComputedStyle = getComputedStyle(element),\n overflow = _getComputedStyle.overflow,\n overflowX = _getComputedStyle.overflowX,\n overflowY = _getComputedStyle.overflowY;\n\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}","import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","import getScrollParent from \"./getScrollParent.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport getWindow from \"./getWindow.js\";\nimport isScrollParent from \"./isScrollParent.js\";\n/*\ngiven a DOM element, return the list of all scroll parents, up the list of ancesors\nuntil we get to the top window object. This list is what we attach scroll listeners\nto, because if any of these parent elements scroll, we'll need to re-calculate the\nreference element's position.\n*/\n\nexport default function listScrollParents(element, list) {\n var _element$ownerDocumen;\n\n if (list === void 0) {\n list = [];\n }\n\n var scrollParent = getScrollParent(element);\n var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body);\n var win = getWindow(scrollParent);\n var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent;\n var updatedList = list.concat(target);\n return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here\n updatedList.concat(listScrollParents(getParentNode(target)));\n}","export default function rectToClientRect(rect) {\n return Object.assign({}, rect, {\n left: rect.x,\n top: rect.y,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n });\n}","import { viewport } from \"../enums.js\";\nimport getViewportRect from \"./getViewportRect.js\";\nimport getDocumentRect from \"./getDocumentRect.js\";\nimport listScrollParents from \"./listScrollParents.js\";\nimport getOffsetParent from \"./getOffsetParent.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport { isElement, isHTMLElement } from \"./instanceOf.js\";\nimport getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getParentNode from \"./getParentNode.js\";\nimport contains from \"./contains.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport rectToClientRect from \"../utils/rectToClientRect.js\";\nimport { max, min } from \"../utils/math.js\";\n\nfunction getInnerBoundingClientRect(element, strategy) {\n var rect = getBoundingClientRect(element, false, strategy === 'fixed');\n rect.top = rect.top + element.clientTop;\n rect.left = rect.left + element.clientLeft;\n rect.bottom = rect.top + element.clientHeight;\n rect.right = rect.left + element.clientWidth;\n rect.width = element.clientWidth;\n rect.height = element.clientHeight;\n rect.x = rect.left;\n rect.y = rect.top;\n return rect;\n}\n\nfunction getClientRectFromMixedType(element, clippingParent, strategy) {\n return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping parent\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingParents(element) {\n var clippingParents = listScrollParents(getParentNode(element));\n var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle(element).position) >= 0;\n var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414\n\n\n return clippingParents.filter(function (clippingParent) {\n return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body';\n });\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping parents\n\n\nexport default function getClippingRect(element, boundary, rootBoundary, strategy) {\n var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary);\n var clippingParents = [].concat(mainClippingParents, [rootBoundary]);\n var firstClippingParent = clippingParents[0];\n var clippingRect = clippingParents.reduce(function (accRect, clippingParent) {\n var rect = getClientRectFromMixedType(element, clippingParent, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromMixedType(element, firstClippingParent, strategy));\n clippingRect.width = clippingRect.right - clippingRect.left;\n clippingRect.height = clippingRect.bottom - clippingRect.top;\n clippingRect.x = clippingRect.left;\n clippingRect.y = clippingRect.top;\n return clippingRect;\n}","import getWindow from \"./getWindow.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport isLayoutViewport from \"./isLayoutViewport.js\";\nexport default function getViewportRect(element, strategy) {\n var win = getWindow(element);\n var html = getDocumentElement(element);\n var visualViewport = win.visualViewport;\n var width = html.clientWidth;\n var height = html.clientHeight;\n var x = 0;\n var y = 0;\n\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n var layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width: width,\n height: height,\n x: x + getWindowScrollBarX(element),\n y: y\n };\n}","import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","import getClippingRect from \"../dom-utils/getClippingRect.js\";\nimport getDocumentElement from \"../dom-utils/getDocumentElement.js\";\nimport getBoundingClientRect from \"../dom-utils/getBoundingClientRect.js\";\nimport computeOffsets from \"./computeOffsets.js\";\nimport rectToClientRect from \"./rectToClientRect.js\";\nimport { clippingParents, reference, popper, bottom, top, right, basePlacements, viewport } from \"../enums.js\";\nimport { isElement } from \"../dom-utils/instanceOf.js\";\nimport mergePaddingObject from \"./mergePaddingObject.js\";\nimport expandToHashMap from \"./expandToHashMap.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport default function detectOverflow(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n _options$placement = _options.placement,\n placement = _options$placement === void 0 ? state.placement : _options$placement,\n _options$strategy = _options.strategy,\n strategy = _options$strategy === void 0 ? state.strategy : _options$strategy,\n _options$boundary = _options.boundary,\n boundary = _options$boundary === void 0 ? clippingParents : _options$boundary,\n _options$rootBoundary = _options.rootBoundary,\n rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary,\n _options$elementConte = _options.elementContext,\n elementContext = _options$elementConte === void 0 ? popper : _options$elementConte,\n _options$altBoundary = _options.altBoundary,\n altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary,\n _options$padding = _options.padding,\n padding = _options$padding === void 0 ? 0 : _options$padding;\n var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements));\n var altContext = elementContext === popper ? reference : popper;\n var popperRect = state.rects.popper;\n var element = state.elements[altBoundary ? altContext : elementContext];\n var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy);\n var referenceClientRect = getBoundingClientRect(state.elements.reference);\n var popperOffsets = computeOffsets({\n reference: referenceClientRect,\n element: popperRect,\n strategy: 'absolute',\n placement: placement\n });\n var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets));\n var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect\n // 0 or negative = within the clipping rect\n\n var overflowOffsets = {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element\n\n if (elementContext === popper && offsetData) {\n var offset = offsetData[placement];\n Object.keys(overflowOffsets).forEach(function (key) {\n var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1;\n var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x';\n overflowOffsets[key] += offset[axis] * multiply;\n });\n }\n\n return overflowOffsets;\n}","import getOppositePlacement from \"../utils/getOppositePlacement.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getOppositeVariationPlacement from \"../utils/getOppositeVariationPlacement.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport computeAutoPlacement from \"../utils/computeAutoPlacement.js\";\nimport { bottom, top, start, right, left, auto } from \"../enums.js\";\nimport getVariation from \"../utils/getVariation.js\"; // eslint-disable-next-line import/no-unused-modules\n\nfunction getExpandedFallbackPlacements(placement) {\n if (getBasePlacement(placement) === auto) {\n return [];\n }\n\n var oppositePlacement = getOppositePlacement(placement);\n return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)];\n}\n\nfunction flip(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n\n if (state.modifiersData[name]._skip) {\n return;\n }\n\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis,\n specifiedFallbackPlacements = options.fallbackPlacements,\n padding = options.padding,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n _options$flipVariatio = options.flipVariations,\n flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio,\n allowedAutoPlacements = options.allowedAutoPlacements;\n var preferredPlacement = state.options.placement;\n var basePlacement = getBasePlacement(preferredPlacement);\n var isBasePlacement = basePlacement === preferredPlacement;\n var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement));\n var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) {\n return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n flipVariations: flipVariations,\n allowedAutoPlacements: allowedAutoPlacements\n }) : placement);\n }, []);\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var checksMap = new Map();\n var makeFallbackChecks = true;\n var firstFittingPlacement = placements[0];\n\n for (var i = 0; i < placements.length; i++) {\n var placement = placements[i];\n\n var _basePlacement = getBasePlacement(placement);\n\n var isStartVariation = getVariation(placement) === start;\n var isVertical = [top, bottom].indexOf(_basePlacement) >= 0;\n var len = isVertical ? 'width' : 'height';\n var overflow = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n altBoundary: altBoundary,\n padding: padding\n });\n var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top;\n\n if (referenceRect[len] > popperRect[len]) {\n mainVariationSide = getOppositePlacement(mainVariationSide);\n }\n\n var altVariationSide = getOppositePlacement(mainVariationSide);\n var checks = [];\n\n if (checkMainAxis) {\n checks.push(overflow[_basePlacement] <= 0);\n }\n\n if (checkAltAxis) {\n checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0);\n }\n\n if (checks.every(function (check) {\n return check;\n })) {\n firstFittingPlacement = placement;\n makeFallbackChecks = false;\n break;\n }\n\n checksMap.set(placement, checks);\n }\n\n if (makeFallbackChecks) {\n // `2` may be desired in some cases – research later\n var numberOfChecks = flipVariations ? 3 : 1;\n\n var _loop = function _loop(_i) {\n var fittingPlacement = placements.find(function (placement) {\n var checks = checksMap.get(placement);\n\n if (checks) {\n return checks.slice(0, _i).every(function (check) {\n return check;\n });\n }\n });\n\n if (fittingPlacement) {\n firstFittingPlacement = fittingPlacement;\n return \"break\";\n }\n };\n\n for (var _i = numberOfChecks; _i > 0; _i--) {\n var _ret = _loop(_i);\n\n if (_ret === \"break\") break;\n }\n }\n\n if (state.placement !== firstFittingPlacement) {\n state.modifiersData[name]._skip = true;\n state.placement = firstFittingPlacement;\n state.reset = true;\n }\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'flip',\n enabled: true,\n phase: 'main',\n fn: flip,\n requiresIfExists: ['offset'],\n data: {\n _skip: false\n }\n};","import getVariation from \"./getVariation.js\";\nimport { variationPlacements, basePlacements, placements as allPlacements } from \"../enums.js\";\nimport detectOverflow from \"./detectOverflow.js\";\nimport getBasePlacement from \"./getBasePlacement.js\";\nexport default function computeAutoPlacement(state, options) {\n if (options === void 0) {\n options = {};\n }\n\n var _options = options,\n placement = _options.placement,\n boundary = _options.boundary,\n rootBoundary = _options.rootBoundary,\n padding = _options.padding,\n flipVariations = _options.flipVariations,\n _options$allowedAutoP = _options.allowedAutoPlacements,\n allowedAutoPlacements = _options$allowedAutoP === void 0 ? allPlacements : _options$allowedAutoP;\n var variation = getVariation(placement);\n var placements = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) {\n return getVariation(placement) === variation;\n }) : basePlacements;\n var allowedPlacements = placements.filter(function (placement) {\n return allowedAutoPlacements.indexOf(placement) >= 0;\n });\n\n if (allowedPlacements.length === 0) {\n allowedPlacements = placements;\n\n if (process.env.NODE_ENV !== \"production\") {\n console.error(['Popper: The `allowedAutoPlacements` option did not allow any', 'placements. Ensure the `placement` option matches the variation', 'of the allowed placements.', 'For example, \"auto\" cannot be used to allow \"bottom-start\".', 'Use \"auto-start\" instead.'].join(' '));\n }\n } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions...\n\n\n var overflows = allowedPlacements.reduce(function (acc, placement) {\n acc[placement] = detectOverflow(state, {\n placement: placement,\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding\n })[getBasePlacement(placement)];\n return acc;\n }, {});\n return Object.keys(overflows).sort(function (a, b) {\n return overflows[a] - overflows[b];\n });\n}","import { top, bottom, left, right } from \"../enums.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\n\nfunction getSideOffsets(overflow, rect, preventedOffsets) {\n if (preventedOffsets === void 0) {\n preventedOffsets = {\n x: 0,\n y: 0\n };\n }\n\n return {\n top: overflow.top - rect.height - preventedOffsets.y,\n right: overflow.right - rect.width + preventedOffsets.x,\n bottom: overflow.bottom - rect.height + preventedOffsets.y,\n left: overflow.left - rect.width - preventedOffsets.x\n };\n}\n\nfunction isAnySideFullyClipped(overflow) {\n return [top, right, bottom, left].some(function (side) {\n return overflow[side] >= 0;\n });\n}\n\nfunction hide(_ref) {\n var state = _ref.state,\n name = _ref.name;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var preventedOffsets = state.modifiersData.preventOverflow;\n var referenceOverflow = detectOverflow(state, {\n elementContext: 'reference'\n });\n var popperAltOverflow = detectOverflow(state, {\n altBoundary: true\n });\n var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect);\n var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets);\n var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets);\n var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets);\n state.modifiersData[name] = {\n referenceClippingOffsets: referenceClippingOffsets,\n popperEscapeOffsets: popperEscapeOffsets,\n isReferenceHidden: isReferenceHidden,\n hasPopperEscaped: hasPopperEscaped\n };\n state.attributes.popper = Object.assign({}, state.attributes.popper, {\n 'data-popper-reference-hidden': isReferenceHidden,\n 'data-popper-escaped': hasPopperEscaped\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'hide',\n enabled: true,\n phase: 'main',\n requiresIfExists: ['preventOverflow'],\n fn: hide\n};","import getBasePlacement from \"../utils/getBasePlacement.js\";\nimport { top, left, right, placements } from \"../enums.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport function distanceAndSkiddingToXY(placement, rects, offset) {\n var basePlacement = getBasePlacement(placement);\n var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1;\n\n var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, {\n placement: placement\n })) : offset,\n skidding = _ref[0],\n distance = _ref[1];\n\n skidding = skidding || 0;\n distance = (distance || 0) * invertDistance;\n return [left, right].indexOf(basePlacement) >= 0 ? {\n x: distance,\n y: skidding\n } : {\n x: skidding,\n y: distance\n };\n}\n\nfunction offset(_ref2) {\n var state = _ref2.state,\n options = _ref2.options,\n name = _ref2.name;\n var _options$offset = options.offset,\n offset = _options$offset === void 0 ? [0, 0] : _options$offset;\n var data = placements.reduce(function (acc, placement) {\n acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset);\n return acc;\n }, {});\n var _data$state$placement = data[state.placement],\n x = _data$state$placement.x,\n y = _data$state$placement.y;\n\n if (state.modifiersData.popperOffsets != null) {\n state.modifiersData.popperOffsets.x += x;\n state.modifiersData.popperOffsets.y += y;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'offset',\n enabled: true,\n phase: 'main',\n requires: ['popperOffsets'],\n fn: offset\n};","import computeOffsets from \"../utils/computeOffsets.js\";\n\nfunction popperOffsets(_ref) {\n var state = _ref.state,\n name = _ref.name;\n // Offsets are the actual position the popper needs to have to be\n // properly positioned near its reference element\n // This is the most basic placement, and will be adjusted by\n // the modifiers in the next step\n state.modifiersData[name] = computeOffsets({\n reference: state.rects.reference,\n element: state.rects.popper,\n strategy: 'absolute',\n placement: state.placement\n });\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'popperOffsets',\n enabled: true,\n phase: 'read',\n fn: popperOffsets,\n data: {}\n};","import { top, left, right, bottom, start } from \"../enums.js\";\nimport getBasePlacement from \"../utils/getBasePlacement.js\";\nimport getMainAxisFromPlacement from \"../utils/getMainAxisFromPlacement.js\";\nimport getAltAxis from \"../utils/getAltAxis.js\";\nimport { within, withinMaxClamp } from \"../utils/within.js\";\nimport getLayoutRect from \"../dom-utils/getLayoutRect.js\";\nimport getOffsetParent from \"../dom-utils/getOffsetParent.js\";\nimport detectOverflow from \"../utils/detectOverflow.js\";\nimport getVariation from \"../utils/getVariation.js\";\nimport getFreshSideObject from \"../utils/getFreshSideObject.js\";\nimport { min as mathMin, max as mathMax } from \"../utils/math.js\";\n\nfunction preventOverflow(_ref) {\n var state = _ref.state,\n options = _ref.options,\n name = _ref.name;\n var _options$mainAxis = options.mainAxis,\n checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis,\n _options$altAxis = options.altAxis,\n checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis,\n boundary = options.boundary,\n rootBoundary = options.rootBoundary,\n altBoundary = options.altBoundary,\n padding = options.padding,\n _options$tether = options.tether,\n tether = _options$tether === void 0 ? true : _options$tether,\n _options$tetherOffset = options.tetherOffset,\n tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset;\n var overflow = detectOverflow(state, {\n boundary: boundary,\n rootBoundary: rootBoundary,\n padding: padding,\n altBoundary: altBoundary\n });\n var basePlacement = getBasePlacement(state.placement);\n var variation = getVariation(state.placement);\n var isBasePlacement = !variation;\n var mainAxis = getMainAxisFromPlacement(basePlacement);\n var altAxis = getAltAxis(mainAxis);\n var popperOffsets = state.modifiersData.popperOffsets;\n var referenceRect = state.rects.reference;\n var popperRect = state.rects.popper;\n var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, {\n placement: state.placement\n })) : tetherOffset;\n var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? {\n mainAxis: tetherOffsetValue,\n altAxis: tetherOffsetValue\n } : Object.assign({\n mainAxis: 0,\n altAxis: 0\n }, tetherOffsetValue);\n var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null;\n var data = {\n x: 0,\n y: 0\n };\n\n if (!popperOffsets) {\n return;\n }\n\n if (checkMainAxis) {\n var _offsetModifierState$;\n\n var mainSide = mainAxis === 'y' ? top : left;\n var altSide = mainAxis === 'y' ? bottom : right;\n var len = mainAxis === 'y' ? 'height' : 'width';\n var offset = popperOffsets[mainAxis];\n var min = offset + overflow[mainSide];\n var max = offset - overflow[altSide];\n var additive = tether ? -popperRect[len] / 2 : 0;\n var minLen = variation === start ? referenceRect[len] : popperRect[len];\n var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go\n // outside the reference bounds\n\n var arrowElement = state.elements.arrow;\n var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : {\n width: 0,\n height: 0\n };\n var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject();\n var arrowPaddingMin = arrowPaddingObject[mainSide];\n var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want\n // to include its full size in the calculation. If the reference is small\n // and near the edge of a boundary, the popper can overflow even if the\n // reference is not overflowing as well (e.g. virtual elements with no\n // width or height)\n\n var arrowLen = within(0, referenceRect[len], arrowRect[len]);\n var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis;\n var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis;\n var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow);\n var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0;\n var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0;\n var tetherMin = offset + minOffset - offsetModifierValue - clientOffset;\n var tetherMax = offset + maxOffset - offsetModifierValue;\n var preventedOffset = within(tether ? mathMin(min, tetherMin) : min, offset, tether ? mathMax(max, tetherMax) : max);\n popperOffsets[mainAxis] = preventedOffset;\n data[mainAxis] = preventedOffset - offset;\n }\n\n if (checkAltAxis) {\n var _offsetModifierState$2;\n\n var _mainSide = mainAxis === 'x' ? top : left;\n\n var _altSide = mainAxis === 'x' ? bottom : right;\n\n var _offset = popperOffsets[altAxis];\n\n var _len = altAxis === 'y' ? 'height' : 'width';\n\n var _min = _offset + overflow[_mainSide];\n\n var _max = _offset - overflow[_altSide];\n\n var isOriginSide = [top, left].indexOf(basePlacement) !== -1;\n\n var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0;\n\n var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis;\n\n var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max;\n\n var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max);\n\n popperOffsets[altAxis] = _preventedOffset;\n data[altAxis] = _preventedOffset - _offset;\n }\n\n state.modifiersData[name] = data;\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'preventOverflow',\n enabled: true,\n phase: 'main',\n fn: preventOverflow,\n requiresIfExists: ['offset']\n};","export default function getAltAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}","import getBoundingClientRect from \"./getBoundingClientRect.js\";\nimport getNodeScroll from \"./getNodeScroll.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport { round } from \"../utils/math.js\";\n\nfunction isElementScaled(element) {\n var rect = element.getBoundingClientRect();\n var scaleX = round(rect.width) / element.offsetWidth || 1;\n var scaleY = round(rect.height) / element.offsetHeight || 1;\n return scaleX !== 1 || scaleY !== 1;\n} // Returns the composite rect of an element relative to its offsetParent.\n// Composite means it takes into account transforms as well as layout.\n\n\nexport default function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n\n var isOffsetParentAnElement = isHTMLElement(offsetParent);\n var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent);\n var documentElement = getDocumentElement(offsetParent);\n var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed);\n var scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n var offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078\n isScrollParent(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n offsets = getBoundingClientRect(offsetParent, true);\n offsets.x += offsetParent.clientLeft;\n offsets.y += offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}","import getWindowScroll from \"./getWindowScroll.js\";\nimport getWindow from \"./getWindow.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nimport getHTMLElementScroll from \"./getHTMLElementScroll.js\";\nexport default function getNodeScroll(node) {\n if (node === getWindow(node) || !isHTMLElement(node)) {\n return getWindowScroll(node);\n } else {\n return getHTMLElementScroll(node);\n }\n}","export default function getHTMLElementScroll(element) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n}","import { modifierPhases } from \"../enums.js\"; // source: https://stackoverflow.com/questions/49875255\n\nfunction order(modifiers) {\n var map = new Map();\n var visited = new Set();\n var result = [];\n modifiers.forEach(function (modifier) {\n map.set(modifier.name, modifier);\n }); // On visiting object, check for its dependencies and visit them recursively\n\n function sort(modifier) {\n visited.add(modifier.name);\n var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []);\n requires.forEach(function (dep) {\n if (!visited.has(dep)) {\n var depModifier = map.get(dep);\n\n if (depModifier) {\n sort(depModifier);\n }\n }\n });\n result.push(modifier);\n }\n\n modifiers.forEach(function (modifier) {\n if (!visited.has(modifier.name)) {\n // check for visited object\n sort(modifier);\n }\n });\n return result;\n}\n\nexport default function orderModifiers(modifiers) {\n // order based on dependencies\n var orderedModifiers = order(modifiers); // order based on phase\n\n return modifierPhases.reduce(function (acc, phase) {\n return acc.concat(orderedModifiers.filter(function (modifier) {\n return modifier.phase === phase;\n }));\n }, []);\n}","import getCompositeRect from \"./dom-utils/getCompositeRect.js\";\nimport getLayoutRect from \"./dom-utils/getLayoutRect.js\";\nimport listScrollParents from \"./dom-utils/listScrollParents.js\";\nimport getOffsetParent from \"./dom-utils/getOffsetParent.js\";\nimport getComputedStyle from \"./dom-utils/getComputedStyle.js\";\nimport orderModifiers from \"./utils/orderModifiers.js\";\nimport debounce from \"./utils/debounce.js\";\nimport validateModifiers from \"./utils/validateModifiers.js\";\nimport uniqueBy from \"./utils/uniqueBy.js\";\nimport getBasePlacement from \"./utils/getBasePlacement.js\";\nimport mergeByName from \"./utils/mergeByName.js\";\nimport detectOverflow from \"./utils/detectOverflow.js\";\nimport { isElement } from \"./dom-utils/instanceOf.js\";\nimport { auto } from \"./enums.js\";\nvar INVALID_ELEMENT_ERROR = 'Popper: Invalid reference or popper argument provided. They must be either a DOM element or virtual element.';\nvar INFINITE_LOOP_ERROR = 'Popper: An infinite loop in the modifiers cycle has been detected! The cycle has been interrupted to prevent a browser crash.';\nvar DEFAULT_OPTIONS = {\n placement: 'bottom',\n modifiers: [],\n strategy: 'absolute'\n};\n\nfunction areValidElements() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return !args.some(function (element) {\n return !(element && typeof element.getBoundingClientRect === 'function');\n });\n}\n\nexport function popperGenerator(generatorOptions) {\n if (generatorOptions === void 0) {\n generatorOptions = {};\n }\n\n var _generatorOptions = generatorOptions,\n _generatorOptions$def = _generatorOptions.defaultModifiers,\n defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def,\n _generatorOptions$def2 = _generatorOptions.defaultOptions,\n defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2;\n return function createPopper(reference, popper, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n var state = {\n placement: 'bottom',\n orderedModifiers: [],\n options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions),\n modifiersData: {},\n elements: {\n reference: reference,\n popper: popper\n },\n attributes: {},\n styles: {}\n };\n var effectCleanupFns = [];\n var isDestroyed = false;\n var instance = {\n state: state,\n setOptions: function setOptions(setOptionsAction) {\n var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction;\n cleanupModifierEffects();\n state.options = Object.assign({}, defaultOptions, state.options, options);\n state.scrollParents = {\n reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [],\n popper: listScrollParents(popper)\n }; // Orders the modifiers based on their dependencies and `phase`\n // properties\n\n var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers\n\n state.orderedModifiers = orderedModifiers.filter(function (m) {\n return m.enabled;\n }); // Validate the provided modifiers so that the consumer will get warned\n // if one of the modifiers is invalid for any reason\n\n if (process.env.NODE_ENV !== \"production\") {\n var modifiers = uniqueBy([].concat(orderedModifiers, state.options.modifiers), function (_ref) {\n var name = _ref.name;\n return name;\n });\n validateModifiers(modifiers);\n\n if (getBasePlacement(state.options.placement) === auto) {\n var flipModifier = state.orderedModifiers.find(function (_ref2) {\n var name = _ref2.name;\n return name === 'flip';\n });\n\n if (!flipModifier) {\n console.error(['Popper: \"auto\" placements require the \"flip\" modifier be', 'present and enabled to work.'].join(' '));\n }\n }\n\n var _getComputedStyle = getComputedStyle(popper),\n marginTop = _getComputedStyle.marginTop,\n marginRight = _getComputedStyle.marginRight,\n marginBottom = _getComputedStyle.marginBottom,\n marginLeft = _getComputedStyle.marginLeft; // We no longer take into account `margins` on the popper, and it can\n // cause bugs with positioning, so we'll warn the consumer\n\n\n if ([marginTop, marginRight, marginBottom, marginLeft].some(function (margin) {\n return parseFloat(margin);\n })) {\n console.warn(['Popper: CSS \"margin\" styles cannot be used to apply padding', 'between the popper and its reference element or boundary.', 'To replicate margin, use the `offset` modifier, as well as', 'the `padding` option in the `preventOverflow` and `flip`', 'modifiers.'].join(' '));\n }\n }\n\n runModifierEffects();\n return instance.update();\n },\n // Sync update – it will always be executed, even if not necessary. This\n // is useful for low frequency updates where sync behavior simplifies the\n // logic.\n // For high frequency updates (e.g. `resize` and `scroll` events), always\n // prefer the async Popper#update method\n forceUpdate: function forceUpdate() {\n if (isDestroyed) {\n return;\n }\n\n var _state$elements = state.elements,\n reference = _state$elements.reference,\n popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements\n // anymore\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return;\n } // Store the reference and popper rects to be read by modifiers\n\n\n state.rects = {\n reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'),\n popper: getLayoutRect(popper)\n }; // Modifiers have the ability to reset the current update cycle. The\n // most common use case for this is the `flip` modifier changing the\n // placement, which then needs to re-run all the modifiers, because the\n // logic was previously ran for the previous placement and is therefore\n // stale/incorrect\n\n state.reset = false;\n state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier\n // is filled with the initial data specified by the modifier. This means\n // it doesn't persist and is fresh on each update.\n // To ensure persistent data, use `${name}#persistent`\n\n state.orderedModifiers.forEach(function (modifier) {\n return state.modifiersData[modifier.name] = Object.assign({}, modifier.data);\n });\n var __debug_loops__ = 0;\n\n for (var index = 0; index < state.orderedModifiers.length; index++) {\n if (process.env.NODE_ENV !== \"production\") {\n __debug_loops__ += 1;\n\n if (__debug_loops__ > 100) {\n console.error(INFINITE_LOOP_ERROR);\n break;\n }\n }\n\n if (state.reset === true) {\n state.reset = false;\n index = -1;\n continue;\n }\n\n var _state$orderedModifie = state.orderedModifiers[index],\n fn = _state$orderedModifie.fn,\n _state$orderedModifie2 = _state$orderedModifie.options,\n _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2,\n name = _state$orderedModifie.name;\n\n if (typeof fn === 'function') {\n state = fn({\n state: state,\n options: _options,\n name: name,\n instance: instance\n }) || state;\n }\n }\n },\n // Async and optimistically optimized update – it will not be executed if\n // not necessary (debounced to run at most once-per-tick)\n update: debounce(function () {\n return new Promise(function (resolve) {\n instance.forceUpdate();\n resolve(state);\n });\n }),\n destroy: function destroy() {\n cleanupModifierEffects();\n isDestroyed = true;\n }\n };\n\n if (!areValidElements(reference, popper)) {\n if (process.env.NODE_ENV !== \"production\") {\n console.error(INVALID_ELEMENT_ERROR);\n }\n\n return instance;\n }\n\n instance.setOptions(options).then(function (state) {\n if (!isDestroyed && options.onFirstUpdate) {\n options.onFirstUpdate(state);\n }\n }); // Modifiers have the ability to execute arbitrary code before the first\n // update cycle runs. They will be executed in the same order as the update\n // cycle. This is useful when a modifier adds some persistent data that\n // other modifiers need to use, but the modifier is run after the dependent\n // one.\n\n function runModifierEffects() {\n state.orderedModifiers.forEach(function (_ref3) {\n var name = _ref3.name,\n _ref3$options = _ref3.options,\n options = _ref3$options === void 0 ? {} : _ref3$options,\n effect = _ref3.effect;\n\n if (typeof effect === 'function') {\n var cleanupFn = effect({\n state: state,\n name: name,\n instance: instance,\n options: options\n });\n\n var noopFn = function noopFn() {};\n\n effectCleanupFns.push(cleanupFn || noopFn);\n }\n });\n }\n\n function cleanupModifierEffects() {\n effectCleanupFns.forEach(function (fn) {\n return fn();\n });\n effectCleanupFns = [];\n }\n\n return instance;\n };\n}\nexport var createPopper = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules\n\nexport { detectOverflow };","export default function debounce(fn) {\n var pending;\n return function () {\n if (!pending) {\n pending = new Promise(function (resolve) {\n Promise.resolve().then(function () {\n pending = undefined;\n resolve(fn());\n });\n });\n }\n\n return pending;\n };\n}","export default function mergeByName(modifiers) {\n var merged = modifiers.reduce(function (merged, current) {\n var existing = merged[current.name];\n merged[current.name] = existing ? Object.assign({}, existing, current, {\n options: Object.assign({}, existing.options, current.options),\n data: Object.assign({}, existing.data, current.data)\n }) : current;\n return merged;\n }, {}); // IE11 does not support Object.values\n\n return Object.keys(merged).map(function (key) {\n return merged[key];\n });\n}","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nimport offset from \"./modifiers/offset.js\";\nimport flip from \"./modifiers/flip.js\";\nimport preventOverflow from \"./modifiers/preventOverflow.js\";\nimport arrow from \"./modifiers/arrow.js\";\nimport hide from \"./modifiers/hide.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles, offset, flip, preventOverflow, arrow, hide];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow }; // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper as createPopperLite } from \"./popper-lite.js\"; // eslint-disable-next-line import/no-unused-modules\n\nexport * from \"./modifiers/index.js\";","import { popperGenerator, detectOverflow } from \"./createPopper.js\";\nimport eventListeners from \"./modifiers/eventListeners.js\";\nimport popperOffsets from \"./modifiers/popperOffsets.js\";\nimport computeStyles from \"./modifiers/computeStyles.js\";\nimport applyStyles from \"./modifiers/applyStyles.js\";\nvar defaultModifiers = [eventListeners, popperOffsets, computeStyles, applyStyles];\nvar createPopper = /*#__PURE__*/popperGenerator({\n defaultModifiers: defaultModifiers\n}); // eslint-disable-next-line import/no-unused-modules\n\nexport { createPopper, popperGenerator, defaultModifiers, detectOverflow };","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { AccordionItem, AccordionOptions } from './types';\nimport { AccordionInterface } from './interface';\n\nconst Default: AccordionOptions = {\n alwaysOpen: false,\n activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white',\n inactiveClasses: 'text-gray-500 dark:text-gray-400',\n onOpen: () => {},\n onClose: () => {},\n onToggle: () => {},\n};\n\nclass Accordion implements AccordionInterface {\n _items: AccordionItem[];\n _options: AccordionOptions;\n\n constructor(\n items: AccordionItem[] = [],\n options: AccordionOptions = Default\n ) {\n this._items = items;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n private _init() {\n if (this._items.length) {\n // show accordion item based on click\n this._items.map((item) => {\n if (item.active) {\n this.open(item.id);\n }\n\n item.triggerEl.addEventListener('click', () => {\n this.toggle(item.id);\n });\n });\n }\n }\n\n getItem(id: string) {\n return this._items.filter((item) => item.id === id)[0];\n }\n\n open(id: string) {\n const item = this.getItem(id);\n\n // don't hide other accordions if always open\n if (!this._options.alwaysOpen) {\n this._items.map((i) => {\n if (i !== item) {\n i.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n i.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n i.targetEl.classList.add('hidden');\n i.triggerEl.setAttribute('aria-expanded', 'false');\n i.active = false;\n\n // rotate icon if set\n if (i.iconEl) {\n i.iconEl.classList.remove('rotate-180');\n }\n }\n });\n }\n\n // show active item\n item.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n item.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n item.triggerEl.setAttribute('aria-expanded', 'true');\n item.targetEl.classList.remove('hidden');\n item.active = true;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.add('rotate-180');\n }\n\n // callback function\n this._options.onOpen(this, item);\n }\n\n toggle(id: string) {\n const item = this.getItem(id);\n\n if (item.active) {\n this.close(id);\n } else {\n this.open(id);\n }\n\n // callback function\n this._options.onToggle(this, item);\n }\n\n close(id: string) {\n const item = this.getItem(id);\n\n item.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n item.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n item.targetEl.classList.add('hidden');\n item.triggerEl.setAttribute('aria-expanded', 'false');\n item.active = false;\n\n // rotate icon if set\n if (item.iconEl) {\n item.iconEl.classList.remove('rotate-180');\n }\n\n // callback function\n this._options.onClose(this, item);\n }\n}\n\nexport function initAccordions() {\n document.querySelectorAll('[data-accordion]').forEach(($accordionEl) => {\n const alwaysOpen = $accordionEl.getAttribute('data-accordion');\n const activeClasses = $accordionEl.getAttribute('data-active-classes');\n const inactiveClasses = $accordionEl.getAttribute(\n 'data-inactive-classes'\n );\n\n const items = [] as AccordionItem[];\n $accordionEl\n .querySelectorAll('[data-accordion-target]')\n .forEach(($triggerEl) => {\n // Consider only items that directly belong to $accordionEl\n // (to make nested accordions work).\n if ($triggerEl.closest('[data-accordion]') === $accordionEl) {\n const item = {\n id: $triggerEl.getAttribute('data-accordion-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-accordion-target')\n ),\n iconEl: $triggerEl.querySelector(\n '[data-accordion-icon]'\n ),\n active:\n $triggerEl.getAttribute('aria-expanded') === 'true'\n ? true\n : false,\n } as AccordionItem;\n items.push(item);\n }\n });\n\n new Accordion(items, {\n alwaysOpen: alwaysOpen === 'open' ? true : false,\n activeClasses: activeClasses\n ? activeClasses\n : Default.activeClasses,\n inactiveClasses: inactiveClasses\n ? inactiveClasses\n : Default.inactiveClasses,\n } as AccordionOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Accordion = Accordion;\n window.initAccordions = initAccordions;\n}\n\nexport default Accordion;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type {\n CarouselOptions,\n CarouselItem,\n IndicatorItem,\n RotationItems,\n} from './types';\nimport { CarouselInterface } from './interface';\n\nconst Default: CarouselOptions = {\n defaultPosition: 0,\n indicators: {\n items: [],\n activeClasses: 'bg-white dark:bg-gray-800',\n inactiveClasses:\n 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800',\n },\n interval: 3000,\n onNext: () => {},\n onPrev: () => {},\n onChange: () => {},\n};\n\nclass Carousel implements CarouselInterface {\n _items: CarouselItem[];\n _indicators: IndicatorItem[];\n _activeItem: CarouselItem;\n _intervalDuration: number;\n _intervalInstance: number;\n _options: CarouselOptions;\n\n constructor(\n items: CarouselItem[] = [],\n options: CarouselOptions = Default\n ) {\n this._items = items;\n this._options = {\n ...Default,\n ...options,\n indicators: { ...Default.indicators, ...options.indicators },\n };\n this._activeItem = this.getItem(this._options.defaultPosition);\n this._indicators = this._options.indicators.items;\n this._intervalDuration = this._options.interval;\n this._intervalInstance = null;\n this._init();\n }\n\n /**\n * initialize carousel and items based on active one\n */\n _init() {\n this._items.map((item: CarouselItem) => {\n item.el.classList.add(\n 'absolute',\n 'inset-0',\n 'transition-transform',\n 'transform'\n );\n });\n\n // if no active item is set then first position is default\n if (this._getActiveItem()) {\n this.slideTo(this._getActiveItem().position);\n } else {\n this.slideTo(0);\n }\n\n this._indicators.map((indicator, position) => {\n indicator.el.addEventListener('click', () => {\n this.slideTo(position);\n });\n });\n }\n\n getItem(position: number) {\n return this._items[position];\n }\n\n /**\n * Slide to the element based on id\n * @param {*} position\n */\n slideTo(position: number) {\n const nextItem: CarouselItem = this._items[position];\n const rotationItems: RotationItems = {\n left:\n nextItem.position === 0\n ? this._items[this._items.length - 1]\n : this._items[nextItem.position - 1],\n middle: nextItem,\n right:\n nextItem.position === this._items.length - 1\n ? this._items[0]\n : this._items[nextItem.position + 1],\n };\n this._rotate(rotationItems);\n this._setActiveItem(nextItem);\n if (this._intervalInstance) {\n this.pause();\n this.cycle();\n }\n\n this._options.onChange(this);\n }\n\n /**\n * Based on the currently active item it will go to the next position\n */\n next() {\n const activeItem = this._getActiveItem();\n let nextItem = null;\n\n // check if last item\n if (activeItem.position === this._items.length - 1) {\n nextItem = this._items[0];\n } else {\n nextItem = this._items[activeItem.position + 1];\n }\n\n this.slideTo(nextItem.position);\n\n // callback function\n this._options.onNext(this);\n }\n\n /**\n * Based on the currently active item it will go to the previous position\n */\n prev() {\n const activeItem = this._getActiveItem();\n let prevItem = null;\n\n // check if first item\n if (activeItem.position === 0) {\n prevItem = this._items[this._items.length - 1];\n } else {\n prevItem = this._items[activeItem.position - 1];\n }\n\n this.slideTo(prevItem.position);\n\n // callback function\n this._options.onPrev(this);\n }\n\n /**\n * This method applies the transform classes based on the left, middle, and right rotation carousel items\n * @param {*} rotationItems\n */\n _rotate(rotationItems: RotationItems) {\n // reset\n this._items.map((item: CarouselItem) => {\n item.el.classList.add('hidden');\n });\n\n // left item (previously active)\n rotationItems.left.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.left.el.classList.add('-translate-x-full', 'z-10');\n\n // currently active item\n rotationItems.middle.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-10'\n );\n rotationItems.middle.el.classList.add('translate-x-0', 'z-20');\n\n // right item (upcoming active)\n rotationItems.right.el.classList.remove(\n '-translate-x-full',\n 'translate-x-full',\n 'translate-x-0',\n 'hidden',\n 'z-20'\n );\n rotationItems.right.el.classList.add('translate-x-full', 'z-10');\n }\n\n /**\n * Set an interval to cycle through the carousel items\n */\n cycle() {\n if (typeof window !== 'undefined') {\n this._intervalInstance = window.setInterval(() => {\n this.next();\n }, this._intervalDuration);\n }\n }\n\n /**\n * Clears the cycling interval\n */\n pause() {\n clearInterval(this._intervalInstance);\n }\n\n /**\n * Get the currently active item\n */\n _getActiveItem() {\n return this._activeItem;\n }\n\n /**\n * Set the currently active item and data attribute\n * @param {*} position\n */\n _setActiveItem(item: CarouselItem) {\n this._activeItem = item;\n const position = item.position;\n\n // update the indicators if available\n if (this._indicators.length) {\n this._indicators.map((indicator) => {\n indicator.el.setAttribute('aria-current', 'false');\n indicator.el.classList.remove(\n ...this._options.indicators.activeClasses.split(' ')\n );\n indicator.el.classList.add(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n });\n this._indicators[position].el.classList.add(\n ...this._options.indicators.activeClasses.split(' ')\n );\n this._indicators[position].el.classList.remove(\n ...this._options.indicators.inactiveClasses.split(' ')\n );\n this._indicators[position].el.setAttribute('aria-current', 'true');\n }\n }\n}\n\nexport function initCarousels() {\n document.querySelectorAll('[data-carousel]').forEach(($carouselEl) => {\n const interval = $carouselEl.getAttribute('data-carousel-interval');\n const slide =\n $carouselEl.getAttribute('data-carousel') === 'slide'\n ? true\n : false;\n\n const items: CarouselItem[] = [];\n let defaultPosition = 0;\n if ($carouselEl.querySelectorAll('[data-carousel-item]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-item]')\n ).map(($carouselItemEl: HTMLElement, position: number) => {\n items.push({\n position: position,\n el: $carouselItemEl,\n });\n\n if (\n $carouselItemEl.getAttribute('data-carousel-item') ===\n 'active'\n ) {\n defaultPosition = position;\n }\n });\n }\n\n const indicators: IndicatorItem[] = [];\n if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) {\n Array.from(\n $carouselEl.querySelectorAll('[data-carousel-slide-to]')\n ).map(($indicatorEl: HTMLElement) => {\n indicators.push({\n position: parseInt(\n $indicatorEl.getAttribute('data-carousel-slide-to')\n ),\n el: $indicatorEl,\n });\n });\n }\n\n const carousel = new Carousel(items, {\n defaultPosition: defaultPosition,\n indicators: {\n items: indicators,\n },\n interval: interval ? interval : Default.interval,\n } as CarouselOptions);\n\n if (slide) {\n carousel.cycle();\n }\n\n // check for controls\n const carouselNextEl = $carouselEl.querySelector(\n '[data-carousel-next]'\n );\n const carouselPrevEl = $carouselEl.querySelector(\n '[data-carousel-prev]'\n );\n\n if (carouselNextEl) {\n carouselNextEl.addEventListener('click', () => {\n carousel.next();\n });\n }\n\n if (carouselPrevEl) {\n carouselPrevEl.addEventListener('click', () => {\n carousel.prev();\n });\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Carousel = Carousel;\n window.initCarousels = initCarousels;\n}\n\nexport default Carousel;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { CollapseOptions } from './types';\nimport { CollapseInterface } from './interface';\n\nconst Default: CollapseOptions = {\n onCollapse: () => {},\n onExpand: () => {},\n onToggle: () => {},\n};\n\nclass Collapse implements CollapseInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: CollapseOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: CollapseOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n if (this._triggerEl.hasAttribute('aria-expanded')) {\n this._visible =\n this._triggerEl.getAttribute('aria-expanded') === 'true';\n } else {\n // fix until v2 not to break previous single collapses which became dismiss\n this._visible = !this._targetEl.classList.contains('hidden');\n }\n\n this._triggerEl.addEventListener('click', () => {\n this.toggle();\n });\n }\n }\n\n collapse() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onCollapse(this);\n }\n\n expand() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onExpand(this);\n }\n\n toggle() {\n if (this._visible) {\n this.collapse();\n } else {\n this.expand();\n }\n // callback function\n this._options.onToggle(this);\n }\n}\n\nexport function initCollapses() {\n document\n .querySelectorAll('[data-collapse-toggle]')\n .forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-collapse-toggle');\n const $targetEl = document.getElementById(targetId);\n\n // check if the target element exists\n if ($targetEl) {\n new Collapse(\n $targetEl as HTMLElement,\n $triggerEl as HTMLElement\n );\n } else {\n console.error(\n `The target element with id \"${targetId}\" does not exist. Please check the data-collapse-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Collapse = Collapse;\n window.initCollapses = initCollapses;\n}\n\nexport default Collapse;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DialOptions, DialTriggerType } from './types';\nimport { DialInterface } from './interface';\n\nconst Default: DialOptions = {\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dial implements DialInterface {\n _parentEl: HTMLElement;\n _triggerEl: HTMLElement;\n _targetEl: HTMLElement;\n _options: DialOptions;\n _visible: boolean;\n\n constructor(\n parentEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n targetEl: HTMLElement | null = null,\n options: DialOptions = Default\n ) {\n this._parentEl = parentEl;\n this._triggerEl = triggerEl;\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n const triggerEventTypes = this._getTriggerEventTypes(\n this._options.triggerType\n );\n triggerEventTypes.showEvents.forEach((ev: string) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEventTypes.hideEvents.forEach((ev: string) => {\n this._parentEl.addEventListener(ev, () => {\n if (!this._parentEl.matches(':hover')) {\n this.hide();\n }\n });\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'false');\n }\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n if (this._triggerEl) {\n this._triggerEl.setAttribute('aria-expanded', 'true');\n }\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this._visible) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n\n _getTriggerEventTypes(triggerType: DialTriggerType) {\n switch (triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n}\n\nexport function initDials() {\n document.querySelectorAll('[data-dial-init]').forEach(($parentEl) => {\n const $triggerEl = $parentEl.querySelector('[data-dial-toggle]');\n\n if ($triggerEl) {\n const dialId = $triggerEl.getAttribute('data-dial-toggle');\n const $dialEl = document.getElementById(dialId);\n\n if ($dialEl) {\n const triggerType =\n $triggerEl.getAttribute('data-dial-trigger');\n new Dial(\n $parentEl as HTMLElement,\n $triggerEl as HTMLElement,\n $dialEl as HTMLElement,\n {\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as DialOptions\n );\n } else {\n console.error(\n `Dial with id ${dialId} does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?`\n );\n }\n } else {\n console.error(\n `Dial with id ${$parentEl.id} does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dial = Dial;\n window.initDials = initDials;\n}\n\nexport default Dial;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DismissOptions } from './types';\nimport { DismissInterface } from './interface';\n\nconst Default: DismissOptions = {\n transition: 'transition-opacity',\n duration: 300,\n timing: 'ease-out',\n onHide: () => {},\n};\n\nclass Dismiss implements DismissInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: DismissOptions;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: DismissOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._triggerEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n hide() {\n this._targetEl.classList.add(\n this._options.transition,\n `duration-${this._options.duration}`,\n this._options.timing,\n 'opacity-0'\n );\n setTimeout(() => {\n this._targetEl.classList.add('hidden');\n }, this._options.duration);\n\n // callback function\n this._options.onHide(this, this._targetEl);\n }\n}\n\nexport function initDismisses() {\n document.querySelectorAll('[data-dismiss-target]').forEach(($triggerEl) => {\n const targetId = $triggerEl.getAttribute('data-dismiss-target');\n const $dismissEl = document.querySelector(targetId);\n\n if ($dismissEl) {\n new Dismiss($dismissEl as HTMLElement, $triggerEl as HTMLElement);\n } else {\n console.error(\n `The dismiss element with id \"${targetId}\" does not exist. Please check the data-dismiss-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dismiss = Dismiss;\n window.initDismisses = initDismisses;\n}\n\nexport default Dismiss;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { DrawerInstance, DrawerOptions, PlacementClasses } from './types';\nimport { DrawerInterface } from './interface';\n\nconst Default: DrawerOptions = {\n placement: 'left',\n bodyScrolling: false,\n backdrop: true,\n edge: false,\n edgeOffset: 'bottom-[60px]',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Drawer implements DrawerInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DrawerOptions;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: DrawerOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._visible = false;\n this._init();\n }\n\n _init() {\n // set initial accessibility attributes\n if (this._targetEl) {\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.classList.add('transition-transform');\n }\n\n // set base placement classes\n this._getPlacementClasses(this._options.placement).base.map((c) => {\n this._targetEl.classList.add(c);\n });\n\n // add keyboard event listener to document\n document.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n // if 'Escape' key is pressed\n if (this.isVisible()) {\n // if the Drawer is visible\n this.hide(); // hide the Drawer\n }\n }\n });\n }\n\n hide() {\n // based on the edge option show placement classes\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.remove(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.add(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n\n // enable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.remove('overflow-hidden');\n }\n\n // destroy backdrop\n if (this._options.backdrop) {\n this._destroyBackdropEl();\n }\n\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n\n show() {\n if (this._options.edge) {\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).active.map((c) => {\n this._targetEl.classList.add(c);\n });\n this._getPlacementClasses(\n this._options.placement + '-edge'\n ).inactive.map((c) => {\n this._targetEl.classList.remove(c);\n });\n } else {\n this._getPlacementClasses(this._options.placement).active.map(\n (c) => {\n this._targetEl.classList.add(c);\n }\n );\n this._getPlacementClasses(this._options.placement).inactive.map(\n (c) => {\n this._targetEl.classList.remove(c);\n }\n );\n }\n\n // set accessibility attributes\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n\n // disable body scroll\n if (!this._options.bodyScrolling) {\n document.body.classList.add('overflow-hidden');\n }\n\n // show backdrop\n if (this._options.backdrop) {\n this._createBackdrop();\n }\n\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n _createBackdrop() {\n if (!this._visible) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('drawer-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n backdropEl.addEventListener('click', () => {\n this.hide();\n });\n }\n }\n\n _destroyBackdropEl() {\n if (this._visible) {\n document.querySelector('[drawer-backdrop]').remove();\n }\n }\n\n _getPlacementClasses(placement: string): PlacementClasses {\n switch (placement) {\n case 'top':\n return {\n base: ['top-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['-translate-y-full'],\n };\n case 'right':\n return {\n base: ['right-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-x-full'],\n };\n case 'bottom':\n return {\n base: ['bottom-0', 'left-0', 'right-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full'],\n };\n case 'left':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n case 'bottom-edge':\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['translate-y-full', this._options.edgeOffset],\n };\n default:\n return {\n base: ['left-0', 'top-0'],\n active: ['transform-none'],\n inactive: ['-translate-x-full'],\n };\n }\n }\n\n isHidden() {\n return !this._visible;\n }\n\n isVisible() {\n return this._visible;\n }\n}\n\nconst getDrawerInstance = (id: string, instances: DrawerInstance[]) => {\n if (instances.some((drawerInstance) => drawerInstance.id === id)) {\n return instances.find((drawerInstance) => drawerInstance.id === id);\n }\n};\n\nexport function initDrawers() {\n const drawerInstances = [] as DrawerInstance[];\n document.querySelectorAll('[data-drawer-target]').forEach(($triggerEl) => {\n // mandatory\n const drawerId = $triggerEl.getAttribute('data-drawer-target');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n // optional\n const placement = $triggerEl.getAttribute('data-drawer-placement');\n const bodyScrolling = $triggerEl.getAttribute(\n 'data-drawer-body-scrolling'\n );\n const backdrop = $triggerEl.getAttribute('data-drawer-backdrop');\n const edge = $triggerEl.getAttribute('data-drawer-edge');\n const edgeOffset = $triggerEl.getAttribute(\n 'data-drawer-edge-offset'\n );\n\n if (!getDrawerInstance(drawerId, drawerInstances)) {\n drawerInstances.push({\n id: drawerId,\n object: new Drawer($drawerEl, {\n placement: placement ? placement : Default.placement,\n bodyScrolling: bodyScrolling\n ? bodyScrolling === 'true'\n ? true\n : false\n : Default.bodyScrolling,\n backdrop: backdrop\n ? backdrop === 'true'\n ? true\n : false\n : Default.backdrop,\n edge: edge\n ? edge === 'true'\n ? true\n : false\n : Default.edge,\n edgeOffset: edgeOffset\n ? edgeOffset\n : Default.edgeOffset,\n } as DrawerOptions),\n });\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-toggle]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-toggle');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer: DrawerInstance = getDrawerInstance(\n drawerId,\n drawerInstances\n );\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.toggle();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n\n document\n .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]')\n .forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-dismiss')\n ? $triggerEl.getAttribute('data-drawer-dismiss')\n : $triggerEl.getAttribute('data-drawer-hide');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.hide();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id`\n );\n }\n });\n\n document.querySelectorAll('[data-drawer-show]').forEach(($triggerEl) => {\n const drawerId = $triggerEl.getAttribute('data-drawer-show');\n const $drawerEl = document.getElementById(drawerId);\n\n if ($drawerEl) {\n const drawer = getDrawerInstance(drawerId, drawerInstances);\n\n if (drawer) {\n $triggerEl.addEventListener('click', () => {\n drawer.object.show();\n });\n } else {\n console.error(\n `Drawer with id ${drawerId} has not been initialized. Please initialize it using the data-drawer-target attribute.`\n );\n }\n } else {\n console.error(\n `Drawer with id ${drawerId} not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Drawer = Drawer;\n window.initDrawers = initDrawers;\n}\n\nexport default Drawer;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { DropdownOptions } from './types';\nimport { DropdownInterface } from './interface';\n\nconst Default: DropdownOptions = {\n placement: 'bottom',\n triggerType: 'click',\n offsetSkidding: 0,\n offsetDistance: 10,\n delay: 300,\n ignoreClickOutsideClass: false,\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Dropdown implements DropdownInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: DropdownOptions;\n _visible: boolean;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetElement: HTMLElement | null = null,\n triggerElement: HTMLElement | null = null,\n options: DropdownOptions = Default\n ) {\n this._targetEl = targetElement;\n this._triggerEl = triggerElement;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n // click event handling for trigger element\n if (this._options.triggerType === 'click') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.toggle();\n });\n });\n }\n\n // hover event handling for trigger element\n if (this._options.triggerType === 'hover') {\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n if (ev === 'click') {\n this.toggle();\n } else {\n setTimeout(() => {\n this.show();\n }, this._options.delay);\n }\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, this._options.delay);\n });\n });\n }\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [\n this._options.offsetSkidding,\n this._options.offsetDistance,\n ],\n },\n },\n ],\n });\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n\n // Ignore clicks on the trigger element (ie. a datepicker input)\n const ignoreClickOutsideClass = this._options.ignoreClickOutsideClass;\n\n let isIgnored = false;\n if (ignoreClickOutsideClass) {\n const ignoredClickOutsideEls = document.querySelectorAll(\n `.${ignoreClickOutsideClass}`\n );\n ignoredClickOutsideEls.forEach((el) => {\n if (el.contains(clickedEl)) {\n isIgnored = true;\n return;\n }\n });\n }\n\n // Ignore clicks on the target element (ie. dropdown itself)\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n !isIgnored &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'click'],\n hideEvents: ['mouseleave'],\n };\n case 'click':\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['click'],\n hideEvents: [],\n };\n }\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n isVisible() {\n return this._visible;\n }\n\n show() {\n this._targetEl.classList.remove('hidden');\n this._targetEl.classList.add('block');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n this._setupClickOutsideListener();\n\n // Update its position\n this._popperInstance.update();\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('block');\n this._targetEl.classList.add('hidden');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n this._visible = false;\n\n this._removeClickOutsideListener();\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initDropdowns() {\n document\n .querySelectorAll('[data-dropdown-toggle]')\n .forEach(($triggerEl) => {\n const dropdownId = $triggerEl.getAttribute('data-dropdown-toggle');\n const $dropdownEl = document.getElementById(dropdownId);\n\n if ($dropdownEl) {\n const placement = $triggerEl.getAttribute(\n 'data-dropdown-placement'\n );\n const offsetSkidding = $triggerEl.getAttribute(\n 'data-dropdown-offset-skidding'\n );\n const offsetDistance = $triggerEl.getAttribute(\n 'data-dropdown-offset-distance'\n );\n const triggerType = $triggerEl.getAttribute(\n 'data-dropdown-trigger'\n );\n const delay = $triggerEl.getAttribute('data-dropdown-delay');\n const ignoreClickOutsideClass = $triggerEl.getAttribute(\n 'data-dropdown-ignore-click-outside-class'\n );\n\n new Dropdown(\n $dropdownEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n offsetSkidding: offsetSkidding\n ? parseInt(offsetSkidding)\n : Default.offsetSkidding,\n offsetDistance: offsetDistance\n ? parseInt(offsetDistance)\n : Default.offsetDistance,\n delay: delay ? parseInt(delay) : Default.delay,\n ignoreClickOutsideClass: ignoreClickOutsideClass\n ? ignoreClickOutsideClass\n : Default.ignoreClickOutsideClass,\n } as DropdownOptions\n );\n } else {\n console.error(\n `The dropdown element with id \"${dropdownId}\" does not exist. Please check the data-dropdown-toggle attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Dropdown = Dropdown;\n window.initDropdowns = initDropdowns;\n}\n\nexport default Dropdown;\n","import { initAccordions } from './accordion';\nimport { initCarousels } from './carousel';\nimport { initCollapses } from './collapse';\nimport { initDials } from './dial';\nimport { initDismisses } from './dismiss';\nimport { initDrawers } from './drawer';\nimport { initDropdowns } from './dropdown';\nimport { initModals } from './modal';\nimport { initPopovers } from './popover';\nimport { initTabs } from './tabs';\nimport { initTooltips } from './tooltip';\n\nexport function initFlowbite() {\n initAccordions();\n initCollapses();\n initCarousels();\n initDismisses();\n initDropdowns();\n initModals();\n initDrawers();\n initTabs();\n initTooltips();\n initPopovers();\n initDials();\n}\n\nif (typeof window !== 'undefined') {\n window.initFlowbite = initFlowbite;\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { ModalInstance, ModalOptions } from './types';\nimport { ModalInterface } from './interface';\n\nconst Default: ModalOptions = {\n placement: 'center',\n backdropClasses:\n 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40',\n backdrop: 'dynamic',\n closable: true,\n onHide: () => {},\n onShow: () => {},\n onToggle: () => {},\n};\n\nclass Modal implements ModalInterface {\n _targetEl: HTMLElement | null;\n _options: ModalOptions;\n _isHidden: boolean;\n _backdropEl: HTMLElement | null;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n\n constructor(\n targetEl: HTMLElement | null = null,\n options: ModalOptions = Default\n ) {\n this._targetEl = targetEl;\n this._options = { ...Default, ...options };\n this._isHidden = true;\n this._backdropEl = null;\n this._init();\n }\n\n _init() {\n if (this._targetEl) {\n this._getPlacementClasses().map((c) => {\n this._targetEl.classList.add(c);\n });\n }\n }\n\n _createBackdrop() {\n if (this._isHidden) {\n const backdropEl = document.createElement('div');\n backdropEl.setAttribute('modal-backdrop', '');\n backdropEl.classList.add(\n ...this._options.backdropClasses.split(' ')\n );\n document.querySelector('body').append(backdropEl);\n this._backdropEl = backdropEl;\n }\n }\n\n _destroyBackdropEl() {\n if (!this._isHidden) {\n document.querySelector('[modal-backdrop]').remove();\n }\n }\n\n _setupModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleOutsideClick(ev.target);\n };\n this._targetEl.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeModalCloseEventListeners() {\n if (this._options.backdrop === 'dynamic') {\n this._targetEl.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _handleOutsideClick(target: EventTarget) {\n if (\n target === this._targetEl ||\n (target === this._backdropEl && this.isVisible())\n ) {\n this.hide();\n }\n }\n\n _getPlacementClasses() {\n switch (this._options.placement) {\n // top\n case 'top-left':\n return ['justify-start', 'items-start'];\n case 'top-center':\n return ['justify-center', 'items-start'];\n case 'top-right':\n return ['justify-end', 'items-start'];\n\n // center\n case 'center-left':\n return ['justify-start', 'items-center'];\n case 'center':\n return ['justify-center', 'items-center'];\n case 'center-right':\n return ['justify-end', 'items-center'];\n\n // bottom\n case 'bottom-left':\n return ['justify-start', 'items-end'];\n case 'bottom-center':\n return ['justify-center', 'items-end'];\n case 'bottom-right':\n return ['justify-end', 'items-end'];\n\n default:\n return ['justify-center', 'items-center'];\n }\n }\n\n toggle() {\n if (this._isHidden) {\n this.show();\n } else {\n this.hide();\n }\n\n // callback function\n this._options.onToggle(this);\n }\n\n show() {\n if (this.isHidden) {\n this._targetEl.classList.add('flex');\n this._targetEl.classList.remove('hidden');\n this._targetEl.setAttribute('aria-modal', 'true');\n this._targetEl.setAttribute('role', 'dialog');\n this._targetEl.removeAttribute('aria-hidden');\n this._createBackdrop();\n this._isHidden = false;\n\n // prevent body scroll\n document.body.classList.add('overflow-hidden');\n\n // Add keyboard event listener to the document\n if (this._options.closable) {\n this._setupModalCloseEventListeners();\n }\n\n // callback function\n this._options.onShow(this);\n }\n }\n\n hide() {\n if (this.isVisible) {\n this._targetEl.classList.add('hidden');\n this._targetEl.classList.remove('flex');\n this._targetEl.setAttribute('aria-hidden', 'true');\n this._targetEl.removeAttribute('aria-modal');\n this._targetEl.removeAttribute('role');\n this._destroyBackdropEl();\n this._isHidden = true;\n\n // re-apply body scroll\n document.body.classList.remove('overflow-hidden');\n\n if (this._options.closable) {\n this._removeModalCloseEventListeners();\n }\n\n // callback function\n this._options.onHide(this);\n }\n }\n\n isVisible() {\n return !this._isHidden;\n }\n\n isHidden() {\n return this._isHidden;\n }\n}\n\nconst getModalInstance = (id: string, instances: ModalInstance[]) => {\n if (instances.some((modalInstance) => modalInstance.id === id)) {\n return instances.find((modalInstance) => modalInstance.id === id);\n }\n return null;\n};\n\nexport function initModals() {\n const modalInstances = [] as ModalInstance[];\n\n // initiate modal based on data-modal-target\n document.querySelectorAll('[data-modal-target]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-target');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n if (!getModalInstance(modalId, modalInstances)) {\n modalInstances.push({\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n });\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.`\n );\n }\n });\n\n // support pre v1.6.0 data-modal-toggle initialization\n document.querySelectorAll('[data-modal-toggle]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-toggle');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const placement = $modalEl.getAttribute('data-modal-placement');\n const backdrop = $modalEl.getAttribute('data-modal-backdrop');\n\n let modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (!modal) {\n modal = {\n id: modalId,\n object: new Modal(\n $modalEl as HTMLElement,\n {\n placement: placement\n ? placement\n : Default.placement,\n backdrop: backdrop ? backdrop : Default.backdrop,\n } as ModalOptions\n ),\n };\n modalInstances.push(modal);\n }\n\n $triggerEl.addEventListener('click', () => {\n modal.object.toggle();\n });\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?`\n );\n }\n });\n\n // show modal on click if exists based on id\n document.querySelectorAll('[data-modal-show]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-show');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isHidden) {\n modal.object.show();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?`\n );\n }\n });\n\n // hide modal on click if exists based on id\n document.querySelectorAll('[data-modal-hide]').forEach(($triggerEl) => {\n const modalId = $triggerEl.getAttribute('data-modal-hide');\n const $modalEl = document.getElementById(modalId);\n\n if ($modalEl) {\n const modal: ModalInstance = getModalInstance(\n modalId,\n modalInstances\n );\n\n if (modal) {\n $triggerEl.addEventListener('click', () => {\n if (modal.object.isVisible) {\n modal.object.hide();\n }\n });\n } else {\n console.error(\n `Modal with id ${modalId} has not been initialized. Please initialize it using the data-modal-target attribute.`\n );\n }\n } else {\n console.error(\n `Modal with id ${modalId} does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Modal = Modal;\n window.initModals = initModals;\n}\n\nexport default Modal;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { PopoverOptions } from './types';\nimport { PopoverInterface } from './interface';\n\nconst Default: PopoverOptions = {\n placement: 'top',\n offset: 10,\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Popover implements PopoverInterface {\n _targetEl: HTMLElement;\n _triggerEl: HTMLElement;\n _options: PopoverOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: PopoverOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n this._targetEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._targetEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n this._targetEl.addEventListener(ev, () => {\n setTimeout(() => {\n if (!this._triggerEl.matches(':hover')) {\n this.hide();\n }\n }, 100);\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, this._options.offset],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n this._options.onToggle(this);\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility to true\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility to false\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initPopovers() {\n document.querySelectorAll('[data-popover-target]').forEach(($triggerEl) => {\n const popoverID = $triggerEl.getAttribute('data-popover-target');\n const $popoverEl = document.getElementById(popoverID);\n\n if ($popoverEl) {\n const triggerType = $triggerEl.getAttribute('data-popover-trigger');\n const placement = $triggerEl.getAttribute('data-popover-placement');\n const offset = $triggerEl.getAttribute('data-popover-offset');\n\n new Popover(\n $popoverEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n offset: offset ? parseInt(offset) : Default.offset,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as PopoverOptions\n );\n } else {\n console.error(\n `The popover element with id \"${popoverID}\" does not exist. Please check the data-popover-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Popover = Popover;\n window.initPopovers = initPopovers;\n}\n\nexport default Popover;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport type { TabItem, TabsOptions } from './types';\nimport { TabsInterface } from './interface';\n\nconst Default: TabsOptions = {\n defaultTabId: null,\n activeClasses:\n 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500',\n inactiveClasses:\n 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300',\n onShow: () => {},\n};\n\nclass Tabs implements TabsInterface {\n _items: TabItem[];\n _activeTab: TabItem;\n _options: TabsOptions;\n\n constructor(items: TabItem[] = [], options: TabsOptions = Default) {\n this._items = items;\n this._activeTab = options ? this.getTab(options.defaultTabId) : null;\n this._options = { ...Default, ...options };\n this._init();\n }\n\n _init() {\n if (this._items.length) {\n // set the first tab as active if not set by explicitly\n if (!this._activeTab) {\n this._setActiveTab(this._items[0]);\n }\n\n // force show the first default tab\n this.show(this._activeTab.id, true);\n\n // show tab content based on click\n this._items.map((tab) => {\n tab.triggerEl.addEventListener('click', () => {\n this.show(tab.id);\n });\n });\n }\n }\n\n getActiveTab() {\n return this._activeTab;\n }\n\n _setActiveTab(tab: TabItem) {\n this._activeTab = tab;\n }\n\n getTab(id: string) {\n return this._items.filter((t) => t.id === id)[0];\n }\n\n show(id: string, forceShow = false) {\n const tab = this.getTab(id);\n\n // don't do anything if already active\n if (tab === this._activeTab && !forceShow) {\n return;\n }\n\n // hide other tabs\n this._items.map((t: TabItem) => {\n if (t !== tab) {\n t.triggerEl.classList.remove(\n ...this._options.activeClasses.split(' ')\n );\n t.triggerEl.classList.add(\n ...this._options.inactiveClasses.split(' ')\n );\n t.targetEl.classList.add('hidden');\n t.triggerEl.setAttribute('aria-selected', 'false');\n }\n });\n\n // show active tab\n tab.triggerEl.classList.add(...this._options.activeClasses.split(' '));\n tab.triggerEl.classList.remove(\n ...this._options.inactiveClasses.split(' ')\n );\n tab.triggerEl.setAttribute('aria-selected', 'true');\n tab.targetEl.classList.remove('hidden');\n\n this._setActiveTab(tab);\n\n // callback function\n this._options.onShow(this, tab);\n }\n}\n\nexport function initTabs() {\n document.querySelectorAll('[data-tabs-toggle]').forEach(($triggerEl) => {\n const tabItems: TabItem[] = [];\n let defaultTabId = null;\n $triggerEl\n .querySelectorAll('[role=\"tab\"]')\n .forEach(($triggerEl: HTMLElement) => {\n const isActive =\n $triggerEl.getAttribute('aria-selected') === 'true';\n const tab: TabItem = {\n id: $triggerEl.getAttribute('data-tabs-target'),\n triggerEl: $triggerEl,\n targetEl: document.querySelector(\n $triggerEl.getAttribute('data-tabs-target')\n ),\n };\n tabItems.push(tab);\n\n if (isActive) {\n defaultTabId = tab.id;\n }\n });\n new Tabs(tabItems, {\n defaultTabId: defaultTabId,\n } as TabsOptions);\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tabs = Tabs;\n window.initTabs = initTabs;\n}\n\nexport default Tabs;\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport { createPopper } from '@popperjs/core';\nimport type {\n Options as PopperOptions,\n Instance as PopperInstance,\n} from '@popperjs/core';\nimport type { TooltipOptions } from './types';\nimport { TooltipInterface } from './interface';\n\nconst Default: TooltipOptions = {\n placement: 'top',\n triggerType: 'hover',\n onShow: () => {},\n onHide: () => {},\n onToggle: () => {},\n};\n\nclass Tooltip implements TooltipInterface {\n _targetEl: HTMLElement | null;\n _triggerEl: HTMLElement | null;\n _options: TooltipOptions;\n _popperInstance: PopperInstance;\n _clickOutsideEventListener: EventListenerOrEventListenerObject;\n _keydownEventListener: EventListenerOrEventListenerObject;\n _visible: boolean;\n\n constructor(\n targetEl: HTMLElement | null = null,\n triggerEl: HTMLElement | null = null,\n options: TooltipOptions = Default\n ) {\n this._targetEl = targetEl;\n this._triggerEl = triggerEl;\n this._options = { ...Default, ...options };\n this._popperInstance = this._createPopperInstance();\n this._visible = false;\n this._init();\n }\n\n _init() {\n if (this._triggerEl) {\n this._setupEventListeners();\n }\n }\n\n _setupEventListeners() {\n const triggerEvents = this._getTriggerEvents();\n triggerEvents.showEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.show();\n });\n });\n triggerEvents.hideEvents.forEach((ev) => {\n this._triggerEl.addEventListener(ev, () => {\n this.hide();\n });\n });\n }\n\n _createPopperInstance() {\n return createPopper(this._triggerEl, this._targetEl, {\n placement: this._options.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, 8],\n },\n },\n ],\n });\n }\n\n _getTriggerEvents() {\n switch (this._options.triggerType) {\n case 'hover':\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n case 'click':\n return {\n showEvents: ['click', 'focus'],\n hideEvents: ['focusout', 'blur'],\n };\n case 'none':\n return {\n showEvents: [],\n hideEvents: [],\n };\n default:\n return {\n showEvents: ['mouseenter', 'focus'],\n hideEvents: ['mouseleave', 'blur'],\n };\n }\n }\n\n _setupKeydownListener() {\n this._keydownEventListener = (ev: KeyboardEvent) => {\n if (ev.key === 'Escape') {\n this.hide();\n }\n };\n document.body.addEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _removeKeydownListener() {\n document.body.removeEventListener(\n 'keydown',\n this._keydownEventListener,\n true\n );\n }\n\n _setupClickOutsideListener() {\n this._clickOutsideEventListener = (ev: MouseEvent) => {\n this._handleClickOutside(ev, this._targetEl);\n };\n document.body.addEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _removeClickOutsideListener() {\n document.body.removeEventListener(\n 'click',\n this._clickOutsideEventListener,\n true\n );\n }\n\n _handleClickOutside(ev: Event, targetEl: HTMLElement) {\n const clickedEl = ev.target as Node;\n if (\n clickedEl !== targetEl &&\n !targetEl.contains(clickedEl) &&\n !this._triggerEl.contains(clickedEl) &&\n this.isVisible()\n ) {\n this.hide();\n }\n }\n\n isVisible() {\n return this._visible;\n }\n\n toggle() {\n if (this.isVisible()) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n show() {\n this._targetEl.classList.remove('opacity-0', 'invisible');\n this._targetEl.classList.add('opacity-100', 'visible');\n\n // Enable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: true },\n ],\n }));\n\n // handle click outside\n this._setupClickOutsideListener();\n\n // handle esc keydown\n this._setupKeydownListener();\n\n // Update its position\n this._popperInstance.update();\n\n // set visibility\n this._visible = true;\n\n // callback function\n this._options.onShow(this);\n }\n\n hide() {\n this._targetEl.classList.remove('opacity-100', 'visible');\n this._targetEl.classList.add('opacity-0', 'invisible');\n\n // Disable the event listeners\n this._popperInstance.setOptions((options: PopperOptions) => ({\n ...options,\n modifiers: [\n ...options.modifiers,\n { name: 'eventListeners', enabled: false },\n ],\n }));\n\n // handle click outside\n this._removeClickOutsideListener();\n\n // handle esc keydown\n this._removeKeydownListener();\n\n // set visibility\n this._visible = false;\n\n // callback function\n this._options.onHide(this);\n }\n}\n\nexport function initTooltips() {\n document.querySelectorAll('[data-tooltip-target]').forEach(($triggerEl) => {\n const tooltipId = $triggerEl.getAttribute('data-tooltip-target');\n const $tooltipEl = document.getElementById(tooltipId);\n\n if ($tooltipEl) {\n const triggerType = $triggerEl.getAttribute('data-tooltip-trigger');\n const placement = $triggerEl.getAttribute('data-tooltip-placement');\n\n new Tooltip(\n $tooltipEl as HTMLElement,\n $triggerEl as HTMLElement,\n {\n placement: placement ? placement : Default.placement,\n triggerType: triggerType\n ? triggerType\n : Default.triggerType,\n } as TooltipOptions\n );\n } else {\n console.error(\n `The tooltip element with id \"${tooltipId}\" does not exist. Please check the data-tooltip-target attribute.`\n );\n }\n });\n}\n\nif (typeof window !== 'undefined') {\n window.Tooltip = Tooltip;\n window.initTooltips = initTooltips;\n}\n\nexport default Tooltip;\n","class Events {\n private _eventType: string;\n private _eventFunctions: EventListener[];\n\n constructor(eventType: string, eventFunctions: EventListener[] = []) {\n this._eventType = eventType;\n this._eventFunctions = eventFunctions;\n }\n\n init() {\n this._eventFunctions.forEach((eventFunction) => {\n if (typeof window !== 'undefined') {\n window.addEventListener(this._eventType, eventFunction);\n }\n });\n }\n}\n\nexport default Events;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// core components\nimport Accordion, { initAccordions } from './components/accordion';\nimport Carousel, { initCarousels } from './components/carousel';\nimport Collapse, { initCollapses } from './components/collapse';\nimport Dial, { initDials } from './components/dial';\nimport Dismiss, { initDismisses } from './components/dismiss';\nimport Drawer, { initDrawers } from './components/drawer';\nimport Dropdown, { initDropdowns } from './components/dropdown';\nimport Modal, { initModals } from './components/modal';\nimport Popover, { initPopovers } from './components/popover';\nimport Tabs, { initTabs } from './components/tabs';\nimport Tooltip, { initTooltips } from './components/tooltip';\nimport './components/index';\nimport Events from './dom/events';\n\nconst turboLoadEvents = new Events('turbo:load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nturboLoadEvents.init();\n\nconst turboFrameLoadEvents = new Events('turbo:frame-load', [\n initAccordions,\n initCollapses,\n initCarousels,\n initDismisses,\n initDropdowns,\n initModals,\n initDrawers,\n initTabs,\n initTooltips,\n initPopovers,\n initDials,\n]);\nturboFrameLoadEvents.init();\n\nexport default {\n Accordion,\n Carousel,\n Collapse,\n Dial,\n Drawer,\n Dismiss,\n Dropdown,\n Modal,\n Popover,\n Tabs,\n Tooltip,\n Events,\n};\n"],"names":["root","factory","exports","module","define","amd","self","bottom","right","left","auto","basePlacements","start","end","clippingParents","viewport","popper","reference","variationPlacements","reduce","acc","placement","concat","beforeRead","read","afterRead","beforeMain","main","afterMain","beforeWrite","write","afterWrite","modifierPhases","getNodeName","element","nodeName","toLowerCase","getWindow","node","window","toString","ownerDocument","defaultView","isElement","Element","isHTMLElement","HTMLElement","isShadowRoot","ShadowRoot","name","enabled","phase","fn","_ref","state","Object","keys","elements","forEach","style","styles","attributes","assign","value","removeAttribute","setAttribute","effect","_ref2","initialStyles","position","options","strategy","top","margin","arrow","hasOwnProperty","property","attribute","requires","getBasePlacement","split","Math","max","min","round","getUAString","uaData","navigator","userAgentData","brands","map","item","brand","version","join","userAgent","isLayoutViewport","test","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scaleX","scaleY","offsetWidth","width","offsetHeight","height","visualViewport","addVisualOffsets","x","offsetLeft","y","offsetTop","getLayoutRect","abs","contains","parent","child","rootNode","getRootNode","next","isSameNode","parentNode","host","getComputedStyle","isTableElement","indexOf","getDocumentElement","document","documentElement","getParentNode","assignedSlot","getTrueOffsetParent","offsetParent","getOffsetParent","isFirefox","currentNode","css","transform","perspective","contain","willChange","filter","getContainingBlock","getMainAxisFromPlacement","within","mergePaddingObject","paddingObject","expandToHashMap","hashMap","key","_state$modifiersData$","arrowElement","popperOffsets","modifiersData","basePlacement","axis","len","padding","rects","toPaddingObject","arrowRect","minProp","maxProp","endDiff","startDiff","arrowOffsetParent","clientSize","clientHeight","clientWidth","centerToReference","center","offset","axisProp","centerOffset","_options$element","querySelector","requiresIfExists","getVariation","unsetSides","mapToStyles","_Object$assign2","popperRect","variation","offsets","gpuAcceleration","adaptive","roundOffsets","isFixed","_offsets$x","_offsets$y","_ref3","hasX","hasY","sideX","sideY","win","heightProp","widthProp","_Object$assign","commonStyles","_ref4","dpr","devicePixelRatio","roundOffsetsByDPR","_ref5","_options$gpuAccelerat","_options$adaptive","_options$roundOffsets","data","passive","instance","_options$scroll","scroll","_options$resize","resize","scrollParents","scrollParent","addEventListener","update","removeEventListener","hash","getOppositePlacement","replace","matched","getOppositeVariationPlacement","getWindowScroll","scrollLeft","pageXOffset","scrollTop","pageYOffset","getWindowScrollBarX","isScrollParent","_getComputedStyle","overflow","overflowX","overflowY","getScrollParent","body","listScrollParents","list","_element$ownerDocumen","isBody","target","updatedList","rectToClientRect","rect","getClientRectFromMixedType","clippingParent","html","layoutViewport","getViewportRect","clientTop","clientLeft","getInnerBoundingClientRect","winScroll","scrollWidth","scrollHeight","direction","getDocumentRect","getClippingRect","boundary","rootBoundary","mainClippingParents","clipperElement","getClippingParents","firstClippingParent","clippingRect","accRect","computeOffsets","commonX","commonY","mainAxis","detectOverflow","_options","_options$placement","_options$strategy","_options$boundary","_options$rootBoundary","_options$elementConte","elementContext","_options$altBoundary","altBoundary","_options$padding","altContext","clippingClientRect","contextElement","referenceClientRect","popperClientRect","elementClientRect","overflowOffsets","offsetData","multiply","_skip","_options$mainAxis","checkMainAxis","_options$altAxis","altAxis","checkAltAxis","specifiedFallbackPlacements","fallbackPlacements","_options$flipVariatio","flipVariations","allowedAutoPlacements","preferredPlacement","oppositePlacement","getExpandedFallbackPlacements","placements","_options$allowedAutoP","allowedPlacements","length","overflows","sort","a","b","computeAutoPlacement","referenceRect","checksMap","Map","makeFallbackChecks","firstFittingPlacement","i","_basePlacement","isStartVariation","isVertical","mainVariationSide","altVariationSide","checks","push","every","check","set","_loop","_i","fittingPlacement","find","get","slice","reset","getSideOffsets","preventedOffsets","isAnySideFullyClipped","some","side","preventOverflow","referenceOverflow","popperAltOverflow","referenceClippingOffsets","popperEscapeOffsets","isReferenceHidden","hasPopperEscaped","_options$offset","invertDistance","skidding","distance","distanceAndSkiddingToXY","_data$state$placement","_options$tether","tether","_options$tetherOffset","tetherOffset","isBasePlacement","tetherOffsetValue","normalizedTetherOffsetValue","offsetModifierState","_offsetModifierState$","mainSide","altSide","additive","minLen","maxLen","arrowPaddingObject","arrowPaddingMin","arrowPaddingMax","arrowLen","minOffset","maxOffset","clientOffset","offsetModifierValue","tetherMax","preventedOffset","_offsetModifierState$2","_mainSide","_altSide","_offset","_len","_min","_max","isOriginSide","_offsetModifierValue","_tetherMin","_tetherMax","_preventedOffset","v","withinMaxClamp","getCompositeRect","elementOrVirtualElement","isOffsetParentAnElement","offsetParentIsScaled","isElementScaled","order","modifiers","visited","Set","result","modifier","add","dep","has","depModifier","DEFAULT_OPTIONS","areValidElements","arguments","args","Array","_key","popperGenerator","generatorOptions","_generatorOptions","_generatorOptions$def","defaultModifiers","_generatorOptions$def2","defaultOptions","pending","orderedModifiers","effectCleanupFns","isDestroyed","setOptions","setOptionsAction","cleanupModifierEffects","orderModifiers","merged","current","existing","mergeByName","m","_ref3$options","cleanupFn","noopFn","forceUpdate","_state$elements","index","_state$orderedModifie","_state$orderedModifie2","Promise","resolve","then","undefined","destroy","onFirstUpdate","createPopper","eventListeners","Default","alwaysOpen","activeClasses","inactiveClasses","onOpen","onClose","onToggle","items","this","_items","_init","active","open","id","triggerEl","toggle","getItem","classList","remove","targetEl","iconEl","close","initAccordions","querySelectorAll","$accordionEl","getAttribute","$triggerEl","closest","Accordion","defaultPosition","indicators","interval","onNext","onPrev","onChange","_activeItem","_indicators","_intervalDuration","_intervalInstance","el","_getActiveItem","slideTo","indicator","nextItem","rotationItems","middle","_rotate","_setActiveItem","pause","cycle","activeItem","prev","prevItem","setInterval","clearInterval","initCarousels","$carouselEl","slide","from","$carouselItemEl","$indicatorEl","parseInt","carousel","Carousel","carouselNextEl","carouselPrevEl","onCollapse","onExpand","_targetEl","_triggerEl","_visible","hasAttribute","collapse","expand","initCollapses","targetId","$targetEl","getElementById","Collapse","console","error","triggerType","onShow","onHide","parentEl","_parentEl","triggerEventTypes","_getTriggerEventTypes","showEvents","ev","show","hideEvents","matches","hide","isHidden","isVisible","initDials","$parentEl","dialId","$dialEl","Dial","transition","duration","timing","setTimeout","initDismisses","$dismissEl","Dismiss","bodyScrolling","backdrop","edge","edgeOffset","backdropClasses","_getPlacementClasses","base","c","event","inactive","_destroyBackdropEl","_createBackdrop","backdropEl","createElement","append","getDrawerInstance","instances","drawerInstance","initDrawers","drawerInstances","drawerId","$drawerEl","object","Drawer","offsetSkidding","offsetDistance","delay","ignoreClickOutsideClass","targetElement","triggerElement","_popperInstance","_createPopperInstance","_setupEventListeners","triggerEvents","_getTriggerEvents","_setupClickOutsideListener","_clickOutsideEventListener","_handleClickOutside","_removeClickOutsideListener","clickedEl","isIgnored","initDropdowns","dropdownId","$dropdownEl","Dropdown","initFlowbite","initModals","initTabs","initTooltips","initPopovers","closable","_isHidden","_backdropEl","_setupModalCloseEventListeners","_handleOutsideClick","_keydownEventListener","_removeModalCloseEventListeners","getModalInstance","modalInstance","modalInstances","modalId","$modalEl","Modal","_setupKeydownListener","_removeKeydownListener","popoverID","$popoverEl","Popover","defaultTabId","_activeTab","getTab","_setActiveTab","tab","getActiveTab","t","forceShow","tabItems","isActive","Tabs","tooltipId","$tooltipEl","Tooltip","eventType","eventFunctions","_eventType","_eventFunctions","init","eventFunction","Events","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","call","d","definition","o","defineProperty","enumerable","obj","prop","prototype","r","Symbol","toStringTag"],"sourceRoot":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts b/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts new file mode 100644 index 0000000..4ea151a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts @@ -0,0 +1,15 @@ +import type { AccordionItem, AccordionOptions } from './types'; +import { AccordionInterface } from './interface'; +declare class Accordion implements AccordionInterface { + _items: AccordionItem[]; + _options: AccordionOptions; + constructor(items?: AccordionItem[], options?: AccordionOptions); + private _init; + getItem(id: string): AccordionItem; + open(id: string): void; + toggle(id: string): void; + close(id: string): void; +} +export declare function initAccordions(): void; +export default Accordion; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts.map new file mode 100644 index 0000000..a7f1f0f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAWjD,cAAM,SAAU,YAAW,kBAAkB;IACzC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,QAAQ,EAAE,gBAAgB,CAAC;gBAGvB,KAAK,GAAE,aAAa,EAAO,EAC3B,OAAO,GAAE,gBAA0B;IAOvC,OAAO,CAAC,KAAK;IAeb,OAAO,CAAC,EAAE,EAAE,MAAM;IAIlB,IAAI,CAAC,EAAE,EAAE,MAAM;IA2Cf,MAAM,CAAC,EAAE,EAAE,MAAM;IAajB,KAAK,CAAC,EAAE,EAAE,MAAM;CAqBnB;AAED,wBAAgB,cAAc,SA2C7B;AAOD,eAAe,SAAS,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/index.js b/node_modules/flowbite/lib/cjs/components/accordion/index.js new file mode 100644 index 0000000..0089ea2 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/index.js @@ -0,0 +1,151 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initAccordions = void 0; +var Default = { + alwaysOpen: false, + activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', + inactiveClasses: 'text-gray-500 dark:text-gray-400', + onOpen: function () { }, + onClose: function () { }, + onToggle: function () { }, +}; +var Accordion = /** @class */ (function () { + function Accordion(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Accordion.prototype._init = function () { + var _this = this; + if (this._items.length) { + // show accordion item based on click + this._items.map(function (item) { + if (item.active) { + _this.open(item.id); + } + item.triggerEl.addEventListener('click', function () { + _this.toggle(item.id); + }); + }); + } + }; + Accordion.prototype.getItem = function (id) { + return this._items.filter(function (item) { return item.id === id; })[0]; + }; + Accordion.prototype.open = function (id) { + var _a, _b; + var _this = this; + var item = this.getItem(id); + // don't hide other accordions if always open + if (!this._options.alwaysOpen) { + this._items.map(function (i) { + var _a, _b; + if (i !== item) { + (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + i.targetEl.classList.add('hidden'); + i.triggerEl.setAttribute('aria-expanded', 'false'); + i.active = false; + // rotate icon if set + if (i.iconEl) { + i.iconEl.classList.remove('rotate-180'); + } + } + }); + } + // show active item + (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + item.triggerEl.setAttribute('aria-expanded', 'true'); + item.targetEl.classList.remove('hidden'); + item.active = true; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.add('rotate-180'); + } + // callback function + this._options.onOpen(this, item); + }; + Accordion.prototype.toggle = function (id) { + var item = this.getItem(id); + if (item.active) { + this.close(id); + } + else { + this.open(id); + } + // callback function + this._options.onToggle(this, item); + }; + Accordion.prototype.close = function (id) { + var _a, _b; + var item = this.getItem(id); + (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); + item.targetEl.classList.add('hidden'); + item.triggerEl.setAttribute('aria-expanded', 'false'); + item.active = false; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.remove('rotate-180'); + } + // callback function + this._options.onClose(this, item); + }; + return Accordion; +}()); +function initAccordions() { + document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { + var alwaysOpen = $accordionEl.getAttribute('data-accordion'); + var activeClasses = $accordionEl.getAttribute('data-active-classes'); + var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); + var items = []; + $accordionEl + .querySelectorAll('[data-accordion-target]') + .forEach(function ($triggerEl) { + // Consider only items that directly belong to $accordionEl + // (to make nested accordions work). + if ($triggerEl.closest('[data-accordion]') === $accordionEl) { + var item = { + id: $triggerEl.getAttribute('data-accordion-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), + iconEl: $triggerEl.querySelector('[data-accordion-icon]'), + active: $triggerEl.getAttribute('aria-expanded') === 'true' + ? true + : false, + }; + items.push(item); + } + }); + new Accordion(items, { + alwaysOpen: alwaysOpen === 'open' ? true : false, + activeClasses: activeClasses + ? activeClasses + : Default.activeClasses, + inactiveClasses: inactiveClasses + ? inactiveClasses + : Default.inactiveClasses, + }); + }); +} +exports.initAccordions = initAccordions; +if (typeof window !== 'undefined') { + window.Accordion = Accordion; + window.initAccordions = initAccordions; +} +exports.default = Accordion; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/index.js.map b/node_modules/flowbite/lib/cjs/components/accordion/index.js.map new file mode 100644 index 0000000..b35b518 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/accordion/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts b/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts new file mode 100644 index 0000000..ebeacd9 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts @@ -0,0 +1,10 @@ +import { AccordionItem, AccordionOptions } from './types'; +export declare interface AccordionInterface { + _items: AccordionItem[]; + _options: AccordionOptions; + getItem(id: string): AccordionItem | undefined; + open(id: string): void; + toggle(id: string): void; + close(id: string): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts.map new file mode 100644 index 0000000..cfc63e5 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/interface.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAG1D,MAAM,CAAC,OAAO,WAAW,kBAAkB;IACvC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,QAAQ,EAAE,gBAAgB,CAAC;IAE3B,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS,CAAC;IAC/C,IAAI,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/interface.js b/node_modules/flowbite/lib/cjs/components/accordion/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/interface.js.map b/node_modules/flowbite/lib/cjs/components/accordion/interface.js.map new file mode 100644 index 0000000..a7ef24a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/accordion/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts b/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts new file mode 100644 index 0000000..c8fb43a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts @@ -0,0 +1,17 @@ +import { AccordionInterface } from './interface'; +export declare type AccordionItem = { + id: string; + triggerEl: HTMLElement; + targetEl: HTMLElement; + iconEl?: HTMLElement | null; + active?: boolean; +}; +export declare type AccordionOptions = { + alwaysOpen?: boolean; + activeClasses?: string; + inactiveClasses?: string; + onOpen?: (accordion: AccordionInterface, item: AccordionItem) => void; + onClose?: (accordion: AccordionInterface, item: AccordionItem) => void; + onToggle?: (accordion: AccordionInterface, item: AccordionItem) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts.map new file mode 100644 index 0000000..c130ff7 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5B,MAAM,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,gBAAgB,GAAG;IACnC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACtE,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvE,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;CAC3E,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/types.js b/node_modules/flowbite/lib/cjs/components/accordion/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/accordion/types.js.map b/node_modules/flowbite/lib/cjs/components/accordion/types.js.map new file mode 100644 index 0000000..e0f0c46 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/accordion/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/accordion/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts b/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts new file mode 100644 index 0000000..0361e3e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts @@ -0,0 +1,54 @@ +import type { CarouselOptions, CarouselItem, IndicatorItem, RotationItems } from './types'; +import { CarouselInterface } from './interface'; +declare class Carousel implements CarouselInterface { + _items: CarouselItem[]; + _indicators: IndicatorItem[]; + _activeItem: CarouselItem; + _intervalDuration: number; + _intervalInstance: number; + _options: CarouselOptions; + constructor(items?: CarouselItem[], options?: CarouselOptions); + /** + * initialize carousel and items based on active one + */ + _init(): void; + getItem(position: number): CarouselItem; + /** + * Slide to the element based on id + * @param {*} position + */ + slideTo(position: number): void; + /** + * Based on the currently active item it will go to the next position + */ + next(): void; + /** + * Based on the currently active item it will go to the previous position + */ + prev(): void; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + _rotate(rotationItems: RotationItems): void; + /** + * Set an interval to cycle through the carousel items + */ + cycle(): void; + /** + * Clears the cycling interval + */ + pause(): void; + /** + * Get the currently active item + */ + _getActiveItem(): CarouselItem; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + _setActiveItem(item: CarouselItem): void; +} +export declare function initCarousels(): void; +export default Carousel; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts.map new file mode 100644 index 0000000..76e86e7 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,eAAe,EACf,YAAY,EACZ,aAAa,EACb,aAAa,EAChB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAgBhD,cAAM,QAAS,YAAW,iBAAiB;IACvC,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,WAAW,EAAE,aAAa,EAAE,CAAC;IAC7B,WAAW,EAAE,YAAY,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,EAAE,eAAe,CAAC;gBAGtB,KAAK,GAAE,YAAY,EAAO,EAC1B,OAAO,GAAE,eAAyB;IAetC;;OAEG;IACH,KAAK;IAwBL,OAAO,CAAC,QAAQ,EAAE,MAAM;IAIxB;;;OAGG;IACH,OAAO,CAAC,QAAQ,EAAE,MAAM;IAuBxB;;OAEG;IACH,IAAI;IAiBJ;;OAEG;IACH,IAAI;IAiBJ;;;OAGG;IACH,OAAO,CAAC,aAAa,EAAE,aAAa;IAqCpC;;OAEG;IACH,KAAK;IAQL;;OAEG;IACH,KAAK;IAIL;;OAEG;IACH,cAAc;IAId;;;OAGG;IACH,cAAc,CAAC,IAAI,EAAE,YAAY;CAwBpC;AAED,wBAAgB,aAAa,SA0E5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/index.js b/node_modules/flowbite/lib/cjs/components/carousel/index.js new file mode 100644 index 0000000..db90e01 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/index.js @@ -0,0 +1,246 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initCarousels = void 0; +var Default = { + defaultPosition: 0, + indicators: { + items: [], + activeClasses: 'bg-white dark:bg-gray-800', + inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', + }, + interval: 3000, + onNext: function () { }, + onPrev: function () { }, + onChange: function () { }, +}; +var Carousel = /** @class */ (function () { + function Carousel(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign(__assign({}, Default), options), { indicators: __assign(__assign({}, Default.indicators), options.indicators) }); + this._activeItem = this.getItem(this._options.defaultPosition); + this._indicators = this._options.indicators.items; + this._intervalDuration = this._options.interval; + this._intervalInstance = null; + this._init(); + } + /** + * initialize carousel and items based on active one + */ + Carousel.prototype._init = function () { + var _this = this; + this._items.map(function (item) { + item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); + }); + // if no active item is set then first position is default + if (this._getActiveItem()) { + this.slideTo(this._getActiveItem().position); + } + else { + this.slideTo(0); + } + this._indicators.map(function (indicator, position) { + indicator.el.addEventListener('click', function () { + _this.slideTo(position); + }); + }); + }; + Carousel.prototype.getItem = function (position) { + return this._items[position]; + }; + /** + * Slide to the element based on id + * @param {*} position + */ + Carousel.prototype.slideTo = function (position) { + var nextItem = this._items[position]; + var rotationItems = { + left: nextItem.position === 0 + ? this._items[this._items.length - 1] + : this._items[nextItem.position - 1], + middle: nextItem, + right: nextItem.position === this._items.length - 1 + ? this._items[0] + : this._items[nextItem.position + 1], + }; + this._rotate(rotationItems); + this._setActiveItem(nextItem); + if (this._intervalInstance) { + this.pause(); + this.cycle(); + } + this._options.onChange(this); + }; + /** + * Based on the currently active item it will go to the next position + */ + Carousel.prototype.next = function () { + var activeItem = this._getActiveItem(); + var nextItem = null; + // check if last item + if (activeItem.position === this._items.length - 1) { + nextItem = this._items[0]; + } + else { + nextItem = this._items[activeItem.position + 1]; + } + this.slideTo(nextItem.position); + // callback function + this._options.onNext(this); + }; + /** + * Based on the currently active item it will go to the previous position + */ + Carousel.prototype.prev = function () { + var activeItem = this._getActiveItem(); + var prevItem = null; + // check if first item + if (activeItem.position === 0) { + prevItem = this._items[this._items.length - 1]; + } + else { + prevItem = this._items[activeItem.position - 1]; + } + this.slideTo(prevItem.position); + // callback function + this._options.onPrev(this); + }; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + Carousel.prototype._rotate = function (rotationItems) { + // reset + this._items.map(function (item) { + item.el.classList.add('hidden'); + }); + // left item (previously active) + rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); + // currently active item + rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); + rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); + // right item (upcoming active) + rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.right.el.classList.add('translate-x-full', 'z-10'); + }; + /** + * Set an interval to cycle through the carousel items + */ + Carousel.prototype.cycle = function () { + var _this = this; + if (typeof window !== 'undefined') { + this._intervalInstance = window.setInterval(function () { + _this.next(); + }, this._intervalDuration); + } + }; + /** + * Clears the cycling interval + */ + Carousel.prototype.pause = function () { + clearInterval(this._intervalInstance); + }; + /** + * Get the currently active item + */ + Carousel.prototype._getActiveItem = function () { + return this._activeItem; + }; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + Carousel.prototype._setActiveItem = function (item) { + var _a, _b; + var _this = this; + this._activeItem = item; + var position = item.position; + // update the indicators if available + if (this._indicators.length) { + this._indicators.map(function (indicator) { + var _a, _b; + indicator.el.setAttribute('aria-current', 'false'); + (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); + (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); + }); + (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); + (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); + this._indicators[position].el.setAttribute('aria-current', 'true'); + } + }; + return Carousel; +}()); +function initCarousels() { + document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { + var interval = $carouselEl.getAttribute('data-carousel-interval'); + var slide = $carouselEl.getAttribute('data-carousel') === 'slide' + ? true + : false; + var items = []; + var defaultPosition = 0; + if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { + items.push({ + position: position, + el: $carouselItemEl, + }); + if ($carouselItemEl.getAttribute('data-carousel-item') === + 'active') { + defaultPosition = position; + } + }); + } + var indicators = []; + if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { + indicators.push({ + position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), + el: $indicatorEl, + }); + }); + } + var carousel = new Carousel(items, { + defaultPosition: defaultPosition, + indicators: { + items: indicators, + }, + interval: interval ? interval : Default.interval, + }); + if (slide) { + carousel.cycle(); + } + // check for controls + var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); + var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); + if (carouselNextEl) { + carouselNextEl.addEventListener('click', function () { + carousel.next(); + }); + } + if (carouselPrevEl) { + carouselPrevEl.addEventListener('click', function () { + carousel.prev(); + }); + } + }); +} +exports.initCarousels = initCarousels; +if (typeof window !== 'undefined') { + window.Carousel = Carousel; + window.initCarousels = initCarousels; +} +exports.default = Carousel; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/index.js.map b/node_modules/flowbite/lib/cjs/components/carousel/index.js.map new file mode 100644 index 0000000..9b08e6a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/carousel/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts b/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts new file mode 100644 index 0000000..edb6114 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts @@ -0,0 +1,20 @@ +import { CarouselOptions, CarouselItem, IndicatorItem, RotationItems } from './types'; +export declare interface CarouselInterface { + _items: CarouselItem[]; + _indicators: IndicatorItem[]; + _activeItem: CarouselItem; + _intervalDuration: number; + _intervalInstance: number; + _options: CarouselOptions; + _init(): void; + getItem(position: number): CarouselItem; + _getActiveItem(): CarouselItem; + _setActiveItem(item: CarouselItem): void; + slideTo(position: number): void; + next(): void; + prev(): void; + _rotate(rotationItems: RotationItems): void; + cycle(): void; + pause(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts.map new file mode 100644 index 0000000..423a855 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,YAAY,EACZ,aAAa,EACb,aAAa,EAChB,MAAM,SAAS,CAAC;AAEjB,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,WAAW,EAAE,aAAa,EAAE,CAAC;IAC7B,WAAW,EAAE,YAAY,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,EAAE,eAAe,CAAC;IAE1B,KAAK,IAAI,IAAI,CAAC;IAEd,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,CAAC;IAExC,cAAc,IAAI,YAAY,CAAC;IAC/B,cAAc,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI,CAAC;IAEzC,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IAEhC,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IAEb,OAAO,CAAC,aAAa,EAAE,aAAa,GAAG,IAAI,CAAC;IAC5C,KAAK,IAAI,IAAI,CAAC;IACd,KAAK,IAAI,IAAI,CAAC;CACjB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/interface.js b/node_modules/flowbite/lib/cjs/components/carousel/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/interface.js.map b/node_modules/flowbite/lib/cjs/components/carousel/interface.js.map new file mode 100644 index 0000000..3c63595 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/carousel/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts b/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts new file mode 100644 index 0000000..8ae7d3d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts @@ -0,0 +1,27 @@ +import { CarouselInterface } from './interface'; +export declare type CarouselItem = { + position: number; + el: HTMLElement; +}; +export declare type IndicatorItem = { + position: number; + el: HTMLElement; +}; +export declare type RotationItems = { + left: CarouselItem; + middle: CarouselItem; + right: CarouselItem; +}; +export declare type CarouselOptions = { + defaultPosition?: number; + indicators?: { + items?: IndicatorItem[]; + activeClasses?: string; + inactiveClasses?: string; + }; + interval?: number; + onNext?: (carousel: CarouselInterface) => void; + onPrev?: (carousel: CarouselInterface) => void; + onChange?: (carousel: CarouselInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts.map new file mode 100644 index 0000000..8cb376d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,YAAY,GAAG;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,EAAE,EAAE,WAAW,CAAC;CACnB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,EAAE,EAAE,WAAW,CAAC;CACnB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,IAAI,EAAE,YAAY,CAAC;IACnB,MAAM,EAAE,YAAY,CAAC;IACrB,KAAK,EAAE,YAAY,CAAC;CACvB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE;QACT,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;QACxB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC5B,CAAC;IACF,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC/C,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC/C,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACpD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/types.js b/node_modules/flowbite/lib/cjs/components/carousel/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/carousel/types.js.map b/node_modules/flowbite/lib/cjs/components/carousel/types.js.map new file mode 100644 index 0000000..72b8fbd --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/carousel/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/carousel/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts b/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts new file mode 100644 index 0000000..5e9ce95 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts @@ -0,0 +1,16 @@ +import type { CollapseOptions } from './types'; +import { CollapseInterface } from './interface'; +declare class Collapse implements CollapseInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: CollapseOptions; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: CollapseOptions); + _init(): void; + collapse(): void; + expand(): void; + toggle(): void; +} +export declare function initCollapses(): void; +export default Collapse; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts.map new file mode 100644 index 0000000..a530d7f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAQhD,cAAM,QAAS,YAAW,iBAAiB;IACvC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,eAAyB;IAStC,KAAK;IAgBL,QAAQ;IAWR,MAAM;IAWN,MAAM;CAST;AAED,wBAAgB,aAAa,SAmB5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/index.js b/node_modules/flowbite/lib/cjs/components/collapse/index.js new file mode 100644 index 0000000..2ff4a0d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/index.js @@ -0,0 +1,98 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initCollapses = void 0; +var Default = { + onCollapse: function () { }, + onExpand: function () { }, + onToggle: function () { }, +}; +var Collapse = /** @class */ (function () { + function Collapse(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Collapse.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + if (this._triggerEl.hasAttribute('aria-expanded')) { + this._visible = + this._triggerEl.getAttribute('aria-expanded') === 'true'; + } + else { + // fix until v2 not to break previous single collapses which became dismiss + this._visible = !this._targetEl.classList.contains('hidden'); + } + this._triggerEl.addEventListener('click', function () { + _this.toggle(); + }); + } + }; + Collapse.prototype.collapse = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onCollapse(this); + }; + Collapse.prototype.expand = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onExpand(this); + }; + Collapse.prototype.toggle = function () { + if (this._visible) { + this.collapse(); + } + else { + this.expand(); + } + // callback function + this._options.onToggle(this); + }; + return Collapse; +}()); +function initCollapses() { + document + .querySelectorAll('[data-collapse-toggle]') + .forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-collapse-toggle'); + var $targetEl = document.getElementById(targetId); + // check if the target element exists + if ($targetEl) { + new Collapse($targetEl, $triggerEl); + } + else { + console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); + } + }); +} +exports.initCollapses = initCollapses; +if (typeof window !== 'undefined') { + window.Collapse = Collapse; + window.initCollapses = initCollapses; +} +exports.default = Collapse; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/index.js.map b/node_modules/flowbite/lib/cjs/components/collapse/index.js.map new file mode 100644 index 0000000..d16391e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/collapse/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts b/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts new file mode 100644 index 0000000..326fc39 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts @@ -0,0 +1,12 @@ +import { CollapseOptions } from './types'; +export declare interface CollapseInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: CollapseOptions; + _visible: boolean; + _init(): void; + collapse(): void; + expand(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts.map new file mode 100644 index 0000000..cdf74c2 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE1C,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAElB,KAAK,IAAI,IAAI,CAAC;IACd,QAAQ,IAAI,IAAI,CAAC;IACjB,MAAM,IAAI,IAAI,CAAC;IACf,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/interface.js b/node_modules/flowbite/lib/cjs/components/collapse/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/interface.js.map b/node_modules/flowbite/lib/cjs/components/collapse/interface.js.map new file mode 100644 index 0000000..b82a2f4 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/collapse/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts b/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts new file mode 100644 index 0000000..3f3094e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts @@ -0,0 +1,7 @@ +import { CollapseInterface } from './interface'; +export declare type CollapseOptions = { + onCollapse?: (collapse: CollapseInterface) => void; + onExpand?: (collapse: CollapseInterface) => void; + onToggle?: (collapse: CollapseInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts.map new file mode 100644 index 0000000..ba058f8 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACnD,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACjD,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACpD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/types.js b/node_modules/flowbite/lib/cjs/components/collapse/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/collapse/types.js.map b/node_modules/flowbite/lib/cjs/components/collapse/types.js.map new file mode 100644 index 0000000..c1e2361 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/collapse/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/collapse/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/index.d.ts b/node_modules/flowbite/lib/cjs/components/dial/index.d.ts new file mode 100644 index 0000000..c333938 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/index.d.ts @@ -0,0 +1,23 @@ +import type { DialOptions, DialTriggerType } from './types'; +import { DialInterface } from './interface'; +declare class Dial implements DialInterface { + _parentEl: HTMLElement; + _triggerEl: HTMLElement; + _targetEl: HTMLElement; + _options: DialOptions; + _visible: boolean; + constructor(parentEl?: HTMLElement | null, triggerEl?: HTMLElement | null, targetEl?: HTMLElement | null, options?: DialOptions); + _init(): void; + hide(): void; + show(): void; + toggle(): void; + isHidden(): boolean; + isVisible(): boolean; + _getTriggerEventTypes(triggerType: DialTriggerType): { + showEvents: string[]; + hideEvents: string[]; + }; +} +export declare function initDials(): void; +export default Dial; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/dial/index.d.ts.map new file mode 100644 index 0000000..1b1cd71 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAS5C,cAAM,IAAK,YAAW,aAAa;IAC/B,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,WAAqB;IAUlC,KAAK;IAuBL,IAAI;IAWJ,IAAI;IAWJ,MAAM;IAQN,QAAQ;IAIR,SAAS;IAIT,qBAAqB,CAAC,WAAW,EAAE,eAAe;;;;CAwBrD;AAED,wBAAgB,SAAS,SAgCxB;AAOD,eAAe,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/index.js b/node_modules/flowbite/lib/cjs/components/dial/index.js new file mode 100644 index 0000000..7d78f95 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/index.js @@ -0,0 +1,142 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initDials = void 0; +var Default = { + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dial = /** @class */ (function () { + function Dial(parentEl, triggerEl, targetEl, options) { + if (parentEl === void 0) { parentEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._parentEl = parentEl; + this._triggerEl = triggerEl; + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Dial.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); + triggerEventTypes.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEventTypes.hideEvents.forEach(function (ev) { + _this._parentEl.addEventListener(ev, function () { + if (!_this._parentEl.matches(':hover')) { + _this.hide(); + } + }); + }); + } + }; + Dial.prototype.hide = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Dial.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dial.prototype.toggle = function () { + if (this._visible) { + this.hide(); + } + else { + this.show(); + } + }; + Dial.prototype.isHidden = function () { + return !this._visible; + }; + Dial.prototype.isVisible = function () { + return this._visible; + }; + Dial.prototype._getTriggerEventTypes = function (triggerType) { + switch (triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + return Dial; +}()); +function initDials() { + document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { + var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); + if ($triggerEl) { + var dialId = $triggerEl.getAttribute('data-dial-toggle'); + var $dialEl = document.getElementById(dialId); + if ($dialEl) { + var triggerType = $triggerEl.getAttribute('data-dial-trigger'); + new Dial($parentEl, $triggerEl, $dialEl, { + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); + } + } + else { + console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); + } + }); +} +exports.initDials = initDials; +if (typeof window !== 'undefined') { + window.Dial = Dial; + window.initDials = initDials; +} +exports.default = Dial; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/index.js.map b/node_modules/flowbite/lib/cjs/components/dial/index.js.map new file mode 100644 index 0000000..89a3d09 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dial/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts b/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts new file mode 100644 index 0000000..de0133b --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts @@ -0,0 +1,16 @@ +import { DialOptions, DialTriggerEventTypes, DialTriggerType } from './types'; +export declare interface DialInterface { + _parentEl: HTMLElement; + _triggerEl: HTMLElement; + _targetEl: HTMLElement; + _options: DialOptions; + _visible: boolean; + _init(): void; + isVisible(): boolean; + isHidden(): boolean; + hide(): void; + show(): void; + toggle(): void; + _getTriggerEventTypes(triggerType: DialTriggerType): DialTriggerEventTypes; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts.map new file mode 100644 index 0000000..cfa626e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE9E,MAAM,CAAC,OAAO,WAAW,aAAa;IAClC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAElB,KAAK,IAAI,IAAI,CAAC;IACd,SAAS,IAAI,OAAO,CAAC;IACrB,QAAQ,IAAI,OAAO,CAAC;IACpB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;IACf,qBAAqB,CAAC,WAAW,EAAE,eAAe,GAAG,qBAAqB,CAAC;CAC9E"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/interface.js b/node_modules/flowbite/lib/cjs/components/dial/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/interface.js.map b/node_modules/flowbite/lib/cjs/components/dial/interface.js.map new file mode 100644 index 0000000..83f6457 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dial/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/types.d.ts b/node_modules/flowbite/lib/cjs/components/dial/types.d.ts new file mode 100644 index 0000000..2f4877c --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/types.d.ts @@ -0,0 +1,13 @@ +import { DialInterface } from './interface'; +export declare type DialTriggerType = 'click' | 'hover' | 'none'; +export declare type DialTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type DialOptions = { + triggerType?: DialTriggerType; + onShow?: (dial: DialInterface) => void; + onHide?: (dial: DialInterface) => void; + onToggle?: (dial: DialInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/dial/types.d.ts.map new file mode 100644 index 0000000..da04793 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEjE,MAAM,CAAC,OAAO,MAAM,qBAAqB,GAAG;IACxC,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,WAAW,GAAG;IAC9B,WAAW,CAAC,EAAE,eAAe,CAAC;IAC9B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;CAC5C,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/types.js b/node_modules/flowbite/lib/cjs/components/dial/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dial/types.js.map b/node_modules/flowbite/lib/cjs/components/dial/types.js.map new file mode 100644 index 0000000..0613f16 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dial/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dial/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts b/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts new file mode 100644 index 0000000..ac75c1d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts @@ -0,0 +1,13 @@ +import type { DismissOptions } from './types'; +import { DismissInterface } from './interface'; +declare class Dismiss implements DismissInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: DismissOptions; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: DismissOptions); + _init(): void; + hide(): void; +} +export declare function initDismisses(): void; +export default Dismiss; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts.map new file mode 100644 index 0000000..5df9d15 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAS/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;gBAGrB,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAQrC,KAAK;IAQL,IAAI;CAcP;AAED,wBAAgB,aAAa,SAa5B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/index.js b/node_modules/flowbite/lib/cjs/components/dismiss/index.js new file mode 100644 index 0000000..eb71eb9 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/index.js @@ -0,0 +1,68 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initDismisses = void 0; +var Default = { + transition: 'transition-opacity', + duration: 300, + timing: 'ease-out', + onHide: function () { }, +}; +var Dismiss = /** @class */ (function () { + function Dismiss(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Dismiss.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + this._triggerEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Dismiss.prototype.hide = function () { + var _this = this; + this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); + setTimeout(function () { + _this._targetEl.classList.add('hidden'); + }, this._options.duration); + // callback function + this._options.onHide(this, this._targetEl); + }; + return Dismiss; +}()); +function initDismisses() { + document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-dismiss-target'); + var $dismissEl = document.querySelector(targetId); + if ($dismissEl) { + new Dismiss($dismissEl, $triggerEl); + } + else { + console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); + } + }); +} +exports.initDismisses = initDismisses; +if (typeof window !== 'undefined') { + window.Dismiss = Dismiss; + window.initDismisses = initDismisses; +} +exports.default = Dismiss; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/index.js.map b/node_modules/flowbite/lib/cjs/components/dismiss/index.js.map new file mode 100644 index 0000000..080b679 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dismiss/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAIA,IAAM,OAAO,GAAmB;IAC5B,UAAU,EAAE,oBAAoB;IAChC,QAAQ,EAAE,GAAG;IACb,MAAM,EAAE,UAAU;IAClB,MAAM,EAAE,cAAO,CAAC;CACnB,CAAC;AAEF;IAKI,iBACI,QAAmC,EACnC,SAAoC,EACpC,OAAiC;QAFjC,yBAAA,EAAA,eAAmC;QACnC,0BAAA,EAAA,gBAAoC;QACpC,wBAAA,EAAA,iBAAiC;QAEjC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,QAAQ,yBAAQ,OAAO,GAAK,OAAO,CAAE,CAAC;QAC3C,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,uBAAK,GAAL;QAAA,iBAMC;QALG,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,OAAO,EAAE;gBACtC,KAAI,CAAC,IAAI,EAAE,CAAC;YAChB,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,sBAAI,GAAJ;QAAA,iBAaC;QAZG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CACxB,IAAI,CAAC,QAAQ,CAAC,UAAU,EACxB,mBAAY,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAE,EACpC,IAAI,CAAC,QAAQ,CAAC,MAAM,EACpB,WAAW,CACd,CAAC;QACF,UAAU,CAAC;YACP,KAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAE3B,oBAAoB;QACpB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACL,cAAC;AAAD,CAAC,AAtCD,IAsCC;AAED,SAAgB,aAAa;IACzB,QAAQ,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC,OAAO,CAAC,UAAC,UAAU;QAClE,IAAM,QAAQ,GAAG,UAAU,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC;QAChE,IAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAEpD,IAAI,UAAU,EAAE;YACZ,IAAI,OAAO,CAAC,UAAyB,EAAE,UAAyB,CAAC,CAAC;SACrE;aAAM;YACH,OAAO,CAAC,KAAK,CACT,wCAAgC,QAAQ,uEAAmE,CAC9G,CAAC;SACL;IACL,CAAC,CAAC,CAAC;AACP,CAAC;AAbD,sCAaC;AAED,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;IAC/B,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,MAAM,CAAC,aAAa,GAAG,aAAa,CAAC;CACxC;AAED,kBAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts b/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts new file mode 100644 index 0000000..e9b8f51 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts @@ -0,0 +1,9 @@ +import { DismissOptions } from './types'; +export declare interface DismissInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: DismissOptions; + _init(): void; + hide(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts.map new file mode 100644 index 0000000..c9c3828 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IAEzB,KAAK,IAAI,IAAI,CAAC;IACd,IAAI,IAAI,IAAI,CAAC;CAChB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/interface.js b/node_modules/flowbite/lib/cjs/components/dismiss/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/interface.js.map b/node_modules/flowbite/lib/cjs/components/dismiss/interface.js.map new file mode 100644 index 0000000..6b664d5 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dismiss/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts b/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts new file mode 100644 index 0000000..c659c00 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts @@ -0,0 +1,8 @@ +import { DismissInterface } from './interface'; +export declare type DismissOptions = { + transition?: string; + duration?: number; + timing?: string; + onHide?: (dismiss: DismissInterface, targetEl: HTMLElement) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts.map new file mode 100644 index 0000000..2ccb43e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,WAAW,KAAK,IAAI,CAAC;CACvE,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/types.js b/node_modules/flowbite/lib/cjs/components/dismiss/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dismiss/types.js.map b/node_modules/flowbite/lib/cjs/components/dismiss/types.js.map new file mode 100644 index 0000000..8ceeeb5 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dismiss/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dismiss/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts b/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts new file mode 100644 index 0000000..eecffb5 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts @@ -0,0 +1,21 @@ +import type { DrawerOptions, PlacementClasses } from './types'; +import { DrawerInterface } from './interface'; +declare class Drawer implements DrawerInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DrawerOptions; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, options?: DrawerOptions); + _init(): void; + hide(): void; + show(): void; + toggle(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _getPlacementClasses(placement: string): PlacementClasses; + isHidden(): boolean; + isVisible(): boolean; +} +export declare function initDrawers(): void; +export default Drawer; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts.map new file mode 100644 index 0000000..9776f54 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAkB,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAe9C,cAAM,MAAO,YAAW,eAAe;IACnC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,aAAuB;IAQpC,KAAK;IAwBL,IAAI;IA+CJ,IAAI;IA8CJ,MAAM;IAQN,eAAe;IAcf,kBAAkB;IAMlB,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB;IAyCzD,QAAQ;IAIR,SAAS;CAGZ;AAQD,wBAAgB,WAAW,SA+H1B;AAOD,eAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/index.js b/node_modules/flowbite/lib/cjs/components/drawer/index.js new file mode 100644 index 0000000..e57682d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/index.js @@ -0,0 +1,314 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initDrawers = void 0; +var Default = { + placement: 'left', + bodyScrolling: false, + backdrop: true, + edge: false, + edgeOffset: 'bottom-[60px]', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Drawer = /** @class */ (function () { + function Drawer(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Drawer.prototype._init = function () { + var _this = this; + // set initial accessibility attributes + if (this._targetEl) { + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.classList.add('transition-transform'); + } + // set base placement classes + this._getPlacementClasses(this._options.placement).base.map(function (c) { + _this._targetEl.classList.add(c); + }); + // add keyboard event listener to document + document.addEventListener('keydown', function (event) { + if (event.key === 'Escape') { + // if 'Escape' key is pressed + if (_this.isVisible()) { + // if the Drawer is visible + _this.hide(); // hide the Drawer + } + } + }); + }; + Drawer.prototype.hide = function () { + var _this = this; + // based on the edge option show placement classes + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + // enable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.remove('overflow-hidden'); + } + // destroy backdrop + if (this._options.backdrop) { + this._destroyBackdropEl(); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Drawer.prototype.show = function () { + var _this = this; + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + // disable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.add('overflow-hidden'); + } + // show backdrop + if (this._options.backdrop) { + this._createBackdrop(); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Drawer.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Drawer.prototype._createBackdrop = function () { + var _a; + var _this = this; + if (!this._visible) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('drawer-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + backdropEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Drawer.prototype._destroyBackdropEl = function () { + if (this._visible) { + document.querySelector('[drawer-backdrop]').remove(); + } + }; + Drawer.prototype._getPlacementClasses = function (placement) { + switch (placement) { + case 'top': + return { + base: ['top-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['-translate-y-full'], + }; + case 'right': + return { + base: ['right-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-x-full'], + }; + case 'bottom': + return { + base: ['bottom-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['translate-y-full'], + }; + case 'left': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + case 'bottom-edge': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-y-full', this._options.edgeOffset], + }; + default: + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + } + }; + Drawer.prototype.isHidden = function () { + return !this._visible; + }; + Drawer.prototype.isVisible = function () { + return this._visible; + }; + return Drawer; +}()); +var getDrawerInstance = function (id, instances) { + if (instances.some(function (drawerInstance) { return drawerInstance.id === id; })) { + return instances.find(function (drawerInstance) { return drawerInstance.id === id; }); + } +}; +function initDrawers() { + var drawerInstances = []; + document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { + // mandatory + var drawerId = $triggerEl.getAttribute('data-drawer-target'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + // optional + var placement = $triggerEl.getAttribute('data-drawer-placement'); + var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); + var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); + var edge = $triggerEl.getAttribute('data-drawer-edge'); + var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); + if (!getDrawerInstance(drawerId, drawerInstances)) { + drawerInstances.push({ + id: drawerId, + object: new Drawer($drawerEl, { + placement: placement ? placement : Default.placement, + bodyScrolling: bodyScrolling + ? bodyScrolling === 'true' + ? true + : false + : Default.bodyScrolling, + backdrop: backdrop + ? backdrop === 'true' + ? true + : false + : Default.backdrop, + edge: edge + ? edge === 'true' + ? true + : false + : Default.edge, + edgeOffset: edgeOffset + ? edgeOffset + : Default.edgeOffset, + }), + }); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_1 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_1) { + $triggerEl.addEventListener('click', function () { + drawer_1.object.toggle(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document + .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') + .forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') + ? $triggerEl.getAttribute('data-drawer-dismiss') + : $triggerEl.getAttribute('data-drawer-hide'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_2 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_2) { + $triggerEl.addEventListener('click', function () { + drawer_2.object.hide(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); + } + }); + document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-show'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_3 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_3) { + $triggerEl.addEventListener('click', function () { + drawer_3.object.show(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); +} +exports.initDrawers = initDrawers; +if (typeof window !== 'undefined') { + window.Drawer = Drawer; + window.initDrawers = initDrawers; +} +exports.default = Drawer; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/index.js.map b/node_modules/flowbite/lib/cjs/components/drawer/index.js.map new file mode 100644 index 0000000..14dfd5f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/drawer/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts b/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts new file mode 100644 index 0000000..a69c8f1 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts @@ -0,0 +1,17 @@ +import { DrawerOptions, PlacementClasses } from './types'; +export declare interface DrawerInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DrawerOptions; + _visible: boolean; + _init(): void; + isVisible(): boolean; + isHidden(): boolean; + hide(): void; + show(): void; + toggle(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _getPlacementClasses(placement: string): PlacementClasses; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts.map new file mode 100644 index 0000000..367b357 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE1D,MAAM,CAAC,OAAO,WAAW,eAAe;IAEpC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,OAAO,CAAC;IAGlB,KAAK,IAAI,IAAI,CAAC;IACd,SAAS,IAAI,OAAO,CAAC;IACrB,QAAQ,IAAI,OAAO,CAAC;IACpB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;IACf,eAAe,IAAI,IAAI,CAAC;IACxB,kBAAkB,IAAI,IAAI,CAAC;IAC3B,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,CAAC;CAC7D"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/interface.js b/node_modules/flowbite/lib/cjs/components/drawer/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/interface.js.map b/node_modules/flowbite/lib/cjs/components/drawer/interface.js.map new file mode 100644 index 0000000..91cef96 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/drawer/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts b/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts new file mode 100644 index 0000000..abc766f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts @@ -0,0 +1,22 @@ +import { DrawerInterface } from './interface'; +export declare type DrawerOptions = { + placement?: string; + bodyScrolling?: boolean; + backdrop?: boolean; + edge?: boolean; + edgeOffset?: string; + backdropClasses?: string; + onShow?: (drawer: DrawerInterface) => void; + onHide?: (drawer: DrawerInterface) => void; + onToggle?: (drawer: DrawerInterface) => void; +}; +export declare type PlacementClasses = { + base: string[]; + active: string[]; + inactive: string[]; +}; +export declare type DrawerInstance = { + id: string; + object: DrawerInterface; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts.map new file mode 100644 index 0000000..ee84e44 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAE9C,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;IAC3C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;IAC3C,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;CAChD,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,gBAAgB,GAAG;IACnC,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,eAAe,CAAC;CAC3B,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/types.js b/node_modules/flowbite/lib/cjs/components/drawer/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/drawer/types.js.map b/node_modules/flowbite/lib/cjs/components/drawer/types.js.map new file mode 100644 index 0000000..b9d5343 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/drawer/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/drawer/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts b/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts new file mode 100644 index 0000000..d0efbf5 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts @@ -0,0 +1,29 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { DropdownOptions } from './types'; +import { DropdownInterface } from './interface'; +declare class Dropdown implements DropdownInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DropdownOptions; + _visible: boolean; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + constructor(targetElement?: HTMLElement | null, triggerElement?: HTMLElement | null, options?: DropdownOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + toggle(): void; + isVisible(): boolean; + show(): void; + hide(): void; +} +export declare function initDropdowns(): void; +export default Dropdown; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts.map new file mode 100644 index 0000000..51a311c --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAchD,cAAM,QAAS,YAAW,iBAAiB;IACvC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;gBAG3D,aAAa,GAAE,WAAW,GAAG,IAAW,EACxC,cAAc,GAAE,WAAW,GAAG,IAAW,EACzC,OAAO,GAAE,eAAyB;IAUtC,KAAK;IAML,oBAAoB;IA+CpB,qBAAqB;IAiBrB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IA+BpD,iBAAiB;;;;IAyBjB,MAAM;IASN,SAAS;IAIT,IAAI;IAuBJ,IAAI;CAoBP;AAED,wBAAgB,aAAa,SAmD5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/index.js b/node_modules/flowbite/lib/cjs/components/dropdown/index.js new file mode 100644 index 0000000..1278c0c --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/index.js @@ -0,0 +1,254 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initDropdowns = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = require("@popperjs/core"); +var Default = { + placement: 'bottom', + triggerType: 'click', + offsetSkidding: 0, + offsetDistance: 10, + delay: 300, + ignoreClickOutsideClass: false, + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dropdown = /** @class */ (function () { + function Dropdown(targetElement, triggerElement, options) { + if (targetElement === void 0) { targetElement = null; } + if (triggerElement === void 0) { triggerElement = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetElement; + this._triggerEl = triggerElement; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Dropdown.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Dropdown.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + // click event handling for trigger element + if (this._options.triggerType === 'click') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.toggle(); + }); + }); + } + // hover event handling for trigger element + if (this._options.triggerType === 'hover') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + if (ev === 'click') { + _this.toggle(); + } + else { + setTimeout(function () { + _this.show(); + }, _this._options.delay); + } + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + }); + } + }; + Dropdown.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [ + this._options.offsetSkidding, + this._options.offsetDistance, + ], + }, + }, + ], + }); + }; + Dropdown.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + // Ignore clicks on the trigger element (ie. a datepicker input) + var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; + var isIgnored = false; + if (ignoreClickOutsideClass) { + var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); + ignoredClickOutsideEls.forEach(function (el) { + if (el.contains(clickedEl)) { + isIgnored = true; + return; + } + }); + } + // Ignore clicks on the target element (ie. dropdown itself) + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + !isIgnored && + this.isVisible()) { + this.hide(); + } + }; + Dropdown.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'click'], + hideEvents: ['mouseleave'], + }; + case 'click': + return { + showEvents: ['click'], + hideEvents: [], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['click'], + hideEvents: [], + }; + } + }; + Dropdown.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Dropdown.prototype.isVisible = function () { + return this._visible; + }; + Dropdown.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + this._targetEl.classList.add('block'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + this._setupClickOutsideListener(); + // Update its position + this._popperInstance.update(); + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dropdown.prototype.hide = function () { + this._targetEl.classList.remove('block'); + this._targetEl.classList.add('hidden'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + this._visible = false; + this._removeClickOutsideListener(); + // callback function + this._options.onHide(this); + }; + return Dropdown; +}()); +function initDropdowns() { + document + .querySelectorAll('[data-dropdown-toggle]') + .forEach(function ($triggerEl) { + var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); + var $dropdownEl = document.getElementById(dropdownId); + if ($dropdownEl) { + var placement = $triggerEl.getAttribute('data-dropdown-placement'); + var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); + var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); + var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); + var delay = $triggerEl.getAttribute('data-dropdown-delay'); + var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); + new Dropdown($dropdownEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + offsetSkidding: offsetSkidding + ? parseInt(offsetSkidding) + : Default.offsetSkidding, + offsetDistance: offsetDistance + ? parseInt(offsetDistance) + : Default.offsetDistance, + delay: delay ? parseInt(delay) : Default.delay, + ignoreClickOutsideClass: ignoreClickOutsideClass + ? ignoreClickOutsideClass + : Default.ignoreClickOutsideClass, + }); + } + else { + console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); + } + }); +} +exports.initDropdowns = initDropdowns; +if (typeof window !== 'undefined') { + window.Dropdown = Dropdown; + window.initDropdowns = initDropdowns; +} +exports.default = Dropdown; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/index.js.map b/node_modules/flowbite/lib/cjs/components/dropdown/index.js.map new file mode 100644 index 0000000..e52532f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dropdown/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts b/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts new file mode 100644 index 0000000..95a1241 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts @@ -0,0 +1,22 @@ +import { DropdownOptions, DropdownTriggerType, DropdownTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface DropdownInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DropdownOptions; + _visible: boolean; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _init(): void; + _createPopperInstance(): PopperInstance; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: DropdownTriggerType): DropdownTriggerEventTypes; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts.map new file mode 100644 index 0000000..eef9c76 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,mBAAmB,EACnB,yBAAyB,EAC5B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAE/D,KAAK,IAAI,IAAI,CAAC;IACd,qBAAqB,IAAI,cAAc,CAAC;IACxC,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,mBAAmB,GACjC,yBAAyB,CAAC;IAC7B,SAAS,IAAI,OAAO,CAAC;IACrB,MAAM,IAAI,IAAI,CAAC;IACf,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;CAChB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/interface.js b/node_modules/flowbite/lib/cjs/components/dropdown/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/interface.js.map b/node_modules/flowbite/lib/cjs/components/dropdown/interface.js.map new file mode 100644 index 0000000..d4c8eb1 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dropdown/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts b/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts new file mode 100644 index 0000000..47c79fb --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts @@ -0,0 +1,19 @@ +import { DropdownInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type DropdownTriggerType = 'click' | 'hover' | 'none'; +export declare type DropdownTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type DropdownOptions = { + placement?: Placement; + triggerType?: DropdownTriggerType; + offsetSkidding?: number; + offsetDistance?: number; + ignoreClickOutsideClass?: string | boolean; + delay?: number; + onShow?: (tooltip: DropdownInterface) => void; + onHide?: (tooltip: DropdownInterface) => void; + onToggle?: (tooltip: DropdownInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts.map new file mode 100644 index 0000000..f74ca43 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,mBAAmB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAErE,MAAM,CAAC,OAAO,MAAM,yBAAyB,GAAG;IAC5C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,mBAAmB,CAAC;IAClC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,uBAAuB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC9C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC9C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACnD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/types.js b/node_modules/flowbite/lib/cjs/components/dropdown/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/dropdown/types.js.map b/node_modules/flowbite/lib/cjs/components/dropdown/types.js.map new file mode 100644 index 0000000..de3d7a3 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/dropdown/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dropdown/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/index.d.ts b/node_modules/flowbite/lib/cjs/components/index.d.ts new file mode 100644 index 0000000..3d22df6 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/index.d.ts @@ -0,0 +1,2 @@ +export declare function initFlowbite(): void; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/index.d.ts.map new file mode 100644 index 0000000..69c6ef6 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAYA,wBAAgB,YAAY,SAY3B"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/index.js b/node_modules/flowbite/lib/cjs/components/index.js new file mode 100644 index 0000000..b099106 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/index.js @@ -0,0 +1,32 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initFlowbite = void 0; +var accordion_1 = require("./accordion"); +var carousel_1 = require("./carousel"); +var collapse_1 = require("./collapse"); +var dial_1 = require("./dial"); +var dismiss_1 = require("./dismiss"); +var drawer_1 = require("./drawer"); +var dropdown_1 = require("./dropdown"); +var modal_1 = require("./modal"); +var popover_1 = require("./popover"); +var tabs_1 = require("./tabs"); +var tooltip_1 = require("./tooltip"); +function initFlowbite() { + (0, accordion_1.initAccordions)(); + (0, collapse_1.initCollapses)(); + (0, carousel_1.initCarousels)(); + (0, dismiss_1.initDismisses)(); + (0, dropdown_1.initDropdowns)(); + (0, modal_1.initModals)(); + (0, drawer_1.initDrawers)(); + (0, tabs_1.initTabs)(); + (0, tooltip_1.initTooltips)(); + (0, popover_1.initPopovers)(); + (0, dial_1.initDials)(); +} +exports.initFlowbite = initFlowbite; +if (typeof window !== 'undefined') { + window.initFlowbite = initFlowbite; +} +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/index.js.map b/node_modules/flowbite/lib/cjs/components/index.js.map new file mode 100644 index 0000000..2d35df4 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":";;;AAAA,yCAA6C;AAC7C,uCAA2C;AAC3C,uCAA2C;AAC3C,+BAAmC;AACnC,qCAA0C;AAC1C,mCAAuC;AACvC,uCAA2C;AAC3C,iCAAqC;AACrC,qCAAyC;AACzC,+BAAkC;AAClC,qCAAyC;AAEzC,SAAgB,YAAY;IACxB,IAAA,0BAAc,GAAE,CAAC;IACjB,IAAA,wBAAa,GAAE,CAAC;IAChB,IAAA,wBAAa,GAAE,CAAC;IAChB,IAAA,uBAAa,GAAE,CAAC;IAChB,IAAA,wBAAa,GAAE,CAAC;IAChB,IAAA,kBAAU,GAAE,CAAC;IACb,IAAA,oBAAW,GAAE,CAAC;IACd,IAAA,eAAQ,GAAE,CAAC;IACX,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,sBAAY,GAAE,CAAC;IACf,IAAA,gBAAS,GAAE,CAAC;AAChB,CAAC;AAZD,oCAYC;AAED,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;IAC/B,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;CACtC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/index.d.ts b/node_modules/flowbite/lib/cjs/components/modal/index.d.ts new file mode 100644 index 0000000..be91df7 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/index.d.ts @@ -0,0 +1,26 @@ +import type { ModalOptions } from './types'; +import { ModalInterface } from './interface'; +declare class Modal implements ModalInterface { + _targetEl: HTMLElement | null; + _options: ModalOptions; + _isHidden: boolean; + _backdropEl: HTMLElement | null; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + constructor(targetEl?: HTMLElement | null, options?: ModalOptions); + _init(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _setupModalCloseEventListeners(): void; + _removeModalCloseEventListeners(): void; + _handleOutsideClick(target: EventTarget): void; + _getPlacementClasses(): string[]; + toggle(): void; + show(): void; + hide(): void; + isVisible(): boolean; + isHidden(): boolean; +} +export declare function initModals(): void; +export default Modal; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/modal/index.d.ts.map new file mode 100644 index 0000000..8c64578 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAiB,YAAY,EAAE,MAAM,SAAS,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAa7C,cAAM,KAAM,YAAW,cAAc;IACjC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,QAAQ,EAAE,YAAY,CAAC;IACvB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;gBAGtD,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,YAAsB;IASnC,KAAK;IAQL,eAAe;IAYf,kBAAkB;IAMlB,8BAA8B;IAwB9B,+BAA+B;IAe/B,mBAAmB,CAAC,MAAM,EAAE,WAAW;IASvC,oBAAoB;IA+BpB,MAAM;IAWN,IAAI;IAuBJ,IAAI;IAsBJ,SAAS;IAIT,QAAQ;CAGX;AASD,wBAAgB,UAAU,SAgIzB;AAOD,eAAe,KAAK,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/index.js b/node_modules/flowbite/lib/cjs/components/modal/index.js new file mode 100644 index 0000000..b4e98f0 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/index.js @@ -0,0 +1,274 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initModals = void 0; +var Default = { + placement: 'center', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + backdrop: 'dynamic', + closable: true, + onHide: function () { }, + onShow: function () { }, + onToggle: function () { }, +}; +var Modal = /** @class */ (function () { + function Modal(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._isHidden = true; + this._backdropEl = null; + this._init(); + } + Modal.prototype._init = function () { + var _this = this; + if (this._targetEl) { + this._getPlacementClasses().map(function (c) { + _this._targetEl.classList.add(c); + }); + } + }; + Modal.prototype._createBackdrop = function () { + var _a; + if (this._isHidden) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('modal-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + this._backdropEl = backdropEl; + } + }; + Modal.prototype._destroyBackdropEl = function () { + if (!this._isHidden) { + document.querySelector('[modal-backdrop]').remove(); + } + }; + Modal.prototype._setupModalCloseEventListeners = function () { + var _this = this; + if (this._options.backdrop === 'dynamic') { + this._clickOutsideEventListener = function (ev) { + _this._handleOutsideClick(ev.target); + }; + this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); + } + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._removeModalCloseEventListeners = function () { + if (this._options.backdrop === 'dynamic') { + this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); + } + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._handleOutsideClick = function (target) { + if (target === this._targetEl || + (target === this._backdropEl && this.isVisible())) { + this.hide(); + } + }; + Modal.prototype._getPlacementClasses = function () { + switch (this._options.placement) { + // top + case 'top-left': + return ['justify-start', 'items-start']; + case 'top-center': + return ['justify-center', 'items-start']; + case 'top-right': + return ['justify-end', 'items-start']; + // center + case 'center-left': + return ['justify-start', 'items-center']; + case 'center': + return ['justify-center', 'items-center']; + case 'center-right': + return ['justify-end', 'items-center']; + // bottom + case 'bottom-left': + return ['justify-start', 'items-end']; + case 'bottom-center': + return ['justify-center', 'items-end']; + case 'bottom-right': + return ['justify-end', 'items-end']; + default: + return ['justify-center', 'items-center']; + } + }; + Modal.prototype.toggle = function () { + if (this._isHidden) { + this.show(); + } + else { + this.hide(); + } + // callback function + this._options.onToggle(this); + }; + Modal.prototype.show = function () { + if (this.isHidden) { + this._targetEl.classList.add('flex'); + this._targetEl.classList.remove('hidden'); + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + this._createBackdrop(); + this._isHidden = false; + // prevent body scroll + document.body.classList.add('overflow-hidden'); + // Add keyboard event listener to the document + if (this._options.closable) { + this._setupModalCloseEventListeners(); + } + // callback function + this._options.onShow(this); + } + }; + Modal.prototype.hide = function () { + if (this.isVisible) { + this._targetEl.classList.add('hidden'); + this._targetEl.classList.remove('flex'); + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + this._destroyBackdropEl(); + this._isHidden = true; + // re-apply body scroll + document.body.classList.remove('overflow-hidden'); + if (this._options.closable) { + this._removeModalCloseEventListeners(); + } + // callback function + this._options.onHide(this); + } + }; + Modal.prototype.isVisible = function () { + return !this._isHidden; + }; + Modal.prototype.isHidden = function () { + return this._isHidden; + }; + return Modal; +}()); +var getModalInstance = function (id, instances) { + if (instances.some(function (modalInstance) { return modalInstance.id === id; })) { + return instances.find(function (modalInstance) { return modalInstance.id === id; }); + } + return null; +}; +function initModals() { + var modalInstances = []; + // initiate modal based on data-modal-target + document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-target'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + if (!getModalInstance(modalId, modalInstances)) { + modalInstances.push({ + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); + } + }); + // support pre v1.6.0 data-modal-toggle initialization + document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-toggle'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + var modal_1 = getModalInstance(modalId, modalInstances); + if (!modal_1) { + modal_1 = { + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }; + modalInstances.push(modal_1); + } + $triggerEl.addEventListener('click', function () { + modal_1.object.toggle(); + }); + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); + } + }); + // show modal on click if exists based on id + document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-show'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_2 = getModalInstance(modalId, modalInstances); + if (modal_2) { + $triggerEl.addEventListener('click', function () { + if (modal_2.object.isHidden) { + modal_2.object.show(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); + } + }); + // hide modal on click if exists based on id + document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-hide'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_3 = getModalInstance(modalId, modalInstances); + if (modal_3) { + $triggerEl.addEventListener('click', function () { + if (modal_3.object.isVisible) { + modal_3.object.hide(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); + } + }); +} +exports.initModals = initModals; +if (typeof window !== 'undefined') { + window.Modal = Modal; + window.initModals = initModals; +} +exports.default = Modal; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/index.js.map b/node_modules/flowbite/lib/cjs/components/modal/index.js.map new file mode 100644 index 0000000..716af94 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/modal/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts b/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts new file mode 100644 index 0000000..2df722b --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts @@ -0,0 +1,21 @@ +import { ModalOptions } from './types'; +export declare interface ModalInterface { + _targetEl: HTMLElement | null; + _options: ModalOptions; + _isHidden: boolean; + _backdropEl: HTMLElement | null; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _init(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _setupModalCloseEventListeners(): void; + _handleOutsideClick(target: EventTarget): void; + _getPlacementClasses(): string[]; + toggle(): void; + show(): void; + hide(): void; + isHidden(): boolean; + isVisible(): boolean; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts.map new file mode 100644 index 0000000..6fa46f7 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,CAAC,OAAO,WAAW,cAAc;IAEnC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAG9B,QAAQ,EAAE,YAAY,CAAC;IAGvB,SAAS,EAAE,OAAO,CAAC;IAGnB,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAEhC,0BAA0B,EAAE,kCAAkC,CAAC;IAE/D,qBAAqB,EAAE,kCAAkC,CAAC;IAG1D,KAAK,IAAI,IAAI,CAAC;IAGd,eAAe,IAAI,IAAI,CAAC;IAGxB,kBAAkB,IAAI,IAAI,CAAC;IAG3B,8BAA8B,IAAI,IAAI,CAAC;IAGvC,mBAAmB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAG/C,oBAAoB,IAAI,MAAM,EAAE,CAAC;IAGjC,MAAM,IAAI,IAAI,CAAC;IAGf,IAAI,IAAI,IAAI,CAAC;IAGb,IAAI,IAAI,IAAI,CAAC;IAGb,QAAQ,IAAI,OAAO,CAAC;IAGpB,SAAS,IAAI,OAAO,CAAC;CACxB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/interface.js b/node_modules/flowbite/lib/cjs/components/modal/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/interface.js.map b/node_modules/flowbite/lib/cjs/components/modal/interface.js.map new file mode 100644 index 0000000..5de1079 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/modal/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/types.d.ts b/node_modules/flowbite/lib/cjs/components/modal/types.d.ts new file mode 100644 index 0000000..5dccfb1 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/types.d.ts @@ -0,0 +1,17 @@ +import { ModalInterface } from './interface'; +export declare type modalBackdrop = 'static' | 'dynamic'; +export declare type modalPlacement = 'top-left' | 'top-center' | 'top-right' | 'center-left' | 'center' | 'center-right' | 'bottom-left' | 'bottom-center' | 'bottom-right'; +export declare type ModalOptions = { + placement?: modalPlacement; + backdropClasses?: string; + backdrop?: modalBackdrop; + closable?: boolean; + onShow?: (modal: ModalInterface) => void; + onHide?: (modal: ModalInterface) => void; + onToggle?: (modal: ModalInterface) => void; +}; +export declare type ModalInstance = { + id: string; + object: ModalInterface; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/modal/types.d.ts.map new file mode 100644 index 0000000..2754732 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG,QAAQ,GAAG,SAAS,CAAC;AACzD,MAAM,CAAC,OAAO,MAAM,cAAc,GAC5B,UAAU,GACV,YAAY,GACZ,WAAW,GACX,aAAa,GACb,QAAQ,GACR,cAAc,GACd,aAAa,GACb,eAAe,GACf,cAAc,CAAC;AAErB,MAAM,CAAC,OAAO,MAAM,YAAY,GAAG;IAC/B,SAAS,CAAC,EAAE,cAAc,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IACzC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IACzC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;CAC9C,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,cAAc,CAAC;CAC1B,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/types.js b/node_modules/flowbite/lib/cjs/components/modal/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/modal/types.js.map b/node_modules/flowbite/lib/cjs/components/modal/types.js.map new file mode 100644 index 0000000..e049979 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/modal/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/modal/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/index.d.ts b/node_modules/flowbite/lib/cjs/components/popover/index.d.ts new file mode 100644 index 0000000..33732b6 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/index.d.ts @@ -0,0 +1,32 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { PopoverOptions } from './types'; +import { PopoverInterface } from './interface'; +declare class Popover implements PopoverInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: PopoverOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: PopoverOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +export declare function initPopovers(): void; +export default Popover; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/popover/index.d.ts.map new file mode 100644 index 0000000..67e916e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAW/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAC1D,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAUrC,KAAK;IAML,oBAAoB;IA6BpB,qBAAqB;IAcrB,iBAAiB;;;;IAyBjB,qBAAqB;IAarB,sBAAsB;IAQtB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IAYpD,SAAS;IAIT,MAAM;IASN,IAAI;IA6BJ,IAAI;CAyBP;AAED,wBAAgB,YAAY,SA2B3B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/index.js b/node_modules/flowbite/lib/cjs/components/popover/index.js new file mode 100644 index 0000000..fa0f48a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/index.js @@ -0,0 +1,222 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initPopovers = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = require("@popperjs/core"); +var Default = { + placement: 'top', + offset: 10, + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Popover = /** @class */ (function () { + function Popover(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Popover.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Popover.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + }); + }; + Popover.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, this._options.offset], + }, + }, + ], + }); + }; + Popover.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Popover.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Popover.prototype.isVisible = function () { + return this._visible; + }; + Popover.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Popover.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility to true + this._visible = true; + // callback function + this._options.onShow(this); + }; + Popover.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility to false + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Popover; +}()); +function initPopovers() { + document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { + var popoverID = $triggerEl.getAttribute('data-popover-target'); + var $popoverEl = document.getElementById(popoverID); + if ($popoverEl) { + var triggerType = $triggerEl.getAttribute('data-popover-trigger'); + var placement = $triggerEl.getAttribute('data-popover-placement'); + var offset = $triggerEl.getAttribute('data-popover-offset'); + new Popover($popoverEl, $triggerEl, { + placement: placement ? placement : Default.placement, + offset: offset ? parseInt(offset) : Default.offset, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); + } + }); +} +exports.initPopovers = initPopovers; +if (typeof window !== 'undefined') { + window.Popover = Popover; + window.initPopovers = initPopovers; +} +exports.default = Popover; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/index.js.map b/node_modules/flowbite/lib/cjs/components/popover/index.js.map new file mode 100644 index 0000000..54e2d46 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/popover/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts b/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts new file mode 100644 index 0000000..851a5a9 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts @@ -0,0 +1,22 @@ +import { PopoverOptions, PopoverTriggerType, PopoverTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface PopoverInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: PopoverOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: PopoverTriggerType): PopoverTriggerEventTypes; + isVisible(): boolean; + show(): void; + hide(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts.map new file mode 100644 index 0000000..8527eea --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,cAAc,EACd,kBAAkB,EAClB,wBAAwB,EAC3B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAE1D,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,qBAAqB,IAAI,IAAI,CAAC;IAC9B,sBAAsB,IAAI,IAAI,CAAC;IAC/B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,kBAAkB,GAChC,wBAAwB,CAAC;IAC5B,SAAS,IAAI,OAAO,CAAC;IACrB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/interface.js b/node_modules/flowbite/lib/cjs/components/popover/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/interface.js.map b/node_modules/flowbite/lib/cjs/components/popover/interface.js.map new file mode 100644 index 0000000..495553d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/popover/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/types.d.ts b/node_modules/flowbite/lib/cjs/components/popover/types.d.ts new file mode 100644 index 0000000..1b8512f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/types.d.ts @@ -0,0 +1,16 @@ +import { PopoverInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type PopoverTriggerType = 'click' | 'hover' | 'none'; +export declare type PopoverTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type PopoverOptions = { + placement?: Placement; + offset?: number; + triggerType?: PopoverTriggerType; + onShow?: (tooltip: PopoverInterface) => void; + onHide?: (tooltip: PopoverInterface) => void; + onToggle?: (tooltip: PopoverInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/popover/types.d.ts.map new file mode 100644 index 0000000..83d1cf6 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,kBAAkB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEpE,MAAM,CAAC,OAAO,MAAM,wBAAwB,GAAG;IAC3C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;CAClD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/types.js b/node_modules/flowbite/lib/cjs/components/popover/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/popover/types.js.map b/node_modules/flowbite/lib/cjs/components/popover/types.js.map new file mode 100644 index 0000000..8f2e0e4 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/popover/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/popover/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts b/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts new file mode 100644 index 0000000..fd62e63 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts @@ -0,0 +1,16 @@ +import type { TabItem, TabsOptions } from './types'; +import { TabsInterface } from './interface'; +declare class Tabs implements TabsInterface { + _items: TabItem[]; + _activeTab: TabItem; + _options: TabsOptions; + constructor(items?: TabItem[], options?: TabsOptions); + _init(): void; + getActiveTab(): TabItem; + _setActiveTab(tab: TabItem): void; + getTab(id: string): TabItem; + show(id: string, forceShow?: boolean): void; +} +export declare function initTabs(): void; +export default Tabs; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts.map new file mode 100644 index 0000000..bafbd71 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAW5C,cAAM,IAAK,YAAW,aAAa;IAC/B,MAAM,EAAE,OAAO,EAAE,CAAC;IAClB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,WAAW,CAAC;gBAEV,KAAK,GAAE,OAAO,EAAO,EAAE,OAAO,GAAE,WAAqB;IAOjE,KAAK;IAmBL,YAAY;IAIZ,aAAa,CAAC,GAAG,EAAE,OAAO;IAI1B,MAAM,CAAC,EAAE,EAAE,MAAM;IAIjB,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,UAAQ;CAmCrC;AAED,wBAAgB,QAAQ,SA0BvB;AAOD,eAAe,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/index.js b/node_modules/flowbite/lib/cjs/components/tabs/index.js new file mode 100644 index 0000000..94c6a31 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/index.js @@ -0,0 +1,115 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initTabs = void 0; +var Default = { + defaultTabId: null, + activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', + inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', + onShow: function () { }, +}; +var Tabs = /** @class */ (function () { + function Tabs(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._activeTab = options ? this.getTab(options.defaultTabId) : null; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Tabs.prototype._init = function () { + var _this = this; + if (this._items.length) { + // set the first tab as active if not set by explicitly + if (!this._activeTab) { + this._setActiveTab(this._items[0]); + } + // force show the first default tab + this.show(this._activeTab.id, true); + // show tab content based on click + this._items.map(function (tab) { + tab.triggerEl.addEventListener('click', function () { + _this.show(tab.id); + }); + }); + } + }; + Tabs.prototype.getActiveTab = function () { + return this._activeTab; + }; + Tabs.prototype._setActiveTab = function (tab) { + this._activeTab = tab; + }; + Tabs.prototype.getTab = function (id) { + return this._items.filter(function (t) { return t.id === id; })[0]; + }; + Tabs.prototype.show = function (id, forceShow) { + var _a, _b; + var _this = this; + if (forceShow === void 0) { forceShow = false; } + var tab = this.getTab(id); + // don't do anything if already active + if (tab === this._activeTab && !forceShow) { + return; + } + // hide other tabs + this._items.map(function (t) { + var _a, _b; + if (t !== tab) { + (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + t.targetEl.classList.add('hidden'); + t.triggerEl.setAttribute('aria-selected', 'false'); + } + }); + // show active tab + (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + tab.triggerEl.setAttribute('aria-selected', 'true'); + tab.targetEl.classList.remove('hidden'); + this._setActiveTab(tab); + // callback function + this._options.onShow(this, tab); + }; + return Tabs; +}()); +function initTabs() { + document.querySelectorAll('[data-tabs-toggle]').forEach(function ($triggerEl) { + var tabItems = []; + var defaultTabId = null; + $triggerEl + .querySelectorAll('[role="tab"]') + .forEach(function ($triggerEl) { + var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; + var tab = { + id: $triggerEl.getAttribute('data-tabs-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), + }; + tabItems.push(tab); + if (isActive) { + defaultTabId = tab.id; + } + }); + new Tabs(tabItems, { + defaultTabId: defaultTabId, + }); + }); +} +exports.initTabs = initTabs; +if (typeof window !== 'undefined') { + window.Tabs = Tabs; + window.initTabs = initTabs; +} +exports.default = Tabs; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/index.js.map b/node_modules/flowbite/lib/cjs/components/tabs/index.js.map new file mode 100644 index 0000000..ddb8dff --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/tabs/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts b/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts new file mode 100644 index 0000000..9e07566 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts @@ -0,0 +1,12 @@ +import { TabItem, TabsOptions } from './types'; +export declare interface TabsInterface { + _items: TabItem[]; + _activeTab: TabItem; + _options: TabsOptions; + _init(): void; + _setActiveTab(tab: TabItem): void; + getActiveTab(): TabItem; + getTab(id: string): TabItem; + show(id: string, forceShow?: boolean): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts.map new file mode 100644 index 0000000..3cd72bd --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE/C,MAAM,CAAC,OAAO,WAAW,aAAa;IAClC,MAAM,EAAE,OAAO,EAAE,CAAC;IAClB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,WAAW,CAAC;IAEtB,KAAK,IAAI,IAAI,CAAC;IACd,aAAa,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;IAClC,YAAY,IAAI,OAAO,CAAC;IACxB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC;IAC5B,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;CAC/C"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/interface.js b/node_modules/flowbite/lib/cjs/components/tabs/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/interface.js.map b/node_modules/flowbite/lib/cjs/components/tabs/interface.js.map new file mode 100644 index 0000000..6fc7bb2 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/tabs/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts b/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts new file mode 100644 index 0000000..342be0d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts @@ -0,0 +1,13 @@ +import { TabsInterface } from './interface'; +export declare type TabsOptions = { + defaultTabId?: string; + activeClasses?: string; + inactiveClasses?: string; + onShow?: (tabs: TabsInterface, tab: TabItem) => void; +}; +export declare type TabItem = { + id: string; + triggerEl: HTMLElement; + targetEl: HTMLElement; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts.map new file mode 100644 index 0000000..da457a9 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,CAAC,OAAO,MAAM,WAAW,GAAG;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,EAAE,GAAG,EAAE,OAAO,KAAK,IAAI,CAAC;CACxD,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,OAAO,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;CACzB,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/types.js b/node_modules/flowbite/lib/cjs/components/tabs/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tabs/types.js.map b/node_modules/flowbite/lib/cjs/components/tabs/types.js.map new file mode 100644 index 0000000..a4a4aff --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tabs/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/tabs/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts b/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts new file mode 100644 index 0000000..041a7da --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts @@ -0,0 +1,32 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { TooltipOptions } from './types'; +import { TooltipInterface } from './interface'; +declare class Tooltip implements TooltipInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: TooltipOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: TooltipOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +export declare function initTooltips(): void; +export default Tooltip; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts.map b/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts.map new file mode 100644 index 0000000..fc88084 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAU/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAC1D,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAUrC,KAAK;IAML,oBAAoB;IAcpB,qBAAqB;IAcrB,iBAAiB;;;;IAyBjB,qBAAqB;IAarB,sBAAsB;IAQtB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IAYpD,SAAS;IAIT,MAAM;IAQN,IAAI;IA6BJ,IAAI;CAyBP;AAED,wBAAgB,YAAY,SAyB3B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/index.js b/node_modules/flowbite/lib/cjs/components/tooltip/index.js new file mode 100644 index 0000000..9371df2 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/index.js @@ -0,0 +1,204 @@ +"use strict"; +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initTooltips = void 0; +/* eslint-disable @typescript-eslint/no-empty-function */ +var core_1 = require("@popperjs/core"); +var Default = { + placement: 'top', + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Tooltip = /** @class */ (function () { + function Tooltip(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Tooltip.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Tooltip.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.hide(); + }); + }); + }; + Tooltip.prototype._createPopperInstance = function () { + return (0, core_1.createPopper)(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, 8], + }, + }, + ], + }); + }; + Tooltip.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Tooltip.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Tooltip.prototype.isVisible = function () { + return this._visible; + }; + Tooltip.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Tooltip.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility + this._visible = true; + // callback function + this._options.onShow(this); + }; + Tooltip.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Tooltip; +}()); +function initTooltips() { + document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { + var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); + var $tooltipEl = document.getElementById(tooltipId); + if ($tooltipEl) { + var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); + var placement = $triggerEl.getAttribute('data-tooltip-placement'); + new Tooltip($tooltipEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); + } + }); +} +exports.initTooltips = initTooltips; +if (typeof window !== 'undefined') { + window.Tooltip = Tooltip; + window.initTooltips = initTooltips; +} +exports.default = Tooltip; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/index.js.map b/node_modules/flowbite/lib/cjs/components/tooltip/index.js.map new file mode 100644 index 0000000..7cc12c6 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/tooltip/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts b/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts new file mode 100644 index 0000000..f081b33 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts @@ -0,0 +1,23 @@ +import { TooltipOptions, TooltipTriggerType, TooltipTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface TooltipInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: TooltipOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _init(): void; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: TooltipTriggerType): TooltipTriggerEventTypes; + isVisible(): boolean; + show(): void; + hide(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts.map b/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts.map new file mode 100644 index 0000000..b395e6b --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,cAAc,EACd,kBAAkB,EAClB,wBAAwB,EAC3B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAE1D,KAAK,IAAI,IAAI,CAAC;IACd,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,qBAAqB,IAAI,IAAI,CAAC;IAC9B,sBAAsB,IAAI,IAAI,CAAC;IAC/B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,kBAAkB,GAChC,wBAAwB,CAAC;IAC5B,SAAS,IAAI,OAAO,CAAC;IACrB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/interface.js b/node_modules/flowbite/lib/cjs/components/tooltip/interface.js new file mode 100644 index 0000000..d549d1f --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/interface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/interface.js.map b/node_modules/flowbite/lib/cjs/components/tooltip/interface.js.map new file mode 100644 index 0000000..8a5f072 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/tooltip/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts b/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts new file mode 100644 index 0000000..1ba5bb3 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts @@ -0,0 +1,15 @@ +import { TooltipInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type TooltipTriggerType = 'click' | 'hover' | 'none'; +export declare type TooltipTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type TooltipOptions = { + placement?: Placement; + triggerType?: TooltipTriggerType; + onShow?: (tooltip: TooltipInterface) => void; + onHide?: (tooltip: TooltipInterface) => void; + onToggle?: (tooltip: TooltipInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts.map b/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts.map new file mode 100644 index 0000000..048bf1d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,kBAAkB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEpE,MAAM,CAAC,OAAO,MAAM,wBAAwB,GAAG;IAC3C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;CAClD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/types.js b/node_modules/flowbite/lib/cjs/components/tooltip/types.js new file mode 100644 index 0000000..11e638d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/types.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/components/tooltip/types.js.map b/node_modules/flowbite/lib/cjs/components/tooltip/types.js.map new file mode 100644 index 0000000..cd09cf9 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/components/tooltip/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/tooltip/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/config/global.d.ts b/node_modules/flowbite/lib/cjs/config/global.d.ts new file mode 100644 index 0000000..8937b76 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/config/global.d.ts @@ -0,0 +1,39 @@ +import Accordion from '../components/accordion'; +import Carousel from '../components/carousel'; +import Collapse from '../components/collapse'; +import Dial from '../components/dial'; +import Dismiss from '../components/dismiss'; +import Drawer from '../components/drawer'; +import Dropdown from '../components/dropdown'; +import Modal from '../components/modal'; +import Popover from '../components/popover'; +import Tabs from '../components/tabs'; +import Tooltip from '../components/tooltip'; +declare global { + interface Window { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Dismiss: typeof Dismiss; + Drawer: typeof Drawer; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + initAccordions: () => void; + initCarousels: () => void; + initCollapses: () => void; + initDials: () => void; + initDismisses: () => void; + initDrawers: () => void; + initDropdowns: () => void; + initModals: () => void; + initPopovers: () => void; + initTabs: () => void; + initTooltips: () => void; + initFlowbite: () => void; + } +} +//# sourceMappingURL=global.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/config/global.d.ts.map b/node_modules/flowbite/lib/cjs/config/global.d.ts.map new file mode 100644 index 0000000..b57ae87 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/config/global.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"global.d.ts","sourceRoot":"","sources":["../../../src/config/global.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,yBAAyB,CAAC;AAChD,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,IAAI,MAAM,oBAAoB,CAAC;AACtC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,MAAM,MAAM,sBAAsB,CAAC;AAC1C,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,KAAK,MAAM,qBAAqB,CAAC;AACxC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,IAAI,MAAM,oBAAoB,CAAC;AACtC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAE5C,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,MAAM;QACZ,SAAS,EAAE,OAAO,SAAS,CAAC;QAC5B,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,IAAI,EAAE,OAAO,IAAI,CAAC;QAClB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,MAAM,EAAE,OAAO,MAAM,CAAC;QACtB,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,KAAK,EAAE,OAAO,KAAK,CAAC;QACpB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,IAAI,EAAE,OAAO,IAAI,CAAC;QAClB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,cAAc,EAAE,MAAM,IAAI,CAAC;QAC3B,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,SAAS,EAAE,MAAM,IAAI,CAAC;QACtB,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,WAAW,EAAE,MAAM,IAAI,CAAC;QACxB,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,UAAU,EAAE,MAAM,IAAI,CAAC;QACvB,YAAY,EAAE,MAAM,IAAI,CAAC;QACzB,QAAQ,EAAE,MAAM,IAAI,CAAC;QACrB,YAAY,EAAE,MAAM,IAAI,CAAC;QACzB,YAAY,EAAE,MAAM,IAAI,CAAC;KAC5B;CACJ"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/config/global.js b/node_modules/flowbite/lib/cjs/config/global.js new file mode 100644 index 0000000..74429bb --- /dev/null +++ b/node_modules/flowbite/lib/cjs/config/global.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=global.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/config/global.js.map b/node_modules/flowbite/lib/cjs/config/global.js.map new file mode 100644 index 0000000..52ccc1e --- /dev/null +++ b/node_modules/flowbite/lib/cjs/config/global.js.map @@ -0,0 +1 @@ +{"version":3,"file":"global.js","sourceRoot":"","sources":["../../../src/config/global.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/dom/events.d.ts b/node_modules/flowbite/lib/cjs/dom/events.d.ts new file mode 100644 index 0000000..3bbb83b --- /dev/null +++ b/node_modules/flowbite/lib/cjs/dom/events.d.ts @@ -0,0 +1,8 @@ +declare class Events { + private _eventType; + private _eventFunctions; + constructor(eventType: string, eventFunctions?: EventListener[]); + init(): void; +} +export default Events; +//# sourceMappingURL=events.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/dom/events.d.ts.map b/node_modules/flowbite/lib/cjs/dom/events.d.ts.map new file mode 100644 index 0000000..de90c16 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/dom/events.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../src/dom/events.ts"],"names":[],"mappings":"AAAA,cAAM,MAAM;IACR,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,eAAe,CAAkB;gBAE7B,SAAS,EAAE,MAAM,EAAE,cAAc,GAAE,aAAa,EAAO;IAKnE,IAAI;CAOP;AAED,eAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/dom/events.js b/node_modules/flowbite/lib/cjs/dom/events.js new file mode 100644 index 0000000..3d7d94c --- /dev/null +++ b/node_modules/flowbite/lib/cjs/dom/events.js @@ -0,0 +1,20 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +var Events = /** @class */ (function () { + function Events(eventType, eventFunctions) { + if (eventFunctions === void 0) { eventFunctions = []; } + this._eventType = eventType; + this._eventFunctions = eventFunctions; + } + Events.prototype.init = function () { + var _this = this; + this._eventFunctions.forEach(function (eventFunction) { + if (typeof window !== 'undefined') { + window.addEventListener(_this._eventType, eventFunction); + } + }); + }; + return Events; +}()); +exports.default = Events; +//# sourceMappingURL=events.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/dom/events.js.map b/node_modules/flowbite/lib/cjs/dom/events.js.map new file mode 100644 index 0000000..369511c --- /dev/null +++ b/node_modules/flowbite/lib/cjs/dom/events.js.map @@ -0,0 +1 @@ +{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/dom/events.ts"],"names":[],"mappings":";;AAAA;IAII,gBAAY,SAAiB,EAAE,cAAoC;QAApC,+BAAA,EAAA,mBAAoC;QAC/D,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;IAC1C,CAAC;IAED,qBAAI,GAAJ;QAAA,iBAMC;QALG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,UAAC,aAAa;YACvC,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;gBAC/B,MAAM,CAAC,gBAAgB,CAAC,KAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;aAC3D;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACL,aAAC;AAAD,CAAC,AAhBD,IAgBC;AAED,kBAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.d.ts b/node_modules/flowbite/lib/cjs/index.d.ts new file mode 100644 index 0000000..5660236 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.d.ts @@ -0,0 +1,47 @@ +import './components/index'; +export { default as Accordion } from './components/accordion'; +export { default as Carousel } from './components/carousel'; +export { default as Collapse } from './components/collapse'; +export { default as Dial } from './components/dial'; +export { default as Dismiss } from './components/dismiss'; +export { default as Drawer } from './components/drawer'; +export { default as Dropdown } from './components/dropdown'; +export { default as Modal } from './components/modal'; +export { default as Popover } from './components/popover'; +export { default as Tabs } from './components/tabs'; +export { default as Tooltip } from './components/tooltip'; +export * from './components/accordion/types'; +export * from './components/carousel/types'; +export * from './components/collapse/types'; +export * from './components/dial/types'; +export * from './components/dismiss/types'; +export * from './components/drawer/types'; +export * from './components/dropdown/types'; +export * from './components/modal/types'; +export * from './components/popover/types'; +export * from './components/tabs/types'; +export * from './components/tooltip/types'; +export * from './components/accordion/interface'; +export * from './components/carousel/interface'; +export * from './components/collapse/interface'; +export * from './components/dial/interface'; +export * from './components/dismiss/interface'; +export * from './components/drawer/interface'; +export * from './components/dropdown/interface'; +export * from './components/modal/interface'; +export * from './components/popover/interface'; +export * from './components/tabs/interface'; +export * from './components/tooltip/interface'; +export { initAccordions } from './components/accordion'; +export { initCarousels } from './components/carousel'; +export { initCollapses } from './components/collapse'; +export { initDials } from './components/dial'; +export { initDismisses } from './components/dismiss'; +export { initDrawers } from './components/drawer'; +export { initDropdowns } from './components/dropdown'; +export { initModals } from './components/modal'; +export { initPopovers } from './components/popover'; +export { initTabs } from './components/tabs'; +export { initTooltips } from './components/tooltip'; +export { initFlowbite } from './components/index'; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.d.ts.map b/node_modules/flowbite/lib/cjs/index.d.ts.map new file mode 100644 index 0000000..8997bca --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAYA,OAAO,oBAAoB,CAAC;AAmB5B,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG1D,cAAc,8BAA8B,CAAC;AAC7C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAG3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,iCAAiC,CAAC;AAChD,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iCAAiC,CAAC;AAChD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gCAAgC,CAAC;AAG/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGpD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.js b/node_modules/flowbite/lib/cjs/index.js new file mode 100644 index 0000000..35c567d --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.js @@ -0,0 +1,119 @@ +"use strict"; +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __exportStar = (this && this.__exportStar) || function(m, exports) { + for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.initFlowbite = exports.initTooltips = exports.initTabs = exports.initPopovers = exports.initModals = exports.initDropdowns = exports.initDrawers = exports.initDismisses = exports.initDials = exports.initCollapses = exports.initCarousels = exports.initAccordions = exports.Tooltip = exports.Tabs = exports.Popover = exports.Modal = exports.Dropdown = exports.Drawer = exports.Dismiss = exports.Dial = exports.Collapse = exports.Carousel = exports.Accordion = void 0; +var events_1 = require("./dom/events"); +var accordion_1 = require("./components/accordion"); +var collapse_1 = require("./components/collapse"); +var carousel_1 = require("./components/carousel"); +var dismiss_1 = require("./components/dismiss"); +var dropdown_1 = require("./components/dropdown"); +var modal_1 = require("./components/modal"); +var drawer_1 = require("./components/drawer"); +var tabs_1 = require("./components/tabs"); +var tooltip_1 = require("./components/tooltip"); +var popover_1 = require("./components/popover"); +var dial_1 = require("./components/dial"); +require("./components/index"); +// setup events for data attributes +var events = new events_1.default('load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +events.init(); +// export all components +var accordion_2 = require("./components/accordion"); +Object.defineProperty(exports, "Accordion", { enumerable: true, get: function () { return accordion_2.default; } }); +var carousel_2 = require("./components/carousel"); +Object.defineProperty(exports, "Carousel", { enumerable: true, get: function () { return carousel_2.default; } }); +var collapse_2 = require("./components/collapse"); +Object.defineProperty(exports, "Collapse", { enumerable: true, get: function () { return collapse_2.default; } }); +var dial_2 = require("./components/dial"); +Object.defineProperty(exports, "Dial", { enumerable: true, get: function () { return dial_2.default; } }); +var dismiss_2 = require("./components/dismiss"); +Object.defineProperty(exports, "Dismiss", { enumerable: true, get: function () { return dismiss_2.default; } }); +var drawer_2 = require("./components/drawer"); +Object.defineProperty(exports, "Drawer", { enumerable: true, get: function () { return drawer_2.default; } }); +var dropdown_2 = require("./components/dropdown"); +Object.defineProperty(exports, "Dropdown", { enumerable: true, get: function () { return dropdown_2.default; } }); +var modal_2 = require("./components/modal"); +Object.defineProperty(exports, "Modal", { enumerable: true, get: function () { return modal_2.default; } }); +var popover_2 = require("./components/popover"); +Object.defineProperty(exports, "Popover", { enumerable: true, get: function () { return popover_2.default; } }); +var tabs_2 = require("./components/tabs"); +Object.defineProperty(exports, "Tabs", { enumerable: true, get: function () { return tabs_2.default; } }); +var tooltip_2 = require("./components/tooltip"); +Object.defineProperty(exports, "Tooltip", { enumerable: true, get: function () { return tooltip_2.default; } }); +// export all types +__exportStar(require("./components/accordion/types"), exports); +__exportStar(require("./components/carousel/types"), exports); +__exportStar(require("./components/collapse/types"), exports); +__exportStar(require("./components/dial/types"), exports); +__exportStar(require("./components/dismiss/types"), exports); +__exportStar(require("./components/drawer/types"), exports); +__exportStar(require("./components/dropdown/types"), exports); +__exportStar(require("./components/modal/types"), exports); +__exportStar(require("./components/popover/types"), exports); +__exportStar(require("./components/tabs/types"), exports); +__exportStar(require("./components/tooltip/types"), exports); +// export all interfaces +__exportStar(require("./components/accordion/interface"), exports); +__exportStar(require("./components/carousel/interface"), exports); +__exportStar(require("./components/collapse/interface"), exports); +__exportStar(require("./components/dial/interface"), exports); +__exportStar(require("./components/dismiss/interface"), exports); +__exportStar(require("./components/drawer/interface"), exports); +__exportStar(require("./components/dropdown/interface"), exports); +__exportStar(require("./components/modal/interface"), exports); +__exportStar(require("./components/popover/interface"), exports); +__exportStar(require("./components/tabs/interface"), exports); +__exportStar(require("./components/tooltip/interface"), exports); +// export init functions +var accordion_3 = require("./components/accordion"); +Object.defineProperty(exports, "initAccordions", { enumerable: true, get: function () { return accordion_3.initAccordions; } }); +var carousel_3 = require("./components/carousel"); +Object.defineProperty(exports, "initCarousels", { enumerable: true, get: function () { return carousel_3.initCarousels; } }); +var collapse_3 = require("./components/collapse"); +Object.defineProperty(exports, "initCollapses", { enumerable: true, get: function () { return collapse_3.initCollapses; } }); +var dial_3 = require("./components/dial"); +Object.defineProperty(exports, "initDials", { enumerable: true, get: function () { return dial_3.initDials; } }); +var dismiss_3 = require("./components/dismiss"); +Object.defineProperty(exports, "initDismisses", { enumerable: true, get: function () { return dismiss_3.initDismisses; } }); +var drawer_3 = require("./components/drawer"); +Object.defineProperty(exports, "initDrawers", { enumerable: true, get: function () { return drawer_3.initDrawers; } }); +var dropdown_3 = require("./components/dropdown"); +Object.defineProperty(exports, "initDropdowns", { enumerable: true, get: function () { return dropdown_3.initDropdowns; } }); +var modal_3 = require("./components/modal"); +Object.defineProperty(exports, "initModals", { enumerable: true, get: function () { return modal_3.initModals; } }); +var popover_3 = require("./components/popover"); +Object.defineProperty(exports, "initPopovers", { enumerable: true, get: function () { return popover_3.initPopovers; } }); +var tabs_3 = require("./components/tabs"); +Object.defineProperty(exports, "initTabs", { enumerable: true, get: function () { return tabs_3.initTabs; } }); +var tooltip_3 = require("./components/tooltip"); +Object.defineProperty(exports, "initTooltips", { enumerable: true, get: function () { return tooltip_3.initTooltips; } }); +// export all init functions +var index_1 = require("./components/index"); +Object.defineProperty(exports, "initFlowbite", { enumerable: true, get: function () { return index_1.initFlowbite; } }); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.js.map b/node_modules/flowbite/lib/cjs/index.js.map new file mode 100644 index 0000000..fbee404 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,uCAAkC;AAClC,oDAAwD;AACxD,kDAAsD;AACtD,kDAAsD;AACtD,gDAAqD;AACrD,kDAAsD;AACtD,4CAAgD;AAChD,8CAAkD;AAClD,0CAA6C;AAC7C,gDAAoD;AACpD,gDAAoD;AACpD,0CAA8C;AAC9C,8BAA4B;AAE5B,mCAAmC;AACnC,IAAM,MAAM,GAAG,IAAI,gBAAM,CAAC,MAAM,EAAE;IAC9B,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,MAAM,CAAC,IAAI,EAAE,CAAC;AAEd,wBAAwB;AACxB,oDAA8D;AAArD,sGAAA,OAAO,OAAa;AAC7B,kDAA4D;AAAnD,oGAAA,OAAO,OAAY;AAC5B,kDAA4D;AAAnD,oGAAA,OAAO,OAAY;AAC5B,0CAAoD;AAA3C,4FAAA,OAAO,OAAQ;AACxB,gDAA0D;AAAjD,kGAAA,OAAO,OAAW;AAC3B,8CAAwD;AAA/C,gGAAA,OAAO,OAAU;AAC1B,kDAA4D;AAAnD,oGAAA,OAAO,OAAY;AAC5B,4CAAsD;AAA7C,8FAAA,OAAO,OAAS;AACzB,gDAA0D;AAAjD,kGAAA,OAAO,OAAW;AAC3B,0CAAoD;AAA3C,4FAAA,OAAO,OAAQ;AACxB,gDAA0D;AAAjD,kGAAA,OAAO,OAAW;AAE3B,mBAAmB;AACnB,+DAA6C;AAC7C,8DAA4C;AAC5C,8DAA4C;AAC5C,0DAAwC;AACxC,6DAA2C;AAC3C,4DAA0C;AAC1C,8DAA4C;AAC5C,2DAAyC;AACzC,6DAA2C;AAC3C,0DAAwC;AACxC,6DAA2C;AAE3C,wBAAwB;AACxB,mEAAiD;AACjD,kEAAgD;AAChD,kEAAgD;AAChD,8DAA4C;AAC5C,iEAA+C;AAC/C,gEAA8C;AAC9C,kEAAgD;AAChD,+DAA6C;AAC7C,iEAA+C;AAC/C,8DAA4C;AAC5C,iEAA+C;AAE/C,wBAAwB;AACxB,oDAAwD;AAA/C,2GAAA,cAAc,OAAA;AACvB,kDAAsD;AAA7C,yGAAA,aAAa,OAAA;AACtB,kDAAsD;AAA7C,yGAAA,aAAa,OAAA;AACtB,0CAA8C;AAArC,iGAAA,SAAS,OAAA;AAClB,gDAAqD;AAA5C,wGAAA,aAAa,OAAA;AACtB,8CAAkD;AAAzC,qGAAA,WAAW,OAAA;AACpB,kDAAsD;AAA7C,yGAAA,aAAa,OAAA;AACtB,4CAAgD;AAAvC,mGAAA,UAAU,OAAA;AACnB,gDAAoD;AAA3C,uGAAA,YAAY,OAAA;AACrB,0CAA6C;AAApC,gGAAA,QAAQ,OAAA;AACjB,gDAAoD;AAA3C,uGAAA,YAAY,OAAA;AAErB,4BAA4B;AAC5B,4CAAkD;AAAzC,qGAAA,YAAY,OAAA"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.phoenix.d.ts b/node_modules/flowbite/lib/cjs/index.phoenix.d.ts new file mode 100644 index 0000000..9bec6d4 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.phoenix.d.ts @@ -0,0 +1,29 @@ +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.phoenix.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.phoenix.d.ts.map b/node_modules/flowbite/lib/cjs/index.phoenix.d.ts.map new file mode 100644 index 0000000..0e05cf0 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.phoenix.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.phoenix.d.ts","sourceRoot":"","sources":["../../src/index.phoenix.ts"],"names":[],"mappings":"AACA,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAgClC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.phoenix.js b/node_modules/flowbite/lib/cjs/index.phoenix.js new file mode 100644 index 0000000..4fcfed0 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.phoenix.js @@ -0,0 +1,59 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +// core components +var accordion_1 = require("./components/accordion"); +var carousel_1 = require("./components/carousel"); +var collapse_1 = require("./components/collapse"); +var dial_1 = require("./components/dial"); +var dismiss_1 = require("./components/dismiss"); +var drawer_1 = require("./components/drawer"); +var dropdown_1 = require("./components/dropdown"); +var modal_1 = require("./components/modal"); +var popover_1 = require("./components/popover"); +var tabs_1 = require("./components/tabs"); +var tooltip_1 = require("./components/tooltip"); +require("./components/index"); +var events_1 = require("./dom/events"); +var liveViewLoadEvents = new events_1.default('phx:page-loading-stop', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +liveViewLoadEvents.init(); +var regularViewLoadEvents = new events_1.default('load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +regularViewLoadEvents.init(); +exports.default = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; +//# sourceMappingURL=index.phoenix.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.phoenix.js.map b/node_modules/flowbite/lib/cjs/index.phoenix.js.map new file mode 100644 index 0000000..ce03836 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.phoenix.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.phoenix.js","sourceRoot":"","sources":["../../src/index.phoenix.ts"],"names":[],"mappings":";;AAAA,kBAAkB;AAClB,oDAAmE;AACnE,kDAAgE;AAChE,kDAAgE;AAChE,0CAAoD;AACpD,gDAA8D;AAC9D,8CAA0D;AAC1D,kDAAgE;AAChE,4CAAuD;AACvD,gDAA6D;AAC7D,0CAAmD;AACnD,gDAA6D;AAC7D,8BAA4B;AAC5B,uCAAkC;AAElC,IAAM,kBAAkB,GAAG,IAAI,gBAAM,CAAC,uBAAuB,EAAE;IAC3D,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,kBAAkB,CAAC,IAAI,EAAE,CAAC;AAE1B,IAAM,qBAAqB,GAAG,IAAI,gBAAM,CAAC,MAAM,EAAE;IAC7C,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,qBAAqB,CAAC,IAAI,EAAE,CAAC;AAE7B,kBAAe;IACX,SAAS,qBAAA;IACT,QAAQ,oBAAA;IACR,QAAQ,oBAAA;IACR,IAAI,gBAAA;IACJ,MAAM,kBAAA;IACN,OAAO,mBAAA;IACP,QAAQ,oBAAA;IACR,KAAK,iBAAA;IACL,OAAO,mBAAA;IACP,IAAI,gBAAA;IACJ,OAAO,mBAAA;IACP,MAAM,kBAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.turbo.d.ts b/node_modules/flowbite/lib/cjs/index.turbo.d.ts new file mode 100644 index 0000000..413a593 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.turbo.d.ts @@ -0,0 +1,29 @@ +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.turbo.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.turbo.d.ts.map b/node_modules/flowbite/lib/cjs/index.turbo.d.ts.map new file mode 100644 index 0000000..4b913c1 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.turbo.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.turbo.d.ts","sourceRoot":"","sources":["../../src/index.turbo.ts"],"names":[],"mappings":"AACA,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAgClC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.turbo.js b/node_modules/flowbite/lib/cjs/index.turbo.js new file mode 100644 index 0000000..b55d5d7 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.turbo.js @@ -0,0 +1,59 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +// core components +var accordion_1 = require("./components/accordion"); +var carousel_1 = require("./components/carousel"); +var collapse_1 = require("./components/collapse"); +var dial_1 = require("./components/dial"); +var dismiss_1 = require("./components/dismiss"); +var drawer_1 = require("./components/drawer"); +var dropdown_1 = require("./components/dropdown"); +var modal_1 = require("./components/modal"); +var popover_1 = require("./components/popover"); +var tabs_1 = require("./components/tabs"); +var tooltip_1 = require("./components/tooltip"); +require("./components/index"); +var events_1 = require("./dom/events"); +var turboLoadEvents = new events_1.default('turbo:load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +turboLoadEvents.init(); +var turboFrameLoadEvents = new events_1.default('turbo:frame-load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +turboFrameLoadEvents.init(); +exports.default = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; +//# sourceMappingURL=index.turbo.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.turbo.js.map b/node_modules/flowbite/lib/cjs/index.turbo.js.map new file mode 100644 index 0000000..5bb7dff --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.turbo.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.turbo.js","sourceRoot":"","sources":["../../src/index.turbo.ts"],"names":[],"mappings":";;AAAA,kBAAkB;AAClB,oDAAmE;AACnE,kDAAgE;AAChE,kDAAgE;AAChE,0CAAoD;AACpD,gDAA8D;AAC9D,8CAA0D;AAC1D,kDAAgE;AAChE,4CAAuD;AACvD,gDAA6D;AAC7D,0CAAmD;AACnD,gDAA6D;AAC7D,8BAA4B;AAC5B,uCAAkC;AAElC,IAAM,eAAe,GAAG,IAAI,gBAAM,CAAC,YAAY,EAAE;IAC7C,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,eAAe,CAAC,IAAI,EAAE,CAAC;AAEvB,IAAM,oBAAoB,GAAG,IAAI,gBAAM,CAAC,kBAAkB,EAAE;IACxD,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,oBAAoB,CAAC,IAAI,EAAE,CAAC;AAE5B,kBAAe;IACX,SAAS,qBAAA;IACT,QAAQ,oBAAA;IACR,QAAQ,oBAAA;IACR,IAAI,gBAAA;IACJ,MAAM,kBAAA;IACN,OAAO,mBAAA;IACP,QAAQ,oBAAA;IACR,KAAK,iBAAA;IACL,OAAO,mBAAA;IACP,IAAI,gBAAA;IACJ,OAAO,mBAAA;IACP,MAAM,kBAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.umd.d.ts b/node_modules/flowbite/lib/cjs/index.umd.d.ts new file mode 100644 index 0000000..98f6048 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.umd.d.ts @@ -0,0 +1,30 @@ +import './flowbite.css'; +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.umd.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.umd.d.ts.map b/node_modules/flowbite/lib/cjs/index.umd.d.ts.map new file mode 100644 index 0000000..60b4ec2 --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.umd.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.umd.d.ts","sourceRoot":"","sources":["../../src/index.umd.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,CAAC;AAGxB,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAiBlC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.umd.js b/node_modules/flowbite/lib/cjs/index.umd.js new file mode 100644 index 0000000..a8352da --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.umd.js @@ -0,0 +1,46 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +require("./flowbite.css"); +// core components +var accordion_1 = require("./components/accordion"); +var carousel_1 = require("./components/carousel"); +var collapse_1 = require("./components/collapse"); +var dial_1 = require("./components/dial"); +var dismiss_1 = require("./components/dismiss"); +var drawer_1 = require("./components/drawer"); +var dropdown_1 = require("./components/dropdown"); +var modal_1 = require("./components/modal"); +var popover_1 = require("./components/popover"); +var tabs_1 = require("./components/tabs"); +var tooltip_1 = require("./components/tooltip"); +require("./components/index"); +var events_1 = require("./dom/events"); +var events = new events_1.default('load', [ + accordion_1.initAccordions, + collapse_1.initCollapses, + carousel_1.initCarousels, + dismiss_1.initDismisses, + dropdown_1.initDropdowns, + modal_1.initModals, + drawer_1.initDrawers, + tabs_1.initTabs, + tooltip_1.initTooltips, + popover_1.initPopovers, + dial_1.initDials, +]); +events.init(); +exports.default = { + Accordion: accordion_1.default, + Carousel: carousel_1.default, + Collapse: collapse_1.default, + Dial: dial_1.default, + Drawer: drawer_1.default, + Dismiss: dismiss_1.default, + Dropdown: dropdown_1.default, + Modal: modal_1.default, + Popover: popover_1.default, + Tabs: tabs_1.default, + Tooltip: tooltip_1.default, + Events: events_1.default, +}; +//# sourceMappingURL=index.umd.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/cjs/index.umd.js.map b/node_modules/flowbite/lib/cjs/index.umd.js.map new file mode 100644 index 0000000..f1c353a --- /dev/null +++ b/node_modules/flowbite/lib/cjs/index.umd.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.umd.js","sourceRoot":"","sources":["../../src/index.umd.ts"],"names":[],"mappings":";;AAAA,0BAAwB;AAExB,kBAAkB;AAClB,oDAAmE;AACnE,kDAAgE;AAChE,kDAAgE;AAChE,0CAAoD;AACpD,gDAA8D;AAC9D,8CAA0D;AAC1D,kDAAgE;AAChE,4CAAuD;AACvD,gDAA6D;AAC7D,0CAAmD;AACnD,gDAA6D;AAC7D,8BAA4B;AAC5B,uCAAkC;AAElC,IAAM,MAAM,GAAG,IAAI,gBAAM,CAAC,MAAM,EAAE;IAC9B,0BAAc;IACd,wBAAa;IACb,wBAAa;IACb,uBAAa;IACb,wBAAa;IACb,kBAAU;IACV,oBAAW;IACX,eAAQ;IACR,sBAAY;IACZ,sBAAY;IACZ,gBAAS;CACZ,CAAC,CAAC;AACH,MAAM,CAAC,IAAI,EAAE,CAAC;AAEd,kBAAe;IACX,SAAS,qBAAA;IACT,QAAQ,oBAAA;IACR,QAAQ,oBAAA;IACR,IAAI,gBAAA;IACJ,MAAM,kBAAA;IACN,OAAO,mBAAA;IACP,QAAQ,oBAAA;IACR,KAAK,iBAAA;IACL,OAAO,mBAAA;IACP,IAAI,gBAAA;IACJ,OAAO,mBAAA;IACP,MAAM,kBAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/index.d.ts b/node_modules/flowbite/lib/esm/components/accordion/index.d.ts new file mode 100644 index 0000000..4ea151a --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/index.d.ts @@ -0,0 +1,15 @@ +import type { AccordionItem, AccordionOptions } from './types'; +import { AccordionInterface } from './interface'; +declare class Accordion implements AccordionInterface { + _items: AccordionItem[]; + _options: AccordionOptions; + constructor(items?: AccordionItem[], options?: AccordionOptions); + private _init; + getItem(id: string): AccordionItem; + open(id: string): void; + toggle(id: string): void; + close(id: string): void; +} +export declare function initAccordions(): void; +export default Accordion; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/index.d.ts.map b/node_modules/flowbite/lib/esm/components/accordion/index.d.ts.map new file mode 100644 index 0000000..a7f1f0f --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAWjD,cAAM,SAAU,YAAW,kBAAkB;IACzC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,QAAQ,EAAE,gBAAgB,CAAC;gBAGvB,KAAK,GAAE,aAAa,EAAO,EAC3B,OAAO,GAAE,gBAA0B;IAOvC,OAAO,CAAC,KAAK;IAeb,OAAO,CAAC,EAAE,EAAE,MAAM;IAIlB,IAAI,CAAC,EAAE,EAAE,MAAM;IA2Cf,MAAM,CAAC,EAAE,EAAE,MAAM;IAajB,KAAK,CAAC,EAAE,EAAE,MAAM;CAqBnB;AAED,wBAAgB,cAAc,SA2C7B;AAOD,eAAe,SAAS,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/index.js b/node_modules/flowbite/lib/esm/components/accordion/index.js new file mode 100644 index 0000000..a82f735 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/index.js @@ -0,0 +1,147 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + alwaysOpen: false, + activeClasses: 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white', + inactiveClasses: 'text-gray-500 dark:text-gray-400', + onOpen: function () { }, + onClose: function () { }, + onToggle: function () { }, +}; +var Accordion = /** @class */ (function () { + function Accordion(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Accordion.prototype._init = function () { + var _this = this; + if (this._items.length) { + // show accordion item based on click + this._items.map(function (item) { + if (item.active) { + _this.open(item.id); + } + item.triggerEl.addEventListener('click', function () { + _this.toggle(item.id); + }); + }); + } + }; + Accordion.prototype.getItem = function (id) { + return this._items.filter(function (item) { return item.id === id; })[0]; + }; + Accordion.prototype.open = function (id) { + var _a, _b; + var _this = this; + var item = this.getItem(id); + // don't hide other accordions if always open + if (!this._options.alwaysOpen) { + this._items.map(function (i) { + var _a, _b; + if (i !== item) { + (_a = i.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = i.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + i.targetEl.classList.add('hidden'); + i.triggerEl.setAttribute('aria-expanded', 'false'); + i.active = false; + // rotate icon if set + if (i.iconEl) { + i.iconEl.classList.remove('rotate-180'); + } + } + }); + } + // show active item + (_a = item.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + item.triggerEl.setAttribute('aria-expanded', 'true'); + item.targetEl.classList.remove('hidden'); + item.active = true; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.add('rotate-180'); + } + // callback function + this._options.onOpen(this, item); + }; + Accordion.prototype.toggle = function (id) { + var item = this.getItem(id); + if (item.active) { + this.close(id); + } + else { + this.open(id); + } + // callback function + this._options.onToggle(this, item); + }; + Accordion.prototype.close = function (id) { + var _a, _b; + var item = this.getItem(id); + (_a = item.triggerEl.classList).remove.apply(_a, this._options.activeClasses.split(' ')); + (_b = item.triggerEl.classList).add.apply(_b, this._options.inactiveClasses.split(' ')); + item.targetEl.classList.add('hidden'); + item.triggerEl.setAttribute('aria-expanded', 'false'); + item.active = false; + // rotate icon if set + if (item.iconEl) { + item.iconEl.classList.remove('rotate-180'); + } + // callback function + this._options.onClose(this, item); + }; + return Accordion; +}()); +export function initAccordions() { + document.querySelectorAll('[data-accordion]').forEach(function ($accordionEl) { + var alwaysOpen = $accordionEl.getAttribute('data-accordion'); + var activeClasses = $accordionEl.getAttribute('data-active-classes'); + var inactiveClasses = $accordionEl.getAttribute('data-inactive-classes'); + var items = []; + $accordionEl + .querySelectorAll('[data-accordion-target]') + .forEach(function ($triggerEl) { + // Consider only items that directly belong to $accordionEl + // (to make nested accordions work). + if ($triggerEl.closest('[data-accordion]') === $accordionEl) { + var item = { + id: $triggerEl.getAttribute('data-accordion-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-accordion-target')), + iconEl: $triggerEl.querySelector('[data-accordion-icon]'), + active: $triggerEl.getAttribute('aria-expanded') === 'true' + ? true + : false, + }; + items.push(item); + } + }); + new Accordion(items, { + alwaysOpen: alwaysOpen === 'open' ? true : false, + activeClasses: activeClasses + ? activeClasses + : Default.activeClasses, + inactiveClasses: inactiveClasses + ? inactiveClasses + : Default.inactiveClasses, + }); + }); +} +if (typeof window !== 'undefined') { + window.Accordion = Accordion; + window.initAccordions = initAccordions; +} +export default Accordion; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/index.js.map b/node_modules/flowbite/lib/esm/components/accordion/index.js.map new file mode 100644 index 0000000..2cd99c7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/accordion/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts b/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts new file mode 100644 index 0000000..ebeacd9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts @@ -0,0 +1,10 @@ +import { AccordionItem, AccordionOptions } from './types'; +export declare interface AccordionInterface { + _items: AccordionItem[]; + _options: AccordionOptions; + getItem(id: string): AccordionItem | undefined; + open(id: string): void; + toggle(id: string): void; + close(id: string): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts.map new file mode 100644 index 0000000..cfc63e5 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/interface.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAG1D,MAAM,CAAC,OAAO,WAAW,kBAAkB;IACvC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,QAAQ,EAAE,gBAAgB,CAAC;IAE3B,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS,CAAC;IAC/C,IAAI,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/interface.js b/node_modules/flowbite/lib/esm/components/accordion/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/interface.js.map b/node_modules/flowbite/lib/esm/components/accordion/interface.js.map new file mode 100644 index 0000000..a7ef24a --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/accordion/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/types.d.ts b/node_modules/flowbite/lib/esm/components/accordion/types.d.ts new file mode 100644 index 0000000..c8fb43a --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/types.d.ts @@ -0,0 +1,17 @@ +import { AccordionInterface } from './interface'; +export declare type AccordionItem = { + id: string; + triggerEl: HTMLElement; + targetEl: HTMLElement; + iconEl?: HTMLElement | null; + active?: boolean; +}; +export declare type AccordionOptions = { + alwaysOpen?: boolean; + activeClasses?: string; + inactiveClasses?: string; + onOpen?: (accordion: AccordionInterface, item: AccordionItem) => void; + onClose?: (accordion: AccordionInterface, item: AccordionItem) => void; + onToggle?: (accordion: AccordionInterface, item: AccordionItem) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/types.d.ts.map b/node_modules/flowbite/lib/esm/components/accordion/types.d.ts.map new file mode 100644 index 0000000..c130ff7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/accordion/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5B,MAAM,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,gBAAgB,GAAG;IACnC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACtE,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvE,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,kBAAkB,EAAE,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;CAC3E,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/types.js b/node_modules/flowbite/lib/esm/components/accordion/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/accordion/types.js.map b/node_modules/flowbite/lib/esm/components/accordion/types.js.map new file mode 100644 index 0000000..e0f0c46 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/accordion/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/accordion/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/index.d.ts b/node_modules/flowbite/lib/esm/components/carousel/index.d.ts new file mode 100644 index 0000000..0361e3e --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/index.d.ts @@ -0,0 +1,54 @@ +import type { CarouselOptions, CarouselItem, IndicatorItem, RotationItems } from './types'; +import { CarouselInterface } from './interface'; +declare class Carousel implements CarouselInterface { + _items: CarouselItem[]; + _indicators: IndicatorItem[]; + _activeItem: CarouselItem; + _intervalDuration: number; + _intervalInstance: number; + _options: CarouselOptions; + constructor(items?: CarouselItem[], options?: CarouselOptions); + /** + * initialize carousel and items based on active one + */ + _init(): void; + getItem(position: number): CarouselItem; + /** + * Slide to the element based on id + * @param {*} position + */ + slideTo(position: number): void; + /** + * Based on the currently active item it will go to the next position + */ + next(): void; + /** + * Based on the currently active item it will go to the previous position + */ + prev(): void; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + _rotate(rotationItems: RotationItems): void; + /** + * Set an interval to cycle through the carousel items + */ + cycle(): void; + /** + * Clears the cycling interval + */ + pause(): void; + /** + * Get the currently active item + */ + _getActiveItem(): CarouselItem; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + _setActiveItem(item: CarouselItem): void; +} +export declare function initCarousels(): void; +export default Carousel; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/index.d.ts.map b/node_modules/flowbite/lib/esm/components/carousel/index.d.ts.map new file mode 100644 index 0000000..76e86e7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,eAAe,EACf,YAAY,EACZ,aAAa,EACb,aAAa,EAChB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAgBhD,cAAM,QAAS,YAAW,iBAAiB;IACvC,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,WAAW,EAAE,aAAa,EAAE,CAAC;IAC7B,WAAW,EAAE,YAAY,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,EAAE,eAAe,CAAC;gBAGtB,KAAK,GAAE,YAAY,EAAO,EAC1B,OAAO,GAAE,eAAyB;IAetC;;OAEG;IACH,KAAK;IAwBL,OAAO,CAAC,QAAQ,EAAE,MAAM;IAIxB;;;OAGG;IACH,OAAO,CAAC,QAAQ,EAAE,MAAM;IAuBxB;;OAEG;IACH,IAAI;IAiBJ;;OAEG;IACH,IAAI;IAiBJ;;;OAGG;IACH,OAAO,CAAC,aAAa,EAAE,aAAa;IAqCpC;;OAEG;IACH,KAAK;IAQL;;OAEG;IACH,KAAK;IAIL;;OAEG;IACH,cAAc;IAId;;;OAGG;IACH,cAAc,CAAC,IAAI,EAAE,YAAY;CAwBpC;AAED,wBAAgB,aAAa,SA0E5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/index.js b/node_modules/flowbite/lib/esm/components/carousel/index.js new file mode 100644 index 0000000..48181f2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/index.js @@ -0,0 +1,242 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + defaultPosition: 0, + indicators: { + items: [], + activeClasses: 'bg-white dark:bg-gray-800', + inactiveClasses: 'bg-white/50 dark:bg-gray-800/50 hover:bg-white dark:hover:bg-gray-800', + }, + interval: 3000, + onNext: function () { }, + onPrev: function () { }, + onChange: function () { }, +}; +var Carousel = /** @class */ (function () { + function Carousel(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._options = __assign(__assign(__assign({}, Default), options), { indicators: __assign(__assign({}, Default.indicators), options.indicators) }); + this._activeItem = this.getItem(this._options.defaultPosition); + this._indicators = this._options.indicators.items; + this._intervalDuration = this._options.interval; + this._intervalInstance = null; + this._init(); + } + /** + * initialize carousel and items based on active one + */ + Carousel.prototype._init = function () { + var _this = this; + this._items.map(function (item) { + item.el.classList.add('absolute', 'inset-0', 'transition-transform', 'transform'); + }); + // if no active item is set then first position is default + if (this._getActiveItem()) { + this.slideTo(this._getActiveItem().position); + } + else { + this.slideTo(0); + } + this._indicators.map(function (indicator, position) { + indicator.el.addEventListener('click', function () { + _this.slideTo(position); + }); + }); + }; + Carousel.prototype.getItem = function (position) { + return this._items[position]; + }; + /** + * Slide to the element based on id + * @param {*} position + */ + Carousel.prototype.slideTo = function (position) { + var nextItem = this._items[position]; + var rotationItems = { + left: nextItem.position === 0 + ? this._items[this._items.length - 1] + : this._items[nextItem.position - 1], + middle: nextItem, + right: nextItem.position === this._items.length - 1 + ? this._items[0] + : this._items[nextItem.position + 1], + }; + this._rotate(rotationItems); + this._setActiveItem(nextItem); + if (this._intervalInstance) { + this.pause(); + this.cycle(); + } + this._options.onChange(this); + }; + /** + * Based on the currently active item it will go to the next position + */ + Carousel.prototype.next = function () { + var activeItem = this._getActiveItem(); + var nextItem = null; + // check if last item + if (activeItem.position === this._items.length - 1) { + nextItem = this._items[0]; + } + else { + nextItem = this._items[activeItem.position + 1]; + } + this.slideTo(nextItem.position); + // callback function + this._options.onNext(this); + }; + /** + * Based on the currently active item it will go to the previous position + */ + Carousel.prototype.prev = function () { + var activeItem = this._getActiveItem(); + var prevItem = null; + // check if first item + if (activeItem.position === 0) { + prevItem = this._items[this._items.length - 1]; + } + else { + prevItem = this._items[activeItem.position - 1]; + } + this.slideTo(prevItem.position); + // callback function + this._options.onPrev(this); + }; + /** + * This method applies the transform classes based on the left, middle, and right rotation carousel items + * @param {*} rotationItems + */ + Carousel.prototype._rotate = function (rotationItems) { + // reset + this._items.map(function (item) { + item.el.classList.add('hidden'); + }); + // left item (previously active) + rotationItems.left.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.left.el.classList.add('-translate-x-full', 'z-10'); + // currently active item + rotationItems.middle.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-10'); + rotationItems.middle.el.classList.add('translate-x-0', 'z-20'); + // right item (upcoming active) + rotationItems.right.el.classList.remove('-translate-x-full', 'translate-x-full', 'translate-x-0', 'hidden', 'z-20'); + rotationItems.right.el.classList.add('translate-x-full', 'z-10'); + }; + /** + * Set an interval to cycle through the carousel items + */ + Carousel.prototype.cycle = function () { + var _this = this; + if (typeof window !== 'undefined') { + this._intervalInstance = window.setInterval(function () { + _this.next(); + }, this._intervalDuration); + } + }; + /** + * Clears the cycling interval + */ + Carousel.prototype.pause = function () { + clearInterval(this._intervalInstance); + }; + /** + * Get the currently active item + */ + Carousel.prototype._getActiveItem = function () { + return this._activeItem; + }; + /** + * Set the currently active item and data attribute + * @param {*} position + */ + Carousel.prototype._setActiveItem = function (item) { + var _a, _b; + var _this = this; + this._activeItem = item; + var position = item.position; + // update the indicators if available + if (this._indicators.length) { + this._indicators.map(function (indicator) { + var _a, _b; + indicator.el.setAttribute('aria-current', 'false'); + (_a = indicator.el.classList).remove.apply(_a, _this._options.indicators.activeClasses.split(' ')); + (_b = indicator.el.classList).add.apply(_b, _this._options.indicators.inactiveClasses.split(' ')); + }); + (_a = this._indicators[position].el.classList).add.apply(_a, this._options.indicators.activeClasses.split(' ')); + (_b = this._indicators[position].el.classList).remove.apply(_b, this._options.indicators.inactiveClasses.split(' ')); + this._indicators[position].el.setAttribute('aria-current', 'true'); + } + }; + return Carousel; +}()); +export function initCarousels() { + document.querySelectorAll('[data-carousel]').forEach(function ($carouselEl) { + var interval = $carouselEl.getAttribute('data-carousel-interval'); + var slide = $carouselEl.getAttribute('data-carousel') === 'slide' + ? true + : false; + var items = []; + var defaultPosition = 0; + if ($carouselEl.querySelectorAll('[data-carousel-item]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-item]')).map(function ($carouselItemEl, position) { + items.push({ + position: position, + el: $carouselItemEl, + }); + if ($carouselItemEl.getAttribute('data-carousel-item') === + 'active') { + defaultPosition = position; + } + }); + } + var indicators = []; + if ($carouselEl.querySelectorAll('[data-carousel-slide-to]').length) { + Array.from($carouselEl.querySelectorAll('[data-carousel-slide-to]')).map(function ($indicatorEl) { + indicators.push({ + position: parseInt($indicatorEl.getAttribute('data-carousel-slide-to')), + el: $indicatorEl, + }); + }); + } + var carousel = new Carousel(items, { + defaultPosition: defaultPosition, + indicators: { + items: indicators, + }, + interval: interval ? interval : Default.interval, + }); + if (slide) { + carousel.cycle(); + } + // check for controls + var carouselNextEl = $carouselEl.querySelector('[data-carousel-next]'); + var carouselPrevEl = $carouselEl.querySelector('[data-carousel-prev]'); + if (carouselNextEl) { + carouselNextEl.addEventListener('click', function () { + carousel.next(); + }); + } + if (carouselPrevEl) { + carouselPrevEl.addEventListener('click', function () { + carousel.prev(); + }); + } + }); +} +if (typeof window !== 'undefined') { + window.Carousel = Carousel; + window.initCarousels = initCarousels; +} +export default Carousel; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/index.js.map b/node_modules/flowbite/lib/esm/components/carousel/index.js.map new file mode 100644 index 0000000..116a49d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/carousel/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts b/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts new file mode 100644 index 0000000..edb6114 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts @@ -0,0 +1,20 @@ +import { CarouselOptions, CarouselItem, IndicatorItem, RotationItems } from './types'; +export declare interface CarouselInterface { + _items: CarouselItem[]; + _indicators: IndicatorItem[]; + _activeItem: CarouselItem; + _intervalDuration: number; + _intervalInstance: number; + _options: CarouselOptions; + _init(): void; + getItem(position: number): CarouselItem; + _getActiveItem(): CarouselItem; + _setActiveItem(item: CarouselItem): void; + slideTo(position: number): void; + next(): void; + prev(): void; + _rotate(rotationItems: RotationItems): void; + cycle(): void; + pause(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts.map new file mode 100644 index 0000000..423a855 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,YAAY,EACZ,aAAa,EACb,aAAa,EAChB,MAAM,SAAS,CAAC;AAEjB,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,WAAW,EAAE,aAAa,EAAE,CAAC;IAC7B,WAAW,EAAE,YAAY,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,QAAQ,EAAE,eAAe,CAAC;IAE1B,KAAK,IAAI,IAAI,CAAC;IAEd,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,CAAC;IAExC,cAAc,IAAI,YAAY,CAAC;IAC/B,cAAc,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI,CAAC;IAEzC,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IAEhC,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IAEb,OAAO,CAAC,aAAa,EAAE,aAAa,GAAG,IAAI,CAAC;IAC5C,KAAK,IAAI,IAAI,CAAC;IACd,KAAK,IAAI,IAAI,CAAC;CACjB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/interface.js b/node_modules/flowbite/lib/esm/components/carousel/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/interface.js.map b/node_modules/flowbite/lib/esm/components/carousel/interface.js.map new file mode 100644 index 0000000..3c63595 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/carousel/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/types.d.ts b/node_modules/flowbite/lib/esm/components/carousel/types.d.ts new file mode 100644 index 0000000..8ae7d3d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/types.d.ts @@ -0,0 +1,27 @@ +import { CarouselInterface } from './interface'; +export declare type CarouselItem = { + position: number; + el: HTMLElement; +}; +export declare type IndicatorItem = { + position: number; + el: HTMLElement; +}; +export declare type RotationItems = { + left: CarouselItem; + middle: CarouselItem; + right: CarouselItem; +}; +export declare type CarouselOptions = { + defaultPosition?: number; + indicators?: { + items?: IndicatorItem[]; + activeClasses?: string; + inactiveClasses?: string; + }; + interval?: number; + onNext?: (carousel: CarouselInterface) => void; + onPrev?: (carousel: CarouselInterface) => void; + onChange?: (carousel: CarouselInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/types.d.ts.map b/node_modules/flowbite/lib/esm/components/carousel/types.d.ts.map new file mode 100644 index 0000000..8cb376d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/carousel/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,YAAY,GAAG;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,EAAE,EAAE,WAAW,CAAC;CACnB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,EAAE,EAAE,WAAW,CAAC;CACnB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,IAAI,EAAE,YAAY,CAAC;IACnB,MAAM,EAAE,YAAY,CAAC;IACrB,KAAK,EAAE,YAAY,CAAC;CACvB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE;QACT,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;QACxB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC5B,CAAC;IACF,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC/C,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC/C,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACpD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/types.js b/node_modules/flowbite/lib/esm/components/carousel/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/carousel/types.js.map b/node_modules/flowbite/lib/esm/components/carousel/types.js.map new file mode 100644 index 0000000..72b8fbd --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/carousel/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/carousel/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/index.d.ts b/node_modules/flowbite/lib/esm/components/collapse/index.d.ts new file mode 100644 index 0000000..5e9ce95 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/index.d.ts @@ -0,0 +1,16 @@ +import type { CollapseOptions } from './types'; +import { CollapseInterface } from './interface'; +declare class Collapse implements CollapseInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: CollapseOptions; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: CollapseOptions); + _init(): void; + collapse(): void; + expand(): void; + toggle(): void; +} +export declare function initCollapses(): void; +export default Collapse; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/index.d.ts.map b/node_modules/flowbite/lib/esm/components/collapse/index.d.ts.map new file mode 100644 index 0000000..a530d7f --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAQhD,cAAM,QAAS,YAAW,iBAAiB;IACvC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,eAAyB;IAStC,KAAK;IAgBL,QAAQ;IAWR,MAAM;IAWN,MAAM;CAST;AAED,wBAAgB,aAAa,SAmB5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/index.js b/node_modules/flowbite/lib/esm/components/collapse/index.js new file mode 100644 index 0000000..873e5ce --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/index.js @@ -0,0 +1,94 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + onCollapse: function () { }, + onExpand: function () { }, + onToggle: function () { }, +}; +var Collapse = /** @class */ (function () { + function Collapse(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Collapse.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + if (this._triggerEl.hasAttribute('aria-expanded')) { + this._visible = + this._triggerEl.getAttribute('aria-expanded') === 'true'; + } + else { + // fix until v2 not to break previous single collapses which became dismiss + this._visible = !this._targetEl.classList.contains('hidden'); + } + this._triggerEl.addEventListener('click', function () { + _this.toggle(); + }); + } + }; + Collapse.prototype.collapse = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onCollapse(this); + }; + Collapse.prototype.expand = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onExpand(this); + }; + Collapse.prototype.toggle = function () { + if (this._visible) { + this.collapse(); + } + else { + this.expand(); + } + // callback function + this._options.onToggle(this); + }; + return Collapse; +}()); +export function initCollapses() { + document + .querySelectorAll('[data-collapse-toggle]') + .forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-collapse-toggle'); + var $targetEl = document.getElementById(targetId); + // check if the target element exists + if ($targetEl) { + new Collapse($targetEl, $triggerEl); + } + else { + console.error("The target element with id \"".concat(targetId, "\" does not exist. Please check the data-collapse-toggle attribute.")); + } + }); +} +if (typeof window !== 'undefined') { + window.Collapse = Collapse; + window.initCollapses = initCollapses; +} +export default Collapse; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/index.js.map b/node_modules/flowbite/lib/esm/components/collapse/index.js.map new file mode 100644 index 0000000..62f86e4 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/collapse/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts b/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts new file mode 100644 index 0000000..326fc39 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts @@ -0,0 +1,12 @@ +import { CollapseOptions } from './types'; +export declare interface CollapseInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: CollapseOptions; + _visible: boolean; + _init(): void; + collapse(): void; + expand(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts.map new file mode 100644 index 0000000..cdf74c2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE1C,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAElB,KAAK,IAAI,IAAI,CAAC;IACd,QAAQ,IAAI,IAAI,CAAC;IACjB,MAAM,IAAI,IAAI,CAAC;IACf,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/interface.js b/node_modules/flowbite/lib/esm/components/collapse/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/interface.js.map b/node_modules/flowbite/lib/esm/components/collapse/interface.js.map new file mode 100644 index 0000000..b82a2f4 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/collapse/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/types.d.ts b/node_modules/flowbite/lib/esm/components/collapse/types.d.ts new file mode 100644 index 0000000..3f3094e --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/types.d.ts @@ -0,0 +1,7 @@ +import { CollapseInterface } from './interface'; +export declare type CollapseOptions = { + onCollapse?: (collapse: CollapseInterface) => void; + onExpand?: (collapse: CollapseInterface) => void; + onToggle?: (collapse: CollapseInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/types.d.ts.map b/node_modules/flowbite/lib/esm/components/collapse/types.d.ts.map new file mode 100644 index 0000000..ba058f8 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/collapse/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,UAAU,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACnD,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACjD,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACpD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/types.js b/node_modules/flowbite/lib/esm/components/collapse/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/collapse/types.js.map b/node_modules/flowbite/lib/esm/components/collapse/types.js.map new file mode 100644 index 0000000..c1e2361 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/collapse/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/collapse/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/index.d.ts b/node_modules/flowbite/lib/esm/components/dial/index.d.ts new file mode 100644 index 0000000..c333938 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/index.d.ts @@ -0,0 +1,23 @@ +import type { DialOptions, DialTriggerType } from './types'; +import { DialInterface } from './interface'; +declare class Dial implements DialInterface { + _parentEl: HTMLElement; + _triggerEl: HTMLElement; + _targetEl: HTMLElement; + _options: DialOptions; + _visible: boolean; + constructor(parentEl?: HTMLElement | null, triggerEl?: HTMLElement | null, targetEl?: HTMLElement | null, options?: DialOptions); + _init(): void; + hide(): void; + show(): void; + toggle(): void; + isHidden(): boolean; + isVisible(): boolean; + _getTriggerEventTypes(triggerType: DialTriggerType): { + showEvents: string[]; + hideEvents: string[]; + }; +} +export declare function initDials(): void; +export default Dial; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/index.d.ts.map b/node_modules/flowbite/lib/esm/components/dial/index.d.ts.map new file mode 100644 index 0000000..1b1cd71 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAS5C,cAAM,IAAK,YAAW,aAAa;IAC/B,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,WAAqB;IAUlC,KAAK;IAuBL,IAAI;IAWJ,IAAI;IAWJ,MAAM;IAQN,QAAQ;IAIR,SAAS;IAIT,qBAAqB,CAAC,WAAW,EAAE,eAAe;;;;CAwBrD;AAED,wBAAgB,SAAS,SAgCxB;AAOD,eAAe,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/index.js b/node_modules/flowbite/lib/esm/components/dial/index.js new file mode 100644 index 0000000..8c8d9ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/index.js @@ -0,0 +1,138 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dial = /** @class */ (function () { + function Dial(parentEl, triggerEl, targetEl, options) { + if (parentEl === void 0) { parentEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._parentEl = parentEl; + this._triggerEl = triggerEl; + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Dial.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + var triggerEventTypes = this._getTriggerEventTypes(this._options.triggerType); + triggerEventTypes.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEventTypes.hideEvents.forEach(function (ev) { + _this._parentEl.addEventListener(ev, function () { + if (!_this._parentEl.matches(':hover')) { + _this.hide(); + } + }); + }); + } + }; + Dial.prototype.hide = function () { + this._targetEl.classList.add('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'false'); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Dial.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + if (this._triggerEl) { + this._triggerEl.setAttribute('aria-expanded', 'true'); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dial.prototype.toggle = function () { + if (this._visible) { + this.hide(); + } + else { + this.show(); + } + }; + Dial.prototype.isHidden = function () { + return !this._visible; + }; + Dial.prototype.isVisible = function () { + return this._visible; + }; + Dial.prototype._getTriggerEventTypes = function (triggerType) { + switch (triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + return Dial; +}()); +export function initDials() { + document.querySelectorAll('[data-dial-init]').forEach(function ($parentEl) { + var $triggerEl = $parentEl.querySelector('[data-dial-toggle]'); + if ($triggerEl) { + var dialId = $triggerEl.getAttribute('data-dial-toggle'); + var $dialEl = document.getElementById(dialId); + if ($dialEl) { + var triggerType = $triggerEl.getAttribute('data-dial-trigger'); + new Dial($parentEl, $triggerEl, $dialEl, { + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("Dial with id ".concat(dialId, " does not exist. Are you sure that the data-dial-toggle attribute points to the correct modal id?")); + } + } + else { + console.error("Dial with id ".concat($parentEl.id, " does not have a trigger element. Are you sure that the data-dial-toggle attribute exists?")); + } + }); +} +if (typeof window !== 'undefined') { + window.Dial = Dial; + window.initDials = initDials; +} +export default Dial; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/index.js.map b/node_modules/flowbite/lib/esm/components/dial/index.js.map new file mode 100644 index 0000000..a98ad1c --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dial/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/interface.d.ts b/node_modules/flowbite/lib/esm/components/dial/interface.d.ts new file mode 100644 index 0000000..de0133b --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/interface.d.ts @@ -0,0 +1,16 @@ +import { DialOptions, DialTriggerEventTypes, DialTriggerType } from './types'; +export declare interface DialInterface { + _parentEl: HTMLElement; + _triggerEl: HTMLElement; + _targetEl: HTMLElement; + _options: DialOptions; + _visible: boolean; + _init(): void; + isVisible(): boolean; + isHidden(): boolean; + hide(): void; + show(): void; + toggle(): void; + _getTriggerEventTypes(triggerType: DialTriggerType): DialTriggerEventTypes; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/dial/interface.d.ts.map new file mode 100644 index 0000000..cfa626e --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAE9E,MAAM,CAAC,OAAO,WAAW,aAAa;IAClC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;IACtB,QAAQ,EAAE,OAAO,CAAC;IAElB,KAAK,IAAI,IAAI,CAAC;IACd,SAAS,IAAI,OAAO,CAAC;IACrB,QAAQ,IAAI,OAAO,CAAC;IACpB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;IACf,qBAAqB,CAAC,WAAW,EAAE,eAAe,GAAG,qBAAqB,CAAC;CAC9E"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/interface.js b/node_modules/flowbite/lib/esm/components/dial/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/interface.js.map b/node_modules/flowbite/lib/esm/components/dial/interface.js.map new file mode 100644 index 0000000..83f6457 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dial/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/types.d.ts b/node_modules/flowbite/lib/esm/components/dial/types.d.ts new file mode 100644 index 0000000..2f4877c --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/types.d.ts @@ -0,0 +1,13 @@ +import { DialInterface } from './interface'; +export declare type DialTriggerType = 'click' | 'hover' | 'none'; +export declare type DialTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type DialOptions = { + triggerType?: DialTriggerType; + onShow?: (dial: DialInterface) => void; + onHide?: (dial: DialInterface) => void; + onToggle?: (dial: DialInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/types.d.ts.map b/node_modules/flowbite/lib/esm/components/dial/types.d.ts.map new file mode 100644 index 0000000..da04793 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dial/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEjE,MAAM,CAAC,OAAO,MAAM,qBAAqB,GAAG;IACxC,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,WAAW,GAAG;IAC9B,WAAW,CAAC,EAAE,eAAe,CAAC;IAC9B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IACvC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;CAC5C,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/types.js b/node_modules/flowbite/lib/esm/components/dial/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dial/types.js.map b/node_modules/flowbite/lib/esm/components/dial/types.js.map new file mode 100644 index 0000000..0613f16 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dial/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dial/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts b/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts new file mode 100644 index 0000000..ac75c1d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts @@ -0,0 +1,13 @@ +import type { DismissOptions } from './types'; +import { DismissInterface } from './interface'; +declare class Dismiss implements DismissInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: DismissOptions; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: DismissOptions); + _init(): void; + hide(): void; +} +export declare function initDismisses(): void; +export default Dismiss; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts.map b/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts.map new file mode 100644 index 0000000..5df9d15 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAS/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;gBAGrB,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAQrC,KAAK;IAQL,IAAI;CAcP;AAED,wBAAgB,aAAa,SAa5B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/index.js b/node_modules/flowbite/lib/esm/components/dismiss/index.js new file mode 100644 index 0000000..8538787 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/index.js @@ -0,0 +1,64 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + transition: 'transition-opacity', + duration: 300, + timing: 'ease-out', + onHide: function () { }, +}; +var Dismiss = /** @class */ (function () { + function Dismiss(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Dismiss.prototype._init = function () { + var _this = this; + if (this._triggerEl) { + this._triggerEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Dismiss.prototype.hide = function () { + var _this = this; + this._targetEl.classList.add(this._options.transition, "duration-".concat(this._options.duration), this._options.timing, 'opacity-0'); + setTimeout(function () { + _this._targetEl.classList.add('hidden'); + }, this._options.duration); + // callback function + this._options.onHide(this, this._targetEl); + }; + return Dismiss; +}()); +export function initDismisses() { + document.querySelectorAll('[data-dismiss-target]').forEach(function ($triggerEl) { + var targetId = $triggerEl.getAttribute('data-dismiss-target'); + var $dismissEl = document.querySelector(targetId); + if ($dismissEl) { + new Dismiss($dismissEl, $triggerEl); + } + else { + console.error("The dismiss element with id \"".concat(targetId, "\" does not exist. Please check the data-dismiss-target attribute.")); + } + }); +} +if (typeof window !== 'undefined') { + window.Dismiss = Dismiss; + window.initDismisses = initDismisses; +} +export default Dismiss; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/index.js.map b/node_modules/flowbite/lib/esm/components/dismiss/index.js.map new file mode 100644 index 0000000..1efc3f0 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dismiss/index.ts"],"names":[],"mappings":";;;;;;;;;;;AAIA,IAAM,OAAO,GAAmB;IAC5B,UAAU,EAAE,oBAAoB;IAChC,QAAQ,EAAE,GAAG;IACb,MAAM,EAAE,UAAU;IAClB,MAAM,EAAE,cAAO,CAAC;CACnB,CAAC;AAEF;IAKI,iBACI,QAAmC,EACnC,SAAoC,EACpC,OAAiC;QAFjC,yBAAA,EAAA,eAAmC;QACnC,0BAAA,EAAA,gBAAoC;QACpC,wBAAA,EAAA,iBAAiC;QAEjC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,QAAQ,yBAAQ,OAAO,GAAK,OAAO,CAAE,CAAC;QAC3C,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,uBAAK,GAAL;QAAA,iBAMC;QALG,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,OAAO,EAAE;gBACtC,KAAI,CAAC,IAAI,EAAE,CAAC;YAChB,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,sBAAI,GAAJ;QAAA,iBAaC;QAZG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CACxB,IAAI,CAAC,QAAQ,CAAC,UAAU,EACxB,mBAAY,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAE,EACpC,IAAI,CAAC,QAAQ,CAAC,MAAM,EACpB,WAAW,CACd,CAAC;QACF,UAAU,CAAC;YACP,KAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAE3B,oBAAoB;QACpB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACL,cAAC;AAAD,CAAC,AAtCD,IAsCC;AAED,MAAM,UAAU,aAAa;IACzB,QAAQ,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC,OAAO,CAAC,UAAC,UAAU;QAClE,IAAM,QAAQ,GAAG,UAAU,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC;QAChE,IAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAEpD,IAAI,UAAU,EAAE;YACZ,IAAI,OAAO,CAAC,UAAyB,EAAE,UAAyB,CAAC,CAAC;SACrE;aAAM;YACH,OAAO,CAAC,KAAK,CACT,wCAAgC,QAAQ,uEAAmE,CAC9G,CAAC;SACL;IACL,CAAC,CAAC,CAAC;AACP,CAAC;AAED,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;IAC/B,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,MAAM,CAAC,aAAa,GAAG,aAAa,CAAC;CACxC;AAED,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts b/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts new file mode 100644 index 0000000..e9b8f51 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts @@ -0,0 +1,9 @@ +import { DismissOptions } from './types'; +export declare interface DismissInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: DismissOptions; + _init(): void; + hide(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts.map new file mode 100644 index 0000000..c9c3828 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IAEzB,KAAK,IAAI,IAAI,CAAC;IACd,IAAI,IAAI,IAAI,CAAC;CAChB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/interface.js b/node_modules/flowbite/lib/esm/components/dismiss/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/interface.js.map b/node_modules/flowbite/lib/esm/components/dismiss/interface.js.map new file mode 100644 index 0000000..6b664d5 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dismiss/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts b/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts new file mode 100644 index 0000000..c659c00 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts @@ -0,0 +1,8 @@ +import { DismissInterface } from './interface'; +export declare type DismissOptions = { + transition?: string; + duration?: number; + timing?: string; + onHide?: (dismiss: DismissInterface, targetEl: HTMLElement) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts.map b/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts.map new file mode 100644 index 0000000..2ccb43e --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dismiss/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,WAAW,KAAK,IAAI,CAAC;CACvE,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/types.js b/node_modules/flowbite/lib/esm/components/dismiss/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dismiss/types.js.map b/node_modules/flowbite/lib/esm/components/dismiss/types.js.map new file mode 100644 index 0000000..8ceeeb5 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dismiss/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dismiss/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/index.d.ts b/node_modules/flowbite/lib/esm/components/drawer/index.d.ts new file mode 100644 index 0000000..eecffb5 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/index.d.ts @@ -0,0 +1,21 @@ +import type { DrawerOptions, PlacementClasses } from './types'; +import { DrawerInterface } from './interface'; +declare class Drawer implements DrawerInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DrawerOptions; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, options?: DrawerOptions); + _init(): void; + hide(): void; + show(): void; + toggle(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _getPlacementClasses(placement: string): PlacementClasses; + isHidden(): boolean; + isVisible(): boolean; +} +export declare function initDrawers(): void; +export default Drawer; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/index.d.ts.map b/node_modules/flowbite/lib/esm/components/drawer/index.d.ts.map new file mode 100644 index 0000000..9776f54 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAkB,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAe9C,cAAM,MAAO,YAAW,eAAe;IACnC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,aAAuB;IAQpC,KAAK;IAwBL,IAAI;IA+CJ,IAAI;IA8CJ,MAAM;IAQN,eAAe;IAcf,kBAAkB;IAMlB,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB;IAyCzD,QAAQ;IAIR,SAAS;CAGZ;AAQD,wBAAgB,WAAW,SA+H1B;AAOD,eAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/index.js b/node_modules/flowbite/lib/esm/components/drawer/index.js new file mode 100644 index 0000000..0f063f0 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/index.js @@ -0,0 +1,310 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + placement: 'left', + bodyScrolling: false, + backdrop: true, + edge: false, + edgeOffset: 'bottom-[60px]', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-30', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Drawer = /** @class */ (function () { + function Drawer(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._visible = false; + this._init(); + } + Drawer.prototype._init = function () { + var _this = this; + // set initial accessibility attributes + if (this._targetEl) { + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.classList.add('transition-transform'); + } + // set base placement classes + this._getPlacementClasses(this._options.placement).base.map(function (c) { + _this._targetEl.classList.add(c); + }); + // add keyboard event listener to document + document.addEventListener('keydown', function (event) { + if (event.key === 'Escape') { + // if 'Escape' key is pressed + if (_this.isVisible()) { + // if the Drawer is visible + _this.hide(); // hide the Drawer + } + } + }); + }; + Drawer.prototype.hide = function () { + var _this = this; + // based on the edge option show placement classes + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.remove(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.add(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + // enable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.remove('overflow-hidden'); + } + // destroy backdrop + if (this._options.backdrop) { + this._destroyBackdropEl(); + } + this._visible = false; + // callback function + this._options.onHide(this); + }; + Drawer.prototype.show = function () { + var _this = this; + if (this._options.edge) { + this._getPlacementClasses(this._options.placement + '-edge').active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement + '-edge').inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + else { + this._getPlacementClasses(this._options.placement).active.map(function (c) { + _this._targetEl.classList.add(c); + }); + this._getPlacementClasses(this._options.placement).inactive.map(function (c) { + _this._targetEl.classList.remove(c); + }); + } + // set accessibility attributes + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + // disable body scroll + if (!this._options.bodyScrolling) { + document.body.classList.add('overflow-hidden'); + } + // show backdrop + if (this._options.backdrop) { + this._createBackdrop(); + } + this._visible = true; + // callback function + this._options.onShow(this); + }; + Drawer.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Drawer.prototype._createBackdrop = function () { + var _a; + var _this = this; + if (!this._visible) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('drawer-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + backdropEl.addEventListener('click', function () { + _this.hide(); + }); + } + }; + Drawer.prototype._destroyBackdropEl = function () { + if (this._visible) { + document.querySelector('[drawer-backdrop]').remove(); + } + }; + Drawer.prototype._getPlacementClasses = function (placement) { + switch (placement) { + case 'top': + return { + base: ['top-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['-translate-y-full'], + }; + case 'right': + return { + base: ['right-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-x-full'], + }; + case 'bottom': + return { + base: ['bottom-0', 'left-0', 'right-0'], + active: ['transform-none'], + inactive: ['translate-y-full'], + }; + case 'left': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + case 'bottom-edge': + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['translate-y-full', this._options.edgeOffset], + }; + default: + return { + base: ['left-0', 'top-0'], + active: ['transform-none'], + inactive: ['-translate-x-full'], + }; + } + }; + Drawer.prototype.isHidden = function () { + return !this._visible; + }; + Drawer.prototype.isVisible = function () { + return this._visible; + }; + return Drawer; +}()); +var getDrawerInstance = function (id, instances) { + if (instances.some(function (drawerInstance) { return drawerInstance.id === id; })) { + return instances.find(function (drawerInstance) { return drawerInstance.id === id; }); + } +}; +export function initDrawers() { + var drawerInstances = []; + document.querySelectorAll('[data-drawer-target]').forEach(function ($triggerEl) { + // mandatory + var drawerId = $triggerEl.getAttribute('data-drawer-target'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + // optional + var placement = $triggerEl.getAttribute('data-drawer-placement'); + var bodyScrolling = $triggerEl.getAttribute('data-drawer-body-scrolling'); + var backdrop = $triggerEl.getAttribute('data-drawer-backdrop'); + var edge = $triggerEl.getAttribute('data-drawer-edge'); + var edgeOffset = $triggerEl.getAttribute('data-drawer-edge-offset'); + if (!getDrawerInstance(drawerId, drawerInstances)) { + drawerInstances.push({ + id: drawerId, + object: new Drawer($drawerEl, { + placement: placement ? placement : Default.placement, + bodyScrolling: bodyScrolling + ? bodyScrolling === 'true' + ? true + : false + : Default.bodyScrolling, + backdrop: backdrop + ? backdrop === 'true' + ? true + : false + : Default.backdrop, + edge: edge + ? edge === 'true' + ? true + : false + : Default.edge, + edgeOffset: edgeOffset + ? edgeOffset + : Default.edgeOffset, + }), + }); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document.querySelectorAll('[data-drawer-toggle]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-toggle'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_1 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_1) { + $triggerEl.addEventListener('click', function () { + drawer_1.object.toggle(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); + document + .querySelectorAll('[data-drawer-dismiss], [data-drawer-hide]') + .forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-dismiss') + ? $triggerEl.getAttribute('data-drawer-dismiss') + : $triggerEl.getAttribute('data-drawer-hide'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_2 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_2) { + $triggerEl.addEventListener('click', function () { + drawer_2.object.hide(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id")); + } + }); + document.querySelectorAll('[data-drawer-show]').forEach(function ($triggerEl) { + var drawerId = $triggerEl.getAttribute('data-drawer-show'); + var $drawerEl = document.getElementById(drawerId); + if ($drawerEl) { + var drawer_3 = getDrawerInstance(drawerId, drawerInstances); + if (drawer_3) { + $triggerEl.addEventListener('click', function () { + drawer_3.object.show(); + }); + } + else { + console.error("Drawer with id ".concat(drawerId, " has not been initialized. Please initialize it using the data-drawer-target attribute.")); + } + } + else { + console.error("Drawer with id ".concat(drawerId, " not found. Are you sure that the data-drawer-target attribute points to the correct drawer id?")); + } + }); +} +if (typeof window !== 'undefined') { + window.Drawer = Drawer; + window.initDrawers = initDrawers; +} +export default Drawer; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/index.js.map b/node_modules/flowbite/lib/esm/components/drawer/index.js.map new file mode 100644 index 0000000..91d007a --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/drawer/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts b/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts new file mode 100644 index 0000000..a69c8f1 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts @@ -0,0 +1,17 @@ +import { DrawerOptions, PlacementClasses } from './types'; +export declare interface DrawerInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DrawerOptions; + _visible: boolean; + _init(): void; + isVisible(): boolean; + isHidden(): boolean; + hide(): void; + show(): void; + toggle(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _getPlacementClasses(placement: string): PlacementClasses; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts.map new file mode 100644 index 0000000..367b357 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE1D,MAAM,CAAC,OAAO,WAAW,eAAe;IAEpC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,EAAE,OAAO,CAAC;IAGlB,KAAK,IAAI,IAAI,CAAC;IACd,SAAS,IAAI,OAAO,CAAC;IACrB,QAAQ,IAAI,OAAO,CAAC;IACpB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;IACf,eAAe,IAAI,IAAI,CAAC;IACxB,kBAAkB,IAAI,IAAI,CAAC;IAC3B,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,CAAC;CAC7D"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/interface.js b/node_modules/flowbite/lib/esm/components/drawer/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/interface.js.map b/node_modules/flowbite/lib/esm/components/drawer/interface.js.map new file mode 100644 index 0000000..91cef96 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/drawer/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/types.d.ts b/node_modules/flowbite/lib/esm/components/drawer/types.d.ts new file mode 100644 index 0000000..abc766f --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/types.d.ts @@ -0,0 +1,22 @@ +import { DrawerInterface } from './interface'; +export declare type DrawerOptions = { + placement?: string; + bodyScrolling?: boolean; + backdrop?: boolean; + edge?: boolean; + edgeOffset?: string; + backdropClasses?: string; + onShow?: (drawer: DrawerInterface) => void; + onHide?: (drawer: DrawerInterface) => void; + onToggle?: (drawer: DrawerInterface) => void; +}; +export declare type PlacementClasses = { + base: string[]; + active: string[]; + inactive: string[]; +}; +export declare type DrawerInstance = { + id: string; + object: DrawerInterface; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/types.d.ts.map b/node_modules/flowbite/lib/esm/components/drawer/types.d.ts.map new file mode 100644 index 0000000..ee84e44 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/drawer/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAE9C,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;IAC3C,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;IAC3C,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,eAAe,KAAK,IAAI,CAAC;CAChD,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,gBAAgB,GAAG;IACnC,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,eAAe,CAAC;CAC3B,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/types.js b/node_modules/flowbite/lib/esm/components/drawer/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/drawer/types.js.map b/node_modules/flowbite/lib/esm/components/drawer/types.js.map new file mode 100644 index 0000000..b9d5343 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/drawer/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/drawer/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts b/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts new file mode 100644 index 0000000..d0efbf5 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts @@ -0,0 +1,29 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { DropdownOptions } from './types'; +import { DropdownInterface } from './interface'; +declare class Dropdown implements DropdownInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DropdownOptions; + _visible: boolean; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + constructor(targetElement?: HTMLElement | null, triggerElement?: HTMLElement | null, options?: DropdownOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + toggle(): void; + isVisible(): boolean; + show(): void; + hide(): void; +} +export declare function initDropdowns(): void; +export default Dropdown; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts.map b/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts.map new file mode 100644 index 0000000..51a311c --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAchD,cAAM,QAAS,YAAW,iBAAiB;IACvC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;gBAG3D,aAAa,GAAE,WAAW,GAAG,IAAW,EACxC,cAAc,GAAE,WAAW,GAAG,IAAW,EACzC,OAAO,GAAE,eAAyB;IAUtC,KAAK;IAML,oBAAoB;IA+CpB,qBAAqB;IAiBrB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IA+BpD,iBAAiB;;;;IAyBjB,MAAM;IASN,SAAS;IAIT,IAAI;IAuBJ,IAAI;CAoBP;AAED,wBAAgB,aAAa,SAmD5B;AAOD,eAAe,QAAQ,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/index.js b/node_modules/flowbite/lib/esm/components/dropdown/index.js new file mode 100644 index 0000000..cbd50d2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/index.js @@ -0,0 +1,250 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +/* eslint-disable @typescript-eslint/no-empty-function */ +import { createPopper } from '@popperjs/core'; +var Default = { + placement: 'bottom', + triggerType: 'click', + offsetSkidding: 0, + offsetDistance: 10, + delay: 300, + ignoreClickOutsideClass: false, + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Dropdown = /** @class */ (function () { + function Dropdown(targetElement, triggerElement, options) { + if (targetElement === void 0) { targetElement = null; } + if (triggerElement === void 0) { triggerElement = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetElement; + this._triggerEl = triggerElement; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Dropdown.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Dropdown.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + // click event handling for trigger element + if (this._options.triggerType === 'click') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.toggle(); + }); + }); + } + // hover event handling for trigger element + if (this._options.triggerType === 'hover') { + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + if (ev === 'click') { + _this.toggle(); + } + else { + setTimeout(function () { + _this.show(); + }, _this._options.delay); + } + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, _this._options.delay); + }); + }); + } + }; + Dropdown.prototype._createPopperInstance = function () { + return createPopper(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [ + this._options.offsetSkidding, + this._options.offsetDistance, + ], + }, + }, + ], + }); + }; + Dropdown.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Dropdown.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + // Ignore clicks on the trigger element (ie. a datepicker input) + var ignoreClickOutsideClass = this._options.ignoreClickOutsideClass; + var isIgnored = false; + if (ignoreClickOutsideClass) { + var ignoredClickOutsideEls = document.querySelectorAll(".".concat(ignoreClickOutsideClass)); + ignoredClickOutsideEls.forEach(function (el) { + if (el.contains(clickedEl)) { + isIgnored = true; + return; + } + }); + } + // Ignore clicks on the target element (ie. dropdown itself) + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + !isIgnored && + this.isVisible()) { + this.hide(); + } + }; + Dropdown.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'click'], + hideEvents: ['mouseleave'], + }; + case 'click': + return { + showEvents: ['click'], + hideEvents: [], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['click'], + hideEvents: [], + }; + } + }; + Dropdown.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Dropdown.prototype.isVisible = function () { + return this._visible; + }; + Dropdown.prototype.show = function () { + this._targetEl.classList.remove('hidden'); + this._targetEl.classList.add('block'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + this._setupClickOutsideListener(); + // Update its position + this._popperInstance.update(); + this._visible = true; + // callback function + this._options.onShow(this); + }; + Dropdown.prototype.hide = function () { + this._targetEl.classList.remove('block'); + this._targetEl.classList.add('hidden'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + this._visible = false; + this._removeClickOutsideListener(); + // callback function + this._options.onHide(this); + }; + return Dropdown; +}()); +export function initDropdowns() { + document + .querySelectorAll('[data-dropdown-toggle]') + .forEach(function ($triggerEl) { + var dropdownId = $triggerEl.getAttribute('data-dropdown-toggle'); + var $dropdownEl = document.getElementById(dropdownId); + if ($dropdownEl) { + var placement = $triggerEl.getAttribute('data-dropdown-placement'); + var offsetSkidding = $triggerEl.getAttribute('data-dropdown-offset-skidding'); + var offsetDistance = $triggerEl.getAttribute('data-dropdown-offset-distance'); + var triggerType = $triggerEl.getAttribute('data-dropdown-trigger'); + var delay = $triggerEl.getAttribute('data-dropdown-delay'); + var ignoreClickOutsideClass = $triggerEl.getAttribute('data-dropdown-ignore-click-outside-class'); + new Dropdown($dropdownEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + offsetSkidding: offsetSkidding + ? parseInt(offsetSkidding) + : Default.offsetSkidding, + offsetDistance: offsetDistance + ? parseInt(offsetDistance) + : Default.offsetDistance, + delay: delay ? parseInt(delay) : Default.delay, + ignoreClickOutsideClass: ignoreClickOutsideClass + ? ignoreClickOutsideClass + : Default.ignoreClickOutsideClass, + }); + } + else { + console.error("The dropdown element with id \"".concat(dropdownId, "\" does not exist. Please check the data-dropdown-toggle attribute.")); + } + }); +} +if (typeof window !== 'undefined') { + window.Dropdown = Dropdown; + window.initDropdowns = initDropdowns; +} +export default Dropdown; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/index.js.map b/node_modules/flowbite/lib/esm/components/dropdown/index.js.map new file mode 100644 index 0000000..cb46e51 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/dropdown/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts b/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts new file mode 100644 index 0000000..95a1241 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts @@ -0,0 +1,22 @@ +import { DropdownOptions, DropdownTriggerType, DropdownTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface DropdownInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: DropdownOptions; + _visible: boolean; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _init(): void; + _createPopperInstance(): PopperInstance; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: DropdownTriggerType): DropdownTriggerEventTypes; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts.map new file mode 100644 index 0000000..eef9c76 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,mBAAmB,EACnB,yBAAyB,EAC5B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,iBAAiB;IACtC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAE/D,KAAK,IAAI,IAAI,CAAC;IACd,qBAAqB,IAAI,cAAc,CAAC;IACxC,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,mBAAmB,GACjC,yBAAyB,CAAC;IAC7B,SAAS,IAAI,OAAO,CAAC;IACrB,MAAM,IAAI,IAAI,CAAC;IACf,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;CAChB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/interface.js b/node_modules/flowbite/lib/esm/components/dropdown/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/interface.js.map b/node_modules/flowbite/lib/esm/components/dropdown/interface.js.map new file mode 100644 index 0000000..d4c8eb1 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/dropdown/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts b/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts new file mode 100644 index 0000000..47c79fb --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts @@ -0,0 +1,19 @@ +import { DropdownInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type DropdownTriggerType = 'click' | 'hover' | 'none'; +export declare type DropdownTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type DropdownOptions = { + placement?: Placement; + triggerType?: DropdownTriggerType; + offsetSkidding?: number; + offsetDistance?: number; + ignoreClickOutsideClass?: string | boolean; + delay?: number; + onShow?: (tooltip: DropdownInterface) => void; + onHide?: (tooltip: DropdownInterface) => void; + onToggle?: (tooltip: DropdownInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts.map b/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts.map new file mode 100644 index 0000000..f74ca43 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/dropdown/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,mBAAmB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAErE,MAAM,CAAC,OAAO,MAAM,yBAAyB,GAAG;IAC5C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,eAAe,GAAG;IAClC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,mBAAmB,CAAC;IAClC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,uBAAuB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC9C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IAC9C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;CACnD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/types.js b/node_modules/flowbite/lib/esm/components/dropdown/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/dropdown/types.js.map b/node_modules/flowbite/lib/esm/components/dropdown/types.js.map new file mode 100644 index 0000000..de3d7a3 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/dropdown/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/dropdown/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/index.d.ts b/node_modules/flowbite/lib/esm/components/index.d.ts new file mode 100644 index 0000000..3d22df6 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/index.d.ts @@ -0,0 +1,2 @@ +export declare function initFlowbite(): void; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/index.d.ts.map b/node_modules/flowbite/lib/esm/components/index.d.ts.map new file mode 100644 index 0000000..69c6ef6 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAYA,wBAAgB,YAAY,SAY3B"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/index.js b/node_modules/flowbite/lib/esm/components/index.js new file mode 100644 index 0000000..ac570a9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/index.js @@ -0,0 +1,28 @@ +import { initAccordions } from './accordion'; +import { initCarousels } from './carousel'; +import { initCollapses } from './collapse'; +import { initDials } from './dial'; +import { initDismisses } from './dismiss'; +import { initDrawers } from './drawer'; +import { initDropdowns } from './dropdown'; +import { initModals } from './modal'; +import { initPopovers } from './popover'; +import { initTabs } from './tabs'; +import { initTooltips } from './tooltip'; +export function initFlowbite() { + initAccordions(); + initCollapses(); + initCarousels(); + initDismisses(); + initDropdowns(); + initModals(); + initDrawers(); + initTabs(); + initTooltips(); + initPopovers(); + initDials(); +} +if (typeof window !== 'undefined') { + window.initFlowbite = initFlowbite; +} +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/index.js.map b/node_modules/flowbite/lib/esm/components/index.js.map new file mode 100644 index 0000000..661c695 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AACnC,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,MAAM,UAAU,YAAY;IACxB,cAAc,EAAE,CAAC;IACjB,aAAa,EAAE,CAAC;IAChB,aAAa,EAAE,CAAC;IAChB,aAAa,EAAE,CAAC;IAChB,aAAa,EAAE,CAAC;IAChB,UAAU,EAAE,CAAC;IACb,WAAW,EAAE,CAAC;IACd,QAAQ,EAAE,CAAC;IACX,YAAY,EAAE,CAAC;IACf,YAAY,EAAE,CAAC;IACf,SAAS,EAAE,CAAC;AAChB,CAAC;AAED,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;IAC/B,MAAM,CAAC,YAAY,GAAG,YAAY,CAAC;CACtC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/index.d.ts b/node_modules/flowbite/lib/esm/components/modal/index.d.ts new file mode 100644 index 0000000..be91df7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/index.d.ts @@ -0,0 +1,26 @@ +import type { ModalOptions } from './types'; +import { ModalInterface } from './interface'; +declare class Modal implements ModalInterface { + _targetEl: HTMLElement | null; + _options: ModalOptions; + _isHidden: boolean; + _backdropEl: HTMLElement | null; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + constructor(targetEl?: HTMLElement | null, options?: ModalOptions); + _init(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _setupModalCloseEventListeners(): void; + _removeModalCloseEventListeners(): void; + _handleOutsideClick(target: EventTarget): void; + _getPlacementClasses(): string[]; + toggle(): void; + show(): void; + hide(): void; + isVisible(): boolean; + isHidden(): boolean; +} +export declare function initModals(): void; +export default Modal; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/index.d.ts.map b/node_modules/flowbite/lib/esm/components/modal/index.d.ts.map new file mode 100644 index 0000000..8c64578 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAiB,YAAY,EAAE,MAAM,SAAS,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAa7C,cAAM,KAAM,YAAW,cAAc;IACjC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,QAAQ,EAAE,YAAY,CAAC;IACvB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;gBAGtD,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,OAAO,GAAE,YAAsB;IASnC,KAAK;IAQL,eAAe;IAYf,kBAAkB;IAMlB,8BAA8B;IAwB9B,+BAA+B;IAe/B,mBAAmB,CAAC,MAAM,EAAE,WAAW;IASvC,oBAAoB;IA+BpB,MAAM;IAWN,IAAI;IAuBJ,IAAI;IAsBJ,SAAS;IAIT,QAAQ;CAGX;AASD,wBAAgB,UAAU,SAgIzB;AAOD,eAAe,KAAK,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/index.js b/node_modules/flowbite/lib/esm/components/modal/index.js new file mode 100644 index 0000000..5894a1b --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/index.js @@ -0,0 +1,270 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + placement: 'center', + backdropClasses: 'bg-gray-900 bg-opacity-50 dark:bg-opacity-80 fixed inset-0 z-40', + backdrop: 'dynamic', + closable: true, + onHide: function () { }, + onShow: function () { }, + onToggle: function () { }, +}; +var Modal = /** @class */ (function () { + function Modal(targetEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._options = __assign(__assign({}, Default), options); + this._isHidden = true; + this._backdropEl = null; + this._init(); + } + Modal.prototype._init = function () { + var _this = this; + if (this._targetEl) { + this._getPlacementClasses().map(function (c) { + _this._targetEl.classList.add(c); + }); + } + }; + Modal.prototype._createBackdrop = function () { + var _a; + if (this._isHidden) { + var backdropEl = document.createElement('div'); + backdropEl.setAttribute('modal-backdrop', ''); + (_a = backdropEl.classList).add.apply(_a, this._options.backdropClasses.split(' ')); + document.querySelector('body').append(backdropEl); + this._backdropEl = backdropEl; + } + }; + Modal.prototype._destroyBackdropEl = function () { + if (!this._isHidden) { + document.querySelector('[modal-backdrop]').remove(); + } + }; + Modal.prototype._setupModalCloseEventListeners = function () { + var _this = this; + if (this._options.backdrop === 'dynamic') { + this._clickOutsideEventListener = function (ev) { + _this._handleOutsideClick(ev.target); + }; + this._targetEl.addEventListener('click', this._clickOutsideEventListener, true); + } + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._removeModalCloseEventListeners = function () { + if (this._options.backdrop === 'dynamic') { + this._targetEl.removeEventListener('click', this._clickOutsideEventListener, true); + } + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Modal.prototype._handleOutsideClick = function (target) { + if (target === this._targetEl || + (target === this._backdropEl && this.isVisible())) { + this.hide(); + } + }; + Modal.prototype._getPlacementClasses = function () { + switch (this._options.placement) { + // top + case 'top-left': + return ['justify-start', 'items-start']; + case 'top-center': + return ['justify-center', 'items-start']; + case 'top-right': + return ['justify-end', 'items-start']; + // center + case 'center-left': + return ['justify-start', 'items-center']; + case 'center': + return ['justify-center', 'items-center']; + case 'center-right': + return ['justify-end', 'items-center']; + // bottom + case 'bottom-left': + return ['justify-start', 'items-end']; + case 'bottom-center': + return ['justify-center', 'items-end']; + case 'bottom-right': + return ['justify-end', 'items-end']; + default: + return ['justify-center', 'items-center']; + } + }; + Modal.prototype.toggle = function () { + if (this._isHidden) { + this.show(); + } + else { + this.hide(); + } + // callback function + this._options.onToggle(this); + }; + Modal.prototype.show = function () { + if (this.isHidden) { + this._targetEl.classList.add('flex'); + this._targetEl.classList.remove('hidden'); + this._targetEl.setAttribute('aria-modal', 'true'); + this._targetEl.setAttribute('role', 'dialog'); + this._targetEl.removeAttribute('aria-hidden'); + this._createBackdrop(); + this._isHidden = false; + // prevent body scroll + document.body.classList.add('overflow-hidden'); + // Add keyboard event listener to the document + if (this._options.closable) { + this._setupModalCloseEventListeners(); + } + // callback function + this._options.onShow(this); + } + }; + Modal.prototype.hide = function () { + if (this.isVisible) { + this._targetEl.classList.add('hidden'); + this._targetEl.classList.remove('flex'); + this._targetEl.setAttribute('aria-hidden', 'true'); + this._targetEl.removeAttribute('aria-modal'); + this._targetEl.removeAttribute('role'); + this._destroyBackdropEl(); + this._isHidden = true; + // re-apply body scroll + document.body.classList.remove('overflow-hidden'); + if (this._options.closable) { + this._removeModalCloseEventListeners(); + } + // callback function + this._options.onHide(this); + } + }; + Modal.prototype.isVisible = function () { + return !this._isHidden; + }; + Modal.prototype.isHidden = function () { + return this._isHidden; + }; + return Modal; +}()); +var getModalInstance = function (id, instances) { + if (instances.some(function (modalInstance) { return modalInstance.id === id; })) { + return instances.find(function (modalInstance) { return modalInstance.id === id; }); + } + return null; +}; +export function initModals() { + var modalInstances = []; + // initiate modal based on data-modal-target + document.querySelectorAll('[data-modal-target]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-target'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + if (!getModalInstance(modalId, modalInstances)) { + modalInstances.push({ + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-target attribute points to the correct modal id?.")); + } + }); + // support pre v1.6.0 data-modal-toggle initialization + document.querySelectorAll('[data-modal-toggle]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-toggle'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var placement = $modalEl.getAttribute('data-modal-placement'); + var backdrop = $modalEl.getAttribute('data-modal-backdrop'); + var modal_1 = getModalInstance(modalId, modalInstances); + if (!modal_1) { + modal_1 = { + id: modalId, + object: new Modal($modalEl, { + placement: placement + ? placement + : Default.placement, + backdrop: backdrop ? backdrop : Default.backdrop, + }), + }; + modalInstances.push(modal_1); + } + $triggerEl.addEventListener('click', function () { + modal_1.object.toggle(); + }); + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-toggle attribute points to the correct modal id?")); + } + }); + // show modal on click if exists based on id + document.querySelectorAll('[data-modal-show]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-show'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_2 = getModalInstance(modalId, modalInstances); + if (modal_2) { + $triggerEl.addEventListener('click', function () { + if (modal_2.object.isHidden) { + modal_2.object.show(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-show attribute points to the correct modal id?")); + } + }); + // hide modal on click if exists based on id + document.querySelectorAll('[data-modal-hide]').forEach(function ($triggerEl) { + var modalId = $triggerEl.getAttribute('data-modal-hide'); + var $modalEl = document.getElementById(modalId); + if ($modalEl) { + var modal_3 = getModalInstance(modalId, modalInstances); + if (modal_3) { + $triggerEl.addEventListener('click', function () { + if (modal_3.object.isVisible) { + modal_3.object.hide(); + } + }); + } + else { + console.error("Modal with id ".concat(modalId, " has not been initialized. Please initialize it using the data-modal-target attribute.")); + } + } + else { + console.error("Modal with id ".concat(modalId, " does not exist. Are you sure that the data-modal-hide attribute points to the correct modal id?")); + } + }); +} +if (typeof window !== 'undefined') { + window.Modal = Modal; + window.initModals = initModals; +} +export default Modal; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/index.js.map b/node_modules/flowbite/lib/esm/components/modal/index.js.map new file mode 100644 index 0000000..6b645b9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/modal/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/interface.d.ts b/node_modules/flowbite/lib/esm/components/modal/interface.d.ts new file mode 100644 index 0000000..2df722b --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/interface.d.ts @@ -0,0 +1,21 @@ +import { ModalOptions } from './types'; +export declare interface ModalInterface { + _targetEl: HTMLElement | null; + _options: ModalOptions; + _isHidden: boolean; + _backdropEl: HTMLElement | null; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _init(): void; + _createBackdrop(): void; + _destroyBackdropEl(): void; + _setupModalCloseEventListeners(): void; + _handleOutsideClick(target: EventTarget): void; + _getPlacementClasses(): string[]; + toggle(): void; + show(): void; + hide(): void; + isHidden(): boolean; + isVisible(): boolean; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/modal/interface.d.ts.map new file mode 100644 index 0000000..6fa46f7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,CAAC,OAAO,WAAW,cAAc;IAEnC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAG9B,QAAQ,EAAE,YAAY,CAAC;IAGvB,SAAS,EAAE,OAAO,CAAC;IAGnB,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAEhC,0BAA0B,EAAE,kCAAkC,CAAC;IAE/D,qBAAqB,EAAE,kCAAkC,CAAC;IAG1D,KAAK,IAAI,IAAI,CAAC;IAGd,eAAe,IAAI,IAAI,CAAC;IAGxB,kBAAkB,IAAI,IAAI,CAAC;IAG3B,8BAA8B,IAAI,IAAI,CAAC;IAGvC,mBAAmB,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAG/C,oBAAoB,IAAI,MAAM,EAAE,CAAC;IAGjC,MAAM,IAAI,IAAI,CAAC;IAGf,IAAI,IAAI,IAAI,CAAC;IAGb,IAAI,IAAI,IAAI,CAAC;IAGb,QAAQ,IAAI,OAAO,CAAC;IAGpB,SAAS,IAAI,OAAO,CAAC;CACxB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/interface.js b/node_modules/flowbite/lib/esm/components/modal/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/interface.js.map b/node_modules/flowbite/lib/esm/components/modal/interface.js.map new file mode 100644 index 0000000..5de1079 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/modal/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/types.d.ts b/node_modules/flowbite/lib/esm/components/modal/types.d.ts new file mode 100644 index 0000000..5dccfb1 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/types.d.ts @@ -0,0 +1,17 @@ +import { ModalInterface } from './interface'; +export declare type modalBackdrop = 'static' | 'dynamic'; +export declare type modalPlacement = 'top-left' | 'top-center' | 'top-right' | 'center-left' | 'center' | 'center-right' | 'bottom-left' | 'bottom-center' | 'bottom-right'; +export declare type ModalOptions = { + placement?: modalPlacement; + backdropClasses?: string; + backdrop?: modalBackdrop; + closable?: boolean; + onShow?: (modal: ModalInterface) => void; + onHide?: (modal: ModalInterface) => void; + onToggle?: (modal: ModalInterface) => void; +}; +export declare type ModalInstance = { + id: string; + object: ModalInterface; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/types.d.ts.map b/node_modules/flowbite/lib/esm/components/modal/types.d.ts.map new file mode 100644 index 0000000..2754732 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/modal/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG,QAAQ,GAAG,SAAS,CAAC;AACzD,MAAM,CAAC,OAAO,MAAM,cAAc,GAC5B,UAAU,GACV,YAAY,GACZ,WAAW,GACX,aAAa,GACb,QAAQ,GACR,cAAc,GACd,aAAa,GACb,eAAe,GACf,cAAc,CAAC;AAErB,MAAM,CAAC,OAAO,MAAM,YAAY,GAAG;IAC/B,SAAS,CAAC,EAAE,cAAc,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IACzC,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IACzC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;CAC9C,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,aAAa,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,cAAc,CAAC;CAC1B,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/types.js b/node_modules/flowbite/lib/esm/components/modal/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/modal/types.js.map b/node_modules/flowbite/lib/esm/components/modal/types.js.map new file mode 100644 index 0000000..e049979 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/modal/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/modal/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/index.d.ts b/node_modules/flowbite/lib/esm/components/popover/index.d.ts new file mode 100644 index 0000000..33732b6 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/index.d.ts @@ -0,0 +1,32 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { PopoverOptions } from './types'; +import { PopoverInterface } from './interface'; +declare class Popover implements PopoverInterface { + _targetEl: HTMLElement; + _triggerEl: HTMLElement; + _options: PopoverOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: PopoverOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +export declare function initPopovers(): void; +export default Popover; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/index.d.ts.map b/node_modules/flowbite/lib/esm/components/popover/index.d.ts.map new file mode 100644 index 0000000..67e916e --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAW/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,CAAC;IACvB,UAAU,EAAE,WAAW,CAAC;IACxB,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAC1D,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAUrC,KAAK;IAML,oBAAoB;IA6BpB,qBAAqB;IAcrB,iBAAiB;;;;IAyBjB,qBAAqB;IAarB,sBAAsB;IAQtB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IAYpD,SAAS;IAIT,MAAM;IASN,IAAI;IA6BJ,IAAI;CAyBP;AAED,wBAAgB,YAAY,SA2B3B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/index.js b/node_modules/flowbite/lib/esm/components/popover/index.js new file mode 100644 index 0000000..ea4eb6d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/index.js @@ -0,0 +1,218 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +/* eslint-disable @typescript-eslint/no-empty-function */ +import { createPopper } from '@popperjs/core'; +var Default = { + placement: 'top', + offset: 10, + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Popover = /** @class */ (function () { + function Popover(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Popover.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Popover.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + _this._targetEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._targetEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + _this._targetEl.addEventListener(ev, function () { + setTimeout(function () { + if (!_this._triggerEl.matches(':hover')) { + _this.hide(); + } + }, 100); + }); + }); + }; + Popover.prototype._createPopperInstance = function () { + return createPopper(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, this._options.offset], + }, + }, + ], + }); + }; + Popover.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Popover.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Popover.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Popover.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Popover.prototype.isVisible = function () { + return this._visible; + }; + Popover.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + this._options.onToggle(this); + }; + Popover.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility to true + this._visible = true; + // callback function + this._options.onShow(this); + }; + Popover.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility to false + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Popover; +}()); +export function initPopovers() { + document.querySelectorAll('[data-popover-target]').forEach(function ($triggerEl) { + var popoverID = $triggerEl.getAttribute('data-popover-target'); + var $popoverEl = document.getElementById(popoverID); + if ($popoverEl) { + var triggerType = $triggerEl.getAttribute('data-popover-trigger'); + var placement = $triggerEl.getAttribute('data-popover-placement'); + var offset = $triggerEl.getAttribute('data-popover-offset'); + new Popover($popoverEl, $triggerEl, { + placement: placement ? placement : Default.placement, + offset: offset ? parseInt(offset) : Default.offset, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The popover element with id \"".concat(popoverID, "\" does not exist. Please check the data-popover-target attribute.")); + } + }); +} +if (typeof window !== 'undefined') { + window.Popover = Popover; + window.initPopovers = initPopovers; +} +export default Popover; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/index.js.map b/node_modules/flowbite/lib/esm/components/popover/index.js.map new file mode 100644 index 0000000..f25289c --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/popover/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/interface.d.ts b/node_modules/flowbite/lib/esm/components/popover/interface.d.ts new file mode 100644 index 0000000..851a5a9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/interface.d.ts @@ -0,0 +1,22 @@ +import { PopoverOptions, PopoverTriggerType, PopoverTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface PopoverInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: PopoverOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: PopoverTriggerType): PopoverTriggerEventTypes; + isVisible(): boolean; + show(): void; + hide(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/popover/interface.d.ts.map new file mode 100644 index 0000000..8527eea --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,cAAc,EACd,kBAAkB,EAClB,wBAAwB,EAC3B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAE1D,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,qBAAqB,IAAI,IAAI,CAAC;IAC9B,sBAAsB,IAAI,IAAI,CAAC;IAC/B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,kBAAkB,GAChC,wBAAwB,CAAC;IAC5B,SAAS,IAAI,OAAO,CAAC;IACrB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/interface.js b/node_modules/flowbite/lib/esm/components/popover/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/interface.js.map b/node_modules/flowbite/lib/esm/components/popover/interface.js.map new file mode 100644 index 0000000..495553d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/popover/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/types.d.ts b/node_modules/flowbite/lib/esm/components/popover/types.d.ts new file mode 100644 index 0000000..1b8512f --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/types.d.ts @@ -0,0 +1,16 @@ +import { PopoverInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type PopoverTriggerType = 'click' | 'hover' | 'none'; +export declare type PopoverTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type PopoverOptions = { + placement?: Placement; + offset?: number; + triggerType?: PopoverTriggerType; + onShow?: (tooltip: PopoverInterface) => void; + onHide?: (tooltip: PopoverInterface) => void; + onToggle?: (tooltip: PopoverInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/types.d.ts.map b/node_modules/flowbite/lib/esm/components/popover/types.d.ts.map new file mode 100644 index 0000000..83d1cf6 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/popover/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,kBAAkB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEpE,MAAM,CAAC,OAAO,MAAM,wBAAwB,GAAG;IAC3C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;CAClD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/types.js b/node_modules/flowbite/lib/esm/components/popover/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/popover/types.js.map b/node_modules/flowbite/lib/esm/components/popover/types.js.map new file mode 100644 index 0000000..8f2e0e4 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/popover/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/popover/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/index.d.ts b/node_modules/flowbite/lib/esm/components/tabs/index.d.ts new file mode 100644 index 0000000..fd62e63 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/index.d.ts @@ -0,0 +1,16 @@ +import type { TabItem, TabsOptions } from './types'; +import { TabsInterface } from './interface'; +declare class Tabs implements TabsInterface { + _items: TabItem[]; + _activeTab: TabItem; + _options: TabsOptions; + constructor(items?: TabItem[], options?: TabsOptions); + _init(): void; + getActiveTab(): TabItem; + _setActiveTab(tab: TabItem): void; + getTab(id: string): TabItem; + show(id: string, forceShow?: boolean): void; +} +export declare function initTabs(): void; +export default Tabs; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/index.d.ts.map b/node_modules/flowbite/lib/esm/components/tabs/index.d.ts.map new file mode 100644 index 0000000..bafbd71 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAW5C,cAAM,IAAK,YAAW,aAAa;IAC/B,MAAM,EAAE,OAAO,EAAE,CAAC;IAClB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,WAAW,CAAC;gBAEV,KAAK,GAAE,OAAO,EAAO,EAAE,OAAO,GAAE,WAAqB;IAOjE,KAAK;IAmBL,YAAY;IAIZ,aAAa,CAAC,GAAG,EAAE,OAAO;IAI1B,MAAM,CAAC,EAAE,EAAE,MAAM;IAIjB,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,UAAQ;CAmCrC;AAED,wBAAgB,QAAQ,SA0BvB;AAOD,eAAe,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/index.js b/node_modules/flowbite/lib/esm/components/tabs/index.js new file mode 100644 index 0000000..2e9a4cc --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/index.js @@ -0,0 +1,111 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var Default = { + defaultTabId: null, + activeClasses: 'text-blue-600 hover:text-blue-600 dark:text-blue-500 dark:hover:text-blue-500 border-blue-600 dark:border-blue-500', + inactiveClasses: 'dark:border-transparent text-gray-500 hover:text-gray-600 dark:text-gray-400 border-gray-100 hover:border-gray-300 dark:border-gray-700 dark:hover:text-gray-300', + onShow: function () { }, +}; +var Tabs = /** @class */ (function () { + function Tabs(items, options) { + if (items === void 0) { items = []; } + if (options === void 0) { options = Default; } + this._items = items; + this._activeTab = options ? this.getTab(options.defaultTabId) : null; + this._options = __assign(__assign({}, Default), options); + this._init(); + } + Tabs.prototype._init = function () { + var _this = this; + if (this._items.length) { + // set the first tab as active if not set by explicitly + if (!this._activeTab) { + this._setActiveTab(this._items[0]); + } + // force show the first default tab + this.show(this._activeTab.id, true); + // show tab content based on click + this._items.map(function (tab) { + tab.triggerEl.addEventListener('click', function () { + _this.show(tab.id); + }); + }); + } + }; + Tabs.prototype.getActiveTab = function () { + return this._activeTab; + }; + Tabs.prototype._setActiveTab = function (tab) { + this._activeTab = tab; + }; + Tabs.prototype.getTab = function (id) { + return this._items.filter(function (t) { return t.id === id; })[0]; + }; + Tabs.prototype.show = function (id, forceShow) { + var _a, _b; + var _this = this; + if (forceShow === void 0) { forceShow = false; } + var tab = this.getTab(id); + // don't do anything if already active + if (tab === this._activeTab && !forceShow) { + return; + } + // hide other tabs + this._items.map(function (t) { + var _a, _b; + if (t !== tab) { + (_a = t.triggerEl.classList).remove.apply(_a, _this._options.activeClasses.split(' ')); + (_b = t.triggerEl.classList).add.apply(_b, _this._options.inactiveClasses.split(' ')); + t.targetEl.classList.add('hidden'); + t.triggerEl.setAttribute('aria-selected', 'false'); + } + }); + // show active tab + (_a = tab.triggerEl.classList).add.apply(_a, this._options.activeClasses.split(' ')); + (_b = tab.triggerEl.classList).remove.apply(_b, this._options.inactiveClasses.split(' ')); + tab.triggerEl.setAttribute('aria-selected', 'true'); + tab.targetEl.classList.remove('hidden'); + this._setActiveTab(tab); + // callback function + this._options.onShow(this, tab); + }; + return Tabs; +}()); +export function initTabs() { + document.querySelectorAll('[data-tabs-toggle]').forEach(function ($triggerEl) { + var tabItems = []; + var defaultTabId = null; + $triggerEl + .querySelectorAll('[role="tab"]') + .forEach(function ($triggerEl) { + var isActive = $triggerEl.getAttribute('aria-selected') === 'true'; + var tab = { + id: $triggerEl.getAttribute('data-tabs-target'), + triggerEl: $triggerEl, + targetEl: document.querySelector($triggerEl.getAttribute('data-tabs-target')), + }; + tabItems.push(tab); + if (isActive) { + defaultTabId = tab.id; + } + }); + new Tabs(tabItems, { + defaultTabId: defaultTabId, + }); + }); +} +if (typeof window !== 'undefined') { + window.Tabs = Tabs; + window.initTabs = initTabs; +} +export default Tabs; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/index.js.map b/node_modules/flowbite/lib/esm/components/tabs/index.js.map new file mode 100644 index 0000000..cefce57 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/tabs/index.ts"],"names":[],"mappings":";;;;;;;;;;;AAIA,IAAM,OAAO,GAAgB;IACzB,YAAY,EAAE,IAAI;IAClB,aAAa,EACT,oHAAoH;IACxH,eAAe,EACX,kKAAkK;IACtK,MAAM,EAAE,cAAO,CAAC;CACnB,CAAC;AAEF;IAKI,cAAY,KAAqB,EAAE,OAA8B;QAArD,sBAAA,EAAA,UAAqB;QAAE,wBAAA,EAAA,iBAA8B;QAC7D,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACrE,IAAI,CAAC,QAAQ,yBAAQ,OAAO,GAAK,OAAO,CAAE,CAAC;QAC3C,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,oBAAK,GAAL;QAAA,iBAiBC;QAhBG,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YACpB,uDAAuD;YACvD,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;gBAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;aACtC;YAED,mCAAmC;YACnC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;YAEpC,kCAAkC;YAClC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,UAAC,GAAG;gBAChB,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE;oBACpC,KAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBACtB,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,2BAAY,GAAZ;QACI,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,4BAAa,GAAb,UAAc,GAAY;QACtB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;IAC1B,CAAC;IAED,qBAAM,GAAN,UAAO,EAAU;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAC,CAAC,IAAK,OAAA,CAAC,CAAC,EAAE,KAAK,EAAE,EAAX,CAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,mBAAI,GAAJ,UAAK,EAAU,EAAE,SAAiB;;QAAlC,iBAkCC;QAlCgB,0BAAA,EAAA,iBAAiB;QAC9B,IAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAE5B,sCAAsC;QACtC,IAAI,GAAG,KAAK,IAAI,CAAC,UAAU,IAAI,CAAC,SAAS,EAAE;YACvC,OAAO;SACV;QAED,kBAAkB;QAClB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,UAAC,CAAU;;YACvB,IAAI,CAAC,KAAK,GAAG,EAAE;gBACX,CAAA,KAAA,CAAC,CAAC,SAAS,CAAC,SAAS,CAAA,CAAC,MAAM,WACrB,KAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,EAC3C;gBACF,CAAA,KAAA,CAAC,CAAC,SAAS,CAAC,SAAS,CAAA,CAAC,GAAG,WAClB,KAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,EAC7C;gBACF,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACnC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;aACtD;QACL,CAAC,CAAC,CAAC;QAEH,kBAAkB;QAClB,CAAA,KAAA,GAAG,CAAC,SAAS,CAAC,SAAS,CAAA,CAAC,GAAG,WAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;QACvE,CAAA,KAAA,GAAG,CAAC,SAAS,CAAC,SAAS,CAAA,CAAC,MAAM,WACvB,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,EAC7C;QACF,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;QACpD,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QAExB,oBAAoB;QACpB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACpC,CAAC;IACL,WAAC;AAAD,CAAC,AA9ED,IA8EC;AAED,MAAM,UAAU,QAAQ;IACpB,QAAQ,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,UAAC,UAAU;QAC/D,IAAM,QAAQ,GAAc,EAAE,CAAC;QAC/B,IAAI,YAAY,GAAG,IAAI,CAAC;QACxB,UAAU;aACL,gBAAgB,CAAC,cAAc,CAAC;aAChC,OAAO,CAAC,UAAC,UAAuB;YAC7B,IAAM,QAAQ,GACV,UAAU,CAAC,YAAY,CAAC,eAAe,CAAC,KAAK,MAAM,CAAC;YACxD,IAAM,GAAG,GAAY;gBACjB,EAAE,EAAE,UAAU,CAAC,YAAY,CAAC,kBAAkB,CAAC;gBAC/C,SAAS,EAAE,UAAU;gBACrB,QAAQ,EAAE,QAAQ,CAAC,aAAa,CAC5B,UAAU,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAC9C;aACJ,CAAC;YACF,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAEnB,IAAI,QAAQ,EAAE;gBACV,YAAY,GAAG,GAAG,CAAC,EAAE,CAAC;aACzB;QACL,CAAC,CAAC,CAAC;QACP,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,YAAY,EAAE,YAAY;SACd,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;AACP,CAAC;AAED,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;IAC/B,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;CAC9B;AAED,eAAe,IAAI,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts b/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts new file mode 100644 index 0000000..9e07566 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts @@ -0,0 +1,12 @@ +import { TabItem, TabsOptions } from './types'; +export declare interface TabsInterface { + _items: TabItem[]; + _activeTab: TabItem; + _options: TabsOptions; + _init(): void; + _setActiveTab(tab: TabItem): void; + getActiveTab(): TabItem; + getTab(id: string): TabItem; + show(id: string, forceShow?: boolean): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts.map new file mode 100644 index 0000000..3cd72bd --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE/C,MAAM,CAAC,OAAO,WAAW,aAAa;IAClC,MAAM,EAAE,OAAO,EAAE,CAAC;IAClB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,WAAW,CAAC;IAEtB,KAAK,IAAI,IAAI,CAAC;IACd,aAAa,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;IAClC,YAAY,IAAI,OAAO,CAAC;IACxB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC;IAC5B,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;CAC/C"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/interface.js b/node_modules/flowbite/lib/esm/components/tabs/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/interface.js.map b/node_modules/flowbite/lib/esm/components/tabs/interface.js.map new file mode 100644 index 0000000..6fc7bb2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/tabs/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/types.d.ts b/node_modules/flowbite/lib/esm/components/tabs/types.d.ts new file mode 100644 index 0000000..342be0d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/types.d.ts @@ -0,0 +1,13 @@ +import { TabsInterface } from './interface'; +export declare type TabsOptions = { + defaultTabId?: string; + activeClasses?: string; + inactiveClasses?: string; + onShow?: (tabs: TabsInterface, tab: TabItem) => void; +}; +export declare type TabItem = { + id: string; + triggerEl: HTMLElement; + targetEl: HTMLElement; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/types.d.ts.map b/node_modules/flowbite/lib/esm/components/tabs/types.d.ts.map new file mode 100644 index 0000000..da457a9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,CAAC,OAAO,MAAM,WAAW,GAAG;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,EAAE,GAAG,EAAE,OAAO,KAAK,IAAI,CAAC;CACxD,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,OAAO,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,EAAE,WAAW,CAAC;CACzB,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/types.js b/node_modules/flowbite/lib/esm/components/tabs/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tabs/types.js.map b/node_modules/flowbite/lib/esm/components/tabs/types.js.map new file mode 100644 index 0000000..a4a4aff --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tabs/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/tabs/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts b/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts new file mode 100644 index 0000000..041a7da --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts @@ -0,0 +1,32 @@ +import type { Instance as PopperInstance } from '@popperjs/core'; +import type { TooltipOptions } from './types'; +import { TooltipInterface } from './interface'; +declare class Tooltip implements TooltipInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: TooltipOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _visible: boolean; + constructor(targetEl?: HTMLElement | null, triggerEl?: HTMLElement | null, options?: TooltipOptions); + _init(): void; + _setupEventListeners(): void; + _createPopperInstance(): PopperInstance; + _getTriggerEvents(): { + showEvents: string[]; + hideEvents: string[]; + }; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + isVisible(): boolean; + toggle(): void; + show(): void; + hide(): void; +} +export declare function initTooltips(): void; +export default Tooltip; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts.map b/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts.map new file mode 100644 index 0000000..fc88084 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/index.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAER,QAAQ,IAAI,cAAc,EAC7B,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAU/C,cAAM,OAAQ,YAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAC1D,QAAQ,EAAE,OAAO,CAAC;gBAGd,QAAQ,GAAE,WAAW,GAAG,IAAW,EACnC,SAAS,GAAE,WAAW,GAAG,IAAW,EACpC,OAAO,GAAE,cAAwB;IAUrC,KAAK;IAML,oBAAoB;IAcpB,qBAAqB;IAcrB,iBAAiB;;;;IAyBjB,qBAAqB;IAarB,sBAAsB;IAQtB,0BAA0B;IAW1B,2BAA2B;IAQ3B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW;IAYpD,SAAS;IAIT,MAAM;IAQN,IAAI;IA6BJ,IAAI;CAyBP;AAED,wBAAgB,YAAY,SAyB3B;AAOD,eAAe,OAAO,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/index.js b/node_modules/flowbite/lib/esm/components/tooltip/index.js new file mode 100644 index 0000000..2fa8da8 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/index.js @@ -0,0 +1,200 @@ +var __assign = (this && this.__assign) || function () { + __assign = Object.assign || function(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) + t[p] = s[p]; + } + return t; + }; + return __assign.apply(this, arguments); +}; +var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { + if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +}; +/* eslint-disable @typescript-eslint/no-empty-function */ +import { createPopper } from '@popperjs/core'; +var Default = { + placement: 'top', + triggerType: 'hover', + onShow: function () { }, + onHide: function () { }, + onToggle: function () { }, +}; +var Tooltip = /** @class */ (function () { + function Tooltip(targetEl, triggerEl, options) { + if (targetEl === void 0) { targetEl = null; } + if (triggerEl === void 0) { triggerEl = null; } + if (options === void 0) { options = Default; } + this._targetEl = targetEl; + this._triggerEl = triggerEl; + this._options = __assign(__assign({}, Default), options); + this._popperInstance = this._createPopperInstance(); + this._visible = false; + this._init(); + } + Tooltip.prototype._init = function () { + if (this._triggerEl) { + this._setupEventListeners(); + } + }; + Tooltip.prototype._setupEventListeners = function () { + var _this = this; + var triggerEvents = this._getTriggerEvents(); + triggerEvents.showEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.show(); + }); + }); + triggerEvents.hideEvents.forEach(function (ev) { + _this._triggerEl.addEventListener(ev, function () { + _this.hide(); + }); + }); + }; + Tooltip.prototype._createPopperInstance = function () { + return createPopper(this._triggerEl, this._targetEl, { + placement: this._options.placement, + modifiers: [ + { + name: 'offset', + options: { + offset: [0, 8], + }, + }, + ], + }); + }; + Tooltip.prototype._getTriggerEvents = function () { + switch (this._options.triggerType) { + case 'hover': + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + case 'click': + return { + showEvents: ['click', 'focus'], + hideEvents: ['focusout', 'blur'], + }; + case 'none': + return { + showEvents: [], + hideEvents: [], + }; + default: + return { + showEvents: ['mouseenter', 'focus'], + hideEvents: ['mouseleave', 'blur'], + }; + } + }; + Tooltip.prototype._setupKeydownListener = function () { + var _this = this; + this._keydownEventListener = function (ev) { + if (ev.key === 'Escape') { + _this.hide(); + } + }; + document.body.addEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._removeKeydownListener = function () { + document.body.removeEventListener('keydown', this._keydownEventListener, true); + }; + Tooltip.prototype._setupClickOutsideListener = function () { + var _this = this; + this._clickOutsideEventListener = function (ev) { + _this._handleClickOutside(ev, _this._targetEl); + }; + document.body.addEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._removeClickOutsideListener = function () { + document.body.removeEventListener('click', this._clickOutsideEventListener, true); + }; + Tooltip.prototype._handleClickOutside = function (ev, targetEl) { + var clickedEl = ev.target; + if (clickedEl !== targetEl && + !targetEl.contains(clickedEl) && + !this._triggerEl.contains(clickedEl) && + this.isVisible()) { + this.hide(); + } + }; + Tooltip.prototype.isVisible = function () { + return this._visible; + }; + Tooltip.prototype.toggle = function () { + if (this.isVisible()) { + this.hide(); + } + else { + this.show(); + } + }; + Tooltip.prototype.show = function () { + this._targetEl.classList.remove('opacity-0', 'invisible'); + this._targetEl.classList.add('opacity-100', 'visible'); + // Enable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: true }, + ], false) })); }); + // handle click outside + this._setupClickOutsideListener(); + // handle esc keydown + this._setupKeydownListener(); + // Update its position + this._popperInstance.update(); + // set visibility + this._visible = true; + // callback function + this._options.onShow(this); + }; + Tooltip.prototype.hide = function () { + this._targetEl.classList.remove('opacity-100', 'visible'); + this._targetEl.classList.add('opacity-0', 'invisible'); + // Disable the event listeners + this._popperInstance.setOptions(function (options) { return (__assign(__assign({}, options), { modifiers: __spreadArray(__spreadArray([], options.modifiers, true), [ + { name: 'eventListeners', enabled: false }, + ], false) })); }); + // handle click outside + this._removeClickOutsideListener(); + // handle esc keydown + this._removeKeydownListener(); + // set visibility + this._visible = false; + // callback function + this._options.onHide(this); + }; + return Tooltip; +}()); +export function initTooltips() { + document.querySelectorAll('[data-tooltip-target]').forEach(function ($triggerEl) { + var tooltipId = $triggerEl.getAttribute('data-tooltip-target'); + var $tooltipEl = document.getElementById(tooltipId); + if ($tooltipEl) { + var triggerType = $triggerEl.getAttribute('data-tooltip-trigger'); + var placement = $triggerEl.getAttribute('data-tooltip-placement'); + new Tooltip($tooltipEl, $triggerEl, { + placement: placement ? placement : Default.placement, + triggerType: triggerType + ? triggerType + : Default.triggerType, + }); + } + else { + console.error("The tooltip element with id \"".concat(tooltipId, "\" does not exist. Please check the data-tooltip-target attribute.")); + } + }); +} +if (typeof window !== 'undefined') { + window.Tooltip = Tooltip; + window.initTooltips = initTooltips; +} +export default Tooltip; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/index.js.map b/node_modules/flowbite/lib/esm/components/tooltip/index.js.map new file mode 100644 index 0000000..75e62ba --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/tooltip/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts b/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts new file mode 100644 index 0000000..f081b33 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts @@ -0,0 +1,23 @@ +import { TooltipOptions, TooltipTriggerType, TooltipTriggerEventTypes } from './types'; +import type { Instance as PopperInstance } from '@popperjs/core'; +export declare interface TooltipInterface { + _targetEl: HTMLElement | null; + _triggerEl: HTMLElement | null; + _options: TooltipOptions; + _popperInstance: PopperInstance; + _clickOutsideEventListener: EventListenerOrEventListenerObject; + _keydownEventListener: EventListenerOrEventListenerObject; + _init(): void; + _setupEventListeners(): void; + _setupClickOutsideListener(): void; + _removeClickOutsideListener(): void; + _setupKeydownListener(): void; + _removeKeydownListener(): void; + _handleClickOutside(ev: Event, targetEl: HTMLElement): void; + _getTriggerEvents(triggerType: TooltipTriggerType): TooltipTriggerEventTypes; + isVisible(): boolean; + show(): void; + hide(): void; + toggle(): void; +} +//# sourceMappingURL=interface.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts.map b/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts.map new file mode 100644 index 0000000..b395e6b --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/interface.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/interface.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,cAAc,EACd,kBAAkB,EAClB,wBAAwB,EAC3B,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,CAAC,OAAO,WAAW,gBAAgB;IACrC,SAAS,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9B,UAAU,EAAE,WAAW,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,cAAc,CAAC;IACzB,eAAe,EAAE,cAAc,CAAC;IAChC,0BAA0B,EAAE,kCAAkC,CAAC;IAC/D,qBAAqB,EAAE,kCAAkC,CAAC;IAE1D,KAAK,IAAI,IAAI,CAAC;IACd,oBAAoB,IAAI,IAAI,CAAC;IAC7B,0BAA0B,IAAI,IAAI,CAAC;IACnC,2BAA2B,IAAI,IAAI,CAAC;IACpC,qBAAqB,IAAI,IAAI,CAAC;IAC9B,sBAAsB,IAAI,IAAI,CAAC;IAC/B,mBAAmB,CAAC,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,CAAC;IAC5D,iBAAiB,CACb,WAAW,EAAE,kBAAkB,GAChC,wBAAwB,CAAC;IAC5B,SAAS,IAAI,OAAO,CAAC;IACrB,IAAI,IAAI,IAAI,CAAC;IACb,IAAI,IAAI,IAAI,CAAC;IACb,MAAM,IAAI,IAAI,CAAC;CAClB"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/interface.js b/node_modules/flowbite/lib/esm/components/tooltip/interface.js new file mode 100644 index 0000000..95423ac --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/interface.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=interface.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/interface.js.map b/node_modules/flowbite/lib/esm/components/tooltip/interface.js.map new file mode 100644 index 0000000..8a5f072 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/interface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../../src/components/tooltip/interface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts b/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts new file mode 100644 index 0000000..1ba5bb3 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts @@ -0,0 +1,15 @@ +import { TooltipInterface } from './interface'; +import type { Placement } from '@popperjs/core'; +export declare type TooltipTriggerType = 'click' | 'hover' | 'none'; +export declare type TooltipTriggerEventTypes = { + showEvents: string[]; + hideEvents: string[]; +}; +export declare type TooltipOptions = { + placement?: Placement; + triggerType?: TooltipTriggerType; + onShow?: (tooltip: TooltipInterface) => void; + onHide?: (tooltip: TooltipInterface) => void; + onToggle?: (tooltip: TooltipInterface) => void; +}; +//# sourceMappingURL=types.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts.map b/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts.map new file mode 100644 index 0000000..048bf1d --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/types.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/tooltip/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,CAAC,OAAO,MAAM,kBAAkB,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;AAEpE,MAAM,CAAC,OAAO,MAAM,wBAAwB,GAAG;IAC3C,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,CAAC,OAAO,MAAM,cAAc,GAAG;IACjC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC7C,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,IAAI,CAAC;CAClD,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/types.js b/node_modules/flowbite/lib/esm/components/tooltip/types.js new file mode 100644 index 0000000..718fd38 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/types.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=types.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/components/tooltip/types.js.map b/node_modules/flowbite/lib/esm/components/tooltip/types.js.map new file mode 100644 index 0000000..cd09cf9 --- /dev/null +++ b/node_modules/flowbite/lib/esm/components/tooltip/types.js.map @@ -0,0 +1 @@ +{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/tooltip/types.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/config/global.d.ts b/node_modules/flowbite/lib/esm/config/global.d.ts new file mode 100644 index 0000000..8937b76 --- /dev/null +++ b/node_modules/flowbite/lib/esm/config/global.d.ts @@ -0,0 +1,39 @@ +import Accordion from '../components/accordion'; +import Carousel from '../components/carousel'; +import Collapse from '../components/collapse'; +import Dial from '../components/dial'; +import Dismiss from '../components/dismiss'; +import Drawer from '../components/drawer'; +import Dropdown from '../components/dropdown'; +import Modal from '../components/modal'; +import Popover from '../components/popover'; +import Tabs from '../components/tabs'; +import Tooltip from '../components/tooltip'; +declare global { + interface Window { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Dismiss: typeof Dismiss; + Drawer: typeof Drawer; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + initAccordions: () => void; + initCarousels: () => void; + initCollapses: () => void; + initDials: () => void; + initDismisses: () => void; + initDrawers: () => void; + initDropdowns: () => void; + initModals: () => void; + initPopovers: () => void; + initTabs: () => void; + initTooltips: () => void; + initFlowbite: () => void; + } +} +//# sourceMappingURL=global.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/config/global.d.ts.map b/node_modules/flowbite/lib/esm/config/global.d.ts.map new file mode 100644 index 0000000..b57ae87 --- /dev/null +++ b/node_modules/flowbite/lib/esm/config/global.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"global.d.ts","sourceRoot":"","sources":["../../../src/config/global.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,yBAAyB,CAAC;AAChD,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,IAAI,MAAM,oBAAoB,CAAC;AACtC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,MAAM,MAAM,sBAAsB,CAAC;AAC1C,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,KAAK,MAAM,qBAAqB,CAAC;AACxC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,IAAI,MAAM,oBAAoB,CAAC;AACtC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAE5C,OAAO,CAAC,MAAM,CAAC;IACX,UAAU,MAAM;QACZ,SAAS,EAAE,OAAO,SAAS,CAAC;QAC5B,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,IAAI,EAAE,OAAO,IAAI,CAAC;QAClB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,MAAM,EAAE,OAAO,MAAM,CAAC;QACtB,QAAQ,EAAE,OAAO,QAAQ,CAAC;QAC1B,KAAK,EAAE,OAAO,KAAK,CAAC;QACpB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,IAAI,EAAE,OAAO,IAAI,CAAC;QAClB,OAAO,EAAE,OAAO,OAAO,CAAC;QACxB,cAAc,EAAE,MAAM,IAAI,CAAC;QAC3B,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,SAAS,EAAE,MAAM,IAAI,CAAC;QACtB,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,WAAW,EAAE,MAAM,IAAI,CAAC;QACxB,aAAa,EAAE,MAAM,IAAI,CAAC;QAC1B,UAAU,EAAE,MAAM,IAAI,CAAC;QACvB,YAAY,EAAE,MAAM,IAAI,CAAC;QACzB,QAAQ,EAAE,MAAM,IAAI,CAAC;QACrB,YAAY,EAAE,MAAM,IAAI,CAAC;QACzB,YAAY,EAAE,MAAM,IAAI,CAAC;KAC5B;CACJ"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/config/global.js b/node_modules/flowbite/lib/esm/config/global.js new file mode 100644 index 0000000..a8d4563 --- /dev/null +++ b/node_modules/flowbite/lib/esm/config/global.js @@ -0,0 +1,2 @@ +export {}; +//# sourceMappingURL=global.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/config/global.js.map b/node_modules/flowbite/lib/esm/config/global.js.map new file mode 100644 index 0000000..52ccc1e --- /dev/null +++ b/node_modules/flowbite/lib/esm/config/global.js.map @@ -0,0 +1 @@ +{"version":3,"file":"global.js","sourceRoot":"","sources":["../../../src/config/global.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/dom/events.d.ts b/node_modules/flowbite/lib/esm/dom/events.d.ts new file mode 100644 index 0000000..3bbb83b --- /dev/null +++ b/node_modules/flowbite/lib/esm/dom/events.d.ts @@ -0,0 +1,8 @@ +declare class Events { + private _eventType; + private _eventFunctions; + constructor(eventType: string, eventFunctions?: EventListener[]); + init(): void; +} +export default Events; +//# sourceMappingURL=events.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/dom/events.d.ts.map b/node_modules/flowbite/lib/esm/dom/events.d.ts.map new file mode 100644 index 0000000..de90c16 --- /dev/null +++ b/node_modules/flowbite/lib/esm/dom/events.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../../src/dom/events.ts"],"names":[],"mappings":"AAAA,cAAM,MAAM;IACR,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,eAAe,CAAkB;gBAE7B,SAAS,EAAE,MAAM,EAAE,cAAc,GAAE,aAAa,EAAO;IAKnE,IAAI;CAOP;AAED,eAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/dom/events.js b/node_modules/flowbite/lib/esm/dom/events.js new file mode 100644 index 0000000..3d335f6 --- /dev/null +++ b/node_modules/flowbite/lib/esm/dom/events.js @@ -0,0 +1,18 @@ +var Events = /** @class */ (function () { + function Events(eventType, eventFunctions) { + if (eventFunctions === void 0) { eventFunctions = []; } + this._eventType = eventType; + this._eventFunctions = eventFunctions; + } + Events.prototype.init = function () { + var _this = this; + this._eventFunctions.forEach(function (eventFunction) { + if (typeof window !== 'undefined') { + window.addEventListener(_this._eventType, eventFunction); + } + }); + }; + return Events; +}()); +export default Events; +//# sourceMappingURL=events.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/dom/events.js.map b/node_modules/flowbite/lib/esm/dom/events.js.map new file mode 100644 index 0000000..727d3ef --- /dev/null +++ b/node_modules/flowbite/lib/esm/dom/events.js.map @@ -0,0 +1 @@ +{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/dom/events.ts"],"names":[],"mappings":"AAAA;IAII,gBAAY,SAAiB,EAAE,cAAoC;QAApC,+BAAA,EAAA,mBAAoC;QAC/D,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;IAC1C,CAAC;IAED,qBAAI,GAAJ;QAAA,iBAMC;QALG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,UAAC,aAAa;YACvC,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;gBAC/B,MAAM,CAAC,gBAAgB,CAAC,KAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;aAC3D;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACL,aAAC;AAAD,CAAC,AAhBD,IAgBC;AAED,eAAe,MAAM,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.d.ts b/node_modules/flowbite/lib/esm/index.d.ts new file mode 100644 index 0000000..5660236 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.d.ts @@ -0,0 +1,47 @@ +import './components/index'; +export { default as Accordion } from './components/accordion'; +export { default as Carousel } from './components/carousel'; +export { default as Collapse } from './components/collapse'; +export { default as Dial } from './components/dial'; +export { default as Dismiss } from './components/dismiss'; +export { default as Drawer } from './components/drawer'; +export { default as Dropdown } from './components/dropdown'; +export { default as Modal } from './components/modal'; +export { default as Popover } from './components/popover'; +export { default as Tabs } from './components/tabs'; +export { default as Tooltip } from './components/tooltip'; +export * from './components/accordion/types'; +export * from './components/carousel/types'; +export * from './components/collapse/types'; +export * from './components/dial/types'; +export * from './components/dismiss/types'; +export * from './components/drawer/types'; +export * from './components/dropdown/types'; +export * from './components/modal/types'; +export * from './components/popover/types'; +export * from './components/tabs/types'; +export * from './components/tooltip/types'; +export * from './components/accordion/interface'; +export * from './components/carousel/interface'; +export * from './components/collapse/interface'; +export * from './components/dial/interface'; +export * from './components/dismiss/interface'; +export * from './components/drawer/interface'; +export * from './components/dropdown/interface'; +export * from './components/modal/interface'; +export * from './components/popover/interface'; +export * from './components/tabs/interface'; +export * from './components/tooltip/interface'; +export { initAccordions } from './components/accordion'; +export { initCarousels } from './components/carousel'; +export { initCollapses } from './components/collapse'; +export { initDials } from './components/dial'; +export { initDismisses } from './components/dismiss'; +export { initDrawers } from './components/drawer'; +export { initDropdowns } from './components/dropdown'; +export { initModals } from './components/modal'; +export { initPopovers } from './components/popover'; +export { initTabs } from './components/tabs'; +export { initTooltips } from './components/tooltip'; +export { initFlowbite } from './components/index'; +//# sourceMappingURL=index.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.d.ts.map b/node_modules/flowbite/lib/esm/index.d.ts.map new file mode 100644 index 0000000..8997bca --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAYA,OAAO,oBAAoB,CAAC;AAmB5B,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG1D,cAAc,8BAA8B,CAAC;AAC7C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAG3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,iCAAiC,CAAC;AAChD,cAAc,iCAAiC,CAAC;AAChD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iCAAiC,CAAC;AAChD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,gCAAgC,CAAC;AAG/C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAGpD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.js b/node_modules/flowbite/lib/esm/index.js new file mode 100644 index 0000000..5511f9c --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.js @@ -0,0 +1,79 @@ +import Events from './dom/events'; +import { initAccordions } from './components/accordion'; +import { initCollapses } from './components/collapse'; +import { initCarousels } from './components/carousel'; +import { initDismisses } from './components/dismiss'; +import { initDropdowns } from './components/dropdown'; +import { initModals } from './components/modal'; +import { initDrawers } from './components/drawer'; +import { initTabs } from './components/tabs'; +import { initTooltips } from './components/tooltip'; +import { initPopovers } from './components/popover'; +import { initDials } from './components/dial'; +import './components/index'; +// setup events for data attributes +var events = new Events('load', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +events.init(); +// export all components +export { default as Accordion } from './components/accordion'; +export { default as Carousel } from './components/carousel'; +export { default as Collapse } from './components/collapse'; +export { default as Dial } from './components/dial'; +export { default as Dismiss } from './components/dismiss'; +export { default as Drawer } from './components/drawer'; +export { default as Dropdown } from './components/dropdown'; +export { default as Modal } from './components/modal'; +export { default as Popover } from './components/popover'; +export { default as Tabs } from './components/tabs'; +export { default as Tooltip } from './components/tooltip'; +// export all types +export * from './components/accordion/types'; +export * from './components/carousel/types'; +export * from './components/collapse/types'; +export * from './components/dial/types'; +export * from './components/dismiss/types'; +export * from './components/drawer/types'; +export * from './components/dropdown/types'; +export * from './components/modal/types'; +export * from './components/popover/types'; +export * from './components/tabs/types'; +export * from './components/tooltip/types'; +// export all interfaces +export * from './components/accordion/interface'; +export * from './components/carousel/interface'; +export * from './components/collapse/interface'; +export * from './components/dial/interface'; +export * from './components/dismiss/interface'; +export * from './components/drawer/interface'; +export * from './components/dropdown/interface'; +export * from './components/modal/interface'; +export * from './components/popover/interface'; +export * from './components/tabs/interface'; +export * from './components/tooltip/interface'; +// export init functions +export { initAccordions } from './components/accordion'; +export { initCarousels } from './components/carousel'; +export { initCollapses } from './components/collapse'; +export { initDials } from './components/dial'; +export { initDismisses } from './components/dismiss'; +export { initDrawers } from './components/drawer'; +export { initDropdowns } from './components/dropdown'; +export { initModals } from './components/modal'; +export { initPopovers } from './components/popover'; +export { initTabs } from './components/tabs'; +export { initTooltips } from './components/tooltip'; +// export all init functions +export { initFlowbite } from './components/index'; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.js.map b/node_modules/flowbite/lib/esm/index.js.map new file mode 100644 index 0000000..f6ee034 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.phoenix.d.ts b/node_modules/flowbite/lib/esm/index.phoenix.d.ts new file mode 100644 index 0000000..9bec6d4 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.phoenix.d.ts @@ -0,0 +1,29 @@ +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.phoenix.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.phoenix.d.ts.map b/node_modules/flowbite/lib/esm/index.phoenix.d.ts.map new file mode 100644 index 0000000..0e05cf0 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.phoenix.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.phoenix.d.ts","sourceRoot":"","sources":["../../src/index.phoenix.ts"],"names":[],"mappings":"AACA,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAgClC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.phoenix.js b/node_modules/flowbite/lib/esm/index.phoenix.js new file mode 100644 index 0000000..f0b94d7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.phoenix.js @@ -0,0 +1,57 @@ +// core components +import Accordion, { initAccordions } from './components/accordion'; +import Carousel, { initCarousels } from './components/carousel'; +import Collapse, { initCollapses } from './components/collapse'; +import Dial, { initDials } from './components/dial'; +import Dismiss, { initDismisses } from './components/dismiss'; +import Drawer, { initDrawers } from './components/drawer'; +import Dropdown, { initDropdowns } from './components/dropdown'; +import Modal, { initModals } from './components/modal'; +import Popover, { initPopovers } from './components/popover'; +import Tabs, { initTabs } from './components/tabs'; +import Tooltip, { initTooltips } from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +var liveViewLoadEvents = new Events('phx:page-loading-stop', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +liveViewLoadEvents.init(); +var regularViewLoadEvents = new Events('load', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +regularViewLoadEvents.init(); +export default { + Accordion: Accordion, + Carousel: Carousel, + Collapse: Collapse, + Dial: Dial, + Drawer: Drawer, + Dismiss: Dismiss, + Dropdown: Dropdown, + Modal: Modal, + Popover: Popover, + Tabs: Tabs, + Tooltip: Tooltip, + Events: Events, +}; +//# sourceMappingURL=index.phoenix.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.phoenix.js.map b/node_modules/flowbite/lib/esm/index.phoenix.js.map new file mode 100644 index 0000000..76890b7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.phoenix.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.phoenix.js","sourceRoot":"","sources":["../../src/index.phoenix.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,OAAO,SAAS,EAAE,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAAO,EAAE,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;AAElC,IAAM,kBAAkB,GAAG,IAAI,MAAM,CAAC,uBAAuB,EAAE;IAC3D,cAAc;IACd,aAAa;IACb,aAAa;IACb,aAAa;IACb,aAAa;IACb,UAAU;IACV,WAAW;IACX,QAAQ;IACR,YAAY;IACZ,YAAY;IACZ,SAAS;CACZ,CAAC,CAAC;AACH,kBAAkB,CAAC,IAAI,EAAE,CAAC;AAE1B,IAAM,qBAAqB,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE;IAC7C,cAAc;IACd,aAAa;IACb,aAAa;IACb,aAAa;IACb,aAAa;IACb,UAAU;IACV,WAAW;IACX,QAAQ;IACR,YAAY;IACZ,YAAY;IACZ,SAAS;CACZ,CAAC,CAAC;AACH,qBAAqB,CAAC,IAAI,EAAE,CAAC;AAE7B,eAAe;IACX,SAAS,WAAA;IACT,QAAQ,UAAA;IACR,QAAQ,UAAA;IACR,IAAI,MAAA;IACJ,MAAM,QAAA;IACN,OAAO,SAAA;IACP,QAAQ,UAAA;IACR,KAAK,OAAA;IACL,OAAO,SAAA;IACP,IAAI,MAAA;IACJ,OAAO,SAAA;IACP,MAAM,QAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.turbo.d.ts b/node_modules/flowbite/lib/esm/index.turbo.d.ts new file mode 100644 index 0000000..413a593 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.turbo.d.ts @@ -0,0 +1,29 @@ +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.turbo.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.turbo.d.ts.map b/node_modules/flowbite/lib/esm/index.turbo.d.ts.map new file mode 100644 index 0000000..4b913c1 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.turbo.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.turbo.d.ts","sourceRoot":"","sources":["../../src/index.turbo.ts"],"names":[],"mappings":"AACA,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAgClC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.turbo.js b/node_modules/flowbite/lib/esm/index.turbo.js new file mode 100644 index 0000000..39db2f2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.turbo.js @@ -0,0 +1,57 @@ +// core components +import Accordion, { initAccordions } from './components/accordion'; +import Carousel, { initCarousels } from './components/carousel'; +import Collapse, { initCollapses } from './components/collapse'; +import Dial, { initDials } from './components/dial'; +import Dismiss, { initDismisses } from './components/dismiss'; +import Drawer, { initDrawers } from './components/drawer'; +import Dropdown, { initDropdowns } from './components/dropdown'; +import Modal, { initModals } from './components/modal'; +import Popover, { initPopovers } from './components/popover'; +import Tabs, { initTabs } from './components/tabs'; +import Tooltip, { initTooltips } from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +var turboLoadEvents = new Events('turbo:load', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +turboLoadEvents.init(); +var turboFrameLoadEvents = new Events('turbo:frame-load', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +turboFrameLoadEvents.init(); +export default { + Accordion: Accordion, + Carousel: Carousel, + Collapse: Collapse, + Dial: Dial, + Drawer: Drawer, + Dismiss: Dismiss, + Dropdown: Dropdown, + Modal: Modal, + Popover: Popover, + Tabs: Tabs, + Tooltip: Tooltip, + Events: Events, +}; +//# sourceMappingURL=index.turbo.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.turbo.js.map b/node_modules/flowbite/lib/esm/index.turbo.js.map new file mode 100644 index 0000000..d518165 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.turbo.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.turbo.js","sourceRoot":"","sources":["../../src/index.turbo.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,OAAO,SAAS,EAAE,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAAO,EAAE,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;AAElC,IAAM,eAAe,GAAG,IAAI,MAAM,CAAC,YAAY,EAAE;IAC7C,cAAc;IACd,aAAa;IACb,aAAa;IACb,aAAa;IACb,aAAa;IACb,UAAU;IACV,WAAW;IACX,QAAQ;IACR,YAAY;IACZ,YAAY;IACZ,SAAS;CACZ,CAAC,CAAC;AACH,eAAe,CAAC,IAAI,EAAE,CAAC;AAEvB,IAAM,oBAAoB,GAAG,IAAI,MAAM,CAAC,kBAAkB,EAAE;IACxD,cAAc;IACd,aAAa;IACb,aAAa;IACb,aAAa;IACb,aAAa;IACb,UAAU;IACV,WAAW;IACX,QAAQ;IACR,YAAY;IACZ,YAAY;IACZ,SAAS;CACZ,CAAC,CAAC;AACH,oBAAoB,CAAC,IAAI,EAAE,CAAC;AAE5B,eAAe;IACX,SAAS,WAAA;IACT,QAAQ,UAAA;IACR,QAAQ,UAAA;IACR,IAAI,MAAA;IACJ,MAAM,QAAA;IACN,OAAO,SAAA;IACP,QAAQ,UAAA;IACR,KAAK,OAAA;IACL,OAAO,SAAA;IACP,IAAI,MAAA;IACJ,OAAO,SAAA;IACP,MAAM,QAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.umd.d.ts b/node_modules/flowbite/lib/esm/index.umd.d.ts new file mode 100644 index 0000000..98f6048 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.umd.d.ts @@ -0,0 +1,30 @@ +import './flowbite.css'; +import Accordion from './components/accordion'; +import Carousel from './components/carousel'; +import Collapse from './components/collapse'; +import Dial from './components/dial'; +import Dismiss from './components/dismiss'; +import Drawer from './components/drawer'; +import Dropdown from './components/dropdown'; +import Modal from './components/modal'; +import Popover from './components/popover'; +import Tabs from './components/tabs'; +import Tooltip from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +declare const _default: { + Accordion: typeof Accordion; + Carousel: typeof Carousel; + Collapse: typeof Collapse; + Dial: typeof Dial; + Drawer: typeof Drawer; + Dismiss: typeof Dismiss; + Dropdown: typeof Dropdown; + Modal: typeof Modal; + Popover: typeof Popover; + Tabs: typeof Tabs; + Tooltip: typeof Tooltip; + Events: typeof Events; +}; +export default _default; +//# sourceMappingURL=index.umd.d.ts.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.umd.d.ts.map b/node_modules/flowbite/lib/esm/index.umd.d.ts.map new file mode 100644 index 0000000..60b4ec2 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.umd.d.ts.map @@ -0,0 +1 @@ +{"version":3,"file":"index.umd.d.ts","sourceRoot":"","sources":["../../src/index.umd.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,CAAC;AAGxB,OAAO,SAA6B,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAmB,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAA0B,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAuB,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAA2B,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAqB,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAkB,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAyB,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;AAiBlC,wBAaE"} \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.umd.js b/node_modules/flowbite/lib/esm/index.umd.js new file mode 100644 index 0000000..a9f35c7 --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.umd.js @@ -0,0 +1,44 @@ +import './flowbite.css'; +// core components +import Accordion, { initAccordions } from './components/accordion'; +import Carousel, { initCarousels } from './components/carousel'; +import Collapse, { initCollapses } from './components/collapse'; +import Dial, { initDials } from './components/dial'; +import Dismiss, { initDismisses } from './components/dismiss'; +import Drawer, { initDrawers } from './components/drawer'; +import Dropdown, { initDropdowns } from './components/dropdown'; +import Modal, { initModals } from './components/modal'; +import Popover, { initPopovers } from './components/popover'; +import Tabs, { initTabs } from './components/tabs'; +import Tooltip, { initTooltips } from './components/tooltip'; +import './components/index'; +import Events from './dom/events'; +var events = new Events('load', [ + initAccordions, + initCollapses, + initCarousels, + initDismisses, + initDropdowns, + initModals, + initDrawers, + initTabs, + initTooltips, + initPopovers, + initDials, +]); +events.init(); +export default { + Accordion: Accordion, + Carousel: Carousel, + Collapse: Collapse, + Dial: Dial, + Drawer: Drawer, + Dismiss: Dismiss, + Dropdown: Dropdown, + Modal: Modal, + Popover: Popover, + Tabs: Tabs, + Tooltip: Tooltip, + Events: Events, +}; +//# sourceMappingURL=index.umd.js.map \ No newline at end of file diff --git a/node_modules/flowbite/lib/esm/index.umd.js.map b/node_modules/flowbite/lib/esm/index.umd.js.map new file mode 100644 index 0000000..5eca6de --- /dev/null +++ b/node_modules/flowbite/lib/esm/index.umd.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.umd.js","sourceRoot":"","sources":["../../src/index.umd.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,CAAC;AAExB,kBAAkB;AAClB,OAAO,SAAS,EAAE,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,IAAI,EAAE,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,OAAO,EAAE,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,QAAQ,EAAE,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,MAAM,MAAM,cAAc,CAAC;AAElC,IAAM,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE;IAC9B,cAAc;IACd,aAAa;IACb,aAAa;IACb,aAAa;IACb,aAAa;IACb,UAAU;IACV,WAAW;IACX,QAAQ;IACR,YAAY;IACZ,YAAY;IACZ,SAAS;CACZ,CAAC,CAAC;AACH,MAAM,CAAC,IAAI,EAAE,CAAC;AAEd,eAAe;IACX,SAAS,WAAA;IACT,QAAQ,UAAA;IACR,QAAQ,UAAA;IACR,IAAI,MAAA;IACJ,MAAM,QAAA;IACN,OAAO,SAAA;IACP,QAAQ,UAAA;IACR,KAAK,OAAA;IACL,OAAO,SAAA;IACP,IAAI,MAAA;IACJ,OAAO,SAAA;IACP,MAAM,QAAA;CACT,CAAC"} \ No newline at end of file diff --git a/node_modules/flowbite/package.json b/node_modules/flowbite/package.json new file mode 100644 index 0000000..1f0b774 --- /dev/null +++ b/node_modules/flowbite/package.json @@ -0,0 +1,121 @@ +{ + "name": "flowbite", + "version": "1.8.1", + "description": "The most popular library of interactive components built with Tailwind CSS", + "keywords": [ + "flowbite", + "typescript", + "javascript", + "webpack", + "html", + "css", + "component library", + "ui components", + "tailwind", + "tailwind css", + "tailwind components", + "tailwind elements", + "tailwind library", + "tailwind sections", + "tailwind css", + "tailwind ui", + "tailwind react", + "tailwind vue", + "tailwind angular", + "tailwind svelte", + "tailwind django", + "Tailwind ruby on rails", + "tailwind laravel", + "tailwind nuxt", + "tailwind next", + "tailwind astro", + "tailwind flask", + "eslint", + "prettier", + "cjs", + "esm", + "umd" + ], + "license": "MIT", + "main": "lib/cjs/index.js", + "module": "lib/esm/index.js", + "types": "lib/esm/index.d.ts", + "style": "dist/flowbite.min.css", + "repository": "https://github.com/themesberg/flowbite.git", + "bugs": "https://github.com/themesberg/flowbite/issues", + "homepage": "https://flowbite.com", + "contributors": [ + "Zoltán Szőgyényi (https://twitter.com/zoltanszogyenyi)", + "Robert Tanislav (https://twitter.com/roberttanislav)" + ], + "author": "Bergside Inc.", + "scripts": { + "start": "NODE_ENV=development run-p start:*", + "start:hugo": "hugo server -D", + "start:webpack": "webpack --mode=development --watch", + "build": "NODE_ENV=production && HUGO_ENV=production && run-s build:webpack build:hugo", + "build:hugo": "hugo", + "build:webpack": "webpack --mode=production", + "build:css:min": "NPM_ENV=production npx postcss src/flowbite.css > dist/flowbite.min.css", + "build:css": "NPM_ENV=development npx postcss src/flowbite.css > dist/flowbite.css", + "build:js": "run-s build:webpack", + "copy:js:dist": "copyfiles --flat static/flowbite.js dist && copyfiles --flat static/flowbite.js.map dist && copyfiles --flat static/flowbite.min.js.map dist && copyfiles --flat static/flowbite.min.js dist && copyfiles --flat static/flowbite.turbo.js dist && copyfiles --flat static/flowbite.turbo.min.js dist && copyfiles --flat static/flowbite.turbo.js.map dist && copyfiles --flat static/flowbite.turbo.min.js.map dist && copyfiles --flat static/flowbite.phoenix.js dist && copyfiles --flat static/flowbite.phoenix.min.js dist && copyfiles --flat static/flowbite.phoenix.js.map dist && copyfiles --flat static/flowbite.phoenix.min.js.map dist && copyfiles --flat static/datepicker.js dist && copyfiles --flat static/datepicker.min.js dist && copyfiles --flat static/datepicker.js.map dist && copyfiles --flat static/datepicker.turbo.js dist && copyfiles --flat static/datepicker.turbo.min.js dist && copyfiles --flat static/datepicker.turbo.js.map dist", + "build:dist": "mkdir -p dist && run-s build:css:min build:css build:js copy:js:dist", + "build:lib": "tsc --outDir lib/cjs && tsc -m es6 --outDir lib/esm", + "clean:lib": "shx rm -rf lib", + "clean:dist": "shx rm -rf dist", + "build:npm": "run-s clean:lib build:lib clean:dist build:dist", + "lint": "eslint . --ext .js,.jsx,.ts,.tsx --ignore-path .gitignore" + }, + "devDependencies": { + "@babel/core": "^7.14.8", + "@babel/preset-env": "^7.14.8", + "@docsearch/js": "^3.0.0-alpha.42", + "@typescript-eslint/eslint-plugin": "^5.46.1", + "@typescript-eslint/parser": "^5.46.1", + "autoprefixer": "^10.3.3", + "babel-loader": "^8.2.2", + "copyfiles": "^2.4.1", + "core-js": "^3.8.1", + "css-loader": "^5.2.7", + "css-minimizer-webpack-plugin": "^3.0.2", + "cssnano": "^5.0.8", + "eslint": "^8.29.0", + "eslint-config-prettier": "^8.0.0", + "eslint-plugin-prettier": "^4.2.1", + "eslint-plugin-tailwindcss": "^3.7.1", + "file-loader": "^6.2.0", + "flowbite-datepicker": "^1.2.2", + "mini-css-extract-plugin": "^1.3.3", + "npm-run-all": "^4.1.5", + "postcss": "^8.3.6", + "postcss-cli": "^8.3.1", + "postcss-loader": "^4.3.0", + "postcss-preset-env": "^6.7.0", + "prettier": "^2.8.1", + "prettier-plugin-tailwindcss": "^0.2.1", + "shx": "^0.3.4", + "source-map-loader": "^2.0.0", + "style-loader": "^2.0.0", + "tailwindcss": "^3.3.0", + "terser-webpack-plugin": "^5.3.6", + "ts-loader": "^9.4.2", + "typescript": "^4.9.4", + "webpack": "^5.47.0", + "webpack-cli": "^4.7.2", + "webpack-dev-server": "^4.11.1", + "windicss": "^3.5.6", + "yarn": "^1.22.10" + }, + "dependencies": { + "@popperjs/core": "^2.9.3", + "mini-svg-data-uri": "^1.4.3" + }, + "files": [ + "lib", + "dist", + "plugin.d.ts", + "plugin.js", + "plugin-windicss.js" + ] +} diff --git a/node_modules/flowbite/plugin-windicss.js b/node_modules/flowbite/plugin-windicss.js new file mode 100644 index 0000000..c9bd26e --- /dev/null +++ b/node_modules/flowbite/plugin-windicss.js @@ -0,0 +1,588 @@ +/* eslint-disable @typescript-eslint/no-var-requires */ +const svgToDataUri = require('mini-svg-data-uri'); +const plugin = require('windicss/plugin'); +const defaultTheme = require('windicss/defaultTheme'); +const colors = require('windicss/colors'); +const [baseFontSize, { lineHeight: baseLineHeight }] = + defaultTheme.fontSize.base; +const { spacing, borderWidth, borderRadius } = defaultTheme; + +module.exports = plugin( + function ({ addBase, theme }) { + addBase({ + [[ + "[type='text']", + "[type='email']", + "[type='url']", + "[type='password']", + "[type='number']", + "[type='date']", + "[type='datetime-local']", + "[type='month']", + "[type='search']", + "[type='tel']", + "[type='time']", + "[type='week']", + '[multiple]', + 'textarea', + 'select', + ]]: { + appearance: 'none', + 'background-color': '#fff', + 'border-color': theme('colors.gray.500', colors.gray[500]), + 'border-width': borderWidth['DEFAULT'], + 'border-radius': borderRadius.none, + 'padding-top': spacing[2], + 'padding-right': spacing[3], + 'padding-bottom': spacing[2], + 'padding-left': spacing[3], + 'font-size': baseFontSize, + 'line-height': baseLineHeight, + '--tw-shadow': '0 0 #0000', + '&:focus': { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-inset': 'var(--tw-empty,/*!*/ /*!*/)', + '--tw-ring-offset-width': '0px', + '--tw-ring-offset-color': '#fff', + '--tw-ring-color': theme( + 'colors.blue.600', + colors.blue[600] + ), + '--tw-ring-offset-shadow': `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`, + '--tw-ring-shadow': `var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)`, + 'box-shadow': `var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)`, + 'border-color': theme('colors.blue.600', colors.blue[600]), + }, + }, + [['input::placeholder', 'textarea::placeholder']]: { + color: theme('colors.gray.500', colors.gray[500]), + opacity: '1', + }, + ['::-webkit-datetime-edit-fields-wrapper']: { + padding: '0', + }, + ['::-webkit-date-and-time-value']: { + 'min-height': '1.5em', + }, + ['select']: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-position': `right ${spacing[2]} center`, + 'background-repeat': `no-repeat`, + 'background-size': `1.5em 1.5em`, + 'padding-right': spacing[10], + 'print-color-adjust': `exact`, + }, + ['[multiple]']: { + 'background-image': 'initial', + 'background-position': 'initial', + 'background-repeat': 'unset', + 'background-size': 'initial', + 'padding-right': spacing[3], + 'print-color-adjust': 'unset', + }, + [[`[type='checkbox']`, `[type='radio']`]]: { + appearance: 'none', + padding: '0', + 'print-color-adjust': 'exact', + display: 'inline-block', + 'vertical-align': 'middle', + 'background-origin': 'border-box', + 'user-select': 'none', + 'flex-shrink': '0', + height: spacing[4], + width: spacing[4], + color: theme('colors.blue.600', colors.blue[600]), + 'background-color': '#fff', + 'border-color': theme('colors.gray.500', colors.gray[500]), + 'border-width': borderWidth['DEFAULT'], + '--tw-shadow': '0 0 #0000', + }, + [`[type='checkbox']`]: { + 'border-radius': borderRadius['none'], + }, + [`[type='radio']`]: { + 'border-radius': '100%', + }, + [[`[type='checkbox']:focus`, `[type='radio']:focus`]]: { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-inset': 'var(--tw-empty,/*!*/ /*!*/)', + '--tw-ring-offset-width': '2px', + '--tw-ring-offset-color': '#fff', + '--tw-ring-color': theme('colors.blue.600', colors.blue[600]), + '--tw-ring-offset-shadow': `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`, + '--tw-ring-shadow': `var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)`, + 'box-shadow': `var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)`, + }, + [[ + `[type='checkbox']:checked`, + `[type='radio']:checked`, + `.dark [type='checkbox']:checked`, + `.dark [type='radio']:checked`, + ]]: { + 'border-color': `transparent`, + 'background-color': `currentColor`, + 'background-size': `100% 100%`, + 'background-position': `center`, + 'background-repeat': `no-repeat`, + }, + [`[type='checkbox']:checked`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + }, + [`[type='radio']:checked`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + }, + [`[type='checkbox']:indeterminate`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'border-color': `transparent`, + 'background-color': `currentColor`, + 'background-size': `100% 100%`, + 'background-position': `center`, + 'background-repeat': `no-repeat`, + }, + [[ + `[type='checkbox']:indeterminate:hover`, + `[type='checkbox']:indeterminate:focus`, + ]]: { + 'border-color': 'transparent', + 'background-color': 'currentColor', + }, + [`[type='file']`]: { + background: 'unset', + 'border-color': 'inherit', + 'border-width': '0', + 'border-radius': '0', + padding: '0', + 'font-size': 'unset', + 'line-height': 'inherit', + }, + [`[type='file']:focus`]: { + outline: `1px auto inherit`, + }, + [[`input[type=file]::file-selector-button`]]: { + color: 'white', + background: theme('colors.gray.800', colors.gray[800]), + border: 0, + 'font-weight': theme('fontWeight.medium'), + 'font-size': theme('fontSize.sm'), + cursor: 'pointer', + 'padding-top': spacing[2.5], + 'padding-bottom': spacing[2.5], + 'padding-left': spacing[8], + 'padding-right': spacing[4], + 'margin-inline-start': '-1rem', + 'margin-inline-end': '1rem', + '&:hover': { + background: theme('colors.gray.700', colors.gray[700]), + }, + }, + [[`.dark input[type=file]::file-selector-button`]]: { + color: 'white', + background: theme('colors.gray.600', colors.gray[600]), + '&:hover': { + background: theme('colors.gray.500', colors.gray[500]), + }, + }, + [[`input[type="range"]::-webkit-slider-thumb`]]: { + height: spacing[5], + width: spacing[5], + background: theme('colors.blue.600', colors.blue[600]), + 'border-radius': borderRadius.full, + border: 0, + appearance: 'none', + '-moz-appearance': 'none', + '-webkit-appearance': 'none', + cursor: 'pointer', + }, + [[`input[type="range"]:disabled::-webkit-slider-thumb`]]: { + background: theme('colors.gray.400', colors.gray[400]), + }, + [[`.dark input[type="range"]:disabled::-webkit-slider-thumb`]]: { + background: theme('colors.gray.500', colors.gray[500]), + }, + [[`input[type="range"]:focus::-webkit-slider-thumb`]]: { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-offset-shadow': + 'var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)', + '--tw-ring-shadow': + 'var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)', + 'box-shadow': + 'var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)', + '--tw-ring-opacity': 1, + '--tw-ring-color': 'rgb(164 202 254 / var(--tw-ring-opacity))', + }, + [[`input[type="range"]::-moz-range-thumb`]]: { + height: spacing[5], + width: spacing[5], + background: theme('colors.blue.600', colors.blue[600]), + 'border-radius': borderRadius.full, + border: 0, + appearance: 'none', + '-moz-appearance': 'none', + '-webkit-appearance': 'none', + cursor: 'pointer', + }, + [[`input[type="range"]:disabled::-moz-range-thumb`]]: { + background: theme('colors.gray.400', colors.gray[400]), + }, + [[`.dark input[type="range"]:disabled::-moz-range-thumb`]]: { + background: theme('colors.gray.500', colors.gray[500]), + }, + [[`input[type="range"]::-moz-range-progress`]]: { + background: theme('colors.blue.500', colors.blue[500]), + }, + [[`input[type="range"]::-ms-fill-lower`]]: { + background: theme('colors.blue.500', colors.blue[500]), + }, + [[`input[type="range"].range-sm::-webkit-slider-thumb`]]: { + height: spacing[4], + width: spacing[4], + }, + [[`input[type="range"].range-lg::-webkit-slider-thumb`]]: { + height: spacing[6], + width: spacing[6], + }, + [[`input[type="range"].range-sm::-moz-range-thumb`]]: { + height: spacing[4], + width: spacing[4], + }, + [[`input[type="range"].range-lg::-moz-range-thumb`]]: { + height: spacing[6], + width: spacing[6], + }, + // remove from v2.x+ + ['.toggle-bg:after']: { + content: '""', + position: 'absolute', + top: spacing[0.5], + left: spacing[0.5], + background: 'white', + 'border-color': theme('colors.gray.300', colors.gray[300]), + 'border-width': borderWidth['DEFAULT'], + 'border-radius': borderRadius.full, + height: theme('height.5'), + width: theme('width.5'), + 'transition-property': + 'background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter', + 'transition-duration': '.15s', + 'box-shadow': + 'var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color)', + }, + ['input:checked + .toggle-bg:after']: { + transform: 'translateX(100%);', + 'border-color': 'white', + }, + ['input:checked + .toggle-bg']: { + background: theme('colors.blue.600', colors.gray[600]), + 'border-color': theme('colors.blue.600', colors.gray[600]), + }, + // remove from v2.x+ END + [['.tooltip-arrow', '.tooltip-arrow:before']]: { + position: 'absolute', + width: '8px', + height: '8px', + background: 'inherit', + }, + ['.tooltip-arrow']: { + visibility: 'hidden', + }, + ['.tooltip-arrow:before']: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + }, + [`[data-tooltip-style^='light'] + .tooltip > .tooltip-arrow:before`]: + { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='top'] > .tooltip-arrow:before`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='right'] > .tooltip-arrow:before`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='bottom'] > .tooltip-arrow:before`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='left'] > .tooltip-arrow:before`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`.tooltip[data-popper-placement^='top'] > .tooltip-arrow`]: { + bottom: '-4px', + }, + [`.tooltip[data-popper-placement^='bottom'] > .tooltip-arrow`]: { + top: '-4px', + }, + [`.tooltip[data-popper-placement^='left'] > .tooltip-arrow`]: { + right: '-4px', + }, + [`.tooltip[data-popper-placement^='right'] > .tooltip-arrow`]: { + left: '-4px', + }, + ['.tooltip.invisible > .tooltip-arrow:before']: { + visibility: 'hidden', + }, + [['[data-popper-arrow]', '[data-popper-arrow]:before']]: { + position: 'absolute', + width: '8px', + height: '8px', + background: 'inherit', + }, + ['[data-popper-arrow]']: { + visibility: 'hidden', + }, + ['[data-popper-arrow]:before']: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + }, + ['[data-popper-arrow]:after']: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + position: 'absolute', + width: '9px', + height: '9px', + background: 'inherit', + }, + [`[role="tooltip"] > [data-popper-arrow]:before`]: { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`.dark [role="tooltip"] > [data-popper-arrow]:before`]: { + 'border-style': 'solid', + 'border-color': colors.gray[600], + }, + [`[role="tooltip"] > [data-popper-arrow]:after`]: { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`.dark [role="tooltip"] > [data-popper-arrow]:after`]: { + 'border-style': 'solid', + 'border-color': colors.gray[600], + }, + [`[role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:before`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:after`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:before`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:after`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:before`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:after`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:before`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:after`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`[role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]`]: + { + bottom: '-5px', + }, + [`[role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]`]: + { + top: '-5px', + }, + [`[role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]`]: + { + right: '-5px', + }, + [`[role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]`]: + { + left: '-5px', + }, + ['[role="tooltip"].invisible > [data-popper-arrow]:before']: { + visibility: 'hidden', + }, + ['[role="tooltip"].invisible > [data-popper-arrow]:after']: { + visibility: 'hidden', + }, + }); + }, + { + darkMode: 'class', // or 'media' or 'class', + theme: { + extend: { + height: { + modal: 'calc(100% - 2rem)', + }, + boxShadow: { + 'sm-light': '0 2px 5px 0px rgba(255, 255, 255, 0.08)', + }, + colors: { + transparent: 'transparent', + white: '#ffffff', + black: '#000000', + gray: { + 50: '#F9FAFB', + 100: '#F3F4F6', + 200: '#E5E7EB', + 300: '#D1D5DB', + 400: '#9CA3AF', + 500: '#6B7280', + 600: '#4B5563', + 700: '#374151', + 800: '#1F2937', + 900: '#111827', + }, + red: { + 50: '#FDF2F2', + 100: '#FDE8E8', + 200: '#FBD5D5', + 300: '#F8B4B4', + 400: '#F98080', + 500: '#F05252', + 600: '#E02424', + 700: '#C81E1E', + 800: '#9B1C1C', + 900: '#771D1D', + }, + orange: { + 50: '#FFF8F1', + 100: '#FEECDC', + 200: '#FCD9BD', + 300: '#FDBA8C', + 400: '#FF8A4C', + 500: '#FF5A1F', + 600: '#D03801', + 700: '#B43403', + 800: '#8A2C0D', + 900: '#771D1D', + }, + yellow: { + 50: '#FDFDEA', + 100: '#FDF6B2', + 200: '#FCE96A', + 300: '#FACA15', + 400: '#E3A008', + 500: '#C27803', + 600: '#9F580A', + 700: '#8E4B10', + 800: '#723B13', + 900: '#633112', + }, + green: { + 50: '#F3FAF7', + 100: '#DEF7EC', + 200: '#BCF0DA', + 300: '#84E1BC', + 400: '#31C48D', + 500: '#0E9F6E', + 600: '#057A55', + 700: '#046C4E', + 800: '#03543F', + 900: '#014737', + }, + teal: { + 50: '#EDFAFA', + 100: '#D5F5F6', + 200: '#AFECEF', + 300: '#7EDCE2', + 400: '#16BDCA', + 500: '#0694A2', + 600: '#047481', + 700: '#036672', + 800: '#05505C', + 900: '#014451', + }, + blue: { + 50: '#EBF5FF', + 100: '#E1EFFE', + 200: '#C3DDFD', + 300: '#A4CAFE', + 400: '#76A9FA', + 500: '#3F83F8', + 600: '#1C64F2', + 700: '#1A56DB', + 800: '#1E429F', + 900: '#233876', + }, + indigo: { + 50: '#F0F5FF', + 100: '#E5EDFF', + 200: '#CDDBFE', + 300: '#B4C6FC', + 400: '#8DA2FB', + 500: '#6875F5', + 600: '#5850EC', + 700: '#5145CD', + 800: '#42389D', + 900: '#362F78', + }, + purple: { + 50: '#F6F5FF', + 100: '#EDEBFE', + 200: '#DCD7FE', + 300: '#CABFFD', + 400: '#AC94FA', + 500: '#9061F9', + 600: '#7E3AF2', + 700: '#6C2BD9', + 800: '#5521B5', + 900: '#4A1D96', + }, + pink: { + 50: '#FDF2F8', + 100: '#FCE8F3', + 200: '#FAD1E8', + 300: '#F8B4D9', + 400: '#F17EB8', + 500: '#E74694', + 600: '#D61F69', + 700: '#BF125D', + 800: '#99154B', + 900: '#751A3D', + }, + }, + }, + }, + } +); diff --git a/node_modules/flowbite/plugin.d.ts b/node_modules/flowbite/plugin.d.ts new file mode 100644 index 0000000..a693e7f --- /dev/null +++ b/node_modules/flowbite/plugin.d.ts @@ -0,0 +1,2 @@ +declare const plugin: { handler: () => void }; +export = plugin; diff --git a/node_modules/flowbite/plugin.js b/node_modules/flowbite/plugin.js new file mode 100644 index 0000000..29bfc9a --- /dev/null +++ b/node_modules/flowbite/plugin.js @@ -0,0 +1,970 @@ +/* eslint-disable @typescript-eslint/no-var-requires */ +const svgToDataUri = require('mini-svg-data-uri'); +const plugin = require('tailwindcss/plugin'); +const defaultTheme = require('tailwindcss/defaultTheme'); +const colors = require('tailwindcss/colors'); +const [baseFontSize, { lineHeight: baseLineHeight }] = + defaultTheme.fontSize.base; +const { spacing, borderWidth, borderRadius, boxShadow } = defaultTheme; + +module.exports = plugin.withOptions( + function (options = {}) { + // Enable forms and tooltip by default if not specified in options + const { charts = false, forms = true, tooltips = true } = options; + + return function ({ addBase, addComponents, theme }) { + // tooltip and popover styles + if (tooltips) { + addBase({ + // remove from v2.x+ END + [['.tooltip-arrow', '.tooltip-arrow:before']]: { + position: 'absolute', + width: '8px', + height: '8px', + background: 'inherit', + }, + [['.tooltip-arrow']]: { + visibility: 'hidden', + }, + [['.tooltip-arrow:before']]: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + }, + [`[data-tooltip-style^='light'] + .tooltip > .tooltip-arrow:before`]: + { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='top'] > .tooltip-arrow:before`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='right'] > .tooltip-arrow:before`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='bottom'] > .tooltip-arrow:before`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[data-tooltip-style^='light'] + .tooltip[data-popper-placement^='left'] > .tooltip-arrow:before`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`.tooltip[data-popper-placement^='top'] > .tooltip-arrow`]: + { + bottom: '-4px', + }, + [`.tooltip[data-popper-placement^='bottom'] > .tooltip-arrow`]: + { + top: '-4px', + }, + [`.tooltip[data-popper-placement^='left'] > .tooltip-arrow`]: + { + right: '-4px', + }, + [`.tooltip[data-popper-placement^='right'] > .tooltip-arrow`]: + { + left: '-4px', + }, + ['.tooltip.invisible > .tooltip-arrow:before']: { + visibility: 'hidden', + }, + [['[data-popper-arrow]', '[data-popper-arrow]:before']]: { + position: 'absolute', + width: '8px', + height: '8px', + background: 'inherit', + }, + ['[data-popper-arrow]']: { + visibility: 'hidden', + }, + ['[data-popper-arrow]:before']: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + }, + ['[data-popper-arrow]:after']: { + content: '""', + visibility: 'visible', + transform: 'rotate(45deg)', + position: 'absolute', + width: '9px', + height: '9px', + background: 'inherit', + }, + [`[role="tooltip"] > [data-popper-arrow]:before`]: { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`.dark [role="tooltip"] > [data-popper-arrow]:before`]: { + 'border-style': 'solid', + 'border-color': colors.gray[600], + }, + [`[role="tooltip"] > [data-popper-arrow]:after`]: { + 'border-style': 'solid', + 'border-color': colors.gray[200], + }, + [`.dark [role="tooltip"] > [data-popper-arrow]:after`]: { + 'border-style': 'solid', + 'border-color': colors.gray[600], + }, + [`[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:before`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]:after`]: + { + 'border-bottom-width': '1px', + 'border-right-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:before`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]:after`]: + { + 'border-bottom-width': '1px', + 'border-left-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:before`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]:after`]: + { + 'border-top-width': '1px', + 'border-left-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:before`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]:after`]: + { + 'border-top-width': '1px', + 'border-right-width': '1px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='top'] > [data-popper-arrow]`]: + { + bottom: '-5px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='bottom'] > [data-popper-arrow]`]: + { + top: '-5px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='left'] > [data-popper-arrow]`]: + { + right: '-5px', + }, + [`[data-popover][role="tooltip"][data-popper-placement^='right'] > [data-popper-arrow]`]: + { + left: '-5px', + }, + ['[role="tooltip"].invisible > [data-popper-arrow]:before']: + { + visibility: 'hidden', + }, + ['[role="tooltip"].invisible > [data-popper-arrow]:after']: + { + visibility: 'hidden', + }, + }); + } + + // form styles + if (forms) { + addBase({ + [[ + "[type='text']", + "[type='email']", + "[type='url']", + "[type='password']", + "[type='number']", + "[type='date']", + "[type='datetime-local']", + "[type='month']", + "[type='search']", + "[type='tel']", + "[type='time']", + "[type='week']", + '[multiple]', + 'textarea', + 'select', + ]]: { + appearance: 'none', + 'background-color': '#fff', + 'border-color': theme( + 'colors.gray.500', + colors.gray[500] + ), + 'border-width': borderWidth['DEFAULT'], + 'border-radius': borderRadius.none, + 'padding-top': spacing[2], + 'padding-right': spacing[3], + 'padding-bottom': spacing[2], + 'padding-left': spacing[3], + 'font-size': baseFontSize, + 'line-height': baseLineHeight, + '--tw-shadow': '0 0 #0000', + '&:focus': { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-inset': 'var(--tw-empty,/*!*/ /*!*/)', + '--tw-ring-offset-width': '0px', + '--tw-ring-offset-color': '#fff', + '--tw-ring-color': theme( + 'colors.blue.600', + colors.blue[600] + ), + '--tw-ring-offset-shadow': `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`, + '--tw-ring-shadow': `var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)`, + 'box-shadow': `var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)`, + 'border-color': theme( + 'colors.blue.600', + colors.blue[600] + ), + }, + }, + [['input::placeholder', 'textarea::placeholder']]: { + color: theme('colors.gray.500', colors.gray[500]), + opacity: '1', + }, + ['::-webkit-datetime-edit-fields-wrapper']: { + padding: '0', + }, + ['::-webkit-date-and-time-value']: { + 'min-height': '1.5em', + }, + ['select:not([size])']: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-position': `right ${spacing[3]} center`, + 'background-repeat': `no-repeat`, + 'background-size': `0.75em 0.75em`, + 'padding-right': spacing[10], + 'print-color-adjust': `exact`, + }, + ['[multiple]']: { + 'background-image': 'initial', + 'background-position': 'initial', + 'background-repeat': 'unset', + 'background-size': 'initial', + 'padding-right': spacing[3], + 'print-color-adjust': 'unset', + }, + [[`[type='checkbox']`, `[type='radio']`]]: { + appearance: 'none', + padding: '0', + 'print-color-adjust': 'exact', + display: 'inline-block', + 'vertical-align': 'middle', + 'background-origin': 'border-box', + 'user-select': 'none', + 'flex-shrink': '0', + height: spacing[4], + width: spacing[4], + color: theme('colors.blue.600', colors.blue[600]), + 'background-color': '#fff', + 'border-color': theme( + 'colors.gray.500', + colors.gray[500] + ), + 'border-width': borderWidth['DEFAULT'], + '--tw-shadow': '0 0 #0000', + }, + [`[type='checkbox']`]: { + 'border-radius': borderRadius['none'], + }, + [`[type='radio']`]: { + 'border-radius': '100%', + }, + [[`[type='checkbox']:focus`, `[type='radio']:focus`]]: { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-inset': 'var(--tw-empty,/*!*/ /*!*/)', + '--tw-ring-offset-width': '2px', + '--tw-ring-offset-color': '#fff', + '--tw-ring-color': theme( + 'colors.blue.600', + colors.blue[600] + ), + '--tw-ring-offset-shadow': `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`, + '--tw-ring-shadow': `var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)`, + 'box-shadow': `var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)`, + }, + [[ + `[type='checkbox']:checked`, + `[type='radio']:checked`, + `.dark [type='checkbox']:checked`, + `.dark [type='radio']:checked`, + ]]: { + 'border-color': `transparent`, + 'background-color': `currentColor`, + 'background-size': `0.55em 0.55em`, + 'background-position': `center`, + 'background-repeat': `no-repeat`, + }, + [`[type='checkbox']:checked`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-repeat': `no-repeat`, + 'background-size': `0.55em 0.55em`, + 'print-color-adjust': `exact`, + }, + [`[type='radio']:checked`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-size': `1em 1em`, + }, + [`.dark [type='radio']:checked`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-size': `1em 1em`, + }, + [`[type='checkbox']:indeterminate`]: { + 'background-image': `url("${svgToDataUri( + `` + )}")`, + 'background-color': `currentColor`, + 'border-color': `transparent`, + 'background-position': `center`, + 'background-repeat': `no-repeat`, + 'background-size': `0.55em 0.55em`, + 'print-color-adjust': `exact`, + }, + [[ + `[type='checkbox']:indeterminate:hover`, + `[type='checkbox']:indeterminate:focus`, + ]]: { + 'border-color': 'transparent', + 'background-color': 'currentColor', + }, + [`[type='file']`]: { + background: 'unset', + 'border-color': 'inherit', + 'border-width': '0', + 'border-radius': '0', + padding: '0', + 'font-size': 'unset', + 'line-height': 'inherit', + }, + [`[type='file']:focus`]: { + outline: `1px auto inherit`, + }, + [[`input[type=file]::file-selector-button`]]: { + color: 'white', + background: theme('colors.gray.800', colors.gray[800]), + border: 0, + 'font-weight': theme('fontWeight.medium'), + 'font-size': theme('fontSize.sm'), + cursor: 'pointer', + 'padding-top': spacing[2.5], + 'padding-bottom': spacing[2.5], + 'padding-left': spacing[8], + 'padding-right': spacing[4], + 'margin-inline-start': '-1rem', + 'margin-inline-end': '1rem', + '&:hover': { + background: theme( + 'colors.gray.700', + colors.gray[700] + ), + }, + }, + [[`.dark input[type=file]::file-selector-button`]]: { + color: 'white', + background: theme('colors.gray.600', colors.gray[600]), + '&:hover': { + background: theme( + 'colors.gray.500', + colors.gray[500] + ), + }, + }, + [[`input[type="range"]::-webkit-slider-thumb`]]: { + height: spacing[5], + width: spacing[5], + background: theme('colors.blue.600', colors.blue[600]), + 'border-radius': borderRadius.full, + border: 0, + appearance: 'none', + '-moz-appearance': 'none', + '-webkit-appearance': 'none', + cursor: 'pointer', + }, + [[`input[type="range"]:disabled::-webkit-slider-thumb`]]: { + background: theme('colors.gray.400', colors.gray[400]), + }, + [[ + `.dark input[type="range"]:disabled::-webkit-slider-thumb`, + ]]: { + background: theme('colors.gray.500', colors.gray[500]), + }, + [[`input[type="range"]:focus::-webkit-slider-thumb`]]: { + outline: '2px solid transparent', + 'outline-offset': '2px', + '--tw-ring-offset-shadow': + 'var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)', + '--tw-ring-shadow': + 'var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)', + 'box-shadow': + 'var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)', + '--tw-ring-opacity': 1, + '--tw-ring-color': + 'rgb(164 202 254 / var(--tw-ring-opacity))', + }, + [[`input[type="range"]::-moz-range-thumb`]]: { + height: spacing[5], + width: spacing[5], + background: theme('colors.blue.600', colors.blue[600]), + 'border-radius': borderRadius.full, + border: 0, + appearance: 'none', + '-moz-appearance': 'none', + '-webkit-appearance': 'none', + cursor: 'pointer', + }, + [[`input[type="range"]:disabled::-moz-range-thumb`]]: { + background: theme('colors.gray.400', colors.gray[400]), + }, + [[`.dark input[type="range"]:disabled::-moz-range-thumb`]]: + { + background: theme( + 'colors.gray.500', + colors.gray[500] + ), + }, + [[`input[type="range"]::-moz-range-progress`]]: { + background: theme('colors.blue.500', colors.blue[500]), + }, + [[`input[type="range"]::-ms-fill-lower`]]: { + background: theme('colors.blue.500', colors.blue[500]), + }, + [[`input[type="range"].range-sm::-webkit-slider-thumb`]]: { + height: spacing[4], + width: spacing[4], + }, + [[`input[type="range"].range-lg::-webkit-slider-thumb`]]: { + height: spacing[6], + width: spacing[6], + }, + [[`input[type="range"].range-sm::-moz-range-thumb`]]: { + height: spacing[4], + width: spacing[4], + }, + [[`input[type="range"].range-lg::-moz-range-thumb`]]: { + height: spacing[6], + width: spacing[6], + }, + // remove from v2.x+ + [['.toggle-bg:after']]: { + content: '""', + position: 'absolute', + top: spacing[0.5], + left: spacing[0.5], + background: 'white', + 'border-color': theme( + 'colors.gray.300', + colors.gray[300] + ), + 'border-width': borderWidth['DEFAULT'], + 'border-radius': borderRadius.full, + height: theme('height.5'), + width: theme('width.5'), + 'transition-property': + 'background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter', + 'transition-duration': '.15s', + 'box-shadow': + 'var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color)', + }, + [['input:checked + .toggle-bg:after']]: { + transform: 'translateX(100%);', + 'border-color': 'white', + }, + [['input:checked + .toggle-bg']]: { + background: theme('colors.blue.600', colors.gray[600]), + 'border-color': theme( + 'colors.blue.600', + colors.gray[600] + ), + }, + }); + } + + // chart styles + if (charts) { + addComponents({ + '.apexcharts-canvas .apexcharts-tooltip': { + backgroundColor: 'white', + color: `${theme('colors.gray.500', colors.gray[500])}`, + border: '0 !important', + borderRadius: `${theme( + 'borderRadius.DEFAULT', + borderRadius.DEFAULT + )}`, + // padding: `${theme('spacing.3', spacing[3])}`, + boxShadow: `${theme('boxShadow.md', boxShadow.md)}`, + }, + '.dark .apexcharts-canvas .apexcharts-tooltip': { + backgroundColor: `${theme( + 'colors.gray.700', + colors.gray[700] + )}`, + color: `${theme('colors.gray.400', colors.gray[400])}`, + borderColor: 'transparent', + boxShadow: `${theme('boxShadow.md', boxShadow.md)}`, + }, + '.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title': + { + paddingTop: `${theme('spacing.2', spacing[2])}`, + paddingBottom: `${theme('spacing.2', spacing[2])}`, + paddingRight: `${theme('spacing.3', spacing[3])}`, + paddingLeft: `${theme('spacing.3', spacing[3])}`, + marginBottom: `${theme('spacing.3', spacing[3])}`, + backgroundColor: `${theme( + 'colors.gray.100', + colors.gray[100] + )}`, + borderBottomColor: `${theme( + 'colors.gray.200', + colors.gray[200] + )}`, + fontSize: `${theme( + 'fontSize.sm', + defaultTheme.fontSize.sm + )} !important`, + fontWeight: `${theme( + 'fontWeight.normal', + defaultTheme.fontWeight.normal + )}`, + color: `${theme( + 'colors.gray.500', + colors.gray[500] + )}`, + }, + '.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-title': + { + backgroundColor: `${theme( + 'colors.gray.600', + colors.gray[600] + )}`, + borderColor: `${theme( + 'colors.gray.500', + colors.gray[500] + )}`, + color: `${theme( + 'colors.gray.400', + colors.gray[400] + )}`, + }, + '.apexcharts-canvas .apexcharts-xaxistooltip': { + color: `${theme('colors.gray.500', colors.gray[500])}`, + paddingTop: `${theme('spacing.2', spacing[2])}`, + paddingBottom: `${theme('spacing.2', spacing[2])}`, + paddingRight: `${theme('spacing.3', spacing[3])}`, + paddingLeft: `${theme('spacing.3', spacing[3])}`, + borderColor: `transparent`, + backgroundColor: 'white', + borderRadius: `${theme( + 'borderRadius.DEFAULT', + borderRadius.DEFAULT + )}`, + boxShadow: `${theme('boxShadow.md', boxShadow.md)}`, + }, + '.dark .apexcharts-canvas .apexcharts-xaxistooltip': { + color: `${theme('colors.gray.400', colors.gray[400])}`, + backgroundColor: `${theme( + 'colors.gray.700', + colors.gray[700] + )}`, + }, + '.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label': + { + color: `${theme( + 'colors.gray.500', + colors.gray[500] + )}`, + fontSize: `${theme( + 'fontSize.sm', + defaultTheme.fontSize.sm + )}`, + }, + '.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-label': + { + color: `${theme( + 'colors.gray.400', + colors.gray[400] + )}`, + }, + '.apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value': + { + color: `${theme( + 'colors.gray.900', + colors.gray[900] + )}`, + fontSize: `${theme( + 'fontSize.sm', + defaultTheme.fontSize.sm + )}`, + }, + '.dark .apexcharts-canvas .apexcharts-tooltip .apexcharts-tooltip-text-y-value': + { + color: 'white', + }, + '.apexcharts-canvas .apexcharts-xaxistooltip-text': { + fontWeight: `${theme( + 'fontWeight.normal', + defaultTheme.fontWeight.normal + )}`, + fontSize: `${theme( + 'fontSize.sm', + defaultTheme.fontSize.sm + )} !important`, + }, + '.apexcharts-canvas .apexcharts-xaxistooltip:after, .apexcharts-canvas .apexcharts-xaxistooltip:before': + { + borderBottomColor: 'white', + }, + '.apexcharts-canvas .apexcharts-xaxistooltip:after': { + borderWidth: '8px', + marginLeft: '-8px', + }, + '.apexcharts-canvas .apexcharts-xaxistooltip:before': { + borderWidth: '10px', + marginLeft: '-10px', + }, + '.dark .apexcharts-canvas .apexcharts-xaxistooltip:after, .dark .apexcharts-canvas .apexcharts-xaxistooltip:before': + { + borderBottomColor: `${theme( + 'colors.gray.700', + colors.gray[700] + )}`, + }, + '.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-y-group': + { + padding: '0', + }, + '.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active': + { + paddingLeft: `${theme('spacing.3', spacing[3])}`, + paddingRight: `${theme('spacing.3', spacing[3])}`, + paddingBottom: `${theme('spacing.3', spacing[3])}`, + backgroundColor: 'white !important', + color: `${theme( + 'colors.gray.500', + colors.gray[500] + )} !important`, + }, + '.dark .apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active': + { + backgroundColor: `${theme( + 'colors.gray.700', + colors.gray[700] + )} !important`, + color: `${theme( + 'colors.gray.400', + colors.gray[400] + )} !important`, + }, + '.apexcharts-canvas .apexcharts-tooltip-series-group.apexcharts-active:first-of-type': + { + paddingTop: `${theme('spacing.3', spacing[3])}`, + }, + '.apexcharts-canvas .apexcharts-legend': { + padding: '0 !important', + }, + '.apexcharts-canvas .apexcharts-legend-text': { + fontSize: `${theme( + 'fontSize.xs', + defaultTheme.fontSize.xs + )}`, + fontWeight: `${theme( + 'fontWeight.medium', + defaultTheme.fontWeight.medium + )} !important`, + paddingLeft: `${theme('spacing.5', spacing[5])}`, + color: `${theme( + 'colors.gray.500', + colors.gray[500] + )} !important`, + }, + '.apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover': + { + color: `${theme( + 'colors.gray.900', + colors.gray[900] + )} !important`, + }, + '.dark .apexcharts-canvas .apexcharts-legend-text': { + color: `${theme( + 'colors.gray.400', + colors.gray[400] + )} !important`, + }, + '.dark .apexcharts-canvas .apexcharts-legend-text:not(.apexcharts-inactive-legend):hover': + { + color: `white !important`, + }, + '.apexcharts-canvas .apexcharts-legend-series': { + marginLeft: `${theme('spacing.2', spacing[2])}`, + marginRight: `${theme('spacing.2', spacing[2])}`, + marginBottom: `${theme( + 'spacing.1', + spacing[1] + )} !important`, + display: 'flex', + alignItems: 'center', + }, + '.apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value': + { + fill: `${theme( + 'colors.gray.900', + colors.gray[900] + )} !important`, + fontSize: `${theme('fontSize.3xl')}`, + fontWeight: `${theme( + 'fontWeight.bold', + defaultTheme.fontWeight.bold + )}`, + }, + '.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-value': + { + fill: `white !important`, + }, + '.apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label': + { + fill: `${theme( + 'colors.gray.500', + colors.gray[500] + )} !important`, + fontSize: `${theme('fontSize.base')}`, + fontWeight: `${theme( + 'fontWeight.normal', + defaultTheme.fontWeight.normal + )}`, + }, + '.dark .apexcharts-canvas .apexcharts-datalabels-group .apexcharts-text.apexcharts-datalabel-label': + { + fill: `${theme( + 'colors.gray.400', + colors.gray[400] + )} !important`, + }, + '.apexcharts-canvas .apexcharts-datalabels .apexcharts-text.apexcharts-pie-label': + { + fontSize: `${theme('fontSize.xs')} !important`, + fontWeight: `${theme( + 'fontWeight.semibold', + defaultTheme.fontWeight.semibold + )} !important`, + textShadow: `${theme( + 'boxShadow.none', + boxShadow.none + )} !important`, + filter: `none !important`, + }, + '.apexcharts-gridline, .apexcharts-xcrosshairs, .apexcharts-ycrosshairs': + { + stroke: `${theme( + 'colors.gray.200', + colors.gray[200] + )} !important`, + }, + '.dark .apexcharts-gridline, .dark .apexcharts-xcrosshairs, .dark .apexcharts-ycrosshairs': + { + stroke: `${theme( + 'colors.gray.700', + colors.gray[700] + )} !important`, + }, + }); + } + }; + }, + function (options = {}) { + // Enable forms and tooltip by default if not specified in options + const { charts = false, forms = true, tooltips = true } = options; + + const safelist = [ + 'w-64', + 'w-1/2', + 'rounded-l-lg', + 'rounded-r-lg', + 'bg-gray-200', + 'grid-cols-4', + 'grid-cols-7', + 'h-6', + 'leading-6', + 'h-9', + 'leading-9', + 'shadow-lg', + ]; + + if (charts) { + safelist.push({ pattern: /^apexcharts-.*$/ }); + } + + return { + safelist: safelist, + darkMode: 'class', // or 'media' or 'class', + theme: { + extend: { + height: { + modal: 'calc(100% - 2rem)', + }, + boxShadow: { + 'sm-light': '0 2px 5px 0px rgba(255, 255, 255, 0.08)', + }, + colors: { + transparent: 'transparent', + white: '#ffffff', + black: '#000000', + gray: { + 50: '#F9FAFB', + 100: '#F3F4F6', + 200: '#E5E7EB', + 300: '#D1D5DB', + 400: '#9CA3AF', + 500: '#6B7280', + 600: '#4B5563', + 700: '#374151', + 800: '#1F2937', + 900: '#111827', + }, + red: { + 50: '#FDF2F2', + 100: '#FDE8E8', + 200: '#FBD5D5', + 300: '#F8B4B4', + 400: '#F98080', + 500: '#F05252', + 600: '#E02424', + 700: '#C81E1E', + 800: '#9B1C1C', + 900: '#771D1D', + }, + orange: { + 50: '#FFF8F1', + 100: '#FEECDC', + 200: '#FCD9BD', + 300: '#FDBA8C', + 400: '#FF8A4C', + 500: '#FF5A1F', + 600: '#D03801', + 700: '#B43403', + 800: '#8A2C0D', + 900: '#771D1D', + }, + yellow: { + 50: '#FDFDEA', + 100: '#FDF6B2', + 200: '#FCE96A', + 300: '#FACA15', + 400: '#E3A008', + 500: '#C27803', + 600: '#9F580A', + 700: '#8E4B10', + 800: '#723B13', + 900: '#633112', + }, + green: { + 50: '#F3FAF7', + 100: '#DEF7EC', + 200: '#BCF0DA', + 300: '#84E1BC', + 400: '#31C48D', + 500: '#0E9F6E', + 600: '#057A55', + 700: '#046C4E', + 800: '#03543F', + 900: '#014737', + }, + teal: { + 50: '#EDFAFA', + 100: '#D5F5F6', + 200: '#AFECEF', + 300: '#7EDCE2', + 400: '#16BDCA', + 500: '#0694A2', + 600: '#047481', + 700: '#036672', + 800: '#05505C', + 900: '#014451', + }, + blue: { + 50: '#EBF5FF', + 100: '#E1EFFE', + 200: '#C3DDFD', + 300: '#A4CAFE', + 400: '#76A9FA', + 500: '#3F83F8', + 600: '#1C64F2', + 700: '#1A56DB', + 800: '#1E429F', + 900: '#233876', + }, + indigo: { + 50: '#F0F5FF', + 100: '#E5EDFF', + 200: '#CDDBFE', + 300: '#B4C6FC', + 400: '#8DA2FB', + 500: '#6875F5', + 600: '#5850EC', + 700: '#5145CD', + 800: '#42389D', + 900: '#362F78', + }, + purple: { + 50: '#F6F5FF', + 100: '#EDEBFE', + 200: '#DCD7FE', + 300: '#CABFFD', + 400: '#AC94FA', + 500: '#9061F9', + 600: '#7E3AF2', + 700: '#6C2BD9', + 800: '#5521B5', + 900: '#4A1D96', + }, + pink: { + 50: '#FDF2F8', + 100: '#FCE8F3', + 200: '#FAD1E8', + 300: '#F8B4D9', + 400: '#F17EB8', + 500: '#E74694', + 600: '#D61F69', + 700: '#BF125D', + 800: '#99154B', + 900: '#751A3D', + }, + }, + }, + }, + }; + } +); diff --git a/node_modules/fsevents/LICENSE b/node_modules/fsevents/LICENSE new file mode 100644 index 0000000..5d70441 --- /dev/null +++ b/node_modules/fsevents/LICENSE @@ -0,0 +1,22 @@ +MIT License +----------- + +Copyright (C) 2010-2020 by Philipp Dunkel, Ben Noordhuis, Elan Shankar, Paul Miller + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/fsevents/README.md b/node_modules/fsevents/README.md new file mode 100644 index 0000000..025c9a1 --- /dev/null +++ b/node_modules/fsevents/README.md @@ -0,0 +1,83 @@ +# fsevents [![NPM](https://nodei.co/npm/fsevents.png)](https://nodei.co/npm/fsevents/) + +Native access to MacOS FSEvents in [Node.js](https://nodejs.org/) + +The FSEvents API in MacOS allows applications to register for notifications of +changes to a given directory tree. It is a very fast and lightweight alternative +to kqueue. + +This is a low-level library. For a cross-platform file watching module that +uses fsevents, check out [Chokidar](https://github.com/paulmillr/chokidar). + +## Installation + +Supports only **Node.js v8.16 and higher**. + +```sh +npm install fsevents +``` + +## Usage + +```js +const fsevents = require('fsevents'); +const stop = fsevents.watch(__dirname, (path, flags, id) => { + const info = fsevents.getInfo(path, flags, id); +}); // To start observation +stop(); // To end observation +``` + +The callback passed as the second parameter to `.watch` get's called whenever the operating system detects a +a change in the file system. It takes three arguments: + +###### `fsevents.watch(dirname: string, (path: string, flags: number, id: string) => void): () => Promise` + + * `path: string` - the item in the filesystem that have been changed + * `flags: number` - a numeric value describing what the change was + * `id: string` - an unique-id identifying this specific event + + Returns closer callback which when called returns a Promise resolving when the watcher process has been shut down. + +###### `fsevents.getInfo(path: string, flags: number, id: string): FsEventInfo` + +The `getInfo` function takes the `path`, `flags` and `id` arguments and converts those parameters into a structure +that is easier to digest to determine what the change was. + +The `FsEventsInfo` has the following shape: + +```js +/** + * @typedef {'created'|'modified'|'deleted'|'moved'|'root-changed'|'cloned'|'unknown'} FsEventsEvent + * @typedef {'file'|'directory'|'symlink'} FsEventsType + */ +{ + "event": "created", // {FsEventsEvent} + "path": "file.txt", + "type": "file", // {FsEventsType} + "changes": { + "inode": true, // Had iNode Meta-Information changed + "finder": false, // Had Finder Meta-Data changed + "access": false, // Had access permissions changed + "xattrs": false // Had xAttributes changed + }, + "flags": 0x100000000 +} +``` + +## Changelog + +- v2.3 supports Apple Silicon ARM CPUs +- v2 supports node 8.16+ and reduces package size massively +- v1.2.8 supports node 6+ +- v1.2.7 supports node 4+ + +## Troubleshooting + +- I'm getting `EBADPLATFORM` `Unsupported platform for fsevents` error. +- It's fine, nothing is broken. fsevents is macos-only. Other platforms are skipped. If you want to hide this warning, report a bug to NPM bugtracker asking them to hide ebadplatform warnings by default. + +## License + +The MIT License Copyright (C) 2010-2020 by Philipp Dunkel, Ben Noordhuis, Elan Shankar, Paul Miller — see LICENSE file. + +Visit our [GitHub page](https://github.com/fsevents/fsevents) and [NPM Page](https://npmjs.org/package/fsevents) diff --git a/node_modules/fsevents/fsevents.d.ts b/node_modules/fsevents/fsevents.d.ts new file mode 100644 index 0000000..2723c04 --- /dev/null +++ b/node_modules/fsevents/fsevents.d.ts @@ -0,0 +1,46 @@ +declare type Event = "created" | "cloned" | "modified" | "deleted" | "moved" | "root-changed" | "unknown"; +declare type Type = "file" | "directory" | "symlink"; +declare type FileChanges = { + inode: boolean; + finder: boolean; + access: boolean; + xattrs: boolean; +}; +declare type Info = { + event: Event; + path: string; + type: Type; + changes: FileChanges; + flags: number; +}; +declare type WatchHandler = (path: string, flags: number, id: string) => void; +export declare function watch(path: string, handler: WatchHandler): () => Promise; +export declare function watch(path: string, since: number, handler: WatchHandler): () => Promise; +export declare function getInfo(path: string, flags: number): Info; +export declare const constants: { + None: 0x00000000; + MustScanSubDirs: 0x00000001; + UserDropped: 0x00000002; + KernelDropped: 0x00000004; + EventIdsWrapped: 0x00000008; + HistoryDone: 0x00000010; + RootChanged: 0x00000020; + Mount: 0x00000040; + Unmount: 0x00000080; + ItemCreated: 0x00000100; + ItemRemoved: 0x00000200; + ItemInodeMetaMod: 0x00000400; + ItemRenamed: 0x00000800; + ItemModified: 0x00001000; + ItemFinderInfoMod: 0x00002000; + ItemChangeOwner: 0x00004000; + ItemXattrMod: 0x00008000; + ItemIsFile: 0x00010000; + ItemIsDir: 0x00020000; + ItemIsSymlink: 0x00040000; + ItemIsHardlink: 0x00100000; + ItemIsLastHardlink: 0x00200000; + OwnEvent: 0x00080000; + ItemCloned: 0x00400000; +}; +export {}; diff --git a/node_modules/fsevents/fsevents.js b/node_modules/fsevents/fsevents.js new file mode 100644 index 0000000..f1b31c9 --- /dev/null +++ b/node_modules/fsevents/fsevents.js @@ -0,0 +1,82 @@ +/* + ** © 2020 by Philipp Dunkel, Ben Noordhuis, Elan Shankar, Paul Miller + ** Licensed under MIT License. + */ + +/* jshint node:true */ +"use strict"; + +if (process.platform !== "darwin") { + throw new Error(`Module 'fsevents' is not compatible with platform '${process.platform}'`); +} + +const Native = require("./fsevents.node"); +const events = Native.constants; + +function watch(path, since, handler) { + if (typeof path !== "string") { + throw new TypeError(`fsevents argument 1 must be a string and not a ${typeof path}`); + } + if ("function" === typeof since && "undefined" === typeof handler) { + handler = since; + since = Native.flags.SinceNow; + } + if (typeof since !== "number") { + throw new TypeError(`fsevents argument 2 must be a number and not a ${typeof since}`); + } + if (typeof handler !== "function") { + throw new TypeError(`fsevents argument 3 must be a function and not a ${typeof handler}`); + } + + let instance = Native.start(Native.global, path, since, handler); + if (!instance) throw new Error(`could not watch: ${path}`); + return () => { + const result = instance ? Promise.resolve(instance).then(Native.stop) : Promise.resolve(undefined); + instance = undefined; + return result; + }; +} + +function getInfo(path, flags) { + return { + path, + flags, + event: getEventType(flags), + type: getFileType(flags), + changes: getFileChanges(flags), + }; +} + +function getFileType(flags) { + if (events.ItemIsFile & flags) return "file"; + if (events.ItemIsDir & flags) return "directory"; + if (events.ItemIsSymlink & flags) return "symlink"; +} +function anyIsTrue(obj) { + for (let key in obj) { + if (obj[key]) return true; + } + return false; +} +function getEventType(flags) { + if (events.ItemRemoved & flags) return "deleted"; + if (events.ItemRenamed & flags) return "moved"; + if (events.ItemCreated & flags) return "created"; + if (events.ItemModified & flags) return "modified"; + if (events.RootChanged & flags) return "root-changed"; + if (events.ItemCloned & flags) return "cloned"; + if (anyIsTrue(flags)) return "modified"; + return "unknown"; +} +function getFileChanges(flags) { + return { + inode: !!(events.ItemInodeMetaMod & flags), + finder: !!(events.ItemFinderInfoMod & flags), + access: !!(events.ItemChangeOwner & flags), + xattrs: !!(events.ItemXattrMod & flags), + }; +} + +exports.watch = watch; +exports.getInfo = getInfo; +exports.constants = events; diff --git a/node_modules/fsevents/fsevents.node b/node_modules/fsevents/fsevents.node new file mode 100755 index 0000000000000000000000000000000000000000..00fac7e88bbc5ed249eaaac87b210a71e2646889 GIT binary patch literal 147128 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 a|NP;OOTMqX|CF;YDn9F9zx(qahW;OGU5pd} literal 0 HcmV?d00001 diff --git a/node_modules/fsevents/package.json b/node_modules/fsevents/package.json new file mode 100644 index 0000000..af6da84 --- /dev/null +++ b/node_modules/fsevents/package.json @@ -0,0 +1,62 @@ +{ + "name": "fsevents", + "version": "2.3.2", + "description": "Native Access to MacOS FSEvents", + "main": "fsevents.js", + "types": "fsevents.d.ts", + "os": [ + "darwin" + ], + "files": [ + "fsevents.d.ts", + "fsevents.js", + "fsevents.node" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + }, + "scripts": { + "clean": "node-gyp clean && rm -f fsevents.node", + "build": "node-gyp clean && rm -f fsevents.node && node-gyp rebuild && node-gyp clean", + "test": "/bin/bash ./test.sh 2>/dev/null", + "prepublishOnly": "npm run build" + }, + "repository": { + "type": "git", + "url": "https://github.com/fsevents/fsevents.git" + }, + "keywords": [ + "fsevents", + "mac" + ], + "contributors": [ + { + "name": "Philipp Dunkel", + "email": "pip@pipobscure.com" + }, + { + "name": "Ben Noordhuis", + "email": "info@bnoordhuis.nl" + }, + { + "name": "Elan Shankar", + "email": "elan.shanker@gmail.com" + }, + { + "name": "Miroslav Bajtoš", + "email": "mbajtoss@gmail.com" + }, + { + "name": "Paul Miller", + "url": "https://paulmillr.com" + } + ], + "license": "MIT", + "bugs": { + "url": "https://github.com/fsevents/fsevents/issues" + }, + "homepage": "https://github.com/fsevents/fsevents", + "devDependencies": { + "node-gyp": "^6.1.0" + } +} diff --git a/node_modules/function-bind/.editorconfig b/node_modules/function-bind/.editorconfig new file mode 100644 index 0000000..ac29ade --- /dev/null +++ b/node_modules/function-bind/.editorconfig @@ -0,0 +1,20 @@ +root = true + +[*] +indent_style = tab +indent_size = 4 +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true +max_line_length = 120 + +[CHANGELOG.md] +indent_style = space +indent_size = 2 + +[*.json] +max_line_length = off + +[Makefile] +max_line_length = off diff --git a/node_modules/function-bind/.eslintrc b/node_modules/function-bind/.eslintrc new file mode 100644 index 0000000..9b33d8e --- /dev/null +++ b/node_modules/function-bind/.eslintrc @@ -0,0 +1,15 @@ +{ + "root": true, + + "extends": "@ljharb", + + "rules": { + "func-name-matching": 0, + "indent": [2, 4], + "max-nested-callbacks": [2, 3], + "max-params": [2, 3], + "max-statements": [2, 20], + "no-new-func": [1], + "strict": [0] + } +} diff --git a/node_modules/function-bind/.jscs.json b/node_modules/function-bind/.jscs.json new file mode 100644 index 0000000..8c44794 --- /dev/null +++ b/node_modules/function-bind/.jscs.json @@ -0,0 +1,176 @@ +{ + "es3": true, + + "additionalRules": [], + + "requireSemicolons": true, + + "disallowMultipleSpaces": true, + + "disallowIdentifierNames": [], + + "requireCurlyBraces": { + "allExcept": [], + "keywords": ["if", "else", "for", "while", "do", "try", "catch"] + }, + + "requireSpaceAfterKeywords": ["if", "else", "for", "while", "do", "switch", "return", "try", "catch", "function"], + + "disallowSpaceAfterKeywords": [], + + "disallowSpaceBeforeComma": true, + "disallowSpaceAfterComma": false, + "disallowSpaceBeforeSemicolon": true, + + "disallowNodeTypes": [ + "DebuggerStatement", + "ForInStatement", + "LabeledStatement", + "SwitchCase", + "SwitchStatement", + "WithStatement" + ], + + "requireObjectKeysOnNewLine": { "allExcept": ["sameLine"] }, + + "requireSpacesInAnonymousFunctionExpression": { "beforeOpeningRoundBrace": true, "beforeOpeningCurlyBrace": true }, + "requireSpacesInNamedFunctionExpression": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInNamedFunctionExpression": { "beforeOpeningRoundBrace": true }, + "requireSpacesInFunctionDeclaration": { "beforeOpeningCurlyBrace": true }, + "disallowSpacesInFunctionDeclaration": { "beforeOpeningRoundBrace": true }, + + "requireSpaceBetweenArguments": true, + + "disallowSpacesInsideParentheses": true, + + "disallowSpacesInsideArrayBrackets": true, + + "disallowQuotedKeysInObjects": { "allExcept": ["reserved"] }, + + "disallowSpaceAfterObjectKeys": true, + + "requireCommaBeforeLineBreak": true, + + "disallowSpaceAfterPrefixUnaryOperators": ["++", "--", "+", "-", "~", "!"], + "requireSpaceAfterPrefixUnaryOperators": [], + + "disallowSpaceBeforePostfixUnaryOperators": ["++", "--"], + "requireSpaceBeforePostfixUnaryOperators": [], + + "disallowSpaceBeforeBinaryOperators": [], + "requireSpaceBeforeBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + + "requireSpaceAfterBinaryOperators": ["+", "-", "/", "*", "=", "==", "===", "!=", "!=="], + "disallowSpaceAfterBinaryOperators": [], + + "disallowImplicitTypeConversion": ["binary", "string"], + + "disallowKeywords": ["with", "eval"], + + "requireKeywordsOnNewLine": [], + "disallowKeywordsOnNewLine": ["else"], + + "requireLineFeedAtFileEnd": true, + + "disallowTrailingWhitespace": true, + + "disallowTrailingComma": true, + + "excludeFiles": ["node_modules/**", "vendor/**"], + + "disallowMultipleLineStrings": true, + + "requireDotNotation": { "allExcept": ["keywords"] }, + + "requireParenthesesAroundIIFE": true, + + "validateLineBreaks": "LF", + + "validateQuoteMarks": { + "escape": true, + "mark": "'" + }, + + "disallowOperatorBeforeLineBreak": [], + + "requireSpaceBeforeKeywords": [ + "do", + "for", + "if", + "else", + "switch", + "case", + "try", + "catch", + "finally", + "while", + "with", + "return" + ], + + "validateAlignedFunctionParameters": { + "lineBreakAfterOpeningBraces": true, + "lineBreakBeforeClosingBraces": true + }, + + "requirePaddingNewLinesBeforeExport": true, + + "validateNewlineAfterArrayElements": { + "maximum": 8 + }, + + "requirePaddingNewLinesAfterUseStrict": true, + + "disallowArrowFunctions": true, + + "disallowMultiLineTernary": true, + + "validateOrderInObjectKeys": "asc-insensitive", + + "disallowIdenticalDestructuringNames": true, + + "disallowNestedTernaries": { "maxLevel": 1 }, + + "requireSpaceAfterComma": { "allExcept": ["trailing"] }, + "requireAlignedMultilineParams": false, + + "requireSpacesInGenerator": { + "afterStar": true + }, + + "disallowSpacesInGenerator": { + "beforeStar": true + }, + + "disallowVar": false, + + "requireArrayDestructuring": false, + + "requireEnhancedObjectLiterals": false, + + "requireObjectDestructuring": false, + + "requireEarlyReturn": false, + + "requireCapitalizedConstructorsNew": { + "allExcept": ["Function", "String", "Object", "Symbol", "Number", "Date", "RegExp", "Error", "Boolean", "Array"] + }, + + "requireImportAlphabetized": false, + + "requireSpaceBeforeObjectValues": true, + "requireSpaceBeforeDestructuredValues": true, + + "disallowSpacesInsideTemplateStringPlaceholders": true, + + "disallowArrayDestructuringReturn": false, + + "requireNewlineBeforeSingleStatementsInIf": false, + + "disallowUnusedVariables": true, + + "requireSpacesInsideImportedObjectBraces": true, + + "requireUseStrict": true +} + diff --git a/node_modules/function-bind/.npmignore b/node_modules/function-bind/.npmignore new file mode 100644 index 0000000..dbb555f --- /dev/null +++ b/node_modules/function-bind/.npmignore @@ -0,0 +1,22 @@ +# gitignore +.DS_Store +.monitor +.*.swp +.nodemonignore +releases +*.log +*.err +fleet.json +public/browserify +bin/*.json +.bin +build +compile +.lock-wscript +coverage +node_modules + +# Only apps should have lockfiles +npm-shrinkwrap.json +package-lock.json +yarn.lock diff --git a/node_modules/function-bind/.travis.yml b/node_modules/function-bind/.travis.yml new file mode 100644 index 0000000..85f70d2 --- /dev/null +++ b/node_modules/function-bind/.travis.yml @@ -0,0 +1,168 @@ +language: node_js +os: + - linux +node_js: + - "8.4" + - "7.10" + - "6.11" + - "5.12" + - "4.8" + - "iojs-v3.3" + - "iojs-v2.5" + - "iojs-v1.8" + - "0.12" + - "0.10" + - "0.8" +before_install: + - 'if [ "${TRAVIS_NODE_VERSION}" = "0.6" ]; then npm install -g npm@1.3 ; elif [ "${TRAVIS_NODE_VERSION}" != "0.9" ]; then case "$(npm --version)" in 1.*) npm install -g npm@1.4.28 ;; 2.*) npm install -g npm@2 ;; esac ; fi' + - 'if [ "${TRAVIS_NODE_VERSION}" != "0.6" ] && [ "${TRAVIS_NODE_VERSION}" != "0.9" ]; then if [ "${TRAVIS_NODE_VERSION%${TRAVIS_NODE_VERSION#[0-9]}}" = "0" ] || [ "${TRAVIS_NODE_VERSION:0:4}" = "iojs" ]; then npm install -g npm@4.5 ; else npm install -g npm; fi; fi' +install: + - 'if [ "${TRAVIS_NODE_VERSION}" = "0.6" ]; then nvm install 0.8 && npm install -g npm@1.3 && npm install -g npm@1.4.28 && npm install -g npm@2 && npm install && nvm use "${TRAVIS_NODE_VERSION}"; else npm install; fi;' +script: + - 'if [ -n "${PRETEST-}" ]; then npm run pretest ; fi' + - 'if [ -n "${POSTTEST-}" ]; then npm run posttest ; fi' + - 'if [ -n "${COVERAGE-}" ]; then npm run coverage ; fi' + - 'if [ -n "${TEST-}" ]; then npm run tests-only ; fi' +sudo: false +env: + - TEST=true +matrix: + fast_finish: true + include: + - node_js: "node" + env: PRETEST=true + - node_js: "4" + env: COVERAGE=true + - node_js: "8.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "8.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "8.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "8.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.9" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.8" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.7" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.5" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "7.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.10" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.9" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.8" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.7" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.5" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "6.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.11" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.10" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.9" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.8" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.7" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.5" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "5.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.7" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.5" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "4.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v3.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v3.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v3.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v2.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v2.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v2.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v2.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v2.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.7" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.5" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.4" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.3" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.2" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.1" + env: TEST=true ALLOW_FAILURE=true + - node_js: "iojs-v1.0" + env: TEST=true ALLOW_FAILURE=true + - node_js: "0.11" + env: TEST=true ALLOW_FAILURE=true + - node_js: "0.9" + env: TEST=true ALLOW_FAILURE=true + - node_js: "0.6" + env: TEST=true ALLOW_FAILURE=true + - node_js: "0.4" + env: TEST=true ALLOW_FAILURE=true + allow_failures: + - os: osx + - env: TEST=true ALLOW_FAILURE=true diff --git a/node_modules/function-bind/LICENSE b/node_modules/function-bind/LICENSE new file mode 100644 index 0000000..62d6d23 --- /dev/null +++ b/node_modules/function-bind/LICENSE @@ -0,0 +1,20 @@ +Copyright (c) 2013 Raynos. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. + diff --git a/node_modules/function-bind/README.md b/node_modules/function-bind/README.md new file mode 100644 index 0000000..81862a0 --- /dev/null +++ b/node_modules/function-bind/README.md @@ -0,0 +1,48 @@ +# function-bind + + + + + +Implementation of function.prototype.bind + +## Example + +I mainly do this for unit tests I run on phantomjs. +PhantomJS does not have Function.prototype.bind :( + +```js +Function.prototype.bind = require("function-bind") +``` + +## Installation + +`npm install function-bind` + +## Contributors + + - Raynos + +## MIT Licenced + + [travis-svg]: https://travis-ci.org/Raynos/function-bind.svg + [travis-url]: https://travis-ci.org/Raynos/function-bind + [npm-badge-svg]: https://badge.fury.io/js/function-bind.svg + [npm-url]: https://npmjs.org/package/function-bind + [5]: https://coveralls.io/repos/Raynos/function-bind/badge.png + [6]: https://coveralls.io/r/Raynos/function-bind + [7]: https://gemnasium.com/Raynos/function-bind.png + [8]: https://gemnasium.com/Raynos/function-bind + [deps-svg]: https://david-dm.org/Raynos/function-bind.svg + [deps-url]: https://david-dm.org/Raynos/function-bind + [dev-deps-svg]: https://david-dm.org/Raynos/function-bind/dev-status.svg + [dev-deps-url]: https://david-dm.org/Raynos/function-bind#info=devDependencies + [11]: https://ci.testling.com/Raynos/function-bind.png + [12]: https://ci.testling.com/Raynos/function-bind diff --git a/node_modules/function-bind/implementation.js b/node_modules/function-bind/implementation.js new file mode 100644 index 0000000..cc4daec --- /dev/null +++ b/node_modules/function-bind/implementation.js @@ -0,0 +1,52 @@ +'use strict'; + +/* eslint no-invalid-this: 1 */ + +var ERROR_MESSAGE = 'Function.prototype.bind called on incompatible '; +var slice = Array.prototype.slice; +var toStr = Object.prototype.toString; +var funcType = '[object Function]'; + +module.exports = function bind(that) { + var target = this; + if (typeof target !== 'function' || toStr.call(target) !== funcType) { + throw new TypeError(ERROR_MESSAGE + target); + } + var args = slice.call(arguments, 1); + + var bound; + var binder = function () { + if (this instanceof bound) { + var result = target.apply( + this, + args.concat(slice.call(arguments)) + ); + if (Object(result) === result) { + return result; + } + return this; + } else { + return target.apply( + that, + args.concat(slice.call(arguments)) + ); + } + }; + + var boundLength = Math.max(0, target.length - args.length); + var boundArgs = []; + for (var i = 0; i < boundLength; i++) { + boundArgs.push('$' + i); + } + + bound = Function('binder', 'return function (' + boundArgs.join(',') + '){ return binder.apply(this,arguments); }')(binder); + + if (target.prototype) { + var Empty = function Empty() {}; + Empty.prototype = target.prototype; + bound.prototype = new Empty(); + Empty.prototype = null; + } + + return bound; +}; diff --git a/node_modules/function-bind/index.js b/node_modules/function-bind/index.js new file mode 100644 index 0000000..3bb6b96 --- /dev/null +++ b/node_modules/function-bind/index.js @@ -0,0 +1,5 @@ +'use strict'; + +var implementation = require('./implementation'); + +module.exports = Function.prototype.bind || implementation; diff --git a/node_modules/function-bind/package.json b/node_modules/function-bind/package.json new file mode 100644 index 0000000..20a1727 --- /dev/null +++ b/node_modules/function-bind/package.json @@ -0,0 +1,63 @@ +{ + "name": "function-bind", + "version": "1.1.1", + "description": "Implementation of Function.prototype.bind", + "keywords": [ + "function", + "bind", + "shim", + "es5" + ], + "author": "Raynos ", + "repository": "git://github.com/Raynos/function-bind.git", + "main": "index", + "homepage": "https://github.com/Raynos/function-bind", + "contributors": [ + { + "name": "Raynos" + }, + { + "name": "Jordan Harband", + "url": "https://github.com/ljharb" + } + ], + "bugs": { + "url": "https://github.com/Raynos/function-bind/issues", + "email": "raynos2@gmail.com" + }, + "dependencies": {}, + "devDependencies": { + "@ljharb/eslint-config": "^12.2.1", + "covert": "^1.1.0", + "eslint": "^4.5.0", + "jscs": "^3.0.7", + "tape": "^4.8.0" + }, + "license": "MIT", + "scripts": { + "pretest": "npm run lint", + "test": "npm run tests-only", + "posttest": "npm run coverage -- --quiet", + "tests-only": "node test", + "coverage": "covert test/*.js", + "lint": "npm run jscs && npm run eslint", + "jscs": "jscs *.js */*.js", + "eslint": "eslint *.js */*.js" + }, + "testling": { + "files": "test/index.js", + "browsers": [ + "ie/8..latest", + "firefox/16..latest", + "firefox/nightly", + "chrome/22..latest", + "chrome/canary", + "opera/12..latest", + "opera/next", + "safari/5.1..latest", + "ipad/6.0..latest", + "iphone/6.0..latest", + "android-browser/4.2..latest" + ] + } +} diff --git a/node_modules/function-bind/test/.eslintrc b/node_modules/function-bind/test/.eslintrc new file mode 100644 index 0000000..8a56d5b --- /dev/null +++ b/node_modules/function-bind/test/.eslintrc @@ -0,0 +1,9 @@ +{ + "rules": { + "array-bracket-newline": 0, + "array-element-newline": 0, + "max-statements-per-line": [2, { "max": 2 }], + "no-invalid-this": 0, + "no-magic-numbers": 0, + } +} diff --git a/node_modules/function-bind/test/index.js b/node_modules/function-bind/test/index.js new file mode 100644 index 0000000..2edecce --- /dev/null +++ b/node_modules/function-bind/test/index.js @@ -0,0 +1,252 @@ +// jscs:disable requireUseStrict + +var test = require('tape'); + +var functionBind = require('../implementation'); +var getCurrentContext = function () { return this; }; + +test('functionBind is a function', function (t) { + t.equal(typeof functionBind, 'function'); + t.end(); +}); + +test('non-functions', function (t) { + var nonFunctions = [true, false, [], {}, 42, 'foo', NaN, /a/g]; + t.plan(nonFunctions.length); + for (var i = 0; i < nonFunctions.length; ++i) { + try { functionBind.call(nonFunctions[i]); } catch (ex) { + t.ok(ex instanceof TypeError, 'throws when given ' + String(nonFunctions[i])); + } + } + t.end(); +}); + +test('without a context', function (t) { + t.test('binds properly', function (st) { + var args, context; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + context = this; + }) + }; + namespace.func(1, 2, 3); + st.deepEqual(args, [1, 2, 3]); + st.equal(context, getCurrentContext.call()); + st.end(); + }); + + t.test('binds properly, and still supplies bound arguments', function (st) { + var args, context; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + context = this; + }, undefined, 1, 2, 3) + }; + namespace.func(4, 5, 6); + st.deepEqual(args, [1, 2, 3, 4, 5, 6]); + st.equal(context, getCurrentContext.call()); + st.end(); + }); + + t.test('returns properly', function (st) { + var args; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + return this; + }, null) + }; + var context = namespace.func(1, 2, 3); + st.equal(context, getCurrentContext.call(), 'returned context is namespaced context'); + st.deepEqual(args, [1, 2, 3], 'passed arguments are correct'); + st.end(); + }); + + t.test('returns properly with bound arguments', function (st) { + var args; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + return this; + }, null, 1, 2, 3) + }; + var context = namespace.func(4, 5, 6); + st.equal(context, getCurrentContext.call(), 'returned context is namespaced context'); + st.deepEqual(args, [1, 2, 3, 4, 5, 6], 'passed arguments are correct'); + st.end(); + }); + + t.test('called as a constructor', function (st) { + var thunkify = function (value) { + return function () { return value; }; + }; + st.test('returns object value', function (sst) { + var expectedReturnValue = [1, 2, 3]; + var Constructor = functionBind.call(thunkify(expectedReturnValue), null); + var result = new Constructor(); + sst.equal(result, expectedReturnValue); + sst.end(); + }); + + st.test('does not return primitive value', function (sst) { + var Constructor = functionBind.call(thunkify(42), null); + var result = new Constructor(); + sst.notEqual(result, 42); + sst.end(); + }); + + st.test('object from bound constructor is instance of original and bound constructor', function (sst) { + var A = function (x) { + this.name = x || 'A'; + }; + var B = functionBind.call(A, null, 'B'); + + var result = new B(); + sst.ok(result instanceof B, 'result is instance of bound constructor'); + sst.ok(result instanceof A, 'result is instance of original constructor'); + sst.end(); + }); + + st.end(); + }); + + t.end(); +}); + +test('with a context', function (t) { + t.test('with no bound arguments', function (st) { + var args, context; + var boundContext = {}; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + context = this; + }, boundContext) + }; + namespace.func(1, 2, 3); + st.equal(context, boundContext, 'binds a context properly'); + st.deepEqual(args, [1, 2, 3], 'supplies passed arguments'); + st.end(); + }); + + t.test('with bound arguments', function (st) { + var args, context; + var boundContext = {}; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + context = this; + }, boundContext, 1, 2, 3) + }; + namespace.func(4, 5, 6); + st.equal(context, boundContext, 'binds a context properly'); + st.deepEqual(args, [1, 2, 3, 4, 5, 6], 'supplies bound and passed arguments'); + st.end(); + }); + + t.test('returns properly', function (st) { + var boundContext = {}; + var args; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + return this; + }, boundContext) + }; + var context = namespace.func(1, 2, 3); + st.equal(context, boundContext, 'returned context is bound context'); + st.notEqual(context, getCurrentContext.call(), 'returned context is not lexical context'); + st.deepEqual(args, [1, 2, 3], 'passed arguments are correct'); + st.end(); + }); + + t.test('returns properly with bound arguments', function (st) { + var boundContext = {}; + var args; + var namespace = { + func: functionBind.call(function () { + args = Array.prototype.slice.call(arguments); + return this; + }, boundContext, 1, 2, 3) + }; + var context = namespace.func(4, 5, 6); + st.equal(context, boundContext, 'returned context is bound context'); + st.notEqual(context, getCurrentContext.call(), 'returned context is not lexical context'); + st.deepEqual(args, [1, 2, 3, 4, 5, 6], 'passed arguments are correct'); + st.end(); + }); + + t.test('passes the correct arguments when called as a constructor', function (st) { + var expected = { name: 'Correct' }; + var namespace = { + Func: functionBind.call(function (arg) { + return arg; + }, { name: 'Incorrect' }) + }; + var returned = new namespace.Func(expected); + st.equal(returned, expected, 'returns the right arg when called as a constructor'); + st.end(); + }); + + t.test('has the new instance\'s context when called as a constructor', function (st) { + var actualContext; + var expectedContext = { foo: 'bar' }; + var namespace = { + Func: functionBind.call(function () { + actualContext = this; + }, expectedContext) + }; + var result = new namespace.Func(); + st.equal(result instanceof namespace.Func, true); + st.notEqual(actualContext, expectedContext); + st.end(); + }); + + t.end(); +}); + +test('bound function length', function (t) { + t.test('sets a correct length without thisArg', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }); + st.equal(subject.length, 3); + st.equal(subject(1, 2, 3), 6); + st.end(); + }); + + t.test('sets a correct length with thisArg', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }, {}); + st.equal(subject.length, 3); + st.equal(subject(1, 2, 3), 6); + st.end(); + }); + + t.test('sets a correct length without thisArg and first argument', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }, undefined, 1); + st.equal(subject.length, 2); + st.equal(subject(2, 3), 6); + st.end(); + }); + + t.test('sets a correct length with thisArg and first argument', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }, {}, 1); + st.equal(subject.length, 2); + st.equal(subject(2, 3), 6); + st.end(); + }); + + t.test('sets a correct length without thisArg and too many arguments', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }, undefined, 1, 2, 3, 4); + st.equal(subject.length, 0); + st.equal(subject(), 6); + st.end(); + }); + + t.test('sets a correct length with thisArg and too many arguments', function (st) { + var subject = functionBind.call(function (a, b, c) { return a + b + c; }, {}, 1, 2, 3, 4); + st.equal(subject.length, 0); + st.equal(subject(), 6); + st.end(); + }); +}); diff --git a/node_modules/glob-parent/LICENSE b/node_modules/glob-parent/LICENSE new file mode 100644 index 0000000..d701b08 --- /dev/null +++ b/node_modules/glob-parent/LICENSE @@ -0,0 +1,15 @@ +The ISC License + +Copyright (c) 2015, 2019 Elan Shanker, 2021 Blaine Bublitz , Eric Schoffstall and other contributors + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR +IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/node_modules/glob-parent/README.md b/node_modules/glob-parent/README.md new file mode 100644 index 0000000..6ae18a1 --- /dev/null +++ b/node_modules/glob-parent/README.md @@ -0,0 +1,134 @@ +

      + + + +

      + +# glob-parent + +[![NPM version][npm-image]][npm-url] [![Downloads][downloads-image]][npm-url] [![Build Status][ci-image]][ci-url] [![Coveralls Status][coveralls-image]][coveralls-url] + +Extract the non-magic parent path from a glob string. + +## Usage + +```js +var globParent = require('glob-parent'); + +globParent('path/to/*.js'); // 'path/to' +globParent('/root/path/to/*.js'); // '/root/path/to' +globParent('/*.js'); // '/' +globParent('*.js'); // '.' +globParent('**/*.js'); // '.' +globParent('path/{to,from}'); // 'path' +globParent('path/!(to|from)'); // 'path' +globParent('path/?(to|from)'); // 'path' +globParent('path/+(to|from)'); // 'path' +globParent('path/*(to|from)'); // 'path' +globParent('path/@(to|from)'); // 'path' +globParent('path/**/*'); // 'path' + +// if provided a non-glob path, returns the nearest dir +globParent('path/foo/bar.js'); // 'path/foo' +globParent('path/foo/'); // 'path/foo' +globParent('path/foo'); // 'path' (see issue #3 for details) +``` + +## API + +### `globParent(maybeGlobString, [options])` + +Takes a string and returns the part of the path before the glob begins. Be aware of Escaping rules and Limitations below. + +#### options + +```js +{ + // Disables the automatic conversion of slashes for Windows + flipBackslashes: true; +} +``` + +## Escaping + +The following characters have special significance in glob patterns and must be escaped if you want them to be treated as regular path characters: + +- `?` (question mark) unless used as a path segment alone +- `*` (asterisk) +- `|` (pipe) +- `(` (opening parenthesis) +- `)` (closing parenthesis) +- `{` (opening curly brace) +- `}` (closing curly brace) +- `[` (opening bracket) +- `]` (closing bracket) + +**Example** + +```js +globParent('foo/[bar]/'); // 'foo' +globParent('foo/\\[bar]/'); // 'foo/[bar]' +``` + +## Limitations + +### Braces & Brackets + +This library attempts a quick and imperfect method of determining which path +parts have glob magic without fully parsing/lexing the pattern. There are some +advanced use cases that can trip it up, such as nested braces where the outer +pair is escaped and the inner one contains a path separator. If you find +yourself in the unlikely circumstance of being affected by this or need to +ensure higher-fidelity glob handling in your library, it is recommended that you +pre-process your input with [expand-braces] and/or [expand-brackets]. + +### Windows + +Backslashes are not valid path separators for globs. If a path with backslashes +is provided anyway, for simple cases, glob-parent will replace the path +separator for you and return the non-glob parent path (now with +forward-slashes, which are still valid as Windows path separators). + +This cannot be used in conjunction with escape characters. + +```js +// BAD +globParent('C:\\Program Files \\(x86\\)\\*.ext'); // 'C:/Program Files /(x86/)' + +// GOOD +globParent('C:/Program Files\\(x86\\)/*.ext'); // 'C:/Program Files (x86)' +``` + +If you are using escape characters for a pattern without path parts (i.e. +relative to `cwd`), prefix with `./` to avoid confusing glob-parent. + +```js +// BAD +globParent('foo \\[bar]'); // 'foo ' +globParent('foo \\[bar]*'); // 'foo ' + +// GOOD +globParent('./foo \\[bar]'); // 'foo [bar]' +globParent('./foo \\[bar]*'); // '.' +``` + +## License + +ISC + + +[downloads-image]: https://img.shields.io/npm/dm/glob-parent.svg?style=flat-square +[npm-url]: https://www.npmjs.com/package/glob-parent +[npm-image]: https://img.shields.io/npm/v/glob-parent.svg?style=flat-square + +[ci-url]: https://github.com/gulpjs/glob-parent/actions?query=workflow:dev +[ci-image]: https://img.shields.io/github/workflow/status/gulpjs/glob-parent/dev?style=flat-square + +[coveralls-url]: https://coveralls.io/r/gulpjs/glob-parent +[coveralls-image]: https://img.shields.io/coveralls/gulpjs/glob-parent/master.svg?style=flat-square + + + +[expand-braces]: https://github.com/jonschlinkert/expand-braces +[expand-brackets]: https://github.com/jonschlinkert/expand-brackets + diff --git a/node_modules/glob-parent/index.js b/node_modules/glob-parent/index.js new file mode 100644 index 0000000..09dde64 --- /dev/null +++ b/node_modules/glob-parent/index.js @@ -0,0 +1,75 @@ +'use strict'; + +var isGlob = require('is-glob'); +var pathPosixDirname = require('path').posix.dirname; +var isWin32 = require('os').platform() === 'win32'; + +var slash = '/'; +var backslash = /\\/g; +var escaped = /\\([!*?|[\](){}])/g; + +/** + * @param {string} str + * @param {Object} opts + * @param {boolean} [opts.flipBackslashes=true] + */ +module.exports = function globParent(str, opts) { + var options = Object.assign({ flipBackslashes: true }, opts); + + // flip windows path separators + if (options.flipBackslashes && isWin32 && str.indexOf(slash) < 0) { + str = str.replace(backslash, slash); + } + + // special case for strings ending in enclosure containing path separator + if (isEnclosure(str)) { + str += slash; + } + + // preserves full path in case of trailing path separator + str += 'a'; + + // remove path parts that are globby + do { + str = pathPosixDirname(str); + } while (isGlobby(str)); + + // remove escape chars and return result + return str.replace(escaped, '$1'); +}; + +function isEnclosure(str) { + var lastChar = str.slice(-1); + + var enclosureStart; + switch (lastChar) { + case '}': + enclosureStart = '{'; + break; + case ']': + enclosureStart = '['; + break; + default: + return false; + } + + var foundIndex = str.indexOf(enclosureStart); + if (foundIndex < 0) { + return false; + } + + return str.slice(foundIndex + 1, -1).includes(slash); +} + +function isGlobby(str) { + if (/\([^()]+$/.test(str)) { + return true; + } + if (str[0] === '{' || str[0] === '[') { + return true; + } + if (/[^\\][{[]/.test(str)) { + return true; + } + return isGlob(str); +} diff --git a/node_modules/glob-parent/package.json b/node_modules/glob-parent/package.json new file mode 100644 index 0000000..baeab42 --- /dev/null +++ b/node_modules/glob-parent/package.json @@ -0,0 +1,54 @@ +{ + "name": "glob-parent", + "version": "6.0.2", + "description": "Extract the non-magic parent path from a glob string.", + "author": "Gulp Team (https://gulpjs.com/)", + "contributors": [ + "Elan Shanker (https://github.com/es128)", + "Blaine Bublitz " + ], + "repository": "gulpjs/glob-parent", + "license": "ISC", + "engines": { + "node": ">=10.13.0" + }, + "main": "index.js", + "files": [ + "LICENSE", + "index.js" + ], + "scripts": { + "lint": "eslint .", + "pretest": "npm run lint", + "test": "nyc mocha --async-only" + }, + "dependencies": { + "is-glob": "^4.0.3" + }, + "devDependencies": { + "eslint": "^7.0.0", + "eslint-config-gulp": "^5.0.0", + "expect": "^26.0.1", + "mocha": "^7.1.2", + "nyc": "^15.0.1" + }, + "nyc": { + "reporter": [ + "lcov", + "text-summary" + ] + }, + "prettier": { + "singleQuote": true + }, + "keywords": [ + "glob", + "parent", + "strip", + "path", + "dirname", + "directory", + "base", + "wildcard" + ] +} diff --git a/node_modules/has/.DS_Store b/node_modules/has/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..c0dd23103b50732e0b37ed9040fd6e0e32d9c85c GIT binary patch literal 6148 zcmeHKu};H447F*7NGu&0^9%ihP=$%H5;JOxU}%&I${zSP27ZGNVBiaQ&py&boEQ;8 zwsiM=_SsIJlygo*bosblh|EQ##2_k_jL@8QoutilDswDWo37nwQv6*LpM53|axa_R z?d18Nj-Iw_n)R+*!&1IoJ-_S6%lX*5{lUAx8)qfYQpiDWQ1dXYsF!2kxMur0)Er{l z?pQVF&(vk@kYFGf2nK?IU;sUvQl2`-91H{l!N9-(&xZ2gZ+p5fW1{@Cyul0%-O`$^ZZW literal 0 HcmV?d00001 diff --git a/node_modules/has/LICENSE-MIT b/node_modules/has/LICENSE-MIT new file mode 100644 index 0000000..ae7014d --- /dev/null +++ b/node_modules/has/LICENSE-MIT @@ -0,0 +1,22 @@ +Copyright (c) 2013 Thiago de Arruda + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/has/README.md b/node_modules/has/README.md new file mode 100644 index 0000000..635e3a4 --- /dev/null +++ b/node_modules/has/README.md @@ -0,0 +1,18 @@ +# has + +> Object.prototype.hasOwnProperty.call shortcut + +## Installation + +```sh +npm install --save has +``` + +## Usage + +```js +var has = require('has'); + +has({}, 'hasOwnProperty'); // false +has(Object.prototype, 'hasOwnProperty'); // true +``` diff --git a/node_modules/has/package.json b/node_modules/has/package.json new file mode 100644 index 0000000..7c4592f --- /dev/null +++ b/node_modules/has/package.json @@ -0,0 +1,48 @@ +{ + "name": "has", + "description": "Object.prototype.hasOwnProperty.call shortcut", + "version": "1.0.3", + "homepage": "https://github.com/tarruda/has", + "author": { + "name": "Thiago de Arruda", + "email": "tpadilha84@gmail.com" + }, + "contributors": [ + { + "name": "Jordan Harband", + "email": "ljharb@gmail.com", + "url": "http://ljharb.codes" + } + ], + "repository": { + "type": "git", + "url": "git://github.com/tarruda/has.git" + }, + "bugs": { + "url": "https://github.com/tarruda/has/issues" + }, + "license": "MIT", + "licenses": [ + { + "type": "MIT", + "url": "https://github.com/tarruda/has/blob/master/LICENSE-MIT" + } + ], + "main": "./src", + "dependencies": { + "function-bind": "^1.1.1" + }, + "devDependencies": { + "@ljharb/eslint-config": "^12.2.1", + "eslint": "^4.19.1", + "tape": "^4.9.0" + }, + "engines": { + "node": ">= 0.4.0" + }, + "scripts": { + "lint": "eslint .", + "pretest": "npm run lint", + "test": "tape test" + } +} diff --git a/node_modules/has/src/index.js b/node_modules/has/src/index.js new file mode 100644 index 0000000..dd92dd9 --- /dev/null +++ b/node_modules/has/src/index.js @@ -0,0 +1,5 @@ +'use strict'; + +var bind = require('function-bind'); + +module.exports = bind.call(Function.call, Object.prototype.hasOwnProperty); diff --git a/node_modules/has/test/index.js b/node_modules/has/test/index.js new file mode 100644 index 0000000..43d480b --- /dev/null +++ b/node_modules/has/test/index.js @@ -0,0 +1,10 @@ +'use strict'; + +var test = require('tape'); +var has = require('../'); + +test('has', function (t) { + t.equal(has({}, 'hasOwnProperty'), false, 'object literal does not have own property "hasOwnProperty"'); + t.equal(has(Object.prototype, 'hasOwnProperty'), true, 'Object.prototype has own property "hasOwnProperty"'); + t.end(); +}); diff --git a/node_modules/is-binary-path/index.d.ts b/node_modules/is-binary-path/index.d.ts new file mode 100644 index 0000000..19dcd43 --- /dev/null +++ b/node_modules/is-binary-path/index.d.ts @@ -0,0 +1,17 @@ +/** +Check if a file path is a binary file. + +@example +``` +import isBinaryPath = require('is-binary-path'); + +isBinaryPath('source/unicorn.png'); +//=> true + +isBinaryPath('source/unicorn.txt'); +//=> false +``` +*/ +declare function isBinaryPath(filePath: string): boolean; + +export = isBinaryPath; diff --git a/node_modules/is-binary-path/index.js b/node_modules/is-binary-path/index.js new file mode 100644 index 0000000..ef7548c --- /dev/null +++ b/node_modules/is-binary-path/index.js @@ -0,0 +1,7 @@ +'use strict'; +const path = require('path'); +const binaryExtensions = require('binary-extensions'); + +const extensions = new Set(binaryExtensions); + +module.exports = filePath => extensions.has(path.extname(filePath).slice(1).toLowerCase()); diff --git a/node_modules/is-binary-path/license b/node_modules/is-binary-path/license new file mode 100644 index 0000000..401b1c7 --- /dev/null +++ b/node_modules/is-binary-path/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) 2019 Sindre Sorhus (https://sindresorhus.com), Paul Miller (https://paulmillr.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/is-binary-path/package.json b/node_modules/is-binary-path/package.json new file mode 100644 index 0000000..a8d005a --- /dev/null +++ b/node_modules/is-binary-path/package.json @@ -0,0 +1,40 @@ +{ + "name": "is-binary-path", + "version": "2.1.0", + "description": "Check if a file path is a binary file", + "license": "MIT", + "repository": "sindresorhus/is-binary-path", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "sindresorhus.com" + }, + "engines": { + "node": ">=8" + }, + "scripts": { + "test": "xo && ava && tsd" + }, + "files": [ + "index.js", + "index.d.ts" + ], + "keywords": [ + "binary", + "extensions", + "extension", + "file", + "path", + "check", + "detect", + "is" + ], + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "devDependencies": { + "ava": "^1.4.1", + "tsd": "^0.7.2", + "xo": "^0.24.0" + } +} diff --git a/node_modules/is-binary-path/readme.md b/node_modules/is-binary-path/readme.md new file mode 100644 index 0000000..b4ab025 --- /dev/null +++ b/node_modules/is-binary-path/readme.md @@ -0,0 +1,34 @@ +# is-binary-path [![Build Status](https://travis-ci.org/sindresorhus/is-binary-path.svg?branch=master)](https://travis-ci.org/sindresorhus/is-binary-path) + +> Check if a file path is a binary file + + +## Install + +``` +$ npm install is-binary-path +``` + + +## Usage + +```js +const isBinaryPath = require('is-binary-path'); + +isBinaryPath('source/unicorn.png'); +//=> true + +isBinaryPath('source/unicorn.txt'); +//=> false +``` + + +## Related + +- [binary-extensions](https://github.com/sindresorhus/binary-extensions) - List of binary file extensions +- [is-text-path](https://github.com/sindresorhus/is-text-path) - Check if a filepath is a text file + + +## License + +MIT © [Sindre Sorhus](https://sindresorhus.com), [Paul Miller](https://paulmillr.com) diff --git a/node_modules/is-core-module/.eslintrc b/node_modules/is-core-module/.eslintrc new file mode 100644 index 0000000..f2e0726 --- /dev/null +++ b/node_modules/is-core-module/.eslintrc @@ -0,0 +1,18 @@ +{ + "extends": "@ljharb", + "root": true, + "rules": { + "func-style": 1, + }, + "overrides": [ + { + "files": "test/**", + "rules": { + "global-require": 0, + "max-depth": 0, + "max-lines-per-function": 0, + "no-negated-condition": 0, + }, + }, + ], +} diff --git a/node_modules/is-core-module/.nycrc b/node_modules/is-core-module/.nycrc new file mode 100644 index 0000000..bdd626c --- /dev/null +++ b/node_modules/is-core-module/.nycrc @@ -0,0 +1,9 @@ +{ + "all": true, + "check-coverage": false, + "reporter": ["text-summary", "text", "html", "json"], + "exclude": [ + "coverage", + "test" + ] +} diff --git a/node_modules/is-core-module/CHANGELOG.md b/node_modules/is-core-module/CHANGELOG.md new file mode 100644 index 0000000..1f4d1d6 --- /dev/null +++ b/node_modules/is-core-module/CHANGELOG.md @@ -0,0 +1,136 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## [v2.9.0](https://github.com/inspect-js/is-core-module/compare/v2.8.1...v2.9.0) - 2022-04-19 + +### Commits + +- [New] add `node:test`, in node 18+ [`f853eca`](https://github.com/inspect-js/is-core-module/commit/f853eca801d0a7d4e1dbb670f1b6d9837d9533c5) +- [Tests] use `mock-property` [`03b3644`](https://github.com/inspect-js/is-core-module/commit/03b3644dff4417f4ba5a7d0aa0138f5f6b3e5c46) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `auto-changelog`, `tape` [`7c0e2d0`](https://github.com/inspect-js/is-core-module/commit/7c0e2d06ed2a89acf53abe2ab34d703ed5b03455) +- [meta] simplify "exports" [`d6ed201`](https://github.com/inspect-js/is-core-module/commit/d6ed201eba7fbba0e59814a9050fc49a6e9878c8) + +## [v2.8.1](https://github.com/inspect-js/is-core-module/compare/v2.8.0...v2.8.1) - 2022-01-05 + +### Commits + +- [actions] reuse common workflows [`cd2cf9b`](https://github.com/inspect-js/is-core-module/commit/cd2cf9b3b66c8d328f65610efe41e9325db7716d) +- [Fix] update node 0.4 results [`062195d`](https://github.com/inspect-js/is-core-module/commit/062195d89f0876a88b95d378b43f7fcc1205bc5b) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `safe-publish-latest`, `tape` [`0790b62`](https://github.com/inspect-js/is-core-module/commit/0790b6222848c6167132f9f73acc3520fa8d1298) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `tape` [`7d139a6`](https://github.com/inspect-js/is-core-module/commit/7d139a6d767709eabf0a0251e074ec1fb230c06e) +- [Tests] run `nyc` in `tests-only`, not `test` [`780e8a0`](https://github.com/inspect-js/is-core-module/commit/780e8a049951c71cf78b1707f0871c48a28bde14) + +## [v2.8.0](https://github.com/inspect-js/is-core-module/compare/v2.7.0...v2.8.0) - 2021-10-14 + +### Commits + +- [actions] update codecov uploader [`0cfe94e`](https://github.com/inspect-js/is-core-module/commit/0cfe94e106a7d005ea03e008c0a21dec13a77904) +- [New] add `readline/promises` to node v17+ [`4f78c30`](https://github.com/inspect-js/is-core-module/commit/4f78c3008b1b58b4db6dc91d99610b1bc859da7e) +- [Tests] node ^14.18 supports `node:` prefixes for CJS [`43e2f17`](https://github.com/inspect-js/is-core-module/commit/43e2f177452cea2f0eaf34f61b5407217bbdb6f4) + +## [v2.7.0](https://github.com/inspect-js/is-core-module/compare/v2.6.0...v2.7.0) - 2021-09-27 + +### Commits + +- [New] node `v14.18` added `node:`-prefixed core modules to `require` [`6d943ab`](https://github.com/inspect-js/is-core-module/commit/6d943abe81382b9bbe344384d80fbfebe1cc0526) +- [Tests] add coverage for Object.prototype pollution [`c6baf5f`](https://github.com/inspect-js/is-core-module/commit/c6baf5f942311a1945c1af41167bb80b84df2af7) +- [Dev Deps] update `@ljharb/eslint-config` [`6717f00`](https://github.com/inspect-js/is-core-module/commit/6717f000d063ea57beb772bded36c2f056ac404c) +- [eslint] fix linter warning [`594c10b`](https://github.com/inspect-js/is-core-module/commit/594c10bb7d39d7eb00925c90924199ff596184b2) +- [meta] add `sideEffects` flag [`c32cfa5`](https://github.com/inspect-js/is-core-module/commit/c32cfa5195632944c4dd4284a142b8476e75be13) + +## [v2.6.0](https://github.com/inspect-js/is-core-module/compare/v2.5.0...v2.6.0) - 2021-08-17 + +### Commits + +- [Dev Deps] update `eslint`, `tape` [`6cc928f`](https://github.com/inspect-js/is-core-module/commit/6cc928f8a4bba66aeeccc4f6beeac736d4bd3081) +- [New] add `stream/consumers` to node `>= 16.7` [`a1a423e`](https://github.com/inspect-js/is-core-module/commit/a1a423e467e4cc27df180234fad5bab45943e67d) +- [Refactor] Remove duplicated `&&` operand [`86faea7`](https://github.com/inspect-js/is-core-module/commit/86faea738213a2433c62d1098488dc9314dca832) +- [Tests] include prereleases [`a4da7a6`](https://github.com/inspect-js/is-core-module/commit/a4da7a6abf7568e2aa4fd98e69452179f1850963) + +## [v2.5.0](https://github.com/inspect-js/is-core-module/compare/v2.4.0...v2.5.0) - 2021-07-12 + +### Commits + +- [Dev Deps] update `auto-changelog`, `eslint` [`6334cc9`](https://github.com/inspect-js/is-core-module/commit/6334cc94f3af7469685bd8f236740991baaf2705) +- [New] add `stream/web` to node v16.5+ [`17ac59b`](https://github.com/inspect-js/is-core-module/commit/17ac59b662d63e220a2e5728625f005c24f177b2) + +## [v2.4.0](https://github.com/inspect-js/is-core-module/compare/v2.3.0...v2.4.0) - 2021-05-09 + +### Commits + +- [readme] add actions and codecov badges [`82b7faa`](https://github.com/inspect-js/is-core-module/commit/82b7faa12b56dbe47fbea67e1a5b9e447027ba40) +- [Dev Deps] update `@ljharb/eslint-config`, `aud` [`8096868`](https://github.com/inspect-js/is-core-module/commit/8096868c024a161ccd4d44110b136763e92eace8) +- [Dev Deps] update `eslint` [`6726824`](https://github.com/inspect-js/is-core-module/commit/67268249b88230018c510f6532a8046d7326346f) +- [New] add `diagnostics_channel` to node `^14.17` [`86c6563`](https://github.com/inspect-js/is-core-module/commit/86c65634201b8ff9b3e48a9a782594579c7f5c3c) +- [meta] fix prepublish script [`697a01e`](https://github.com/inspect-js/is-core-module/commit/697a01e3c9c0be074066520954f30fb28532ec57) + +## [v2.3.0](https://github.com/inspect-js/is-core-module/compare/v2.2.0...v2.3.0) - 2021-04-24 + +### Commits + +- [meta] do not publish github action workflow files [`060d4bb`](https://github.com/inspect-js/is-core-module/commit/060d4bb971a29451c19ff336eb56bee27f9fa95a) +- [New] add support for `node:` prefix, in node 16+ [`7341223`](https://github.com/inspect-js/is-core-module/commit/73412230a769f6e81c05eea50b6520cebf54ed2f) +- [actions] use `node/install` instead of `node/run`; use `codecov` action [`016269a`](https://github.com/inspect-js/is-core-module/commit/016269abae9f6657a5254adfbb813f09a05067f9) +- [patch] remove unneeded `.0` in version ranges [`cb466a6`](https://github.com/inspect-js/is-core-module/commit/cb466a6d89e52b8389e5c12715efcd550c41cea3) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`, `tape` [`c9f9c39`](https://github.com/inspect-js/is-core-module/commit/c9f9c396ace60ef81906f98059c064e6452473ed) +- [actions] update workflows [`3ee4a89`](https://github.com/inspect-js/is-core-module/commit/3ee4a89fd5a02fccd43882d905448ea6a98e9a3c) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config` [`dee4fed`](https://github.com/inspect-js/is-core-module/commit/dee4fed79690c1d43a22f7fa9426abebdc6d727f) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config` [`7d046ba`](https://github.com/inspect-js/is-core-module/commit/7d046ba07ae8c9292e43652694ca808d7b309de8) +- [meta] use `prepublishOnly` script for npm 7+ [`149e677`](https://github.com/inspect-js/is-core-module/commit/149e6771a5ede6d097e71785b467a9c4b4977cc7) +- [readme] remove travis badge [`903b51d`](https://github.com/inspect-js/is-core-module/commit/903b51d6b69b98abeabfbc3695c345b02646f19c) + +## [v2.2.0](https://github.com/inspect-js/is-core-module/compare/v2.1.0...v2.2.0) - 2020-11-26 + +### Commits + +- [Tests] migrate tests to Github Actions [`c919f57`](https://github.com/inspect-js/is-core-module/commit/c919f573c0a92d10a0acad0b650b5aecb033d426) +- [patch] `core.json`: %s/ /\t/g [`db3f685`](https://github.com/inspect-js/is-core-module/commit/db3f68581f53e73cc09cd675955eb1bdd6a5a39b) +- [Tests] run `nyc` on all tests [`b2f925f`](https://github.com/inspect-js/is-core-module/commit/b2f925f8866f210ef441f39fcc8cc42692ab89b1) +- [Dev Deps] update `eslint`, `@ljharb/eslint-config`, `aud`; add `safe-publish-latest` [`89f02a2`](https://github.com/inspect-js/is-core-module/commit/89f02a2b4162246dea303a6ee31bb9a550b05c72) +- [New] add `path/posix`, `path/win32`, `util/types` [`77f94f1`](https://github.com/inspect-js/is-core-module/commit/77f94f1e90ffd7c0be2a3f1aa8574ebf7fd981b3) + +## [v2.1.0](https://github.com/inspect-js/is-core-module/compare/v2.0.0...v2.1.0) - 2020-11-04 + +### Commits + +- [Dev Deps] update `eslint` [`5e0034e`](https://github.com/inspect-js/is-core-module/commit/5e0034eae57c09c8f1bd769f502486a00f56c6e4) +- [New] Add `diagnostics_channel` [`c2d83d0`](https://github.com/inspect-js/is-core-module/commit/c2d83d0a0225a1a658945d9bab7036ea347d29ec) + +## [v2.0.0](https://github.com/inspect-js/is-core-module/compare/v1.0.2...v2.0.0) - 2020-09-29 + +### Commits + +- v2 implementation [`865aeb5`](https://github.com/inspect-js/is-core-module/commit/865aeb5ca0e90248a3dfff5d7622e4751fdeb9cd) +- Only apps should have lockfiles [`5a5e660`](https://github.com/inspect-js/is-core-module/commit/5a5e660d568e37eb44e17fb1ebb12a105205fc2b) +- Initial commit for v2 [`5a51524`](https://github.com/inspect-js/is-core-module/commit/5a51524e06f92adece5fbb138c69b7b9748a2348) +- Tests [`116eae4`](https://github.com/inspect-js/is-core-module/commit/116eae4fccd01bc72c1fd3cc4b7561c387afc496) +- [meta] add `auto-changelog` [`c24388b`](https://github.com/inspect-js/is-core-module/commit/c24388bee828d223040519d1f5b226ca35beee63) +- [actions] add "Automatic Rebase" and "require allow edits" actions [`34292db`](https://github.com/inspect-js/is-core-module/commit/34292dbcbadae0868aff03c22dbd8b7b8a11558a) +- [Tests] add `npm run lint` [`4f9eeee`](https://github.com/inspect-js/is-core-module/commit/4f9eeee7ddff10698bbf528620f4dc8d4fa3e697) +- [readme] fix travis badges, https all URLs [`e516a73`](https://github.com/inspect-js/is-core-module/commit/e516a73b0dccce20938c432b1ba512eae8eff9e9) +- [meta] create FUNDING.yml [`1aabebc`](https://github.com/inspect-js/is-core-module/commit/1aabebca98d01f8a04e46bc2e2520fa93cf21ac6) +- [Fix] `domain`: domain landed sometime > v0.7.7 and <= v0.7.12 [`2df7d37`](https://github.com/inspect-js/is-core-module/commit/2df7d37595d41b15eeada732b706b926c2771655) +- [Fix] `sys`: worked in 0.6, not 0.7, and 0.8+ [`a75c134`](https://github.com/inspect-js/is-core-module/commit/a75c134229e1e9441801f6b73f6a52489346eb65) + +## [v1.0.2](https://github.com/inspect-js/is-core-module/compare/v1.0.1...v1.0.2) - 2014-09-28 + +### Commits + +- simpler [`66fe90f`](https://github.com/inspect-js/is-core-module/commit/66fe90f9771581b9adc0c3900baa52c21b5baea2) + +## [v1.0.1](https://github.com/inspect-js/is-core-module/compare/v1.0.0...v1.0.1) - 2014-09-28 + +### Commits + +- remove stupid [`f21f906`](https://github.com/inspect-js/is-core-module/commit/f21f906f882c2bd656a5fc5ed6fbe48ddaffb2ac) +- update readme [`1eff0ec`](https://github.com/inspect-js/is-core-module/commit/1eff0ec69798d1ec65771552d1562911e90a8027) + +## v1.0.0 - 2014-09-28 + +### Commits + +- init [`48e5e76`](https://github.com/inspect-js/is-core-module/commit/48e5e76cac378fddb8c1f7d4055b8dfc943d6b96) diff --git a/node_modules/is-core-module/LICENSE b/node_modules/is-core-module/LICENSE new file mode 100644 index 0000000..2e50287 --- /dev/null +++ b/node_modules/is-core-module/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2014 Dave Justice + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/node_modules/is-core-module/README.md b/node_modules/is-core-module/README.md new file mode 100644 index 0000000..062d906 --- /dev/null +++ b/node_modules/is-core-module/README.md @@ -0,0 +1,40 @@ +# is-core-module [![Version Badge][2]][1] + +[![github actions][actions-image]][actions-url] +[![coverage][codecov-image]][codecov-url] +[![dependency status][5]][6] +[![dev dependency status][7]][8] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] + +[![npm badge][11]][1] + +Is this specifier a node.js core module? Optionally provide a node version to check; defaults to the current node version. + +## Example + +```js +var isCore = require('is-core-module'); +var assert = require('assert'); +assert(isCore('fs')); +assert(!isCore('butts')); +``` + +## Tests +Clone the repo, `npm install`, and run `npm test` + +[1]: https://npmjs.org/package/is-core-module +[2]: https://versionbadg.es/inspect-js/is-core-module.svg +[5]: https://david-dm.org/inspect-js/is-core-module.svg +[6]: https://david-dm.org/inspect-js/is-core-module +[7]: https://david-dm.org/inspect-js/is-core-module/dev-status.svg +[8]: https://david-dm.org/inspect-js/is-core-module#info=devDependencies +[11]: https://nodei.co/npm/is-core-module.png?downloads=true&stars=true +[license-image]: https://img.shields.io/npm/l/is-core-module.svg +[license-url]: LICENSE +[downloads-image]: https://img.shields.io/npm/dm/is-core-module.svg +[downloads-url]: https://npm-stat.com/charts.html?package=is-core-module +[codecov-image]: https://codecov.io/gh/inspect-js/is-core-module/branch/main/graphs/badge.svg +[codecov-url]: https://app.codecov.io/gh/inspect-js/is-core-module/ +[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/inspect-js/is-core-module +[actions-url]: https://github.com/inspect-js/is-core-module/actions diff --git a/node_modules/is-core-module/core.json b/node_modules/is-core-module/core.json new file mode 100644 index 0000000..058584b --- /dev/null +++ b/node_modules/is-core-module/core.json @@ -0,0 +1,153 @@ +{ + "assert": true, + "node:assert": [">= 14.18 && < 15", ">= 16"], + "assert/strict": ">= 15", + "node:assert/strict": ">= 16", + "async_hooks": ">= 8", + "node:async_hooks": [">= 14.18 && < 15", ">= 16"], + "buffer_ieee754": ">= 0.5 && < 0.9.7", + "buffer": true, + "node:buffer": [">= 14.18 && < 15", ">= 16"], + "child_process": true, + "node:child_process": [">= 14.18 && < 15", ">= 16"], + "cluster": ">= 0.5", + "node:cluster": [">= 14.18 && < 15", ">= 16"], + "console": true, + "node:console": [">= 14.18 && < 15", ">= 16"], + "constants": true, + "node:constants": [">= 14.18 && < 15", ">= 16"], + "crypto": true, + "node:crypto": [">= 14.18 && < 15", ">= 16"], + "_debug_agent": ">= 1 && < 8", + "_debugger": "< 8", + "dgram": true, + "node:dgram": [">= 14.18 && < 15", ">= 16"], + "diagnostics_channel": [">= 14.17 && < 15", ">= 15.1"], + "node:diagnostics_channel": [">= 14.18 && < 15", ">= 16"], + "dns": true, + "node:dns": [">= 14.18 && < 15", ">= 16"], + "dns/promises": ">= 15", + "node:dns/promises": ">= 16", + "domain": ">= 0.7.12", + "node:domain": [">= 14.18 && < 15", ">= 16"], + "events": true, + "node:events": [">= 14.18 && < 15", ">= 16"], + "freelist": "< 6", + "fs": true, + "node:fs": [">= 14.18 && < 15", ">= 16"], + "fs/promises": [">= 10 && < 10.1", ">= 14"], + "node:fs/promises": [">= 14.18 && < 15", ">= 16"], + "_http_agent": ">= 0.11.1", + "node:_http_agent": [">= 14.18 && < 15", ">= 16"], + "_http_client": ">= 0.11.1", + "node:_http_client": [">= 14.18 && < 15", ">= 16"], + "_http_common": ">= 0.11.1", + "node:_http_common": [">= 14.18 && < 15", ">= 16"], + "_http_incoming": ">= 0.11.1", + "node:_http_incoming": [">= 14.18 && < 15", ">= 16"], + "_http_outgoing": ">= 0.11.1", + "node:_http_outgoing": [">= 14.18 && < 15", ">= 16"], + "_http_server": ">= 0.11.1", + "node:_http_server": [">= 14.18 && < 15", ">= 16"], + "http": true, + "node:http": [">= 14.18 && < 15", ">= 16"], + "http2": ">= 8.8", + "node:http2": [">= 14.18 && < 15", ">= 16"], + "https": true, + "node:https": [">= 14.18 && < 15", ">= 16"], + "inspector": ">= 8", + "node:inspector": [">= 14.18 && < 15", ">= 16"], + "_linklist": "< 8", + "module": true, + "node:module": [">= 14.18 && < 15", ">= 16"], + "net": true, + "node:net": [">= 14.18 && < 15", ">= 16"], + "node-inspect/lib/_inspect": ">= 7.6 && < 12", + "node-inspect/lib/internal/inspect_client": ">= 7.6 && < 12", + "node-inspect/lib/internal/inspect_repl": ">= 7.6 && < 12", + "os": true, + "node:os": [">= 14.18 && < 15", ">= 16"], + "path": true, + "node:path": [">= 14.18 && < 15", ">= 16"], + "path/posix": ">= 15.3", + "node:path/posix": ">= 16", + "path/win32": ">= 15.3", + "node:path/win32": ">= 16", + "perf_hooks": ">= 8.5", + "node:perf_hooks": [">= 14.18 && < 15", ">= 16"], + "process": ">= 1", + "node:process": [">= 14.18 && < 15", ">= 16"], + "punycode": ">= 0.5", + "node:punycode": [">= 14.18 && < 15", ">= 16"], + "querystring": true, + "node:querystring": [">= 14.18 && < 15", ">= 16"], + "readline": true, + "node:readline": [">= 14.18 && < 15", ">= 16"], + "readline/promises": ">= 17", + "node:readline/promises": ">= 17", + "repl": true, + "node:repl": [">= 14.18 && < 15", ">= 16"], + "smalloc": ">= 0.11.5 && < 3", + "_stream_duplex": ">= 0.9.4", + "node:_stream_duplex": [">= 14.18 && < 15", ">= 16"], + "_stream_transform": ">= 0.9.4", + "node:_stream_transform": [">= 14.18 && < 15", ">= 16"], + "_stream_wrap": ">= 1.4.1", + "node:_stream_wrap": [">= 14.18 && < 15", ">= 16"], + "_stream_passthrough": ">= 0.9.4", + "node:_stream_passthrough": [">= 14.18 && < 15", ">= 16"], + "_stream_readable": ">= 0.9.4", + "node:_stream_readable": [">= 14.18 && < 15", ">= 16"], + "_stream_writable": ">= 0.9.4", + "node:_stream_writable": [">= 14.18 && < 15", ">= 16"], + "stream": true, + "node:stream": [">= 14.18 && < 15", ">= 16"], + "stream/consumers": ">= 16.7", + "node:stream/consumers": ">= 16.7", + "stream/promises": ">= 15", + "node:stream/promises": ">= 16", + "stream/web": ">= 16.5", + "node:stream/web": ">= 16.5", + "string_decoder": true, + "node:string_decoder": [">= 14.18 && < 15", ">= 16"], + "sys": [">= 0.4 && < 0.7", ">= 0.8"], + "node:sys": [">= 14.18 && < 15", ">= 16"], + "node:test": ">= 18", + "timers": true, + "node:timers": [">= 14.18 && < 15", ">= 16"], + "timers/promises": ">= 15", + "node:timers/promises": ">= 16", + "_tls_common": ">= 0.11.13", + "node:_tls_common": [">= 14.18 && < 15", ">= 16"], + "_tls_legacy": ">= 0.11.3 && < 10", + "_tls_wrap": ">= 0.11.3", + "node:_tls_wrap": [">= 14.18 && < 15", ">= 16"], + "tls": true, + "node:tls": [">= 14.18 && < 15", ">= 16"], + "trace_events": ">= 10", + "node:trace_events": [">= 14.18 && < 15", ">= 16"], + "tty": true, + "node:tty": [">= 14.18 && < 15", ">= 16"], + "url": true, + "node:url": [">= 14.18 && < 15", ">= 16"], + "util": true, + "node:util": [">= 14.18 && < 15", ">= 16"], + "util/types": ">= 15.3", + "node:util/types": ">= 16", + "v8/tools/arguments": ">= 10 && < 12", + "v8/tools/codemap": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/consarray": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/csvparser": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/logreader": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/profile_view": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/splaytree": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8": ">= 1", + "node:v8": [">= 14.18 && < 15", ">= 16"], + "vm": true, + "node:vm": [">= 14.18 && < 15", ">= 16"], + "wasi": ">= 13.4 && < 13.5", + "worker_threads": ">= 11.7", + "node:worker_threads": [">= 14.18 && < 15", ">= 16"], + "zlib": ">= 0.5", + "node:zlib": [">= 14.18 && < 15", ">= 16"] +} diff --git a/node_modules/is-core-module/index.js b/node_modules/is-core-module/index.js new file mode 100644 index 0000000..f9637e0 --- /dev/null +++ b/node_modules/is-core-module/index.js @@ -0,0 +1,69 @@ +'use strict'; + +var has = require('has'); + +function specifierIncluded(current, specifier) { + var nodeParts = current.split('.'); + var parts = specifier.split(' '); + var op = parts.length > 1 ? parts[0] : '='; + var versionParts = (parts.length > 1 ? parts[1] : parts[0]).split('.'); + + for (var i = 0; i < 3; ++i) { + var cur = parseInt(nodeParts[i] || 0, 10); + var ver = parseInt(versionParts[i] || 0, 10); + if (cur === ver) { + continue; // eslint-disable-line no-restricted-syntax, no-continue + } + if (op === '<') { + return cur < ver; + } + if (op === '>=') { + return cur >= ver; + } + return false; + } + return op === '>='; +} + +function matchesRange(current, range) { + var specifiers = range.split(/ ?&& ?/); + if (specifiers.length === 0) { + return false; + } + for (var i = 0; i < specifiers.length; ++i) { + if (!specifierIncluded(current, specifiers[i])) { + return false; + } + } + return true; +} + +function versionIncluded(nodeVersion, specifierValue) { + if (typeof specifierValue === 'boolean') { + return specifierValue; + } + + var current = typeof nodeVersion === 'undefined' + ? process.versions && process.versions.node + : nodeVersion; + + if (typeof current !== 'string') { + throw new TypeError(typeof nodeVersion === 'undefined' ? 'Unable to determine current node version' : 'If provided, a valid node version is required'); + } + + if (specifierValue && typeof specifierValue === 'object') { + for (var i = 0; i < specifierValue.length; ++i) { + if (matchesRange(current, specifierValue[i])) { + return true; + } + } + return false; + } + return matchesRange(current, specifierValue); +} + +var data = require('./core.json'); + +module.exports = function isCore(x, nodeVersion) { + return has(data, x) && versionIncluded(nodeVersion, data[x]); +}; diff --git a/node_modules/is-core-module/package.json b/node_modules/is-core-module/package.json new file mode 100644 index 0000000..80ce9f5 --- /dev/null +++ b/node_modules/is-core-module/package.json @@ -0,0 +1,65 @@ +{ + "name": "is-core-module", + "version": "2.9.0", + "description": "Is this specifier a node.js core module?", + "main": "index.js", + "sideEffects": false, + "exports": { + ".": "./index.js", + "./package.json": "./package.json" + }, + "scripts": { + "prepublish": "not-in-publish || npm run prepublishOnly", + "prepublishOnly": "safe-publish-latest", + "lint": "eslint .", + "pretest": "npm run lint", + "tests-only": "nyc tape 'test/**/*.js'", + "test": "npm run tests-only", + "posttest": "aud --production", + "version": "auto-changelog && git add CHANGELOG.md", + "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\"" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/inspect-js/is-core-module.git" + }, + "keywords": [ + "core", + "modules", + "module", + "npm", + "node", + "dependencies" + ], + "author": "Jordan Harband ", + "funding": { + "url": "https://github.com/sponsors/ljharb" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/inspect-js/is-core-module/issues" + }, + "homepage": "https://github.com/inspect-js/is-core-module", + "dependencies": { + "has": "^1.0.3" + }, + "devDependencies": { + "@ljharb/eslint-config": "^21.0.0", + "aud": "^2.0.0", + "auto-changelog": "^2.4.0", + "eslint": "=8.8.0", + "mock-property": "^1.0.0", + "nyc": "^10.3.2", + "safe-publish-latest": "^2.0.0", + "semver": "^6.3.0", + "tape": "^5.5.3" + }, + "auto-changelog": { + "output": "CHANGELOG.md", + "template": "keepachangelog", + "unreleased": false, + "commitLimit": false, + "backfillLimit": false, + "hideCredit": true + } +} diff --git a/node_modules/is-core-module/test/index.js b/node_modules/is-core-module/test/index.js new file mode 100644 index 0000000..4385b20 --- /dev/null +++ b/node_modules/is-core-module/test/index.js @@ -0,0 +1,133 @@ +'use strict'; + +var test = require('tape'); +var keys = require('object-keys'); +var semver = require('semver'); +var mockProperty = require('mock-property'); + +var isCore = require('../'); +var data = require('../core.json'); + +var supportsNodePrefix = semver.satisfies(process.versions.node, '^14.18 || >= 16', { includePrerelease: true }); + +test('core modules', function (t) { + t.test('isCore()', function (st) { + st.ok(isCore('fs')); + st.ok(isCore('net')); + st.ok(isCore('http')); + + st.ok(!isCore('seq')); + st.ok(!isCore('../')); + + st.ok(!isCore('toString')); + + st.end(); + }); + + t.test('core list', function (st) { + var cores = keys(data); + st.plan(cores.length); + + for (var i = 0; i < cores.length; ++i) { + var mod = cores[i]; + var requireFunc = function () { require(mod); }; // eslint-disable-line no-loop-func + if (isCore(mod)) { + st.doesNotThrow(requireFunc, mod + ' supported; requiring does not throw'); + } else { + st['throws'](requireFunc, mod + ' not supported; requiring throws'); + } + } + + st.end(); + }); + + t.test('core via repl module', { skip: !data.repl }, function (st) { + var libs = require('repl')._builtinLibs; // eslint-disable-line no-underscore-dangle + if (!libs) { + st.skip('module.builtinModules does not exist'); + } else { + for (var i = 0; i < libs.length; ++i) { + var mod = libs[i]; + st.ok(data[mod], mod + ' is a core module'); + st.doesNotThrow( + function () { require(mod); }, // eslint-disable-line no-loop-func + 'requiring ' + mod + ' does not throw' + ); + if (mod.slice(0, 5) !== 'node:') { + if (supportsNodePrefix) { + st.doesNotThrow( + function () { require('node:' + mod); }, // eslint-disable-line no-loop-func + 'requiring node:' + mod + ' does not throw' + ); + } else { + st['throws']( + function () { require('node:' + mod); }, // eslint-disable-line no-loop-func + 'requiring node:' + mod + ' throws' + ); + } + } + } + } + st.end(); + }); + + t.test('core via builtinModules list', { skip: !data.module }, function (st) { + var libs = require('module').builtinModules; + if (!libs) { + st.skip('module.builtinModules does not exist'); + } else { + var excludeList = [ + '_debug_agent', + 'v8/tools/tickprocessor-driver', + 'v8/tools/SourceMap', + 'v8/tools/tickprocessor', + 'v8/tools/profile' + ]; + // see https://github.com/nodejs/node/issues/42785 + if (semver.satisfies(process.version, '>= 18')) { + libs = libs.concat('node:test'); + } + for (var i = 0; i < libs.length; ++i) { + var mod = libs[i]; + if (excludeList.indexOf(mod) === -1) { + st.ok(data[mod], mod + ' is a core module'); + st.doesNotThrow( + function () { require(mod); }, // eslint-disable-line no-loop-func + 'requiring ' + mod + ' does not throw' + ); + if (mod.slice(0, 5) !== 'node:') { + if (supportsNodePrefix) { + st.doesNotThrow( + function () { require('node:' + mod); }, // eslint-disable-line no-loop-func + 'requiring node:' + mod + ' does not throw' + ); + } else { + st['throws']( + function () { require('node:' + mod); }, // eslint-disable-line no-loop-func + 'requiring node:' + mod + ' throws' + ); + } + } + } + } + } + st.end(); + }); + + t.test('Object.prototype pollution', function (st) { + var nonKey = 'not a core module'; + st.teardown(mockProperty(Object.prototype, 'fs', { value: false })); + st.teardown(mockProperty(Object.prototype, 'path', { value: '>= 999999999' })); + st.teardown(mockProperty(Object.prototype, 'http', { value: data.http })); + st.teardown(mockProperty(Object.prototype, nonKey, { value: true })); + + st.equal(isCore('fs'), true, 'fs is a core module even if Object.prototype lies'); + st.equal(isCore('path'), true, 'path is a core module even if Object.prototype lies'); + st.equal(isCore('http'), true, 'path is a core module even if Object.prototype matches data'); + st.equal(isCore(nonKey), false, '"' + nonKey + '" is not a core module even if Object.prototype lies'); + + st.end(); + }); + + t.end(); +}); diff --git a/node_modules/is-extglob/LICENSE b/node_modules/is-extglob/LICENSE new file mode 100644 index 0000000..842218c --- /dev/null +++ b/node_modules/is-extglob/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-2016, Jon Schlinkert + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/is-extglob/README.md b/node_modules/is-extglob/README.md new file mode 100644 index 0000000..0416af5 --- /dev/null +++ b/node_modules/is-extglob/README.md @@ -0,0 +1,107 @@ +# is-extglob [![NPM version](https://img.shields.io/npm/v/is-extglob.svg?style=flat)](https://www.npmjs.com/package/is-extglob) [![NPM downloads](https://img.shields.io/npm/dm/is-extglob.svg?style=flat)](https://npmjs.org/package/is-extglob) [![Build Status](https://img.shields.io/travis/jonschlinkert/is-extglob.svg?style=flat)](https://travis-ci.org/jonschlinkert/is-extglob) + +> Returns true if a string has an extglob. + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +$ npm install --save is-extglob +``` + +## Usage + +```js +var isExtglob = require('is-extglob'); +``` + +**True** + +```js +isExtglob('?(abc)'); +isExtglob('@(abc)'); +isExtglob('!(abc)'); +isExtglob('*(abc)'); +isExtglob('+(abc)'); +``` + +**False** + +Escaped extglobs: + +```js +isExtglob('\\?(abc)'); +isExtglob('\\@(abc)'); +isExtglob('\\!(abc)'); +isExtglob('\\*(abc)'); +isExtglob('\\+(abc)'); +``` + +Everything else... + +```js +isExtglob('foo.js'); +isExtglob('!foo.js'); +isExtglob('*.js'); +isExtglob('**/abc.js'); +isExtglob('abc/*.js'); +isExtglob('abc/(aaa|bbb).js'); +isExtglob('abc/[a-z].js'); +isExtglob('abc/{a,b}.js'); +isExtglob('abc/?.js'); +isExtglob('abc.js'); +isExtglob('abc/def/ghi.js'); +``` + +## History + +**v2.0** + +Adds support for escaping. Escaped exglobs no longer return true. + +## About + +### Related projects + +* [has-glob](https://www.npmjs.com/package/has-glob): Returns `true` if an array has a glob pattern. | [homepage](https://github.com/jonschlinkert/has-glob "Returns `true` if an array has a glob pattern.") +* [is-glob](https://www.npmjs.com/package/is-glob): Returns `true` if the given string looks like a glob pattern or an extglob pattern… [more](https://github.com/jonschlinkert/is-glob) | [homepage](https://github.com/jonschlinkert/is-glob "Returns `true` if the given string looks like a glob pattern or an extglob pattern. This makes it easy to create code that only uses external modules like node-glob when necessary, resulting in much faster code execution and initialization time, and a bet") +* [micromatch](https://www.npmjs.com/package/micromatch): Glob matching for javascript/node.js. A drop-in replacement and faster alternative to minimatch and multimatch. | [homepage](https://github.com/jonschlinkert/micromatch "Glob matching for javascript/node.js. A drop-in replacement and faster alternative to minimatch and multimatch.") + +### Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +### Building docs + +_(This document was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme) (a [verb](https://github.com/verbose/verb) generator), please don't edit the readme directly. Any changes to the readme must be made in [.verb.md](.verb.md).)_ + +To generate the readme and API documentation with [verb](https://github.com/verbose/verb): + +```sh +$ npm install -g verb verb-generate-readme && verb +``` + +### Running tests + +Install dev dependencies: + +```sh +$ npm install -d && npm test +``` + +### Author + +**Jon Schlinkert** + +* [github/jonschlinkert](https://github.com/jonschlinkert) +* [twitter/jonschlinkert](http://twitter.com/jonschlinkert) + +### License + +Copyright © 2016, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT license](https://github.com/jonschlinkert/is-extglob/blob/master/LICENSE). + +*** + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.1.31, on October 12, 2016._ \ No newline at end of file diff --git a/node_modules/is-extglob/index.js b/node_modules/is-extglob/index.js new file mode 100644 index 0000000..c1d986f --- /dev/null +++ b/node_modules/is-extglob/index.js @@ -0,0 +1,20 @@ +/*! + * is-extglob + * + * Copyright (c) 2014-2016, Jon Schlinkert. + * Licensed under the MIT License. + */ + +module.exports = function isExtglob(str) { + if (typeof str !== 'string' || str === '') { + return false; + } + + var match; + while ((match = /(\\).|([@?!+*]\(.*\))/g.exec(str))) { + if (match[2]) return true; + str = str.slice(match.index + match[0].length); + } + + return false; +}; diff --git a/node_modules/is-extglob/package.json b/node_modules/is-extglob/package.json new file mode 100644 index 0000000..7a90836 --- /dev/null +++ b/node_modules/is-extglob/package.json @@ -0,0 +1,69 @@ +{ + "name": "is-extglob", + "description": "Returns true if a string has an extglob.", + "version": "2.1.1", + "homepage": "https://github.com/jonschlinkert/is-extglob", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "repository": "jonschlinkert/is-extglob", + "bugs": { + "url": "https://github.com/jonschlinkert/is-extglob/issues" + }, + "license": "MIT", + "files": [ + "index.js" + ], + "main": "index.js", + "engines": { + "node": ">=0.10.0" + }, + "scripts": { + "test": "mocha" + }, + "devDependencies": { + "gulp-format-md": "^0.1.10", + "mocha": "^3.0.2" + }, + "keywords": [ + "bash", + "braces", + "check", + "exec", + "expression", + "extglob", + "glob", + "globbing", + "globstar", + "is", + "match", + "matches", + "pattern", + "regex", + "regular", + "string", + "test" + ], + "verb": { + "toc": false, + "layout": "default", + "tasks": [ + "readme" + ], + "plugins": [ + "gulp-format-md" + ], + "related": { + "list": [ + "has-glob", + "is-glob", + "micromatch" + ] + }, + "reflinks": [ + "verb", + "verb-generate-readme" + ], + "lint": { + "reflinks": true + } + } +} diff --git a/node_modules/is-glob/LICENSE b/node_modules/is-glob/LICENSE new file mode 100644 index 0000000..3f2eca1 --- /dev/null +++ b/node_modules/is-glob/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-2017, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/is-glob/README.md b/node_modules/is-glob/README.md new file mode 100644 index 0000000..740724b --- /dev/null +++ b/node_modules/is-glob/README.md @@ -0,0 +1,206 @@ +# is-glob [![NPM version](https://img.shields.io/npm/v/is-glob.svg?style=flat)](https://www.npmjs.com/package/is-glob) [![NPM monthly downloads](https://img.shields.io/npm/dm/is-glob.svg?style=flat)](https://npmjs.org/package/is-glob) [![NPM total downloads](https://img.shields.io/npm/dt/is-glob.svg?style=flat)](https://npmjs.org/package/is-glob) [![Build Status](https://img.shields.io/github/workflow/status/micromatch/is-glob/dev)](https://github.com/micromatch/is-glob/actions) + +> Returns `true` if the given string looks like a glob pattern or an extglob pattern. This makes it easy to create code that only uses external modules like node-glob when necessary, resulting in much faster code execution and initialization time, and a better user experience. + +Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +$ npm install --save is-glob +``` + +You might also be interested in [is-valid-glob](https://github.com/jonschlinkert/is-valid-glob) and [has-glob](https://github.com/jonschlinkert/has-glob). + +## Usage + +```js +var isGlob = require('is-glob'); +``` + +### Default behavior + +**True** + +Patterns that have glob characters or regex patterns will return `true`: + +```js +isGlob('!foo.js'); +isGlob('*.js'); +isGlob('**/abc.js'); +isGlob('abc/*.js'); +isGlob('abc/(aaa|bbb).js'); +isGlob('abc/[a-z].js'); +isGlob('abc/{a,b}.js'); +//=> true +``` + +Extglobs + +```js +isGlob('abc/@(a).js'); +isGlob('abc/!(a).js'); +isGlob('abc/+(a).js'); +isGlob('abc/*(a).js'); +isGlob('abc/?(a).js'); +//=> true +``` + +**False** + +Escaped globs or extglobs return `false`: + +```js +isGlob('abc/\\@(a).js'); +isGlob('abc/\\!(a).js'); +isGlob('abc/\\+(a).js'); +isGlob('abc/\\*(a).js'); +isGlob('abc/\\?(a).js'); +isGlob('\\!foo.js'); +isGlob('\\*.js'); +isGlob('\\*\\*/abc.js'); +isGlob('abc/\\*.js'); +isGlob('abc/\\(aaa|bbb).js'); +isGlob('abc/\\[a-z].js'); +isGlob('abc/\\{a,b}.js'); +//=> false +``` + +Patterns that do not have glob patterns return `false`: + +```js +isGlob('abc.js'); +isGlob('abc/def/ghi.js'); +isGlob('foo.js'); +isGlob('abc/@.js'); +isGlob('abc/+.js'); +isGlob('abc/?.js'); +isGlob(); +isGlob(null); +//=> false +``` + +Arrays are also `false` (If you want to check if an array has a glob pattern, use [has-glob](https://github.com/jonschlinkert/has-glob)): + +```js +isGlob(['**/*.js']); +isGlob(['foo.js']); +//=> false +``` + +### Option strict + +When `options.strict === false` the behavior is less strict in determining if a pattern is a glob. Meaning that +some patterns that would return `false` may return `true`. This is done so that matching libraries like [micromatch](https://github.com/micromatch/micromatch) have a chance at determining if the pattern is a glob or not. + +**True** + +Patterns that have glob characters or regex patterns will return `true`: + +```js +isGlob('!foo.js', {strict: false}); +isGlob('*.js', {strict: false}); +isGlob('**/abc.js', {strict: false}); +isGlob('abc/*.js', {strict: false}); +isGlob('abc/(aaa|bbb).js', {strict: false}); +isGlob('abc/[a-z].js', {strict: false}); +isGlob('abc/{a,b}.js', {strict: false}); +//=> true +``` + +Extglobs + +```js +isGlob('abc/@(a).js', {strict: false}); +isGlob('abc/!(a).js', {strict: false}); +isGlob('abc/+(a).js', {strict: false}); +isGlob('abc/*(a).js', {strict: false}); +isGlob('abc/?(a).js', {strict: false}); +//=> true +``` + +**False** + +Escaped globs or extglobs return `false`: + +```js +isGlob('\\!foo.js', {strict: false}); +isGlob('\\*.js', {strict: false}); +isGlob('\\*\\*/abc.js', {strict: false}); +isGlob('abc/\\*.js', {strict: false}); +isGlob('abc/\\(aaa|bbb).js', {strict: false}); +isGlob('abc/\\[a-z].js', {strict: false}); +isGlob('abc/\\{a,b}.js', {strict: false}); +//=> false +``` + +## About + +
      +Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +
      + +
      +Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +$ npm install && npm test +``` + +
      + +
      +Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +$ npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
      + +### Related projects + +You might also be interested in these projects: + +* [assemble](https://www.npmjs.com/package/assemble): Get the rocks out of your socks! Assemble makes you fast at creating web projects… [more](https://github.com/assemble/assemble) | [homepage](https://github.com/assemble/assemble "Get the rocks out of your socks! Assemble makes you fast at creating web projects. Assemble is used by thousands of projects for rapid prototyping, creating themes, scaffolds, boilerplates, e-books, UI components, API documentation, blogs, building websit") +* [base](https://www.npmjs.com/package/base): Framework for rapidly creating high quality, server-side node.js applications, using plugins like building blocks | [homepage](https://github.com/node-base/base "Framework for rapidly creating high quality, server-side node.js applications, using plugins like building blocks") +* [update](https://www.npmjs.com/package/update): Be scalable! Update is a new, open source developer framework and CLI for automating updates… [more](https://github.com/update/update) | [homepage](https://github.com/update/update "Be scalable! Update is a new, open source developer framework and CLI for automating updates of any kind in code projects.") +* [verb](https://www.npmjs.com/package/verb): Documentation generator for GitHub projects. Verb is extremely powerful, easy to use, and is used… [more](https://github.com/verbose/verb) | [homepage](https://github.com/verbose/verb "Documentation generator for GitHub projects. Verb is extremely powerful, easy to use, and is used on hundreds of projects of all sizes to generate everything from API docs to readmes.") + +### Contributors + +| **Commits** | **Contributor** | +| --- | --- | +| 47 | [jonschlinkert](https://github.com/jonschlinkert) | +| 5 | [doowb](https://github.com/doowb) | +| 1 | [phated](https://github.com/phated) | +| 1 | [danhper](https://github.com/danhper) | +| 1 | [paulmillr](https://github.com/paulmillr) | + +### Author + +**Jon Schlinkert** + +* [GitHub Profile](https://github.com/jonschlinkert) +* [Twitter Profile](https://twitter.com/jonschlinkert) +* [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) + +### License + +Copyright © 2019, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). + +*** + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on March 27, 2019._ \ No newline at end of file diff --git a/node_modules/is-glob/index.js b/node_modules/is-glob/index.js new file mode 100644 index 0000000..620f563 --- /dev/null +++ b/node_modules/is-glob/index.js @@ -0,0 +1,150 @@ +/*! + * is-glob + * + * Copyright (c) 2014-2017, Jon Schlinkert. + * Released under the MIT License. + */ + +var isExtglob = require('is-extglob'); +var chars = { '{': '}', '(': ')', '[': ']'}; +var strictCheck = function(str) { + if (str[0] === '!') { + return true; + } + var index = 0; + var pipeIndex = -2; + var closeSquareIndex = -2; + var closeCurlyIndex = -2; + var closeParenIndex = -2; + var backSlashIndex = -2; + while (index < str.length) { + if (str[index] === '*') { + return true; + } + + if (str[index + 1] === '?' && /[\].+)]/.test(str[index])) { + return true; + } + + if (closeSquareIndex !== -1 && str[index] === '[' && str[index + 1] !== ']') { + if (closeSquareIndex < index) { + closeSquareIndex = str.indexOf(']', index); + } + if (closeSquareIndex > index) { + if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) { + return true; + } + backSlashIndex = str.indexOf('\\', index); + if (backSlashIndex === -1 || backSlashIndex > closeSquareIndex) { + return true; + } + } + } + + if (closeCurlyIndex !== -1 && str[index] === '{' && str[index + 1] !== '}') { + closeCurlyIndex = str.indexOf('}', index); + if (closeCurlyIndex > index) { + backSlashIndex = str.indexOf('\\', index); + if (backSlashIndex === -1 || backSlashIndex > closeCurlyIndex) { + return true; + } + } + } + + if (closeParenIndex !== -1 && str[index] === '(' && str[index + 1] === '?' && /[:!=]/.test(str[index + 2]) && str[index + 3] !== ')') { + closeParenIndex = str.indexOf(')', index); + if (closeParenIndex > index) { + backSlashIndex = str.indexOf('\\', index); + if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) { + return true; + } + } + } + + if (pipeIndex !== -1 && str[index] === '(' && str[index + 1] !== '|') { + if (pipeIndex < index) { + pipeIndex = str.indexOf('|', index); + } + if (pipeIndex !== -1 && str[pipeIndex + 1] !== ')') { + closeParenIndex = str.indexOf(')', pipeIndex); + if (closeParenIndex > pipeIndex) { + backSlashIndex = str.indexOf('\\', pipeIndex); + if (backSlashIndex === -1 || backSlashIndex > closeParenIndex) { + return true; + } + } + } + } + + if (str[index] === '\\') { + var open = str[index + 1]; + index += 2; + var close = chars[open]; + + if (close) { + var n = str.indexOf(close, index); + if (n !== -1) { + index = n + 1; + } + } + + if (str[index] === '!') { + return true; + } + } else { + index++; + } + } + return false; +}; + +var relaxedCheck = function(str) { + if (str[0] === '!') { + return true; + } + var index = 0; + while (index < str.length) { + if (/[*?{}()[\]]/.test(str[index])) { + return true; + } + + if (str[index] === '\\') { + var open = str[index + 1]; + index += 2; + var close = chars[open]; + + if (close) { + var n = str.indexOf(close, index); + if (n !== -1) { + index = n + 1; + } + } + + if (str[index] === '!') { + return true; + } + } else { + index++; + } + } + return false; +}; + +module.exports = function isGlob(str, options) { + if (typeof str !== 'string' || str === '') { + return false; + } + + if (isExtglob(str)) { + return true; + } + + var check = strictCheck; + + // optionally relax check + if (options && options.strict === false) { + check = relaxedCheck; + } + + return check(str); +}; diff --git a/node_modules/is-glob/package.json b/node_modules/is-glob/package.json new file mode 100644 index 0000000..858af03 --- /dev/null +++ b/node_modules/is-glob/package.json @@ -0,0 +1,81 @@ +{ + "name": "is-glob", + "description": "Returns `true` if the given string looks like a glob pattern or an extglob pattern. This makes it easy to create code that only uses external modules like node-glob when necessary, resulting in much faster code execution and initialization time, and a better user experience.", + "version": "4.0.3", + "homepage": "https://github.com/micromatch/is-glob", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "contributors": [ + "Brian Woodward (https://twitter.com/doowb)", + "Daniel Perez (https://tuvistavie.com)", + "Jon Schlinkert (http://twitter.com/jonschlinkert)" + ], + "repository": "micromatch/is-glob", + "bugs": { + "url": "https://github.com/micromatch/is-glob/issues" + }, + "license": "MIT", + "files": [ + "index.js" + ], + "main": "index.js", + "engines": { + "node": ">=0.10.0" + }, + "scripts": { + "test": "mocha && node benchmark.js" + }, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "devDependencies": { + "gulp-format-md": "^0.1.10", + "mocha": "^3.0.2" + }, + "keywords": [ + "bash", + "braces", + "check", + "exec", + "expression", + "extglob", + "glob", + "globbing", + "globstar", + "is", + "match", + "matches", + "pattern", + "regex", + "regular", + "string", + "test" + ], + "verb": { + "layout": "default", + "plugins": [ + "gulp-format-md" + ], + "related": { + "list": [ + "assemble", + "base", + "update", + "verb" + ] + }, + "reflinks": [ + "assemble", + "bach", + "base", + "composer", + "gulp", + "has-glob", + "is-valid-glob", + "micromatch", + "npm", + "scaffold", + "verb", + "vinyl" + ] + } +} diff --git a/node_modules/is-number/LICENSE b/node_modules/is-number/LICENSE new file mode 100644 index 0000000..9af4a67 --- /dev/null +++ b/node_modules/is-number/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-present, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/is-number/README.md b/node_modules/is-number/README.md new file mode 100644 index 0000000..eb8149e --- /dev/null +++ b/node_modules/is-number/README.md @@ -0,0 +1,187 @@ +# is-number [![NPM version](https://img.shields.io/npm/v/is-number.svg?style=flat)](https://www.npmjs.com/package/is-number) [![NPM monthly downloads](https://img.shields.io/npm/dm/is-number.svg?style=flat)](https://npmjs.org/package/is-number) [![NPM total downloads](https://img.shields.io/npm/dt/is-number.svg?style=flat)](https://npmjs.org/package/is-number) [![Linux Build Status](https://img.shields.io/travis/jonschlinkert/is-number.svg?style=flat&label=Travis)](https://travis-ci.org/jonschlinkert/is-number) + +> Returns true if the value is a finite number. + +Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +$ npm install --save is-number +``` + +## Why is this needed? + +In JavaScript, it's not always as straightforward as it should be to reliably check if a value is a number. It's common for devs to use `+`, `-`, or `Number()` to cast a string value to a number (for example, when values are returned from user input, regex matches, parsers, etc). But there are many non-intuitive edge cases that yield unexpected results: + +```js +console.log(+[]); //=> 0 +console.log(+''); //=> 0 +console.log(+' '); //=> 0 +console.log(typeof NaN); //=> 'number' +``` + +This library offers a performant way to smooth out edge cases like these. + +## Usage + +```js +const isNumber = require('is-number'); +``` + +See the [tests](./test.js) for more examples. + +### true + +```js +isNumber(5e3); // true +isNumber(0xff); // true +isNumber(-1.1); // true +isNumber(0); // true +isNumber(1); // true +isNumber(1.1); // true +isNumber(10); // true +isNumber(10.10); // true +isNumber(100); // true +isNumber('-1.1'); // true +isNumber('0'); // true +isNumber('012'); // true +isNumber('0xff'); // true +isNumber('1'); // true +isNumber('1.1'); // true +isNumber('10'); // true +isNumber('10.10'); // true +isNumber('100'); // true +isNumber('5e3'); // true +isNumber(parseInt('012')); // true +isNumber(parseFloat('012')); // true +``` + +### False + +Everything else is false, as you would expect: + +```js +isNumber(Infinity); // false +isNumber(NaN); // false +isNumber(null); // false +isNumber(undefined); // false +isNumber(''); // false +isNumber(' '); // false +isNumber('foo'); // false +isNumber([1]); // false +isNumber([]); // false +isNumber(function () {}); // false +isNumber({}); // false +``` + +## Release history + +### 7.0.0 + +* Refactor. Now uses `.isFinite` if it exists. +* Performance is about the same as v6.0 when the value is a string or number. But it's now 3x-4x faster when the value is not a string or number. + +### 6.0.0 + +* Optimizations, thanks to @benaadams. + +### 5.0.0 + +**Breaking changes** + +* removed support for `instanceof Number` and `instanceof String` + +## Benchmarks + +As with all benchmarks, take these with a grain of salt. See the [benchmarks](./benchmark/index.js) for more detail. + +``` +# all +v7.0 x 413,222 ops/sec ±2.02% (86 runs sampled) +v6.0 x 111,061 ops/sec ±1.29% (85 runs sampled) +parseFloat x 317,596 ops/sec ±1.36% (86 runs sampled) +fastest is 'v7.0' + +# string +v7.0 x 3,054,496 ops/sec ±1.05% (89 runs sampled) +v6.0 x 2,957,781 ops/sec ±0.98% (88 runs sampled) +parseFloat x 3,071,060 ops/sec ±1.13% (88 runs sampled) +fastest is 'parseFloat,v7.0' + +# number +v7.0 x 3,146,895 ops/sec ±0.89% (89 runs sampled) +v6.0 x 3,214,038 ops/sec ±1.07% (89 runs sampled) +parseFloat x 3,077,588 ops/sec ±1.07% (87 runs sampled) +fastest is 'v6.0' +``` + +## About + +
      +Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +
      + +
      +Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +$ npm install && npm test +``` + +
      + +
      +Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +$ npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
      + +### Related projects + +You might also be interested in these projects: + +* [is-plain-object](https://www.npmjs.com/package/is-plain-object): Returns true if an object was created by the `Object` constructor. | [homepage](https://github.com/jonschlinkert/is-plain-object "Returns true if an object was created by the `Object` constructor.") +* [is-primitive](https://www.npmjs.com/package/is-primitive): Returns `true` if the value is a primitive. | [homepage](https://github.com/jonschlinkert/is-primitive "Returns `true` if the value is a primitive. ") +* [isobject](https://www.npmjs.com/package/isobject): Returns true if the value is an object and not an array or null. | [homepage](https://github.com/jonschlinkert/isobject "Returns true if the value is an object and not an array or null.") +* [kind-of](https://www.npmjs.com/package/kind-of): Get the native type of a value. | [homepage](https://github.com/jonschlinkert/kind-of "Get the native type of a value.") + +### Contributors + +| **Commits** | **Contributor** | +| --- | --- | +| 49 | [jonschlinkert](https://github.com/jonschlinkert) | +| 5 | [charlike-old](https://github.com/charlike-old) | +| 1 | [benaadams](https://github.com/benaadams) | +| 1 | [realityking](https://github.com/realityking) | + +### Author + +**Jon Schlinkert** + +* [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) +* [GitHub Profile](https://github.com/jonschlinkert) +* [Twitter Profile](https://twitter.com/jonschlinkert) + +### License + +Copyright © 2018, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). + +*** + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.6.0, on June 15, 2018._ \ No newline at end of file diff --git a/node_modules/is-number/index.js b/node_modules/is-number/index.js new file mode 100644 index 0000000..27f19b7 --- /dev/null +++ b/node_modules/is-number/index.js @@ -0,0 +1,18 @@ +/*! + * is-number + * + * Copyright (c) 2014-present, Jon Schlinkert. + * Released under the MIT License. + */ + +'use strict'; + +module.exports = function(num) { + if (typeof num === 'number') { + return num - num === 0; + } + if (typeof num === 'string' && num.trim() !== '') { + return Number.isFinite ? Number.isFinite(+num) : isFinite(+num); + } + return false; +}; diff --git a/node_modules/is-number/package.json b/node_modules/is-number/package.json new file mode 100644 index 0000000..3715072 --- /dev/null +++ b/node_modules/is-number/package.json @@ -0,0 +1,82 @@ +{ + "name": "is-number", + "description": "Returns true if a number or string value is a finite number. Useful for regex matches, parsing, user input, etc.", + "version": "7.0.0", + "homepage": "https://github.com/jonschlinkert/is-number", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "contributors": [ + "Jon Schlinkert (http://twitter.com/jonschlinkert)", + "Olsten Larck (https://i.am.charlike.online)", + "Rouven Weßling (www.rouvenwessling.de)" + ], + "repository": "jonschlinkert/is-number", + "bugs": { + "url": "https://github.com/jonschlinkert/is-number/issues" + }, + "license": "MIT", + "files": [ + "index.js" + ], + "main": "index.js", + "engines": { + "node": ">=0.12.0" + }, + "scripts": { + "test": "mocha" + }, + "devDependencies": { + "ansi": "^0.3.1", + "benchmark": "^2.1.4", + "gulp-format-md": "^1.0.0", + "mocha": "^3.5.3" + }, + "keywords": [ + "cast", + "check", + "coerce", + "coercion", + "finite", + "integer", + "is", + "isnan", + "is-nan", + "is-num", + "is-number", + "isnumber", + "isfinite", + "istype", + "kind", + "math", + "nan", + "num", + "number", + "numeric", + "parseFloat", + "parseInt", + "test", + "type", + "typeof", + "value" + ], + "verb": { + "toc": false, + "layout": "default", + "tasks": [ + "readme" + ], + "related": { + "list": [ + "is-plain-object", + "is-primitive", + "isobject", + "kind-of" + ] + }, + "plugins": [ + "gulp-format-md" + ], + "lint": { + "reflinks": true + } + } +} diff --git a/node_modules/lilconfig/dist/index.d.ts b/node_modules/lilconfig/dist/index.d.ts new file mode 100644 index 0000000..766c58c --- /dev/null +++ b/node_modules/lilconfig/dist/index.d.ts @@ -0,0 +1,38 @@ +export declare type LilconfigResult = null | { + filepath: string; + config: any; + isEmpty?: boolean; +}; +interface OptionsBase { + stopDir?: string; + searchPlaces?: string[]; + ignoreEmptySearchPlaces?: boolean; + packageProp?: string | string[]; +} +export declare type Transform = TransformSync | ((result: LilconfigResult) => Promise); +export declare type TransformSync = (result: LilconfigResult) => LilconfigResult; +declare type LoaderResult = any; +export declare type LoaderSync = (filepath: string, content: string) => LoaderResult; +export declare type Loader = LoaderSync | ((filepath: string, content: string) => Promise); +export declare type Loaders = Record; +export declare type LoadersSync = Record; +export interface Options extends OptionsBase { + loaders?: Loaders; + transform?: Transform; +} +export interface OptionsSync extends OptionsBase { + loaders?: LoadersSync; + transform?: TransformSync; +} +export declare const defaultLoaders: LoadersSync; +declare type AsyncSearcher = { + search(searchFrom?: string): Promise; + load(filepath: string): Promise; +}; +export declare function lilconfig(name: string, options?: Partial): AsyncSearcher; +declare type SyncSearcher = { + search(searchFrom?: string): LilconfigResult; + load(filepath: string): LilconfigResult; +}; +export declare function lilconfigSync(name: string, options?: OptionsSync): SyncSearcher; +export {}; diff --git a/node_modules/lilconfig/dist/index.js b/node_modules/lilconfig/dist/index.js new file mode 100644 index 0000000..0b684ff --- /dev/null +++ b/node_modules/lilconfig/dist/index.js @@ -0,0 +1,247 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.lilconfigSync = exports.lilconfig = exports.defaultLoaders = void 0; +const path = require("path"); +const fs = require("fs"); +const os = require("os"); +const fsReadFileAsync = fs.promises.readFile; +function getDefaultSearchPlaces(name) { + return [ + 'package.json', + `.${name}rc.json`, + `.${name}rc.js`, + `${name}.config.js`, + `.${name}rc.cjs`, + `${name}.config.cjs`, + ]; +} +function getSearchPaths(startDir, stopDir) { + return startDir + .split(path.sep) + .reduceRight((acc, _, ind, arr) => { + const currentPath = arr.slice(0, ind + 1).join(path.sep); + if (!acc.passedStopDir) + acc.searchPlaces.push(currentPath || path.sep); + if (currentPath === stopDir) + acc.passedStopDir = true; + return acc; + }, { searchPlaces: [], passedStopDir: false }).searchPlaces; +} +exports.defaultLoaders = Object.freeze({ + '.js': require, + '.json': require, + '.cjs': require, + noExt(_, content) { + return JSON.parse(content); + }, +}); +function getExtDesc(ext) { + return ext === 'noExt' ? 'files without extensions' : `extension "${ext}"`; +} +function getOptions(name, options = {}) { + const conf = { + stopDir: os.homedir(), + searchPlaces: getDefaultSearchPlaces(name), + ignoreEmptySearchPlaces: true, + transform: (x) => x, + packageProp: [name], + ...options, + loaders: { ...exports.defaultLoaders, ...options.loaders }, + }; + conf.searchPlaces.forEach(place => { + const key = path.extname(place) || 'noExt'; + const loader = conf.loaders[key]; + if (!loader) { + throw new Error(`No loader specified for ${getExtDesc(key)}, so searchPlaces item "${place}" is invalid`); + } + if (typeof loader !== 'function') { + throw new Error(`loader for ${getExtDesc(key)} is not a function (type provided: "${typeof loader}"), so searchPlaces item "${place}" is invalid`); + } + }); + return conf; +} +function getPackageProp(props, obj) { + if (typeof props === 'string' && props in obj) + return obj[props]; + return ((Array.isArray(props) ? props : props.split('.')).reduce((acc, prop) => (acc === undefined ? acc : acc[prop]), obj) || null); +} +function getSearchItems(searchPlaces, searchPaths) { + return searchPaths.reduce((acc, searchPath) => { + searchPlaces.forEach(fileName => acc.push({ + fileName, + filepath: path.join(searchPath, fileName), + loaderKey: path.extname(fileName) || 'noExt', + })); + return acc; + }, []); +} +function validateFilePath(filepath) { + if (!filepath) + throw new Error('load must pass a non-empty string'); +} +function validateLoader(loader, ext) { + if (!loader) + throw new Error(`No loader specified for extension "${ext}"`); + if (typeof loader !== 'function') + throw new Error('loader is not a function'); +} +function lilconfig(name, options) { + const { ignoreEmptySearchPlaces, loaders, packageProp, searchPlaces, stopDir, transform, } = getOptions(name, options); + return { + async search(searchFrom = process.cwd()) { + const searchPaths = getSearchPaths(searchFrom, stopDir); + const result = { + config: null, + filepath: '', + }; + const searchItems = getSearchItems(searchPlaces, searchPaths); + for (const { fileName, filepath, loaderKey } of searchItems) { + try { + await fs.promises.access(filepath); + } + catch (_a) { + continue; + } + const content = String(await fsReadFileAsync(filepath)); + const loader = loaders[loaderKey]; + if (fileName === 'package.json') { + const pkg = await loader(filepath, content); + const maybeConfig = getPackageProp(packageProp, pkg); + if (maybeConfig != null) { + result.config = maybeConfig; + result.filepath = filepath; + break; + } + continue; + } + const isEmpty = content.trim() === ''; + if (isEmpty && ignoreEmptySearchPlaces) + continue; + if (isEmpty) { + result.isEmpty = true; + result.config = undefined; + } + else { + validateLoader(loader, loaderKey); + result.config = await loader(filepath, content); + } + result.filepath = filepath; + break; + } + if (result.filepath === '' && result.config === null) + return transform(null); + return transform(result); + }, + async load(filepath) { + validateFilePath(filepath); + const absPath = path.resolve(process.cwd(), filepath); + const { base, ext } = path.parse(absPath); + const loaderKey = ext || 'noExt'; + const loader = loaders[loaderKey]; + validateLoader(loader, loaderKey); + const content = String(await fsReadFileAsync(absPath)); + if (base === 'package.json') { + const pkg = await loader(absPath, content); + return transform({ + config: getPackageProp(packageProp, pkg), + filepath: absPath, + }); + } + const result = { + config: null, + filepath: absPath, + }; + const isEmpty = content.trim() === ''; + if (isEmpty && ignoreEmptySearchPlaces) + return transform({ + config: undefined, + filepath: absPath, + isEmpty: true, + }); + result.config = isEmpty + ? undefined + : await loader(absPath, content); + return transform(isEmpty ? { ...result, isEmpty, config: undefined } : result); + }, + }; +} +exports.lilconfig = lilconfig; +function lilconfigSync(name, options) { + const { ignoreEmptySearchPlaces, loaders, packageProp, searchPlaces, stopDir, transform, } = getOptions(name, options); + return { + search(searchFrom = process.cwd()) { + const searchPaths = getSearchPaths(searchFrom, stopDir); + const result = { + config: null, + filepath: '', + }; + const searchItems = getSearchItems(searchPlaces, searchPaths); + for (const { fileName, filepath, loaderKey } of searchItems) { + try { + fs.accessSync(filepath); + } + catch (_a) { + continue; + } + const loader = loaders[loaderKey]; + const content = String(fs.readFileSync(filepath)); + if (fileName === 'package.json') { + const pkg = loader(filepath, content); + const maybeConfig = getPackageProp(packageProp, pkg); + if (maybeConfig != null) { + result.config = maybeConfig; + result.filepath = filepath; + break; + } + continue; + } + const isEmpty = content.trim() === ''; + if (isEmpty && ignoreEmptySearchPlaces) + continue; + if (isEmpty) { + result.isEmpty = true; + result.config = undefined; + } + else { + validateLoader(loader, loaderKey); + result.config = loader(filepath, content); + } + result.filepath = filepath; + break; + } + if (result.filepath === '' && result.config === null) + return transform(null); + return transform(result); + }, + load(filepath) { + validateFilePath(filepath); + const absPath = path.resolve(process.cwd(), filepath); + const { base, ext } = path.parse(absPath); + const loaderKey = ext || 'noExt'; + const loader = loaders[loaderKey]; + validateLoader(loader, loaderKey); + const content = String(fs.readFileSync(absPath)); + if (base === 'package.json') { + const pkg = loader(absPath, content); + return transform({ + config: getPackageProp(packageProp, pkg), + filepath: absPath, + }); + } + const result = { + config: null, + filepath: absPath, + }; + const isEmpty = content.trim() === ''; + if (isEmpty && ignoreEmptySearchPlaces) + return transform({ + filepath: absPath, + config: undefined, + isEmpty: true, + }); + result.config = isEmpty ? undefined : loader(absPath, content); + return transform(isEmpty ? { ...result, isEmpty, config: undefined } : result); + }, + }; +} +exports.lilconfigSync = lilconfigSync; diff --git a/node_modules/lilconfig/package.json b/node_modules/lilconfig/package.json new file mode 100644 index 0000000..6b0a384 --- /dev/null +++ b/node_modules/lilconfig/package.json @@ -0,0 +1,48 @@ +{ + "name": "lilconfig", + "version": "2.0.5", + "description": "A zero-dependency alternative to cosmiconfig", + "main": "dist/index.js", + "types": "dist/index.d.ts", + "scripts": { + "prebuild": "npm run clean", + "build": "tsc --declaration", + "postbuild": "du -h ./dist/*", + "clean": "rm -rf ./dist", + "test": "jest --coverage", + "lint": "eslint ./src/*.ts" + }, + "keywords": [ + "cosmiconfig", + "config", + "configuration", + "search" + ], + "files": [ + "dist/*" + ], + "repository": { + "type": "git", + "url": "https://github.com/antonk52/lilconfig" + }, + "bugs": "https://github.com/antonk52/lilconfig/issues", + "author": "antonk52", + "license": "MIT", + "devDependencies": { + "@types/jest": "^27.0.2", + "@types/node": "^14.17.2", + "@typescript-eslint/eslint-plugin": "^5.3.0", + "@typescript-eslint/parser": "^5.3.0", + "cosmiconfig": "^7.0.1", + "eslint": "^8.1.0", + "eslint-config-prettier": "^8.3.0", + "eslint-plugin-prettier": "^4.0.0", + "jest": "^27.3.1", + "prettier": "^2.4.1", + "ts-jest": "^27.0.7", + "typescript": "^4.4.4" + }, + "engines": { + "node": ">=10" + } +} diff --git a/node_modules/lilconfig/readme.md b/node_modules/lilconfig/readme.md new file mode 100644 index 0000000..fea770d --- /dev/null +++ b/node_modules/lilconfig/readme.md @@ -0,0 +1,118 @@ +# Lilconfig ⚙️ +[![npm version](https://badge.fury.io/js/lilconfig.svg)](https://badge.fury.io/js/lilconfig) +[![install size](https://packagephobia.now.sh/badge?p=lilconfig)](https://packagephobia.now.sh/result?p=lilconfig) +[![Coverage Status](https://coveralls.io/repos/github/antonk52/lilconfig/badge.svg)](https://coveralls.io/github/antonk52/lilconfig) + +A zero-dependency alternative to [cosmiconfig](https://www.npmjs.com/package/cosmiconfig) with the same API. + +## Installation + +```sh +npm install lilconfig +``` + +## Usage + +```js +import {lilconfig, lilconfigSync} from 'lilconfig'; + +// all keys are optional +const options = { + stopDir: '/Users/you/some/dir', + searchPlaces: ['package.json', 'myapp.conf.js'], + ignoreEmptySearchPlaces: false +} + +lilconfig( + 'myapp', + options // optional +).search() // Promise + +lilconfigSync( + 'myapp', + options // optional +).load(pathToConfig) // LilconfigResult + +/** + * LilconfigResult + * { + * config: any; // your config + * filepath: string; + * } + */ +``` + +## Difference to `cosmiconfig` +Lilconfig does not intend to be 100% compatible with `cosmiconfig` but tries to mimic it where possible. The key differences are: +- **no** support for yaml files out of the box(`lilconfig` attempts to parse files with no extension as JSON instead of YAML). You can still add the support for YAML files by providing a loader, see an [example](#loaders-example) below. +- **no** cache + +### Options difference between the two. + +|cosmiconfig option | lilconfig | +|------------------------|-----------| +|cache | ❌ | +|loaders | ✅ | +|ignoreEmptySearchPlaces | ✅ | +|packageProp | ✅ | +|searchPlaces | ✅ | +|stopDir | ✅ | +|transform | ✅ | + +## Loaders examples + +### Yaml loader + +If you need the YAML support you can provide your own loader + +```js +import {lilconfig} from 'lilconfig'; +import yaml from 'yaml'; + +function loadYaml(filepath, content) { + return yaml.parse(content); +} + +const options = { + loaders: { + '.yaml': loadYaml, + '.yml': loadYaml, + // loader for files with no extension + noExt: loadYaml + } +}; + +lilconfig('myapp', options) + .search() + .then(result => { + result // {config, filepath} + }); +``` + +### ESM loader + +Lilconfig v2 does not support ESM modules out of the box. However, you can support it with a custom a loader. Note that this will only work with the async `lilconfig` function and won't work with the sync `lilconfigSync`. + +```js +import {lilconfig} from 'lilconfig'; + +const loadEsm = filepath => import(filepath); + +lilconfig('myapp', { + loaders: { + '.js': loadEsm, + '.mjs': loadEsm, + } +}) + .search() + .then(result => { + result // {config, filepath} + + result.config.default // if config uses `export default` + }); +``` + +## Version correlation + +- lilconig v1 → cosmiconfig v6 +- lilconig v2 → cosmiconfig v7 diff --git a/node_modules/merge2/LICENSE b/node_modules/merge2/LICENSE new file mode 100644 index 0000000..31dd9c7 --- /dev/null +++ b/node_modules/merge2/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-2020 Teambition + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/merge2/README.md b/node_modules/merge2/README.md new file mode 100644 index 0000000..27f8eb9 --- /dev/null +++ b/node_modules/merge2/README.md @@ -0,0 +1,144 @@ +# merge2 + +Merge multiple streams into one stream in sequence or parallel. + +[![NPM version][npm-image]][npm-url] +[![Build Status][travis-image]][travis-url] +[![Downloads][downloads-image]][downloads-url] + +## Install + +Install with [npm](https://npmjs.org/package/merge2) + +```sh +npm install merge2 +``` + +## Usage + +```js +const gulp = require('gulp') +const merge2 = require('merge2') +const concat = require('gulp-concat') +const minifyHtml = require('gulp-minify-html') +const ngtemplate = require('gulp-ngtemplate') + +gulp.task('app-js', function () { + return merge2( + gulp.src('static/src/tpl/*.html') + .pipe(minifyHtml({empty: true})) + .pipe(ngtemplate({ + module: 'genTemplates', + standalone: true + }) + ), gulp.src([ + 'static/src/js/app.js', + 'static/src/js/locale_zh-cn.js', + 'static/src/js/router.js', + 'static/src/js/tools.js', + 'static/src/js/services.js', + 'static/src/js/filters.js', + 'static/src/js/directives.js', + 'static/src/js/controllers.js' + ]) + ) + .pipe(concat('app.js')) + .pipe(gulp.dest('static/dist/js/')) +}) +``` + +```js +const stream = merge2([stream1, stream2], stream3, {end: false}) +//... +stream.add(stream4, stream5) +//.. +stream.end() +``` + +```js +// equal to merge2([stream1, stream2], stream3) +const stream = merge2() +stream.add([stream1, stream2]) +stream.add(stream3) +``` + +```js +// merge order: +// 1. merge `stream1`; +// 2. merge `stream2` and `stream3` in parallel after `stream1` merged; +// 3. merge 'stream4' after `stream2` and `stream3` merged; +const stream = merge2(stream1, [stream2, stream3], stream4) + +// merge order: +// 1. merge `stream5` and `stream6` in parallel after `stream4` merged; +// 2. merge 'stream7' after `stream5` and `stream6` merged; +stream.add([stream5, stream6], stream7) +``` + +```js +// nest merge +// equal to merge2(stream1, stream2, stream6, stream3, [stream4, stream5]); +const streamA = merge2(stream1, stream2) +const streamB = merge2(stream3, [stream4, stream5]) +const stream = merge2(streamA, streamB) +streamA.add(stream6) +``` + +## API + +```js +const merge2 = require('merge2') +``` + +### merge2() + +### merge2(options) + +### merge2(stream1, stream2, ..., streamN) + +### merge2(stream1, stream2, ..., streamN, options) + +### merge2(stream1, [stream2, stream3, ...], streamN, options) + +return a duplex stream (mergedStream). streams in array will be merged in parallel. + +### mergedStream.add(stream) + +### mergedStream.add(stream1, [stream2, stream3, ...], ...) + +return the mergedStream. + +### mergedStream.on('queueDrain', function() {}) + +It will emit 'queueDrain' when all streams merged. If you set `end === false` in options, this event give you a notice that should add more streams to merge or end the mergedStream. + +#### stream + +*option* +Type: `Readable` or `Duplex` or `Transform` stream. + +#### options + +*option* +Type: `Object`. + +* **end** - `Boolean` - if `end === false` then mergedStream will not be auto ended, you should end by yourself. **Default:** `undefined` + +* **pipeError** - `Boolean` - if `pipeError === true` then mergedStream will emit `error` event from source streams. **Default:** `undefined` + +* **objectMode** - `Boolean` . **Default:** `true` + +`objectMode` and other options(`highWaterMark`, `defaultEncoding` ...) is same as Node.js `Stream`. + +## License + +MIT © [Teambition](https://www.teambition.com) + +[npm-url]: https://npmjs.org/package/merge2 +[npm-image]: http://img.shields.io/npm/v/merge2.svg + +[travis-url]: https://travis-ci.org/teambition/merge2 +[travis-image]: http://img.shields.io/travis/teambition/merge2.svg + +[downloads-url]: https://npmjs.org/package/merge2 +[downloads-image]: http://img.shields.io/npm/dm/merge2.svg?style=flat-square diff --git a/node_modules/merge2/index.js b/node_modules/merge2/index.js new file mode 100644 index 0000000..78a61ed --- /dev/null +++ b/node_modules/merge2/index.js @@ -0,0 +1,144 @@ +'use strict' +/* + * merge2 + * https://github.com/teambition/merge2 + * + * Copyright (c) 2014-2020 Teambition + * Licensed under the MIT license. + */ +const Stream = require('stream') +const PassThrough = Stream.PassThrough +const slice = Array.prototype.slice + +module.exports = merge2 + +function merge2 () { + const streamsQueue = [] + const args = slice.call(arguments) + let merging = false + let options = args[args.length - 1] + + if (options && !Array.isArray(options) && options.pipe == null) { + args.pop() + } else { + options = {} + } + + const doEnd = options.end !== false + const doPipeError = options.pipeError === true + if (options.objectMode == null) { + options.objectMode = true + } + if (options.highWaterMark == null) { + options.highWaterMark = 64 * 1024 + } + const mergedStream = PassThrough(options) + + function addStream () { + for (let i = 0, len = arguments.length; i < len; i++) { + streamsQueue.push(pauseStreams(arguments[i], options)) + } + mergeStream() + return this + } + + function mergeStream () { + if (merging) { + return + } + merging = true + + let streams = streamsQueue.shift() + if (!streams) { + process.nextTick(endStream) + return + } + if (!Array.isArray(streams)) { + streams = [streams] + } + + let pipesCount = streams.length + 1 + + function next () { + if (--pipesCount > 0) { + return + } + merging = false + mergeStream() + } + + function pipe (stream) { + function onend () { + stream.removeListener('merge2UnpipeEnd', onend) + stream.removeListener('end', onend) + if (doPipeError) { + stream.removeListener('error', onerror) + } + next() + } + function onerror (err) { + mergedStream.emit('error', err) + } + // skip ended stream + if (stream._readableState.endEmitted) { + return next() + } + + stream.on('merge2UnpipeEnd', onend) + stream.on('end', onend) + + if (doPipeError) { + stream.on('error', onerror) + } + + stream.pipe(mergedStream, { end: false }) + // compatible for old stream + stream.resume() + } + + for (let i = 0; i < streams.length; i++) { + pipe(streams[i]) + } + + next() + } + + function endStream () { + merging = false + // emit 'queueDrain' when all streams merged. + mergedStream.emit('queueDrain') + if (doEnd) { + mergedStream.end() + } + } + + mergedStream.setMaxListeners(0) + mergedStream.add = addStream + mergedStream.on('unpipe', function (stream) { + stream.emit('merge2UnpipeEnd') + }) + + if (args.length) { + addStream.apply(null, args) + } + return mergedStream +} + +// check and pause streams for pipe. +function pauseStreams (streams, options) { + if (!Array.isArray(streams)) { + // Backwards-compat with old-style streams + if (!streams._readableState && streams.pipe) { + streams = streams.pipe(PassThrough(options)) + } + if (!streams._readableState || !streams.pause || !streams.pipe) { + throw new Error('Only readable stream can be merged.') + } + streams.pause() + } else { + for (let i = 0, len = streams.length; i < len; i++) { + streams[i] = pauseStreams(streams[i], options) + } + } + return streams +} diff --git a/node_modules/merge2/package.json b/node_modules/merge2/package.json new file mode 100644 index 0000000..7777307 --- /dev/null +++ b/node_modules/merge2/package.json @@ -0,0 +1,43 @@ +{ + "name": "merge2", + "description": "Merge multiple streams into one stream in sequence or parallel.", + "authors": [ + "Yan Qing " + ], + "license": "MIT", + "version": "1.4.1", + "main": "./index.js", + "repository": { + "type": "git", + "url": "git@github.com:teambition/merge2.git" + }, + "homepage": "https://github.com/teambition/merge2", + "keywords": [ + "merge2", + "multiple", + "sequence", + "parallel", + "merge", + "stream", + "merge stream", + "sync" + ], + "engines": { + "node": ">= 8" + }, + "dependencies": {}, + "devDependencies": { + "standard": "^14.3.4", + "through2": "^3.0.1", + "thunks": "^4.9.6", + "tman": "^1.10.0", + "to-through": "^2.0.0" + }, + "scripts": { + "test": "standard && tman" + }, + "files": [ + "README.md", + "index.js" + ] +} diff --git a/node_modules/micromatch/LICENSE b/node_modules/micromatch/LICENSE new file mode 100755 index 0000000..9af4a67 --- /dev/null +++ b/node_modules/micromatch/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-present, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/micromatch/README.md b/node_modules/micromatch/README.md new file mode 100644 index 0000000..fd56336 --- /dev/null +++ b/node_modules/micromatch/README.md @@ -0,0 +1,1011 @@ +# micromatch [![NPM version](https://img.shields.io/npm/v/micromatch.svg?style=flat)](https://www.npmjs.com/package/micromatch) [![NPM monthly downloads](https://img.shields.io/npm/dm/micromatch.svg?style=flat)](https://npmjs.org/package/micromatch) [![NPM total downloads](https://img.shields.io/npm/dt/micromatch.svg?style=flat)](https://npmjs.org/package/micromatch) [![Tests](https://github.com/micromatch/micromatch/actions/workflows/test.yml/badge.svg)](https://github.com/micromatch/micromatch/actions/workflows/test.yml) + +> Glob matching for javascript/node.js. A replacement and faster alternative to minimatch and multimatch. + +Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. + +## Table of Contents + +
      +Details + +- [Install](#install) +- [Quickstart](#quickstart) +- [Why use micromatch?](#why-use-micromatch) + * [Matching features](#matching-features) +- [Switching to micromatch](#switching-to-micromatch) + * [From minimatch](#from-minimatch) + * [From multimatch](#from-multimatch) +- [API](#api) +- [Options](#options) +- [Options Examples](#options-examples) + * [options.basename](#optionsbasename) + * [options.bash](#optionsbash) + * [options.expandRange](#optionsexpandrange) + * [options.format](#optionsformat) + * [options.ignore](#optionsignore) + * [options.matchBase](#optionsmatchbase) + * [options.noextglob](#optionsnoextglob) + * [options.nonegate](#optionsnonegate) + * [options.noglobstar](#optionsnoglobstar) + * [options.nonull](#optionsnonull) + * [options.nullglob](#optionsnullglob) + * [options.onIgnore](#optionsonignore) + * [options.onMatch](#optionsonmatch) + * [options.onResult](#optionsonresult) + * [options.posixSlashes](#optionsposixslashes) + * [options.unescape](#optionsunescape) +- [Extended globbing](#extended-globbing) + * [Extglobs](#extglobs) + * [Braces](#braces) + * [Regex character classes](#regex-character-classes) + * [Regex groups](#regex-groups) + * [POSIX bracket expressions](#posix-bracket-expressions) +- [Notes](#notes) + * [Bash 4.3 parity](#bash-43-parity) + * [Backslashes](#backslashes) +- [Benchmarks](#benchmarks) + * [Running benchmarks](#running-benchmarks) + * [Latest results](#latest-results) +- [Contributing](#contributing) +- [About](#about) + +
      + +## Install + +Install with [npm](https://www.npmjs.com/) (requires [Node.js](https://nodejs.org/en/) >=8.6): + +```sh +$ npm install --save micromatch +``` + +## Quickstart + +```js +const micromatch = require('micromatch'); +// micromatch(list, patterns[, options]); +``` + +The [main export](#micromatch) takes a list of strings and one or more glob patterns: + +```js +console.log(micromatch(['foo', 'bar', 'baz', 'qux'], ['f*', 'b*'])) //=> ['foo', 'bar', 'baz'] +console.log(micromatch(['foo', 'bar', 'baz', 'qux'], ['*', '!b*'])) //=> ['foo', 'qux'] +``` + +Use [.isMatch()](#ismatch) to for boolean matching: + +```js +console.log(micromatch.isMatch('foo', 'f*')) //=> true +console.log(micromatch.isMatch('foo', ['b*', 'f*'])) //=> true +``` + +[Switching](#switching-to-micromatch) from minimatch and multimatch is easy! + +
      + +## Why use micromatch? + +> micromatch is a [replacement](#switching-to-micromatch) for minimatch and multimatch + +* Supports all of the same matching features as [minimatch](https://github.com/isaacs/minimatch) and [multimatch](https://github.com/sindresorhus/multimatch) +* More complete support for the Bash 4.3 specification than minimatch and multimatch. Micromatch passes _all of the spec tests_ from bash, including some that bash still fails. +* **Fast & Performant** - Loads in about 5ms and performs [fast matches](#benchmarks). +* **Glob matching** - Using wildcards (`*` and `?`), globstars (`**`) for nested directories +* **[Advanced globbing](#extended-globbing)** - Supports [extglobs](#extglobs), [braces](#braces-1), and [POSIX brackets](#posix-bracket-expressions), and support for escaping special characters with `\` or quotes. +* **Accurate** - Covers more scenarios [than minimatch](https://github.com/yarnpkg/yarn/pull/3339) +* **Well tested** - More than 5,000 [test assertions](./test) +* **Windows support** - More reliable windows support than minimatch and multimatch. +* **[Safe](https://github.com/micromatch/braces#braces-is-safe)** - Micromatch is not subject to DoS with brace patterns like minimatch and multimatch. + +### Matching features + +* Support for multiple glob patterns (no need for wrappers like multimatch) +* Wildcards (`**`, `*.js`) +* Negation (`'!a/*.js'`, `'*!(b).js'`) +* [extglobs](#extglobs) (`+(x|y)`, `!(a|b)`) +* [POSIX character classes](#posix-bracket-expressions) (`[[:alpha:][:digit:]]`) +* [brace expansion](https://github.com/micromatch/braces) (`foo/{1..5}.md`, `bar/{a,b,c}.js`) +* regex character classes (`foo-[1-5].js`) +* regex logical "or" (`foo/(abc|xyz).js`) + +You can mix and match these features to create whatever patterns you need! + +## Switching to micromatch + +_(There is one notable difference between micromatch and minimatch in regards to how backslashes are handled. See [the notes about backslashes](#backslashes) for more information.)_ + +### From minimatch + +Use [micromatch.isMatch()](#ismatch) instead of `minimatch()`: + +```js +console.log(micromatch.isMatch('foo', 'b*')); //=> false +``` + +Use [micromatch.match()](#match) instead of `minimatch.match()`: + +```js +console.log(micromatch.match(['foo', 'bar'], 'b*')); //=> 'bar' +``` + +### From multimatch + +Same signature: + +```js +console.log(micromatch(['foo', 'bar', 'baz'], ['f*', '*z'])); //=> ['foo', 'baz'] +``` + +## API + +**Params** + +* `list` **{String|Array}**: List of strings to match. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `options` **{Object}**: See available [options](#options) +* `returns` **{Array}**: Returns an array of matches + +**Example** + +```js +const mm = require('micromatch'); +// mm(list, patterns[, options]); + +console.log(mm(['a.js', 'a.txt'], ['*.js'])); +//=> [ 'a.js' ] +``` + +### [.matcher](index.js#L104) + +Returns a matcher function from the given glob `pattern` and `options`. The returned function takes a string to match as its only argument and returns true if the string is a match. + +**Params** + +* `pattern` **{String}**: Glob pattern +* `options` **{Object}** +* `returns` **{Function}**: Returns a matcher function. + +**Example** + +```js +const mm = require('micromatch'); +// mm.matcher(pattern[, options]); + +const isMatch = mm.matcher('*.!(*a)'); +console.log(isMatch('a.a')); //=> false +console.log(isMatch('a.b')); //=> true +``` + +### [.isMatch](index.js#L123) + +Returns true if **any** of the given glob `patterns` match the specified `string`. + +**Params** + +* `str` **{String}**: The string to test. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `[options]` **{Object}**: See available [options](#options). +* `returns` **{Boolean}**: Returns true if any patterns match `str` + +**Example** + +```js +const mm = require('micromatch'); +// mm.isMatch(string, patterns[, options]); + +console.log(mm.isMatch('a.a', ['b.*', '*.a'])); //=> true +console.log(mm.isMatch('a.a', 'b.*')); //=> false +``` + +### [.not](index.js#L148) + +Returns a list of strings that _**do not match any**_ of the given `patterns`. + +**Params** + +* `list` **{Array}**: Array of strings to match. +* `patterns` **{String|Array}**: One or more glob pattern to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Array}**: Returns an array of strings that **do not match** the given patterns. + +**Example** + +```js +const mm = require('micromatch'); +// mm.not(list, patterns[, options]); + +console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a')); +//=> ['b.b', 'c.c'] +``` + +### [.contains](index.js#L188) + +Returns true if the given `string` contains the given pattern. Similar to [.isMatch](#isMatch) but the pattern can match any part of the string. + +**Params** + +* `str` **{String}**: The string to match. +* `patterns` **{String|Array}**: Glob pattern to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Boolean}**: Returns true if any of the patterns matches any part of `str`. + +**Example** + +```js +var mm = require('micromatch'); +// mm.contains(string, pattern[, options]); + +console.log(mm.contains('aa/bb/cc', '*b')); +//=> true +console.log(mm.contains('aa/bb/cc', '*d')); +//=> false +``` + +### [.matchKeys](index.js#L230) + +Filter the keys of the given object with the given `glob` pattern and `options`. Does not attempt to match nested keys. If you need this feature, use [glob-object](https://github.com/jonschlinkert/glob-object) instead. + +**Params** + +* `object` **{Object}**: The object with keys to filter. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Object}**: Returns an object with only keys that match the given patterns. + +**Example** + +```js +const mm = require('micromatch'); +// mm.matchKeys(object, patterns[, options]); + +const obj = { aa: 'a', ab: 'b', ac: 'c' }; +console.log(mm.matchKeys(obj, '*b')); +//=> { ab: 'b' } +``` + +### [.some](index.js#L259) + +Returns true if some of the strings in the given `list` match any of the given glob `patterns`. + +**Params** + +* `list` **{String|Array}**: The string or array of strings to test. Returns as soon as the first match is found. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Boolean}**: Returns true if any `patterns` matches any of the strings in `list` + +**Example** + +```js +const mm = require('micromatch'); +// mm.some(list, patterns[, options]); + +console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); +// true +console.log(mm.some(['foo.js'], ['*.js', '!foo.js'])); +// false +``` + +### [.every](index.js#L295) + +Returns true if every string in the given `list` matches any of the given glob `patterns`. + +**Params** + +* `list` **{String|Array}**: The string or array of strings to test. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Boolean}**: Returns true if all `patterns` matches all of the strings in `list` + +**Example** + +```js +const mm = require('micromatch'); +// mm.every(list, patterns[, options]); + +console.log(mm.every('foo.js', ['foo.js'])); +// true +console.log(mm.every(['foo.js', 'bar.js'], ['*.js'])); +// true +console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); +// false +console.log(mm.every(['foo.js'], ['*.js', '!foo.js'])); +// false +``` + +### [.all](index.js#L334) + +Returns true if **all** of the given `patterns` match the specified string. + +**Params** + +* `str` **{String|Array}**: The string to test. +* `patterns` **{String|Array}**: One or more glob patterns to use for matching. +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Boolean}**: Returns true if any patterns match `str` + +**Example** + +```js +const mm = require('micromatch'); +// mm.all(string, patterns[, options]); + +console.log(mm.all('foo.js', ['foo.js'])); +// true + +console.log(mm.all('foo.js', ['*.js', '!foo.js'])); +// false + +console.log(mm.all('foo.js', ['*.js', 'foo.js'])); +// true + +console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js'])); +// true +``` + +### [.capture](index.js#L361) + +Returns an array of matches captured by `pattern` in `string, or`null` if the pattern did not match. + +**Params** + +* `glob` **{String}**: Glob pattern to use for matching. +* `input` **{String}**: String to match +* `options` **{Object}**: See available [options](#options) for changing how matches are performed +* `returns` **{Array|null}**: Returns an array of captures if the input matches the glob pattern, otherwise `null`. + +**Example** + +```js +const mm = require('micromatch'); +// mm.capture(pattern, string[, options]); + +console.log(mm.capture('test/*.js', 'test/foo.js')); +//=> ['foo'] +console.log(mm.capture('test/*.js', 'foo/bar.css')); +//=> null +``` + +### [.makeRe](index.js#L387) + +Create a regular expression from the given glob `pattern`. + +**Params** + +* `pattern` **{String}**: A glob pattern to convert to regex. +* `options` **{Object}** +* `returns` **{RegExp}**: Returns a regex created from the given pattern. + +**Example** + +```js +const mm = require('micromatch'); +// mm.makeRe(pattern[, options]); + +console.log(mm.makeRe('*.js')); +//=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/ +``` + +### [.scan](index.js#L403) + +Scan a glob pattern to separate the pattern into segments. Used by the [split](#split) method. + +**Params** + +* `pattern` **{String}** +* `options` **{Object}** +* `returns` **{Object}**: Returns an object with + +**Example** + +```js +const mm = require('micromatch'); +const state = mm.scan(pattern[, options]); +``` + +### [.parse](index.js#L419) + +Parse a glob pattern to create the source string for a regular expression. + +**Params** + +* `glob` **{String}** +* `options` **{Object}** +* `returns` **{Object}**: Returns an object with useful properties and output to be used as regex source string. + +**Example** + +```js +const mm = require('micromatch'); +const state = mm.parse(pattern[, options]); +``` + +### [.braces](index.js#L446) + +Process the given brace `pattern`. + +**Params** + +* `pattern` **{String}**: String with brace pattern to process. +* `options` **{Object}**: Any [options](#options) to change how expansion is performed. See the [braces](https://github.com/micromatch/braces) library for all available options. +* `returns` **{Array}** + +**Example** + +```js +const { braces } = require('micromatch'); +console.log(braces('foo/{a,b,c}/bar')); +//=> [ 'foo/(a|b|c)/bar' ] + +console.log(braces('foo/{a,b,c}/bar', { expand: true })); +//=> [ 'foo/a/bar', 'foo/b/bar', 'foo/c/bar' ] +``` + +## Options + +| **Option** | **Type** | **Default value** | **Description** | +| --- | --- | --- | --- | +| `basename` | `boolean` | `false` | If set, then patterns without slashes will be matched against the basename of the path if it contains slashes. For example, `a?b` would match the path `/xyz/123/acb`, but not `/xyz/acb/123`. | +| `bash` | `boolean` | `false` | Follow bash matching rules more strictly - disallows backslashes as escape characters, and treats single stars as globstars (`**`). | +| `capture` | `boolean` | `undefined` | Return regex matches in supporting methods. | +| `contains` | `boolean` | `undefined` | Allows glob to match any part of the given string(s). | +| `cwd` | `string` | `process.cwd()` | Current working directory. Used by `picomatch.split()` | +| `debug` | `boolean` | `undefined` | Debug regular expressions when an error is thrown. | +| `dot` | `boolean` | `false` | Match dotfiles. Otherwise dotfiles are ignored unless a `.` is explicitly defined in the pattern. | +| `expandRange` | `function` | `undefined` | Custom function for expanding ranges in brace patterns, such as `{a..z}`. The function receives the range values as two arguments, and it must return a string to be used in the generated regex. It's recommended that returned strings be wrapped in parentheses. This option is overridden by the `expandBrace` option. | +| `failglob` | `boolean` | `false` | Similar to the `failglob` behavior in Bash, throws an error when no matches are found. Based on the bash option of the same name. | +| `fastpaths` | `boolean` | `true` | To speed up processing, full parsing is skipped for a handful common glob patterns. Disable this behavior by setting this option to `false`. | +| `flags` | `boolean` | `undefined` | Regex flags to use in the generated regex. If defined, the `nocase` option will be overridden. | +| [format](#optionsformat) | `function` | `undefined` | Custom function for formatting the returned string. This is useful for removing leading slashes, converting Windows paths to Posix paths, etc. | +| `ignore` | `array\|string` | `undefined` | One or more glob patterns for excluding strings that should not be matched from the result. | +| `keepQuotes` | `boolean` | `false` | Retain quotes in the generated regex, since quotes may also be used as an alternative to backslashes. | +| `literalBrackets` | `boolean` | `undefined` | When `true`, brackets in the glob pattern will be escaped so that only literal brackets will be matched. | +| `lookbehinds` | `boolean` | `true` | Support regex positive and negative lookbehinds. Note that you must be using Node 8.1.10 or higher to enable regex lookbehinds. | +| `matchBase` | `boolean` | `false` | Alias for `basename` | +| `maxLength` | `boolean` | `65536` | Limit the max length of the input string. An error is thrown if the input string is longer than this value. | +| `nobrace` | `boolean` | `false` | Disable brace matching, so that `{a,b}` and `{1..3}` would be treated as literal characters. | +| `nobracket` | `boolean` | `undefined` | Disable matching with regex brackets. | +| `nocase` | `boolean` | `false` | Perform case-insensitive matching. Equivalent to the regex `i` flag. Note that this option is ignored when the `flags` option is defined. | +| `nodupes` | `boolean` | `true` | Deprecated, use `nounique` instead. This option will be removed in a future major release. By default duplicates are removed. Disable uniquification by setting this option to false. | +| `noext` | `boolean` | `false` | Alias for `noextglob` | +| `noextglob` | `boolean` | `false` | Disable support for matching with [extglobs](#extglobs) (like `+(a\|b)`) | +| `noglobstar` | `boolean` | `false` | Disable support for matching nested directories with globstars (`**`) | +| `nonegate` | `boolean` | `false` | Disable support for negating with leading `!` | +| `noquantifiers` | `boolean` | `false` | Disable support for regex quantifiers (like `a{1,2}`) and treat them as brace patterns to be expanded. | +| [onIgnore](#optionsonIgnore) | `function` | `undefined` | Function to be called on ignored items. | +| [onMatch](#optionsonMatch) | `function` | `undefined` | Function to be called on matched items. | +| [onResult](#optionsonResult) | `function` | `undefined` | Function to be called on all items, regardless of whether or not they are matched or ignored. | +| `posix` | `boolean` | `false` | Support [POSIX character classes](#posix-bracket-expressions) ("posix brackets"). | +| `posixSlashes` | `boolean` | `undefined` | Convert all slashes in file paths to forward slashes. This does not convert slashes in the glob pattern itself | +| `prepend` | `string` | `undefined` | String to prepend to the generated regex used for matching. | +| `regex` | `boolean` | `false` | Use regular expression rules for `+` (instead of matching literal `+`), and for stars that follow closing parentheses or brackets (as in `)*` and `]*`). | +| `strictBrackets` | `boolean` | `undefined` | Throw an error if brackets, braces, or parens are imbalanced. | +| `strictSlashes` | `boolean` | `undefined` | When true, picomatch won't match trailing slashes with single stars. | +| `unescape` | `boolean` | `undefined` | Remove preceding backslashes from escaped glob characters before creating the regular expression to perform matches. | +| `unixify` | `boolean` | `undefined` | Alias for `posixSlashes`, for backwards compatitibility. | + +## Options Examples + +### options.basename + +Allow glob patterns without slashes to match a file path based on its basename. Same behavior as [minimatch](https://github.com/isaacs/minimatch) option `matchBase`. + +**Type**: `Boolean` + +**Default**: `false` + +**Example** + +```js +micromatch(['a/b.js', 'a/c.md'], '*.js'); +//=> [] + +micromatch(['a/b.js', 'a/c.md'], '*.js', { basename: true }); +//=> ['a/b.js'] +``` + +### options.bash + +Enabled by default, this option enforces bash-like behavior with stars immediately following a bracket expression. Bash bracket expressions are similar to regex character classes, but unlike regex, a star following a bracket expression **does not repeat the bracketed characters**. Instead, the star is treated the same as any other star. + +**Type**: `Boolean` + +**Default**: `true` + +**Example** + +```js +const files = ['abc', 'ajz']; +console.log(micromatch(files, '[a-c]*')); +//=> ['abc', 'ajz'] + +console.log(micromatch(files, '[a-c]*', { bash: false })); +``` + +### options.expandRange + +**Type**: `function` + +**Default**: `undefined` + +Custom function for expanding ranges in brace patterns. The [fill-range](https://github.com/jonschlinkert/fill-range) library is ideal for this purpose, or you can use custom code to do whatever you need. + +**Example** + +The following example shows how to create a glob that matches a numeric folder name between `01` and `25`, with leading zeros. + +```js +const fill = require('fill-range'); +const regex = micromatch.makeRe('foo/{01..25}/bar', { + expandRange(a, b) { + return `(${fill(a, b, { toRegex: true })})`; + } +}); + +console.log(regex) +//=> /^(?:foo\/((?:0[1-9]|1[0-9]|2[0-5]))\/bar)$/ + +console.log(regex.test('foo/00/bar')) // false +console.log(regex.test('foo/01/bar')) // true +console.log(regex.test('foo/10/bar')) // true +console.log(regex.test('foo/22/bar')) // true +console.log(regex.test('foo/25/bar')) // true +console.log(regex.test('foo/26/bar')) // false +``` + +### options.format + +**Type**: `function` + +**Default**: `undefined` + +Custom function for formatting strings before they're matched. + +**Example** + +```js +// strip leading './' from strings +const format = str => str.replace(/^\.\//, ''); +const isMatch = picomatch('foo/*.js', { format }); +console.log(isMatch('./foo/bar.js')) //=> true +``` + +### options.ignore + +String or array of glob patterns to match files to ignore. + +**Type**: `String|Array` + +**Default**: `undefined` + +```js +const isMatch = micromatch.matcher('*', { ignore: 'f*' }); +console.log(isMatch('foo')) //=> false +console.log(isMatch('bar')) //=> true +console.log(isMatch('baz')) //=> true +``` + +### options.matchBase + +Alias for [options.basename](#options-basename). + +### options.noextglob + +Disable extglob support, so that [extglobs](#extglobs) are regarded as literal characters. + +**Type**: `Boolean` + +**Default**: `undefined` + +**Examples** + +```js +console.log(micromatch(['a/z', 'a/b', 'a/!(z)'], 'a/!(z)')); +//=> ['a/b', 'a/!(z)'] + +console.log(micromatch(['a/z', 'a/b', 'a/!(z)'], 'a/!(z)', { noextglob: true })); +//=> ['a/!(z)'] (matches only as literal characters) +``` + +### options.nonegate + +Disallow negation (`!`) patterns, and treat leading `!` as a literal character to match. + +**Type**: `Boolean` + +**Default**: `undefined` + +### options.noglobstar + +Disable matching with globstars (`**`). + +**Type**: `Boolean` + +**Default**: `undefined` + +```js +micromatch(['a/b', 'a/b/c', 'a/b/c/d'], 'a/**'); +//=> ['a/b', 'a/b/c', 'a/b/c/d'] + +micromatch(['a/b', 'a/b/c', 'a/b/c/d'], 'a/**', {noglobstar: true}); +//=> ['a/b'] +``` + +### options.nonull + +Alias for [options.nullglob](#options-nullglob). + +### options.nullglob + +If `true`, when no matches are found the actual (arrayified) glob pattern is returned instead of an empty array. Same behavior as [minimatch](https://github.com/isaacs/minimatch) option `nonull`. + +**Type**: `Boolean` + +**Default**: `undefined` + +### options.onIgnore + +```js +const onIgnore = ({ glob, regex, input, output }) => { + console.log({ glob, regex, input, output }); + // { glob: '*', regex: /^(?:(?!\.)(?=.)[^\/]*?\/?)$/, input: 'foo', output: 'foo' } +}; + +const isMatch = micromatch.matcher('*', { onIgnore, ignore: 'f*' }); +isMatch('foo'); +isMatch('bar'); +isMatch('baz'); +``` + +### options.onMatch + +```js +const onMatch = ({ glob, regex, input, output }) => { + console.log({ input, output }); + // { input: 'some\\path', output: 'some/path' } + // { input: 'some\\path', output: 'some/path' } + // { input: 'some\\path', output: 'some/path' } +}; + +const isMatch = micromatch.matcher('**', { onMatch, posixSlashes: true }); +isMatch('some\\path'); +isMatch('some\\path'); +isMatch('some\\path'); +``` + +### options.onResult + +```js +const onResult = ({ glob, regex, input, output }) => { + console.log({ glob, regex, input, output }); +}; + +const isMatch = micromatch('*', { onResult, ignore: 'f*' }); +isMatch('foo'); +isMatch('bar'); +isMatch('baz'); +``` + +### options.posixSlashes + +Convert path separators on returned files to posix/unix-style forward slashes. Aliased as `unixify` for backwards compatibility. + +**Type**: `Boolean` + +**Default**: `true` on windows, `false` everywhere else. + +**Example** + +```js +console.log(micromatch.match(['a\\b\\c'], 'a/**')); +//=> ['a/b/c'] + +console.log(micromatch.match(['a\\b\\c'], { posixSlashes: false })); +//=> ['a\\b\\c'] +``` + +### options.unescape + +Remove backslashes from escaped glob characters before creating the regular expression to perform matches. + +**Type**: `Boolean` + +**Default**: `undefined` + +**Example** + +In this example we want to match a literal `*`: + +```js +console.log(micromatch.match(['abc', 'a\\*c'], 'a\\*c')); +//=> ['a\\*c'] + +console.log(micromatch.match(['abc', 'a\\*c'], 'a\\*c', { unescape: true })); +//=> ['a*c'] +``` + +
      +
      + +## Extended globbing + +Micromatch supports the following extended globbing features. + +### Extglobs + +Extended globbing, as described by the bash man page: + +| **pattern** | **regex equivalent** | **description** | +| --- | --- | --- | +| `?(pattern)` | `(pattern)?` | Matches zero or one occurrence of the given patterns | +| `*(pattern)` | `(pattern)*` | Matches zero or more occurrences of the given patterns | +| `+(pattern)` | `(pattern)+` | Matches one or more occurrences of the given patterns | +| `@(pattern)` | `(pattern)` * | Matches one of the given patterns | +| `!(pattern)` | N/A (equivalent regex is much more complicated) | Matches anything except one of the given patterns | + +* Note that `@` isn't a regex character. + +### Braces + +Brace patterns can be used to match specific ranges or sets of characters. + +**Example** + +The pattern `{f,b}*/{1..3}/{b,q}*` would match any of following strings: + +``` +foo/1/bar +foo/2/bar +foo/3/bar +baz/1/qux +baz/2/qux +baz/3/qux +``` + +Visit [braces](https://github.com/micromatch/braces) to see the full range of features and options related to brace expansion, or to create brace matching or expansion related issues. + +### Regex character classes + +Given the list: `['a.js', 'b.js', 'c.js', 'd.js', 'E.js']`: + +* `[ac].js`: matches both `a` and `c`, returning `['a.js', 'c.js']` +* `[b-d].js`: matches from `b` to `d`, returning `['b.js', 'c.js', 'd.js']` +* `a/[A-Z].js`: matches and uppercase letter, returning `['a/E.md']` + +Learn about [regex character classes](http://www.regular-expressions.info/charclass.html). + +### Regex groups + +Given `['a.js', 'b.js', 'c.js', 'd.js', 'E.js']`: + +* `(a|c).js`: would match either `a` or `c`, returning `['a.js', 'c.js']` +* `(b|d).js`: would match either `b` or `d`, returning `['b.js', 'd.js']` +* `(b|[A-Z]).js`: would match either `b` or an uppercase letter, returning `['b.js', 'E.js']` + +As with regex, parens can be nested, so patterns like `((a|b)|c)/b` will work. Although brace expansion might be friendlier to use, depending on preference. + +### POSIX bracket expressions + +POSIX brackets are intended to be more user-friendly than regex character classes. This of course is in the eye of the beholder. + +**Example** + +```js +console.log(micromatch.isMatch('a1', '[[:alpha:][:digit:]]')) //=> true +console.log(micromatch.isMatch('a1', '[[:alpha:][:alpha:]]')) //=> false +``` + +*** + +## Notes + +### Bash 4.3 parity + +Whenever possible matching behavior is based on behavior Bash 4.3, which is mostly consistent with minimatch. + +However, it's suprising how many edge cases and rabbit holes there are with glob matching, and since there is no real glob specification, and micromatch is more accurate than both Bash and minimatch, there are cases where best-guesses were made for behavior. In a few cases where Bash had no answers, we used wildmatch (used by git) as a fallback. + +### Backslashes + +There is an important, notable difference between minimatch and micromatch _in regards to how backslashes are handled_ in glob patterns. + +* Micromatch exclusively and explicitly reserves backslashes for escaping characters in a glob pattern, even on windows, which is consistent with bash behavior. _More importantly, unescaping globs can result in unsafe regular expressions_. +* Minimatch converts all backslashes to forward slashes, which means you can't use backslashes to escape any characters in your glob patterns. + +We made this decision for micromatch for a couple of reasons: + +* Consistency with bash conventions. +* Glob patterns are not filepaths. They are a type of [regular language](https://en.wikipedia.org/wiki/Regular_language) that is converted to a JavaScript regular expression. Thus, when forward slashes are defined in a glob pattern, the resulting regular expression will match windows or POSIX path separators just fine. + +**A note about joining paths to globs** + +Note that when you pass something like `path.join('foo', '*')` to micromatch, you are creating a filepath and expecting it to still work as a glob pattern. This causes problems on windows, since the `path.sep` is `\\`. + +In other words, since `\\` is reserved as an escape character in globs, on windows `path.join('foo', '*')` would result in `foo\\*`, which tells micromatch to match `*` as a literal character. This is the same behavior as bash. + +To solve this, you might be inspired to do something like `'foo\\*'.replace(/\\/g, '/')`, but this causes another, potentially much more serious, problem. + +## Benchmarks + +### Running benchmarks + +Install dependencies for running benchmarks: + +```sh +$ cd bench && npm install +``` + +Run the benchmarks: + +```sh +$ npm run bench +``` + +### Latest results + +As of March 24, 2022 (longer bars are better): + +```sh +# .makeRe star + micromatch x 2,232,802 ops/sec ±2.34% (89 runs sampled)) + minimatch x 781,018 ops/sec ±6.74% (92 runs sampled)) + +# .makeRe star; dot=true + micromatch x 1,863,453 ops/sec ±0.74% (93 runs sampled) + minimatch x 723,105 ops/sec ±0.75% (93 runs sampled) + +# .makeRe globstar + micromatch x 1,624,179 ops/sec ±2.22% (91 runs sampled) + minimatch x 1,117,230 ops/sec ±2.78% (86 runs sampled)) + +# .makeRe globstars + micromatch x 1,658,642 ops/sec ±0.86% (92 runs sampled) + minimatch x 741,224 ops/sec ±1.24% (89 runs sampled)) + +# .makeRe with leading star + micromatch x 1,525,014 ops/sec ±1.63% (90 runs sampled) + minimatch x 561,074 ops/sec ±3.07% (89 runs sampled) + +# .makeRe - braces + micromatch x 172,478 ops/sec ±2.37% (78 runs sampled) + minimatch x 96,087 ops/sec ±2.34% (88 runs sampled))) + +# .makeRe braces - range (expanded) + micromatch x 26,973 ops/sec ±0.84% (89 runs sampled) + minimatch x 3,023 ops/sec ±0.99% (90 runs sampled)) + +# .makeRe braces - range (compiled) + micromatch x 152,892 ops/sec ±1.67% (83 runs sampled) + minimatch x 992 ops/sec ±3.50% (89 runs sampled)d)) + +# .makeRe braces - nested ranges (expanded) + micromatch x 15,816 ops/sec ±13.05% (80 runs sampled) + minimatch x 2,953 ops/sec ±1.64% (91 runs sampled) + +# .makeRe braces - nested ranges (compiled) + micromatch x 110,881 ops/sec ±1.85% (82 runs sampled) + minimatch x 1,008 ops/sec ±1.51% (91 runs sampled) + +# .makeRe braces - set (compiled) + micromatch x 134,930 ops/sec ±3.54% (63 runs sampled)) + minimatch x 43,242 ops/sec ±0.60% (93 runs sampled) + +# .makeRe braces - nested sets (compiled) + micromatch x 94,455 ops/sec ±1.74% (69 runs sampled)) + minimatch x 27,720 ops/sec ±1.84% (93 runs sampled)) +``` + +## Contributing + +All contributions are welcome! Please read [the contributing guide](.github/contributing.md) to get started. + +**Bug reports** + +Please create an issue if you encounter a bug or matching behavior that doesn't seem correct. If you find a matching-related issue, please: + +* [research existing issues first](../../issues) (open and closed) +* visit the [GNU Bash documentation](https://www.gnu.org/software/bash/manual/) to see how Bash deals with the pattern +* visit the [minimatch](https://github.com/isaacs/minimatch) documentation to cross-check expected behavior in node.js +* if all else fails, since there is no real specification for globs we will probably need to discuss expected behavior and decide how to resolve it. which means any detail you can provide to help with this discussion would be greatly appreciated. + +**Platform issues** + +It's important to us that micromatch work consistently on all platforms. If you encounter any platform-specific matching or path related issues, please let us know (pull requests are also greatly appreciated). + +## About + +
      +Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +Please read the [contributing guide](.github/contributing.md) for advice on opening issues, pull requests, and coding standards. + +
      + +
      +Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +$ npm install && npm test +``` + +
      + +
      +Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +$ npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
      + +### Related projects + +You might also be interested in these projects: + +* [braces](https://www.npmjs.com/package/braces): Bash-like brace expansion, implemented in JavaScript. Safer than other brace expansion libs, with complete support… [more](https://github.com/micromatch/braces) | [homepage](https://github.com/micromatch/braces "Bash-like brace expansion, implemented in JavaScript. Safer than other brace expansion libs, with complete support for the Bash 4.3 braces specification, without sacrificing speed.") +* [expand-brackets](https://www.npmjs.com/package/expand-brackets): Expand POSIX bracket expressions (character classes) in glob patterns. | [homepage](https://github.com/micromatch/expand-brackets "Expand POSIX bracket expressions (character classes) in glob patterns.") +* [extglob](https://www.npmjs.com/package/extglob): Extended glob support for JavaScript. Adds (almost) the expressive power of regular expressions to glob… [more](https://github.com/micromatch/extglob) | [homepage](https://github.com/micromatch/extglob "Extended glob support for JavaScript. Adds (almost) the expressive power of regular expressions to glob patterns.") +* [fill-range](https://www.npmjs.com/package/fill-range): Fill in a range of numbers or letters, optionally passing an increment or `step` to… [more](https://github.com/jonschlinkert/fill-range) | [homepage](https://github.com/jonschlinkert/fill-range "Fill in a range of numbers or letters, optionally passing an increment or `step` to use, or create a regex-compatible range with `options.toRegex`") +* [nanomatch](https://www.npmjs.com/package/nanomatch): Fast, minimal glob matcher for node.js. Similar to micromatch, minimatch and multimatch, but complete Bash… [more](https://github.com/micromatch/nanomatch) | [homepage](https://github.com/micromatch/nanomatch "Fast, minimal glob matcher for node.js. Similar to micromatch, minimatch and multimatch, but complete Bash 4.3 wildcard support only (no support for exglobs, posix brackets or braces)") + +### Contributors + +| **Commits** | **Contributor** | +| --- | --- | +| 512 | [jonschlinkert](https://github.com/jonschlinkert) | +| 12 | [es128](https://github.com/es128) | +| 9 | [danez](https://github.com/danez) | +| 8 | [doowb](https://github.com/doowb) | +| 6 | [paulmillr](https://github.com/paulmillr) | +| 5 | [mrmlnc](https://github.com/mrmlnc) | +| 3 | [DrPizza](https://github.com/DrPizza) | +| 2 | [TrySound](https://github.com/TrySound) | +| 2 | [mceIdo](https://github.com/mceIdo) | +| 2 | [Glazy](https://github.com/Glazy) | +| 2 | [MartinKolarik](https://github.com/MartinKolarik) | +| 2 | [antonyk](https://github.com/antonyk) | +| 2 | [Tvrqvoise](https://github.com/Tvrqvoise) | +| 1 | [amilajack](https://github.com/amilajack) | +| 1 | [Cslove](https://github.com/Cslove) | +| 1 | [devongovett](https://github.com/devongovett) | +| 1 | [DianeLooney](https://github.com/DianeLooney) | +| 1 | [UltCombo](https://github.com/UltCombo) | +| 1 | [frangio](https://github.com/frangio) | +| 1 | [joyceerhl](https://github.com/joyceerhl) | +| 1 | [juszczykjakub](https://github.com/juszczykjakub) | +| 1 | [muescha](https://github.com/muescha) | +| 1 | [sebdeckers](https://github.com/sebdeckers) | +| 1 | [tomByrer](https://github.com/tomByrer) | +| 1 | [fidian](https://github.com/fidian) | +| 1 | [curbengh](https://github.com/curbengh) | +| 1 | [simlu](https://github.com/simlu) | +| 1 | [wtgtybhertgeghgtwtg](https://github.com/wtgtybhertgeghgtwtg) | +| 1 | [yvele](https://github.com/yvele) | + +### Author + +**Jon Schlinkert** + +* [GitHub Profile](https://github.com/jonschlinkert) +* [Twitter Profile](https://twitter.com/jonschlinkert) +* [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) + +### License + +Copyright © 2022, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). + +*** + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.8.0, on March 24, 2022._ \ No newline at end of file diff --git a/node_modules/micromatch/index.js b/node_modules/micromatch/index.js new file mode 100644 index 0000000..1fad7f7 --- /dev/null +++ b/node_modules/micromatch/index.js @@ -0,0 +1,467 @@ +'use strict'; + +const util = require('util'); +const braces = require('braces'); +const picomatch = require('picomatch'); +const utils = require('picomatch/lib/utils'); +const isEmptyString = val => val === '' || val === './'; + +/** + * Returns an array of strings that match one or more glob patterns. + * + * ```js + * const mm = require('micromatch'); + * // mm(list, patterns[, options]); + * + * console.log(mm(['a.js', 'a.txt'], ['*.js'])); + * //=> [ 'a.js' ] + * ``` + * @param {String|Array} `list` List of strings to match. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `options` See available [options](#options) + * @return {Array} Returns an array of matches + * @summary false + * @api public + */ + +const micromatch = (list, patterns, options) => { + patterns = [].concat(patterns); + list = [].concat(list); + + let omit = new Set(); + let keep = new Set(); + let items = new Set(); + let negatives = 0; + + let onResult = state => { + items.add(state.output); + if (options && options.onResult) { + options.onResult(state); + } + }; + + for (let i = 0; i < patterns.length; i++) { + let isMatch = picomatch(String(patterns[i]), { ...options, onResult }, true); + let negated = isMatch.state.negated || isMatch.state.negatedExtglob; + if (negated) negatives++; + + for (let item of list) { + let matched = isMatch(item, true); + + let match = negated ? !matched.isMatch : matched.isMatch; + if (!match) continue; + + if (negated) { + omit.add(matched.output); + } else { + omit.delete(matched.output); + keep.add(matched.output); + } + } + } + + let result = negatives === patterns.length ? [...items] : [...keep]; + let matches = result.filter(item => !omit.has(item)); + + if (options && matches.length === 0) { + if (options.failglob === true) { + throw new Error(`No matches found for "${patterns.join(', ')}"`); + } + + if (options.nonull === true || options.nullglob === true) { + return options.unescape ? patterns.map(p => p.replace(/\\/g, '')) : patterns; + } + } + + return matches; +}; + +/** + * Backwards compatibility + */ + +micromatch.match = micromatch; + +/** + * Returns a matcher function from the given glob `pattern` and `options`. + * The returned function takes a string to match as its only argument and returns + * true if the string is a match. + * + * ```js + * const mm = require('micromatch'); + * // mm.matcher(pattern[, options]); + * + * const isMatch = mm.matcher('*.!(*a)'); + * console.log(isMatch('a.a')); //=> false + * console.log(isMatch('a.b')); //=> true + * ``` + * @param {String} `pattern` Glob pattern + * @param {Object} `options` + * @return {Function} Returns a matcher function. + * @api public + */ + +micromatch.matcher = (pattern, options) => picomatch(pattern, options); + +/** + * Returns true if **any** of the given glob `patterns` match the specified `string`. + * + * ```js + * const mm = require('micromatch'); + * // mm.isMatch(string, patterns[, options]); + * + * console.log(mm.isMatch('a.a', ['b.*', '*.a'])); //=> true + * console.log(mm.isMatch('a.a', 'b.*')); //=> false + * ``` + * @param {String} `str` The string to test. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `[options]` See available [options](#options). + * @return {Boolean} Returns true if any patterns match `str` + * @api public + */ + +micromatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str); + +/** + * Backwards compatibility + */ + +micromatch.any = micromatch.isMatch; + +/** + * Returns a list of strings that _**do not match any**_ of the given `patterns`. + * + * ```js + * const mm = require('micromatch'); + * // mm.not(list, patterns[, options]); + * + * console.log(mm.not(['a.a', 'b.b', 'c.c'], '*.a')); + * //=> ['b.b', 'c.c'] + * ``` + * @param {Array} `list` Array of strings to match. + * @param {String|Array} `patterns` One or more glob pattern to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Array} Returns an array of strings that **do not match** the given patterns. + * @api public + */ + +micromatch.not = (list, patterns, options = {}) => { + patterns = [].concat(patterns).map(String); + let result = new Set(); + let items = []; + + let onResult = state => { + if (options.onResult) options.onResult(state); + items.push(state.output); + }; + + let matches = new Set(micromatch(list, patterns, { ...options, onResult })); + + for (let item of items) { + if (!matches.has(item)) { + result.add(item); + } + } + return [...result]; +}; + +/** + * Returns true if the given `string` contains the given pattern. Similar + * to [.isMatch](#isMatch) but the pattern can match any part of the string. + * + * ```js + * var mm = require('micromatch'); + * // mm.contains(string, pattern[, options]); + * + * console.log(mm.contains('aa/bb/cc', '*b')); + * //=> true + * console.log(mm.contains('aa/bb/cc', '*d')); + * //=> false + * ``` + * @param {String} `str` The string to match. + * @param {String|Array} `patterns` Glob pattern to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Boolean} Returns true if any of the patterns matches any part of `str`. + * @api public + */ + +micromatch.contains = (str, pattern, options) => { + if (typeof str !== 'string') { + throw new TypeError(`Expected a string: "${util.inspect(str)}"`); + } + + if (Array.isArray(pattern)) { + return pattern.some(p => micromatch.contains(str, p, options)); + } + + if (typeof pattern === 'string') { + if (isEmptyString(str) || isEmptyString(pattern)) { + return false; + } + + if (str.includes(pattern) || (str.startsWith('./') && str.slice(2).includes(pattern))) { + return true; + } + } + + return micromatch.isMatch(str, pattern, { ...options, contains: true }); +}; + +/** + * Filter the keys of the given object with the given `glob` pattern + * and `options`. Does not attempt to match nested keys. If you need this feature, + * use [glob-object][] instead. + * + * ```js + * const mm = require('micromatch'); + * // mm.matchKeys(object, patterns[, options]); + * + * const obj = { aa: 'a', ab: 'b', ac: 'c' }; + * console.log(mm.matchKeys(obj, '*b')); + * //=> { ab: 'b' } + * ``` + * @param {Object} `object` The object with keys to filter. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Object} Returns an object with only keys that match the given patterns. + * @api public + */ + +micromatch.matchKeys = (obj, patterns, options) => { + if (!utils.isObject(obj)) { + throw new TypeError('Expected the first argument to be an object'); + } + let keys = micromatch(Object.keys(obj), patterns, options); + let res = {}; + for (let key of keys) res[key] = obj[key]; + return res; +}; + +/** + * Returns true if some of the strings in the given `list` match any of the given glob `patterns`. + * + * ```js + * const mm = require('micromatch'); + * // mm.some(list, patterns[, options]); + * + * console.log(mm.some(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); + * // true + * console.log(mm.some(['foo.js'], ['*.js', '!foo.js'])); + * // false + * ``` + * @param {String|Array} `list` The string or array of strings to test. Returns as soon as the first match is found. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Boolean} Returns true if any `patterns` matches any of the strings in `list` + * @api public + */ + +micromatch.some = (list, patterns, options) => { + let items = [].concat(list); + + for (let pattern of [].concat(patterns)) { + let isMatch = picomatch(String(pattern), options); + if (items.some(item => isMatch(item))) { + return true; + } + } + return false; +}; + +/** + * Returns true if every string in the given `list` matches + * any of the given glob `patterns`. + * + * ```js + * const mm = require('micromatch'); + * // mm.every(list, patterns[, options]); + * + * console.log(mm.every('foo.js', ['foo.js'])); + * // true + * console.log(mm.every(['foo.js', 'bar.js'], ['*.js'])); + * // true + * console.log(mm.every(['foo.js', 'bar.js'], ['*.js', '!foo.js'])); + * // false + * console.log(mm.every(['foo.js'], ['*.js', '!foo.js'])); + * // false + * ``` + * @param {String|Array} `list` The string or array of strings to test. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Boolean} Returns true if all `patterns` matches all of the strings in `list` + * @api public + */ + +micromatch.every = (list, patterns, options) => { + let items = [].concat(list); + + for (let pattern of [].concat(patterns)) { + let isMatch = picomatch(String(pattern), options); + if (!items.every(item => isMatch(item))) { + return false; + } + } + return true; +}; + +/** + * Returns true if **all** of the given `patterns` match + * the specified string. + * + * ```js + * const mm = require('micromatch'); + * // mm.all(string, patterns[, options]); + * + * console.log(mm.all('foo.js', ['foo.js'])); + * // true + * + * console.log(mm.all('foo.js', ['*.js', '!foo.js'])); + * // false + * + * console.log(mm.all('foo.js', ['*.js', 'foo.js'])); + * // true + * + * console.log(mm.all('foo.js', ['*.js', 'f*', '*o*', '*o.js'])); + * // true + * ``` + * @param {String|Array} `str` The string to test. + * @param {String|Array} `patterns` One or more glob patterns to use for matching. + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Boolean} Returns true if any patterns match `str` + * @api public + */ + +micromatch.all = (str, patterns, options) => { + if (typeof str !== 'string') { + throw new TypeError(`Expected a string: "${util.inspect(str)}"`); + } + + return [].concat(patterns).every(p => picomatch(p, options)(str)); +}; + +/** + * Returns an array of matches captured by `pattern` in `string, or `null` if the pattern did not match. + * + * ```js + * const mm = require('micromatch'); + * // mm.capture(pattern, string[, options]); + * + * console.log(mm.capture('test/*.js', 'test/foo.js')); + * //=> ['foo'] + * console.log(mm.capture('test/*.js', 'foo/bar.css')); + * //=> null + * ``` + * @param {String} `glob` Glob pattern to use for matching. + * @param {String} `input` String to match + * @param {Object} `options` See available [options](#options) for changing how matches are performed + * @return {Array|null} Returns an array of captures if the input matches the glob pattern, otherwise `null`. + * @api public + */ + +micromatch.capture = (glob, input, options) => { + let posix = utils.isWindows(options); + let regex = picomatch.makeRe(String(glob), { ...options, capture: true }); + let match = regex.exec(posix ? utils.toPosixSlashes(input) : input); + + if (match) { + return match.slice(1).map(v => v === void 0 ? '' : v); + } +}; + +/** + * Create a regular expression from the given glob `pattern`. + * + * ```js + * const mm = require('micromatch'); + * // mm.makeRe(pattern[, options]); + * + * console.log(mm.makeRe('*.js')); + * //=> /^(?:(\.[\\\/])?(?!\.)(?=.)[^\/]*?\.js)$/ + * ``` + * @param {String} `pattern` A glob pattern to convert to regex. + * @param {Object} `options` + * @return {RegExp} Returns a regex created from the given pattern. + * @api public + */ + +micromatch.makeRe = (...args) => picomatch.makeRe(...args); + +/** + * Scan a glob pattern to separate the pattern into segments. Used + * by the [split](#split) method. + * + * ```js + * const mm = require('micromatch'); + * const state = mm.scan(pattern[, options]); + * ``` + * @param {String} `pattern` + * @param {Object} `options` + * @return {Object} Returns an object with + * @api public + */ + +micromatch.scan = (...args) => picomatch.scan(...args); + +/** + * Parse a glob pattern to create the source string for a regular + * expression. + * + * ```js + * const mm = require('micromatch'); + * const state = mm.parse(pattern[, options]); + * ``` + * @param {String} `glob` + * @param {Object} `options` + * @return {Object} Returns an object with useful properties and output to be used as regex source string. + * @api public + */ + +micromatch.parse = (patterns, options) => { + let res = []; + for (let pattern of [].concat(patterns || [])) { + for (let str of braces(String(pattern), options)) { + res.push(picomatch.parse(str, options)); + } + } + return res; +}; + +/** + * Process the given brace `pattern`. + * + * ```js + * const { braces } = require('micromatch'); + * console.log(braces('foo/{a,b,c}/bar')); + * //=> [ 'foo/(a|b|c)/bar' ] + * + * console.log(braces('foo/{a,b,c}/bar', { expand: true })); + * //=> [ 'foo/a/bar', 'foo/b/bar', 'foo/c/bar' ] + * ``` + * @param {String} `pattern` String with brace pattern to process. + * @param {Object} `options` Any [options](#options) to change how expansion is performed. See the [braces][] library for all available options. + * @return {Array} + * @api public + */ + +micromatch.braces = (pattern, options) => { + if (typeof pattern !== 'string') throw new TypeError('Expected a string'); + if ((options && options.nobrace === true) || !/\{.*\}/.test(pattern)) { + return [pattern]; + } + return braces(pattern, options); +}; + +/** + * Expand braces + */ + +micromatch.braceExpand = (pattern, options) => { + if (typeof pattern !== 'string') throw new TypeError('Expected a string'); + return micromatch.braces(pattern, { ...options, expand: true }); +}; + +/** + * Expose micromatch + */ + +module.exports = micromatch; diff --git a/node_modules/micromatch/package.json b/node_modules/micromatch/package.json new file mode 100644 index 0000000..6061d5b --- /dev/null +++ b/node_modules/micromatch/package.json @@ -0,0 +1,119 @@ +{ + "name": "micromatch", + "description": "Glob matching for javascript/node.js. A replacement and faster alternative to minimatch and multimatch.", + "version": "4.0.5", + "homepage": "https://github.com/micromatch/micromatch", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "contributors": [ + "(https://github.com/DianeLooney)", + "Amila Welihinda (amilajack.com)", + "Bogdan Chadkin (https://github.com/TrySound)", + "Brian Woodward (https://twitter.com/doowb)", + "Devon Govett (http://badassjs.com)", + "Elan Shanker (https://github.com/es128)", + "Fabrício Matté (https://ultcombo.js.org)", + "Jon Schlinkert (http://twitter.com/jonschlinkert)", + "Martin Kolárik (https://kolarik.sk)", + "Olsten Larck (https://i.am.charlike.online)", + "Paul Miller (paulmillr.com)", + "Tom Byrer (https://github.com/tomByrer)", + "Tyler Akins (http://rumkin.com)", + "Peter Bright (https://github.com/drpizza)", + "Kuba Juszczyk (https://github.com/ku8ar)" + ], + "repository": "micromatch/micromatch", + "bugs": { + "url": "https://github.com/micromatch/micromatch/issues" + }, + "license": "MIT", + "files": [ + "index.js" + ], + "main": "index.js", + "engines": { + "node": ">=8.6" + }, + "scripts": { + "test": "mocha" + }, + "dependencies": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + }, + "devDependencies": { + "fill-range": "^7.0.1", + "gulp-format-md": "^2.0.0", + "minimatch": "^5.0.1", + "mocha": "^9.2.2", + "time-require": "github:jonschlinkert/time-require" + }, + "keywords": [ + "bash", + "bracket", + "character-class", + "expand", + "expansion", + "expression", + "extglob", + "extglobs", + "file", + "files", + "filter", + "find", + "glob", + "globbing", + "globs", + "globstar", + "lookahead", + "lookaround", + "lookbehind", + "match", + "matcher", + "matches", + "matching", + "micromatch", + "minimatch", + "multimatch", + "negate", + "negation", + "path", + "pattern", + "patterns", + "posix", + "regex", + "regexp", + "regular", + "shell", + "star", + "wildcard" + ], + "verb": { + "toc": "collapsible", + "layout": "default", + "tasks": [ + "readme" + ], + "plugins": [ + "gulp-format-md" + ], + "lint": { + "reflinks": true + }, + "related": { + "list": [ + "braces", + "expand-brackets", + "extglob", + "fill-range", + "nanomatch" + ] + }, + "reflinks": [ + "extglob", + "fill-range", + "glob-object", + "minimatch", + "multimatch" + ] + } +} diff --git a/node_modules/mini-svg-data-uri/LICENSE b/node_modules/mini-svg-data-uri/LICENSE new file mode 100644 index 0000000..bf23b14 --- /dev/null +++ b/node_modules/mini-svg-data-uri/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2018 Taylor Hunt + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/mini-svg-data-uri/README.md b/node_modules/mini-svg-data-uri/README.md new file mode 100644 index 0000000..c6a109c --- /dev/null +++ b/node_modules/mini-svg-data-uri/README.md @@ -0,0 +1,109 @@ +Mini SVG `data:` URI +==================== + +This tool converts SVGs into the most compact, compressible `data:` URI that SVG-supporting browsers tolerate. The results look like this (169 bytes): + +```url +data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 50 50' +%3e%3cpath d='M22 38V51L32 32l19-19v12C44 26 43 10 38 0 52 15 49 39 22 38z'/%3e +%3c/svg%3e +``` + +Compare to the Base64 version (210 bytes): + +```url +data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIH +ZpZXdCb3g9IjAgMCA1MCA1MCI+PHBhdGggZD0iTTIyIDM4VjUxTDMyIDMybDE5LTE5djEyQzQ0IDI2ID +QzIDEwIDM4IDAgNTIgMTUgNDkgMzkgMjIgMzh6Ii8+PC9zdmc+ +``` + +Or the URL-encoded version other tools produce (256 bytes): + +```url +data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org% +2F2000%2Fsvg%22%20viewBox%3D%220%200%2050%2050%22%3E%3Cpath%20d%3D%22M22%2038V51 +L32%2032l19-19v12C44%2026%2043%2010%2038%200%2052%2015%2049%2039%2022%2038z%22%2 +F%3E%3C%2Fsvg%3E +``` + +For a more realistic example, I inlined the icons from the [Open Iconic](https://useiconic.com/open) project into CSS files with the 3 above methods: + +| Compression | Base64 | Basic %-encoding | `mini-svg-data-uri` | +|-------------|----------:|-----------------:|--------------------:| +| None | 96.459 kB | 103.268 kB | 76.583 kB | +| `gzip -9` | 17.902 kB | 13.780 kB | 12.974 kB | +| `brotli -Z` | 15.797 kB | 11.693 kB | 10.976 kB | + +Roughly 6% smaller compressed, but don't write off the ≈20% uncompressed savings either. [Some browser caches decompress before store](https://blogs.msdn.microsoft.com/ieinternals/2014/10/21/compressing-the-web/), and parsing time/memory usage scale linearly with uncompressed filesize. + + +Usage +----- + +```js +var svgToMiniDataURI = require('mini-svg-data-uri'); + +var svg = ''; + +var optimizedSVGDataURI = svgToMiniDataURI(svg); +// "data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 50 50'%3e%3cpath d='M22 38V51L32 32l19-19v12C44 26 43 10 38 0 52 15 49 39 22 38z'/%3e%3c/svg%3e" +``` + +You can also [try it in your browser at RunKit](https://npm.runkit.com/mini-svg-data-uri). + +### CLI + +If you have it installed globally, or as some kind of dependency inside your project’s directory: + +```sh +mini-svg-data-uri file.svg # writes to stdout +mini-svg-data-uri file.svg file.svg.uri # writes to the given output filename +``` + +Use `--help` for more info. + +### Warning + +* This **does not optimize the SVG source file**. You’ll want [svgo](https://github.com/svg/svgo) or its brother [SVGOMG](https://jakearchibald.github.io/svgomg/) for that. + +* The default output **does not work inside `srcset` attributes**. Use the `.toSrcset` method for that: + + ```js + var srcsetExample = html` + + + + `; + ``` + +* The resulting Data URI should be wrapped with double quotes: `url("…")`, ``, etc. + +* This might change or break SVGs that use `"` in character data, like inside `` or `aria-label` or something. Try curly quotes (`“”`) or `"` instead. + + +FAQ +--- + +### Don’t you need a `charset` in the MIME Type? + +`charset` does nothing for Data URIs. The URI can only be the encoding of its parent file — it’s included in it! + +### Why lowercase the URL-encoded hex pairs? + +It compresses slightly better. No, really. Using the same files from earlier: + +| Compression | Uppercase (`%AF`) | Lowercase (`%af`) | +|-------------|------------------:|------------------:| +| `gzip -9` | 12.978 kB | 12.974 kB | +| `brotli -Z` | 10.988 kB | 10.976 kB | + +I did say *slightly*. + + +Browser support +--------------- + +* Internet Explorer 9 and up, including Edge +* Firefox, Safari, Chrome, whatever else uses their engines +* Android WebKit 3+ +* Opera Mini’s server-side Presto diff --git a/node_modules/mini-svg-data-uri/cli.js b/node_modules/mini-svg-data-uri/cli.js new file mode 100755 index 0000000..c5a47dd --- /dev/null +++ b/node_modules/mini-svg-data-uri/cli.js @@ -0,0 +1,41 @@ +#!/usr/bin/env node + +let help = ` +Usage: mini-svg-data-uri [dest] + +Options: +-v, --version Output the version number +-h, --help Display help for command + +Examples: + mini-svg-data-uri file.svg Write to stdout + mini-svg-data-uri icon.svg icon.uri Write to file +`; + +let [source, dest] = process.argv.slice(2); + +switch (source) { + case '-h': + case '--help': + case undefined: + console.log(help); + process.exit(); + + case '-v': + case '--version': + console.log(require('./package').version); + process.exit(); +} + +const fs = require('fs'); +const svgToMiniDataURI = require('.'); + +fs.readFile(source, 'utf8', (err, data) => { + if (err) { + console.error(err.message); + console.log(help); + process.exit(1); + } + const out = svgToMiniDataURI(data); + dest ? fs.writeFileSync(dest, out) : console.log(out); +}); diff --git a/node_modules/mini-svg-data-uri/index.d.ts b/node_modules/mini-svg-data-uri/index.d.ts new file mode 100644 index 0000000..e1f2686 --- /dev/null +++ b/node_modules/mini-svg-data-uri/index.d.ts @@ -0,0 +1,7 @@ +declare function svgToTinyDataUri(svgString: string): string; + +declare namespace svgToTinyDataUri { + function toSrcset(svgString: string): string; +} + +export = svgToTinyDataUri; \ No newline at end of file diff --git a/node_modules/mini-svg-data-uri/index.js b/node_modules/mini-svg-data-uri/index.js new file mode 100644 index 0000000..971cc38 --- /dev/null +++ b/node_modules/mini-svg-data-uri/index.js @@ -0,0 +1,55 @@ +var shorterNames = require('./shorter-css-color-names'); +var REGEX = { + whitespace: /\s+/g, + urlHexPairs: /%[\dA-F]{2}/g, + quotes: /"/g, +} + +function collapseWhitespace(str) { + return str.trim().replace(REGEX.whitespace, ' '); +} + +function dataURIPayload(string) { + return encodeURIComponent(string) + .replace(REGEX.urlHexPairs, specialHexEncode); +} + +// `#` gets converted to `%23`, so quite a few CSS named colors are shorter than +// their equivalent URL-encoded hex codes. +function colorCodeToShorterNames(string) { + Object.keys(shorterNames).forEach(function(key) { + if (shorterNames[key].test(string)) { + string = string.replace(shorterNames[key], key); + } + }); + + return string; +} + +function specialHexEncode(match) { + switch (match) { // Browsers tolerate these characters, and they're frequent + case '%20': return ' '; + case '%3D': return '='; + case '%3A': return ':'; + case '%2F': return '/'; + default: return match.toLowerCase(); // compresses better + } +} + +function svgToTinyDataUri(svgString) { + if (typeof svgString !== 'string') { + throw new TypeError('Expected a string, but received ' + typeof svgString); + } + // Strip the Byte-Order Mark if the SVG has one + if (svgString.charCodeAt(0) === 0xfeff) { svgString = svgString.slice(1) } + + var body = colorCodeToShorterNames(collapseWhitespace(svgString)) + .replace(REGEX.quotes, "'"); + return 'data:image/svg+xml,' + dataURIPayload(body); +} + +svgToTinyDataUri.toSrcset = function toSrcset(svgString) { + return svgToTinyDataUri(svgString).replace(/ /g, '%20'); +} + +module.exports = svgToTinyDataUri; diff --git a/node_modules/mini-svg-data-uri/index.test-d.ts b/node_modules/mini-svg-data-uri/index.test-d.ts new file mode 100644 index 0000000..740b215 --- /dev/null +++ b/node_modules/mini-svg-data-uri/index.test-d.ts @@ -0,0 +1,5 @@ +import svgToTinyDataUri from "."; + +svgToTinyDataUri('xx'); + +svgToTinyDataUri.toSrcset('xxx'); \ No newline at end of file diff --git a/node_modules/mini-svg-data-uri/package.json b/node_modules/mini-svg-data-uri/package.json new file mode 100644 index 0000000..da3b9cc --- /dev/null +++ b/node_modules/mini-svg-data-uri/package.json @@ -0,0 +1,26 @@ +{ + "name": "mini-svg-data-uri", + "version": "1.4.4", + "description": "Small, efficient encoding of SVG data URIs for CSS, HTML, etc.", + "main": "index.js", + "types": "index.d.ts", + "bin": "cli.js", + "repository": { + "type": "git", + "url": "git+https://github.com/tigt/mini-svg-data-uri.git" + }, + "keywords": [ + "svg", + "url", + "data", + "uri", + "minification", + "url encoding" + ], + "author": "Taylor “Tigt” Hunt (https://ti.gt/)", + "license": "MIT", + "bugs": { + "url": "https://github.com/tigt/mini-svg-data-uri/issues" + }, + "homepage": "https://github.com/tigt/mini-svg-data-uri#readme" +} diff --git a/node_modules/mini-svg-data-uri/shorter-css-color-names.js b/node_modules/mini-svg-data-uri/shorter-css-color-names.js new file mode 100644 index 0000000..5e93f5d --- /dev/null +++ b/node_modules/mini-svg-data-uri/shorter-css-color-names.js @@ -0,0 +1,56 @@ +module.exports = { + aqua: /#00ffff(ff)?(?!\w)|#0ff(f)?(?!\w)/gi, + azure: /#f0ffff(ff)?(?!\w)/gi, + beige: /#f5f5dc(ff)?(?!\w)/gi, + bisque: /#ffe4c4(ff)?(?!\w)/gi, + black: /#000000(ff)?(?!\w)|#000(f)?(?!\w)/gi, + blue: /#0000ff(ff)?(?!\w)|#00f(f)?(?!\w)/gi, + brown: /#a52a2a(ff)?(?!\w)/gi, + coral: /#ff7f50(ff)?(?!\w)/gi, + cornsilk: /#fff8dc(ff)?(?!\w)/gi, + crimson: /#dc143c(ff)?(?!\w)/gi, + cyan: /#00ffff(ff)?(?!\w)|#0ff(f)?(?!\w)/gi, + darkblue: /#00008b(ff)?(?!\w)/gi, + darkcyan: /#008b8b(ff)?(?!\w)/gi, + darkgrey: /#a9a9a9(ff)?(?!\w)/gi, + darkred: /#8b0000(ff)?(?!\w)/gi, + deeppink: /#ff1493(ff)?(?!\w)/gi, + dimgrey: /#696969(ff)?(?!\w)/gi, + gold: /#ffd700(ff)?(?!\w)/gi, + green: /#008000(ff)?(?!\w)/gi, + grey: /#808080(ff)?(?!\w)/gi, + honeydew: /#f0fff0(ff)?(?!\w)/gi, + hotpink: /#ff69b4(ff)?(?!\w)/gi, + indigo: /#4b0082(ff)?(?!\w)/gi, + ivory: /#fffff0(ff)?(?!\w)/gi, + khaki: /#f0e68c(ff)?(?!\w)/gi, + lavender: /#e6e6fa(ff)?(?!\w)/gi, + lime: /#00ff00(ff)?(?!\w)|#0f0(f)?(?!\w)/gi, + linen: /#faf0e6(ff)?(?!\w)/gi, + maroon: /#800000(ff)?(?!\w)/gi, + moccasin: /#ffe4b5(ff)?(?!\w)/gi, + navy: /#000080(ff)?(?!\w)/gi, + oldlace: /#fdf5e6(ff)?(?!\w)/gi, + olive: /#808000(ff)?(?!\w)/gi, + orange: /#ffa500(ff)?(?!\w)/gi, + orchid: /#da70d6(ff)?(?!\w)/gi, + peru: /#cd853f(ff)?(?!\w)/gi, + pink: /#ffc0cb(ff)?(?!\w)/gi, + plum: /#dda0dd(ff)?(?!\w)/gi, + purple: /#800080(ff)?(?!\w)/gi, + red: /#ff0000(ff)?(?!\w)|#f00(f)?(?!\w)/gi, + salmon: /#fa8072(ff)?(?!\w)/gi, + seagreen: /#2e8b57(ff)?(?!\w)/gi, + seashell: /#fff5ee(ff)?(?!\w)/gi, + sienna: /#a0522d(ff)?(?!\w)/gi, + silver: /#c0c0c0(ff)?(?!\w)/gi, + skyblue: /#87ceeb(ff)?(?!\w)/gi, + snow: /#fffafa(ff)?(?!\w)/gi, + tan: /#d2b48c(ff)?(?!\w)/gi, + teal: /#008080(ff)?(?!\w)/gi, + thistle: /#d8bfd8(ff)?(?!\w)/gi, + tomato: /#ff6347(ff)?(?!\w)/gi, + violet: /#ee82ee(ff)?(?!\w)/gi, + wheat: /#f5deb3(ff)?(?!\w)/gi, + white: /#ffffff(ff)?(?!\w)|#fff(f)?(?!\w)/gi, +}; diff --git a/node_modules/minimist/.DS_Store b/node_modules/minimist/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..6339ca95b11f2edf8c350cf9d8c4b0cb6e196b1b GIT binary patch literal 6148 zcmeHKOG?B*5Um;mM%>KOWnW=#5Qn%I<^np-po_!=9Knqc(2IBrFW_->;R$@zRf!3S z;7UZRp!y~CNp)VDR5uav@^-TzniEk96`UPlm=N)cj$~#QadLb{O$BX>%f;%V8b!O| zH!>jKZlAVvN9R;h@B5XtP4{FRQC4}rE~+&=>HX`&8^6CCPepCM5mjHwYH6#L1J1yZfjzyQOaI3y@2m6wFv;(n0cYS(F~CW_%9nU0 y>#d`glU^I3XHXG|YZSW_T*Ow4SZT#a&?vA6xd3K{jUp@%-v~q+d~gPSlz|U(yG=m= literal 0 HcmV?d00001 diff --git a/node_modules/minimist/.travis.yml b/node_modules/minimist/.travis.yml new file mode 100644 index 0000000..74c57bf --- /dev/null +++ b/node_modules/minimist/.travis.yml @@ -0,0 +1,8 @@ +language: node_js +node_js: + - "0.8" + - "0.10" + - "0.12" + - "iojs" +before_install: + - npm install -g npm@~1.4.6 diff --git a/node_modules/minimist/LICENSE b/node_modules/minimist/LICENSE new file mode 100644 index 0000000..ee27ba4 --- /dev/null +++ b/node_modules/minimist/LICENSE @@ -0,0 +1,18 @@ +This software is released under the MIT license: + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/minimist/example/parse.js b/node_modules/minimist/example/parse.js new file mode 100644 index 0000000..f7c8d49 --- /dev/null +++ b/node_modules/minimist/example/parse.js @@ -0,0 +1,2 @@ +var argv = require('../')(process.argv.slice(2)); +console.log(argv); diff --git a/node_modules/minimist/index.js b/node_modules/minimist/index.js new file mode 100644 index 0000000..d9c3eb7 --- /dev/null +++ b/node_modules/minimist/index.js @@ -0,0 +1,249 @@ +module.exports = function (args, opts) { + if (!opts) opts = {}; + + var flags = { bools : {}, strings : {}, unknownFn: null }; + + if (typeof opts['unknown'] === 'function') { + flags.unknownFn = opts['unknown']; + } + + if (typeof opts['boolean'] === 'boolean' && opts['boolean']) { + flags.allBools = true; + } else { + [].concat(opts['boolean']).filter(Boolean).forEach(function (key) { + flags.bools[key] = true; + }); + } + + var aliases = {}; + Object.keys(opts.alias || {}).forEach(function (key) { + aliases[key] = [].concat(opts.alias[key]); + aliases[key].forEach(function (x) { + aliases[x] = [key].concat(aliases[key].filter(function (y) { + return x !== y; + })); + }); + }); + + [].concat(opts.string).filter(Boolean).forEach(function (key) { + flags.strings[key] = true; + if (aliases[key]) { + flags.strings[aliases[key]] = true; + } + }); + + var defaults = opts['default'] || {}; + + var argv = { _ : [] }; + Object.keys(flags.bools).forEach(function (key) { + setArg(key, defaults[key] === undefined ? false : defaults[key]); + }); + + var notFlags = []; + + if (args.indexOf('--') !== -1) { + notFlags = args.slice(args.indexOf('--')+1); + args = args.slice(0, args.indexOf('--')); + } + + function argDefined(key, arg) { + return (flags.allBools && /^--[^=]+$/.test(arg)) || + flags.strings[key] || flags.bools[key] || aliases[key]; + } + + function setArg (key, val, arg) { + if (arg && flags.unknownFn && !argDefined(key, arg)) { + if (flags.unknownFn(arg) === false) return; + } + + var value = !flags.strings[key] && isNumber(val) + ? Number(val) : val + ; + setKey(argv, key.split('.'), value); + + (aliases[key] || []).forEach(function (x) { + setKey(argv, x.split('.'), value); + }); + } + + function setKey (obj, keys, value) { + var o = obj; + for (var i = 0; i < keys.length-1; i++) { + var key = keys[i]; + if (isConstructorOrProto(o, key)) return; + if (o[key] === undefined) o[key] = {}; + if (o[key] === Object.prototype || o[key] === Number.prototype + || o[key] === String.prototype) o[key] = {}; + if (o[key] === Array.prototype) o[key] = []; + o = o[key]; + } + + var key = keys[keys.length - 1]; + if (isConstructorOrProto(o, key)) return; + if (o === Object.prototype || o === Number.prototype + || o === String.prototype) o = {}; + if (o === Array.prototype) o = []; + if (o[key] === undefined || flags.bools[key] || typeof o[key] === 'boolean') { + o[key] = value; + } + else if (Array.isArray(o[key])) { + o[key].push(value); + } + else { + o[key] = [ o[key], value ]; + } + } + + function aliasIsBoolean(key) { + return aliases[key].some(function (x) { + return flags.bools[x]; + }); + } + + for (var i = 0; i < args.length; i++) { + var arg = args[i]; + + if (/^--.+=/.test(arg)) { + // Using [\s\S] instead of . because js doesn't support the + // 'dotall' regex modifier. See: + // http://stackoverflow.com/a/1068308/13216 + var m = arg.match(/^--([^=]+)=([\s\S]*)$/); + var key = m[1]; + var value = m[2]; + if (flags.bools[key]) { + value = value !== 'false'; + } + setArg(key, value, arg); + } + else if (/^--no-.+/.test(arg)) { + var key = arg.match(/^--no-(.+)/)[1]; + setArg(key, false, arg); + } + else if (/^--.+/.test(arg)) { + var key = arg.match(/^--(.+)/)[1]; + var next = args[i + 1]; + if (next !== undefined && !/^-/.test(next) + && !flags.bools[key] + && !flags.allBools + && (aliases[key] ? !aliasIsBoolean(key) : true)) { + setArg(key, next, arg); + i++; + } + else if (/^(true|false)$/.test(next)) { + setArg(key, next === 'true', arg); + i++; + } + else { + setArg(key, flags.strings[key] ? '' : true, arg); + } + } + else if (/^-[^-]+/.test(arg)) { + var letters = arg.slice(1,-1).split(''); + + var broken = false; + for (var j = 0; j < letters.length; j++) { + var next = arg.slice(j+2); + + if (next === '-') { + setArg(letters[j], next, arg) + continue; + } + + if (/[A-Za-z]/.test(letters[j]) && /=/.test(next)) { + setArg(letters[j], next.split('=')[1], arg); + broken = true; + break; + } + + if (/[A-Za-z]/.test(letters[j]) + && /-?\d+(\.\d*)?(e-?\d+)?$/.test(next)) { + setArg(letters[j], next, arg); + broken = true; + break; + } + + if (letters[j+1] && letters[j+1].match(/\W/)) { + setArg(letters[j], arg.slice(j+2), arg); + broken = true; + break; + } + else { + setArg(letters[j], flags.strings[letters[j]] ? '' : true, arg); + } + } + + var key = arg.slice(-1)[0]; + if (!broken && key !== '-') { + if (args[i+1] && !/^(-|--)[^-]/.test(args[i+1]) + && !flags.bools[key] + && (aliases[key] ? !aliasIsBoolean(key) : true)) { + setArg(key, args[i+1], arg); + i++; + } + else if (args[i+1] && /^(true|false)$/.test(args[i+1])) { + setArg(key, args[i+1] === 'true', arg); + i++; + } + else { + setArg(key, flags.strings[key] ? '' : true, arg); + } + } + } + else { + if (!flags.unknownFn || flags.unknownFn(arg) !== false) { + argv._.push( + flags.strings['_'] || !isNumber(arg) ? arg : Number(arg) + ); + } + if (opts.stopEarly) { + argv._.push.apply(argv._, args.slice(i + 1)); + break; + } + } + } + + Object.keys(defaults).forEach(function (key) { + if (!hasKey(argv, key.split('.'))) { + setKey(argv, key.split('.'), defaults[key]); + + (aliases[key] || []).forEach(function (x) { + setKey(argv, x.split('.'), defaults[key]); + }); + } + }); + + if (opts['--']) { + argv['--'] = new Array(); + notFlags.forEach(function(key) { + argv['--'].push(key); + }); + } + else { + notFlags.forEach(function(key) { + argv._.push(key); + }); + } + + return argv; +}; + +function hasKey (obj, keys) { + var o = obj; + keys.slice(0,-1).forEach(function (key) { + o = (o[key] || {}); + }); + + var key = keys[keys.length - 1]; + return key in o; +} + +function isNumber (x) { + if (typeof x === 'number') return true; + if (/^0x[0-9a-f]+$/i.test(x)) return true; + return /^[-+]?(?:\d+(?:\.\d*)?|\.\d+)(e[-+]?\d+)?$/.test(x); +} + + +function isConstructorOrProto (obj, key) { + return key === 'constructor' && typeof obj[key] === 'function' || key === '__proto__'; +} diff --git a/node_modules/minimist/package.json b/node_modules/minimist/package.json new file mode 100644 index 0000000..c225853 --- /dev/null +++ b/node_modules/minimist/package.json @@ -0,0 +1,45 @@ +{ + "name": "minimist", + "version": "1.2.6", + "description": "parse argument options", + "main": "index.js", + "devDependencies": { + "covert": "^1.0.0", + "tap": "~0.4.0", + "tape": "^3.5.0" + }, + "scripts": { + "test": "tap test/*.js", + "coverage": "covert test/*.js" + }, + "testling": { + "files": "test/*.js", + "browsers": [ + "ie/6..latest", + "ff/5", + "firefox/latest", + "chrome/10", + "chrome/latest", + "safari/5.1", + "safari/latest", + "opera/12" + ] + }, + "repository": { + "type": "git", + "url": "git://github.com/substack/minimist.git" + }, + "homepage": "https://github.com/substack/minimist", + "keywords": [ + "argv", + "getopt", + "parser", + "optimist" + ], + "author": { + "name": "James Halliday", + "email": "mail@substack.net", + "url": "http://substack.net" + }, + "license": "MIT" +} diff --git a/node_modules/minimist/readme.markdown b/node_modules/minimist/readme.markdown new file mode 100644 index 0000000..859d1ab --- /dev/null +++ b/node_modules/minimist/readme.markdown @@ -0,0 +1,98 @@ +# minimist + +parse argument options + +This module is the guts of optimist's argument parser without all the +fanciful decoration. + +# example + +``` js +var argv = require('minimist')(process.argv.slice(2)); +console.log(argv); +``` + +``` +$ node example/parse.js -a beep -b boop +{ _: [], a: 'beep', b: 'boop' } +``` + +``` +$ node example/parse.js -x 3 -y 4 -n5 -abc --beep=boop foo bar baz +{ _: [ 'foo', 'bar', 'baz' ], + x: 3, + y: 4, + n: 5, + a: true, + b: true, + c: true, + beep: 'boop' } +``` + +# security + +Previous versions had a prototype pollution bug that could cause privilege +escalation in some circumstances when handling untrusted user input. + +Please use version 1.2.6 or later: + +* https://security.snyk.io/vuln/SNYK-JS-MINIMIST-2429795 (version <=1.2.5) +* https://snyk.io/vuln/SNYK-JS-MINIMIST-559764 (version <=1.2.3) + +# methods + +``` js +var parseArgs = require('minimist') +``` + +## var argv = parseArgs(args, opts={}) + +Return an argument object `argv` populated with the array arguments from `args`. + +`argv._` contains all the arguments that didn't have an option associated with +them. + +Numeric-looking arguments will be returned as numbers unless `opts.string` or +`opts.boolean` is set for that argument name. + +Any arguments after `'--'` will not be parsed and will end up in `argv._`. + +options can be: + +* `opts.string` - a string or array of strings argument names to always treat as +strings +* `opts.boolean` - a boolean, string or array of strings to always treat as +booleans. if `true` will treat all double hyphenated arguments without equal signs +as boolean (e.g. affects `--foo`, not `-f` or `--foo=bar`) +* `opts.alias` - an object mapping string names to strings or arrays of string +argument names to use as aliases +* `opts.default` - an object mapping string argument names to default values +* `opts.stopEarly` - when true, populate `argv._` with everything after the +first non-option +* `opts['--']` - when true, populate `argv._` with everything before the `--` +and `argv['--']` with everything after the `--`. Here's an example: + + ``` + > require('./')('one two three -- four five --six'.split(' '), { '--': true }) + { _: [ 'one', 'two', 'three' ], + '--': [ 'four', 'five', '--six' ] } + ``` + + Note that with `opts['--']` set, parsing for arguments still stops after the + `--`. + +* `opts.unknown` - a function which is invoked with a command line parameter not +defined in the `opts` configuration object. If the function returns `false`, the +unknown option is not added to `argv`. + +# install + +With [npm](https://npmjs.org) do: + +``` +npm install minimist +``` + +# license + +MIT diff --git a/node_modules/minimist/test/all_bool.js b/node_modules/minimist/test/all_bool.js new file mode 100644 index 0000000..ac83548 --- /dev/null +++ b/node_modules/minimist/test/all_bool.js @@ -0,0 +1,32 @@ +var parse = require('../'); +var test = require('tape'); + +test('flag boolean true (default all --args to boolean)', function (t) { + var argv = parse(['moo', '--honk', 'cow'], { + boolean: true + }); + + t.deepEqual(argv, { + honk: true, + _: ['moo', 'cow'] + }); + + t.deepEqual(typeof argv.honk, 'boolean'); + t.end(); +}); + +test('flag boolean true only affects double hyphen arguments without equals signs', function (t) { + var argv = parse(['moo', '--honk', 'cow', '-p', '55', '--tacos=good'], { + boolean: true + }); + + t.deepEqual(argv, { + honk: true, + tacos: 'good', + p: 55, + _: ['moo', 'cow'] + }); + + t.deepEqual(typeof argv.honk, 'boolean'); + t.end(); +}); diff --git a/node_modules/minimist/test/bool.js b/node_modules/minimist/test/bool.js new file mode 100644 index 0000000..5f7dbde --- /dev/null +++ b/node_modules/minimist/test/bool.js @@ -0,0 +1,178 @@ +var parse = require('../'); +var test = require('tape'); + +test('flag boolean default false', function (t) { + var argv = parse(['moo'], { + boolean: ['t', 'verbose'], + default: { verbose: false, t: false } + }); + + t.deepEqual(argv, { + verbose: false, + t: false, + _: ['moo'] + }); + + t.deepEqual(typeof argv.verbose, 'boolean'); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); + +}); + +test('boolean groups', function (t) { + var argv = parse([ '-x', '-z', 'one', 'two', 'three' ], { + boolean: ['x','y','z'] + }); + + t.deepEqual(argv, { + x : true, + y : false, + z : true, + _ : [ 'one', 'two', 'three' ] + }); + + t.deepEqual(typeof argv.x, 'boolean'); + t.deepEqual(typeof argv.y, 'boolean'); + t.deepEqual(typeof argv.z, 'boolean'); + t.end(); +}); +test('boolean and alias with chainable api', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + herp: { alias: 'h', boolean: true } + }; + var aliasedArgv = parse(aliased, { + boolean: 'herp', + alias: { h: 'herp' } + }); + var propertyArgv = parse(regular, { + boolean: 'herp', + alias: { h: 'herp' } + }); + var expected = { + herp: true, + h: true, + '_': [ 'derp' ] + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +test('boolean and alias with options hash', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var opts = { + alias: { 'h': 'herp' }, + boolean: 'herp' + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + var expected = { + herp: true, + h: true, + '_': [ 'derp' ] + }; + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +test('boolean and alias array with options hash', function (t) { + var aliased = [ '-h', 'derp' ]; + var regular = [ '--herp', 'derp' ]; + var alt = [ '--harp', 'derp' ]; + var opts = { + alias: { 'h': ['herp', 'harp'] }, + boolean: 'h' + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + var altPropertyArgv = parse(alt, opts); + var expected = { + harp: true, + herp: true, + h: true, + '_': [ 'derp' ] + }; + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.same(altPropertyArgv, expected); + t.end(); +}); + +test('boolean and alias using explicit true', function (t) { + var aliased = [ '-h', 'true' ]; + var regular = [ '--herp', 'true' ]; + var opts = { + alias: { h: 'herp' }, + boolean: 'h' + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + var expected = { + herp: true, + h: true, + '_': [ ] + }; + + t.same(aliasedArgv, expected); + t.same(propertyArgv, expected); + t.end(); +}); + +// regression, see https://github.com/substack/node-optimist/issues/71 +test('boolean and --x=true', function(t) { + var parsed = parse(['--boool', '--other=true'], { + boolean: 'boool' + }); + + t.same(parsed.boool, true); + t.same(parsed.other, 'true'); + + parsed = parse(['--boool', '--other=false'], { + boolean: 'boool' + }); + + t.same(parsed.boool, true); + t.same(parsed.other, 'false'); + t.end(); +}); + +test('boolean --boool=true', function (t) { + var parsed = parse(['--boool=true'], { + default: { + boool: false + }, + boolean: ['boool'] + }); + + t.same(parsed.boool, true); + t.end(); +}); + +test('boolean --boool=false', function (t) { + var parsed = parse(['--boool=false'], { + default: { + boool: true + }, + boolean: ['boool'] + }); + + t.same(parsed.boool, false); + t.end(); +}); + +test('boolean using something similar to true', function (t) { + var opts = { boolean: 'h' }; + var result = parse(['-h', 'true.txt'], opts); + var expected = { + h: true, + '_': ['true.txt'] + }; + + t.same(result, expected); + t.end(); +}); \ No newline at end of file diff --git a/node_modules/minimist/test/dash.js b/node_modules/minimist/test/dash.js new file mode 100644 index 0000000..5a4fa5b --- /dev/null +++ b/node_modules/minimist/test/dash.js @@ -0,0 +1,31 @@ +var parse = require('../'); +var test = require('tape'); + +test('-', function (t) { + t.plan(5); + t.deepEqual(parse([ '-n', '-' ]), { n: '-', _: [] }); + t.deepEqual(parse([ '-' ]), { _: [ '-' ] }); + t.deepEqual(parse([ '-f-' ]), { f: '-', _: [] }); + t.deepEqual( + parse([ '-b', '-' ], { boolean: 'b' }), + { b: true, _: [ '-' ] } + ); + t.deepEqual( + parse([ '-s', '-' ], { string: 's' }), + { s: '-', _: [] } + ); +}); + +test('-a -- b', function (t) { + t.plan(3); + t.deepEqual(parse([ '-a', '--', 'b' ]), { a: true, _: [ 'b' ] }); + t.deepEqual(parse([ '--a', '--', 'b' ]), { a: true, _: [ 'b' ] }); + t.deepEqual(parse([ '--a', '--', 'b' ]), { a: true, _: [ 'b' ] }); +}); + +test('move arguments after the -- into their own `--` array', function(t) { + t.plan(1); + t.deepEqual( + parse([ '--name', 'John', 'before', '--', 'after' ], { '--': true }), + { name: 'John', _: [ 'before' ], '--': [ 'after' ] }); +}); diff --git a/node_modules/minimist/test/default_bool.js b/node_modules/minimist/test/default_bool.js new file mode 100644 index 0000000..780a311 --- /dev/null +++ b/node_modules/minimist/test/default_bool.js @@ -0,0 +1,35 @@ +var test = require('tape'); +var parse = require('../'); + +test('boolean default true', function (t) { + var argv = parse([], { + boolean: 'sometrue', + default: { sometrue: true } + }); + t.equal(argv.sometrue, true); + t.end(); +}); + +test('boolean default false', function (t) { + var argv = parse([], { + boolean: 'somefalse', + default: { somefalse: false } + }); + t.equal(argv.somefalse, false); + t.end(); +}); + +test('boolean default to null', function (t) { + var argv = parse([], { + boolean: 'maybe', + default: { maybe: null } + }); + t.equal(argv.maybe, null); + var argv = parse(['--maybe'], { + boolean: 'maybe', + default: { maybe: null } + }); + t.equal(argv.maybe, true); + t.end(); + +}) diff --git a/node_modules/minimist/test/dotted.js b/node_modules/minimist/test/dotted.js new file mode 100644 index 0000000..d8b3e85 --- /dev/null +++ b/node_modules/minimist/test/dotted.js @@ -0,0 +1,22 @@ +var parse = require('../'); +var test = require('tape'); + +test('dotted alias', function (t) { + var argv = parse(['--a.b', '22'], {default: {'a.b': 11}, alias: {'a.b': 'aa.bb'}}); + t.equal(argv.a.b, 22); + t.equal(argv.aa.bb, 22); + t.end(); +}); + +test('dotted default', function (t) { + var argv = parse('', {default: {'a.b': 11}, alias: {'a.b': 'aa.bb'}}); + t.equal(argv.a.b, 11); + t.equal(argv.aa.bb, 11); + t.end(); +}); + +test('dotted default with no alias', function (t) { + var argv = parse('', {default: {'a.b': 11}}); + t.equal(argv.a.b, 11); + t.end(); +}); diff --git a/node_modules/minimist/test/kv_short.js b/node_modules/minimist/test/kv_short.js new file mode 100644 index 0000000..f813b30 --- /dev/null +++ b/node_modules/minimist/test/kv_short.js @@ -0,0 +1,16 @@ +var parse = require('../'); +var test = require('tape'); + +test('short -k=v' , function (t) { + t.plan(1); + + var argv = parse([ '-b=123' ]); + t.deepEqual(argv, { b: 123, _: [] }); +}); + +test('multi short -k=v' , function (t) { + t.plan(1); + + var argv = parse([ '-a=whatever', '-b=robots' ]); + t.deepEqual(argv, { a: 'whatever', b: 'robots', _: [] }); +}); diff --git a/node_modules/minimist/test/long.js b/node_modules/minimist/test/long.js new file mode 100644 index 0000000..5d3a1e0 --- /dev/null +++ b/node_modules/minimist/test/long.js @@ -0,0 +1,31 @@ +var test = require('tape'); +var parse = require('../'); + +test('long opts', function (t) { + t.deepEqual( + parse([ '--bool' ]), + { bool : true, _ : [] }, + 'long boolean' + ); + t.deepEqual( + parse([ '--pow', 'xixxle' ]), + { pow : 'xixxle', _ : [] }, + 'long capture sp' + ); + t.deepEqual( + parse([ '--pow=xixxle' ]), + { pow : 'xixxle', _ : [] }, + 'long capture eq' + ); + t.deepEqual( + parse([ '--host', 'localhost', '--port', '555' ]), + { host : 'localhost', port : 555, _ : [] }, + 'long captures sp' + ); + t.deepEqual( + parse([ '--host=localhost', '--port=555' ]), + { host : 'localhost', port : 555, _ : [] }, + 'long captures eq' + ); + t.end(); +}); diff --git a/node_modules/minimist/test/num.js b/node_modules/minimist/test/num.js new file mode 100644 index 0000000..2cc77f4 --- /dev/null +++ b/node_modules/minimist/test/num.js @@ -0,0 +1,36 @@ +var parse = require('../'); +var test = require('tape'); + +test('nums', function (t) { + var argv = parse([ + '-x', '1234', + '-y', '5.67', + '-z', '1e7', + '-w', '10f', + '--hex', '0xdeadbeef', + '789' + ]); + t.deepEqual(argv, { + x : 1234, + y : 5.67, + z : 1e7, + w : '10f', + hex : 0xdeadbeef, + _ : [ 789 ] + }); + t.deepEqual(typeof argv.x, 'number'); + t.deepEqual(typeof argv.y, 'number'); + t.deepEqual(typeof argv.z, 'number'); + t.deepEqual(typeof argv.w, 'string'); + t.deepEqual(typeof argv.hex, 'number'); + t.deepEqual(typeof argv._[0], 'number'); + t.end(); +}); + +test('already a number', function (t) { + var argv = parse([ '-x', 1234, 789 ]); + t.deepEqual(argv, { x : 1234, _ : [ 789 ] }); + t.deepEqual(typeof argv.x, 'number'); + t.deepEqual(typeof argv._[0], 'number'); + t.end(); +}); diff --git a/node_modules/minimist/test/parse.js b/node_modules/minimist/test/parse.js new file mode 100644 index 0000000..7b4a2a1 --- /dev/null +++ b/node_modules/minimist/test/parse.js @@ -0,0 +1,197 @@ +var parse = require('../'); +var test = require('tape'); + +test('parse args', function (t) { + t.deepEqual( + parse([ '--no-moo' ]), + { moo : false, _ : [] }, + 'no' + ); + t.deepEqual( + parse([ '-v', 'a', '-v', 'b', '-v', 'c' ]), + { v : ['a','b','c'], _ : [] }, + 'multi' + ); + t.end(); +}); + +test('comprehensive', function (t) { + t.deepEqual( + parse([ + '--name=meowmers', 'bare', '-cats', 'woo', + '-h', 'awesome', '--multi=quux', + '--key', 'value', + '-b', '--bool', '--no-meep', '--multi=baz', + '--', '--not-a-flag', 'eek' + ]), + { + c : true, + a : true, + t : true, + s : 'woo', + h : 'awesome', + b : true, + bool : true, + key : 'value', + multi : [ 'quux', 'baz' ], + meep : false, + name : 'meowmers', + _ : [ 'bare', '--not-a-flag', 'eek' ] + } + ); + t.end(); +}); + +test('flag boolean', function (t) { + var argv = parse([ '-t', 'moo' ], { boolean: 't' }); + t.deepEqual(argv, { t : true, _ : [ 'moo' ] }); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); +}); + +test('flag boolean value', function (t) { + var argv = parse(['--verbose', 'false', 'moo', '-t', 'true'], { + boolean: [ 't', 'verbose' ], + default: { verbose: true } + }); + + t.deepEqual(argv, { + verbose: false, + t: true, + _: ['moo'] + }); + + t.deepEqual(typeof argv.verbose, 'boolean'); + t.deepEqual(typeof argv.t, 'boolean'); + t.end(); +}); + +test('newlines in params' , function (t) { + var args = parse([ '-s', "X\nX" ]) + t.deepEqual(args, { _ : [], s : "X\nX" }); + + // reproduce in bash: + // VALUE="new + // line" + // node program.js --s="$VALUE" + args = parse([ "--s=X\nX" ]) + t.deepEqual(args, { _ : [], s : "X\nX" }); + t.end(); +}); + +test('strings' , function (t) { + var s = parse([ '-s', '0001234' ], { string: 's' }).s; + t.equal(s, '0001234'); + t.equal(typeof s, 'string'); + + var x = parse([ '-x', '56' ], { string: 'x' }).x; + t.equal(x, '56'); + t.equal(typeof x, 'string'); + t.end(); +}); + +test('stringArgs', function (t) { + var s = parse([ ' ', ' ' ], { string: '_' })._; + t.same(s.length, 2); + t.same(typeof s[0], 'string'); + t.same(s[0], ' '); + t.same(typeof s[1], 'string'); + t.same(s[1], ' '); + t.end(); +}); + +test('empty strings', function(t) { + var s = parse([ '-s' ], { string: 's' }).s; + t.equal(s, ''); + t.equal(typeof s, 'string'); + + var str = parse([ '--str' ], { string: 'str' }).str; + t.equal(str, ''); + t.equal(typeof str, 'string'); + + var letters = parse([ '-art' ], { + string: [ 'a', 't' ] + }); + + t.equal(letters.a, ''); + t.equal(letters.r, true); + t.equal(letters.t, ''); + + t.end(); +}); + + +test('string and alias', function(t) { + var x = parse([ '--str', '000123' ], { + string: 's', + alias: { s: 'str' } + }); + + t.equal(x.str, '000123'); + t.equal(typeof x.str, 'string'); + t.equal(x.s, '000123'); + t.equal(typeof x.s, 'string'); + + var y = parse([ '-s', '000123' ], { + string: 'str', + alias: { str: 's' } + }); + + t.equal(y.str, '000123'); + t.equal(typeof y.str, 'string'); + t.equal(y.s, '000123'); + t.equal(typeof y.s, 'string'); + t.end(); +}); + +test('slashBreak', function (t) { + t.same( + parse([ '-I/foo/bar/baz' ]), + { I : '/foo/bar/baz', _ : [] } + ); + t.same( + parse([ '-xyz/foo/bar/baz' ]), + { x : true, y : true, z : '/foo/bar/baz', _ : [] } + ); + t.end(); +}); + +test('alias', function (t) { + var argv = parse([ '-f', '11', '--zoom', '55' ], { + alias: { z: 'zoom' } + }); + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.f, 11); + t.end(); +}); + +test('multiAlias', function (t) { + var argv = parse([ '-f', '11', '--zoom', '55' ], { + alias: { z: [ 'zm', 'zoom' ] } + }); + t.equal(argv.zoom, 55); + t.equal(argv.z, argv.zoom); + t.equal(argv.z, argv.zm); + t.equal(argv.f, 11); + t.end(); +}); + +test('nested dotted objects', function (t) { + var argv = parse([ + '--foo.bar', '3', '--foo.baz', '4', + '--foo.quux.quibble', '5', '--foo.quux.o_O', + '--beep.boop' + ]); + + t.same(argv.foo, { + bar : 3, + baz : 4, + quux : { + quibble : 5, + o_O : true + } + }); + t.same(argv.beep, { boop : true }); + t.end(); +}); diff --git a/node_modules/minimist/test/parse_modified.js b/node_modules/minimist/test/parse_modified.js new file mode 100644 index 0000000..ab620dc --- /dev/null +++ b/node_modules/minimist/test/parse_modified.js @@ -0,0 +1,9 @@ +var parse = require('../'); +var test = require('tape'); + +test('parse with modifier functions' , function (t) { + t.plan(1); + + var argv = parse([ '-b', '123' ], { boolean: 'b' }); + t.deepEqual(argv, { b: true, _: [123] }); +}); diff --git a/node_modules/minimist/test/proto.js b/node_modules/minimist/test/proto.js new file mode 100644 index 0000000..4ac62df --- /dev/null +++ b/node_modules/minimist/test/proto.js @@ -0,0 +1,60 @@ +var parse = require('../'); +var test = require('tape'); + +test('proto pollution', function (t) { + var argv = parse(['--__proto__.x','123']); + t.equal({}.x, undefined); + t.equal(argv.__proto__.x, undefined); + t.equal(argv.x, undefined); + t.end(); +}); + +test('proto pollution (array)', function (t) { + var argv = parse(['--x','4','--x','5','--x.__proto__.z','789']); + t.equal({}.z, undefined); + t.deepEqual(argv.x, [4,5]); + t.equal(argv.x.z, undefined); + t.equal(argv.x.__proto__.z, undefined); + t.end(); +}); + +test('proto pollution (number)', function (t) { + var argv = parse(['--x','5','--x.__proto__.z','100']); + t.equal({}.z, undefined); + t.equal((4).z, undefined); + t.equal(argv.x, 5); + t.equal(argv.x.z, undefined); + t.end(); +}); + +test('proto pollution (string)', function (t) { + var argv = parse(['--x','abc','--x.__proto__.z','def']); + t.equal({}.z, undefined); + t.equal('...'.z, undefined); + t.equal(argv.x, 'abc'); + t.equal(argv.x.z, undefined); + t.end(); +}); + +test('proto pollution (constructor)', function (t) { + var argv = parse(['--constructor.prototype.y','123']); + t.equal({}.y, undefined); + t.equal(argv.y, undefined); + t.end(); +}); + +test('proto pollution (constructor function)', function (t) { + var argv = parse(['--_.concat.constructor.prototype.y', '123']); + function fnToBeTested() {} + t.equal(fnToBeTested.y, undefined); + t.equal(argv.y, undefined); + t.end(); +}); + +// powered by snyk - https://github.com/backstage/backstage/issues/10343 +test('proto pollution (constructor function) snyk', function (t) { + var argv = parse('--_.constructor.constructor.prototype.foo bar'.split(' ')); + t.equal((function(){}).foo, undefined); + t.equal(argv.y, undefined); + t.end(); +}) diff --git a/node_modules/minimist/test/short.js b/node_modules/minimist/test/short.js new file mode 100644 index 0000000..d513a1c --- /dev/null +++ b/node_modules/minimist/test/short.js @@ -0,0 +1,67 @@ +var parse = require('../'); +var test = require('tape'); + +test('numeric short args', function (t) { + t.plan(2); + t.deepEqual(parse([ '-n123' ]), { n: 123, _: [] }); + t.deepEqual( + parse([ '-123', '456' ]), + { 1: true, 2: true, 3: 456, _: [] } + ); +}); + +test('short', function (t) { + t.deepEqual( + parse([ '-b' ]), + { b : true, _ : [] }, + 'short boolean' + ); + t.deepEqual( + parse([ 'foo', 'bar', 'baz' ]), + { _ : [ 'foo', 'bar', 'baz' ] }, + 'bare' + ); + t.deepEqual( + parse([ '-cats' ]), + { c : true, a : true, t : true, s : true, _ : [] }, + 'group' + ); + t.deepEqual( + parse([ '-cats', 'meow' ]), + { c : true, a : true, t : true, s : 'meow', _ : [] }, + 'short group next' + ); + t.deepEqual( + parse([ '-h', 'localhost' ]), + { h : 'localhost', _ : [] }, + 'short capture' + ); + t.deepEqual( + parse([ '-h', 'localhost', '-p', '555' ]), + { h : 'localhost', p : 555, _ : [] }, + 'short captures' + ); + t.end(); +}); + +test('mixed short bool and capture', function (t) { + t.same( + parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ] + } + ); + t.end(); +}); + +test('short and long', function (t) { + t.deepEqual( + parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), + { + f : true, p : 555, h : 'localhost', + _ : [ 'script.js' ] + } + ); + t.end(); +}); diff --git a/node_modules/minimist/test/stop_early.js b/node_modules/minimist/test/stop_early.js new file mode 100644 index 0000000..bdf9fbc --- /dev/null +++ b/node_modules/minimist/test/stop_early.js @@ -0,0 +1,15 @@ +var parse = require('../'); +var test = require('tape'); + +test('stops parsing on the first non-option when stopEarly is set', function (t) { + var argv = parse(['--aaa', 'bbb', 'ccc', '--ddd'], { + stopEarly: true + }); + + t.deepEqual(argv, { + aaa: 'bbb', + _: ['ccc', '--ddd'] + }); + + t.end(); +}); diff --git a/node_modules/minimist/test/unknown.js b/node_modules/minimist/test/unknown.js new file mode 100644 index 0000000..462a36b --- /dev/null +++ b/node_modules/minimist/test/unknown.js @@ -0,0 +1,102 @@ +var parse = require('../'); +var test = require('tape'); + +test('boolean and alias is not unknown', function (t) { + var unknown = []; + function unknownFn(arg) { + unknown.push(arg); + return false; + } + var aliased = [ '-h', 'true', '--derp', 'true' ]; + var regular = [ '--herp', 'true', '-d', 'true' ]; + var opts = { + alias: { h: 'herp' }, + boolean: 'h', + unknown: unknownFn + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + + t.same(unknown, ['--derp', '-d']); + t.end(); +}); + +test('flag boolean true any double hyphen argument is not unknown', function (t) { + var unknown = []; + function unknownFn(arg) { + unknown.push(arg); + return false; + } + var argv = parse(['--honk', '--tacos=good', 'cow', '-p', '55'], { + boolean: true, + unknown: unknownFn + }); + t.same(unknown, ['--tacos=good', 'cow', '-p']); + t.same(argv, { + honk: true, + _: [] + }); + t.end(); +}); + +test('string and alias is not unknown', function (t) { + var unknown = []; + function unknownFn(arg) { + unknown.push(arg); + return false; + } + var aliased = [ '-h', 'hello', '--derp', 'goodbye' ]; + var regular = [ '--herp', 'hello', '-d', 'moon' ]; + var opts = { + alias: { h: 'herp' }, + string: 'h', + unknown: unknownFn + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + + t.same(unknown, ['--derp', '-d']); + t.end(); +}); + +test('default and alias is not unknown', function (t) { + var unknown = []; + function unknownFn(arg) { + unknown.push(arg); + return false; + } + var aliased = [ '-h', 'hello' ]; + var regular = [ '--herp', 'hello' ]; + var opts = { + default: { 'h': 'bar' }, + alias: { 'h': 'herp' }, + unknown: unknownFn + }; + var aliasedArgv = parse(aliased, opts); + var propertyArgv = parse(regular, opts); + + t.same(unknown, []); + t.end(); + unknownFn(); // exercise fn for 100% coverage +}); + +test('value following -- is not unknown', function (t) { + var unknown = []; + function unknownFn(arg) { + unknown.push(arg); + return false; + } + var aliased = [ '--bad', '--', 'good', 'arg' ]; + var opts = { + '--': true, + unknown: unknownFn + }; + var argv = parse(aliased, opts); + + t.same(unknown, ['--bad']); + t.same(argv, { + '--': ['good', 'arg'], + '_': [] + }) + t.end(); +}); diff --git a/node_modules/minimist/test/whitespace.js b/node_modules/minimist/test/whitespace.js new file mode 100644 index 0000000..8a52a58 --- /dev/null +++ b/node_modules/minimist/test/whitespace.js @@ -0,0 +1,8 @@ +var parse = require('../'); +var test = require('tape'); + +test('whitespace should be whitespace' , function (t) { + t.plan(1); + var x = parse([ '-x', '\t' ]).x; + t.equal(x, '\t'); +}); diff --git a/node_modules/nanoid/.DS_Store b/node_modules/nanoid/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..43349d322151a4d4b8b7d33a0fe134bba2dfce9f GIT binary patch literal 6148 zcmeHKu};H44E50`_KD8Ua&OJojrg*I)To>wSMI>)p9_wdU{m`*mM% z-70^B0rYH^@W`T$%78MU43rG;`4B-FV~2%BIXW=N6#y8(EP`k0vA~E8z}R775f+HC zp+FmI+!e#vaM&Z~7dtF0+Hf+G8SA*r#@$eiWQRQxcQUa>9hCuPz-ORgUt8S&uXf-6 z{UCi)29$w+#efNtZqmV)TyL#yj(cqcy@Rr_Utv)~Ft~Os58R4Rp(2=z_yHI@EG)tT P(H{Y!K?h~vM;Z78WA>X9 literal 0 HcmV?d00001 diff --git a/node_modules/nanoid/LICENSE b/node_modules/nanoid/LICENSE new file mode 100644 index 0000000..37f56aa --- /dev/null +++ b/node_modules/nanoid/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright 2017 Andrey Sitnik + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/nanoid/README.md b/node_modules/nanoid/README.md new file mode 100644 index 0000000..35abb57 --- /dev/null +++ b/node_modules/nanoid/README.md @@ -0,0 +1,39 @@ +# Nano ID + +Nano ID logo by Anton Lovchikov + +**English** | [Русский](./README.ru.md) | [简体中文](./README.zh-CN.md) | [Bahasa Indonesia](./README.id-ID.md) + +A tiny, secure, URL-friendly, unique string ID generator for JavaScript. + +> “An amazing level of senseless perfectionism, +> which is simply impossible not to respect.” + +* **Small.** 130 bytes (minified and gzipped). No dependencies. + [Size Limit] controls the size. +* **Fast.** It is 2 times faster than UUID. +* **Safe.** It uses hardware random generator. Can be used in clusters. +* **Short IDs.** It uses a larger alphabet than UUID (`A-Za-z0-9_-`). + So ID size was reduced from 36 to 21 symbols. +* **Portable.** Nano ID was ported + to [20 programming languages](#other-programming-languages). + +```js +import { nanoid } from 'nanoid' +model.id = nanoid() //=> "V1StGXR8_Z5jdHi6B-myT" +``` + +Supports modern browsers, IE [with Babel], Node.js and React Native. + +[online tool]: https://gitpod.io/#https://github.com/ai/nanoid/ +[with Babel]: https://developer.epages.com/blog/coding/how-to-transpile-node-modules-with-babel-and-webpack-in-a-monorepo/ +[Size Limit]: https://github.com/ai/size-limit + + + Sponsored by Evil Martians + + +## Docs +Read full docs **[here](https://github.com/ai/nanoid#readme)**. diff --git a/node_modules/nanoid/async/index.browser.cjs b/node_modules/nanoid/async/index.browser.cjs new file mode 100644 index 0000000..7e5bba8 --- /dev/null +++ b/node_modules/nanoid/async/index.browser.cjs @@ -0,0 +1,34 @@ +let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes)) +let customAlphabet = (alphabet, defaultSize = 21) => { + let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1 + let step = -~((1.6 * mask * defaultSize) / alphabet.length) + return async (size = defaultSize) => { + let id = '' + while (true) { + let bytes = crypto.getRandomValues(new Uint8Array(step)) + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + } + } +} +let nanoid = async (size = 21) => { + let id = '' + let bytes = crypto.getRandomValues(new Uint8Array(size)) + while (size--) { + let byte = bytes[size] & 63 + if (byte < 36) { + id += byte.toString(36) + } else if (byte < 62) { + id += (byte - 26).toString(36).toUpperCase() + } else if (byte < 63) { + id += '_' + } else { + id += '-' + } + } + return id +} +module.exports = { nanoid, customAlphabet, random } diff --git a/node_modules/nanoid/async/index.browser.js b/node_modules/nanoid/async/index.browser.js new file mode 100644 index 0000000..5ece04d --- /dev/null +++ b/node_modules/nanoid/async/index.browser.js @@ -0,0 +1,34 @@ +let random = async bytes => crypto.getRandomValues(new Uint8Array(bytes)) +let customAlphabet = (alphabet, defaultSize = 21) => { + let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1 + let step = -~((1.6 * mask * defaultSize) / alphabet.length) + return async (size = defaultSize) => { + let id = '' + while (true) { + let bytes = crypto.getRandomValues(new Uint8Array(step)) + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + } + } +} +let nanoid = async (size = 21) => { + let id = '' + let bytes = crypto.getRandomValues(new Uint8Array(size)) + while (size--) { + let byte = bytes[size] & 63 + if (byte < 36) { + id += byte.toString(36) + } else if (byte < 62) { + id += (byte - 26).toString(36).toUpperCase() + } else if (byte < 63) { + id += '_' + } else { + id += '-' + } + } + return id +} +export { nanoid, customAlphabet, random } diff --git a/node_modules/nanoid/async/index.cjs b/node_modules/nanoid/async/index.cjs new file mode 100644 index 0000000..50db105 --- /dev/null +++ b/node_modules/nanoid/async/index.cjs @@ -0,0 +1,35 @@ +let crypto = require('crypto') +let { urlAlphabet } = require('../url-alphabet/index.cjs') +let random = bytes => + new Promise((resolve, reject) => { + crypto.randomFill(Buffer.allocUnsafe(bytes), (err, buf) => { + if (err) { + reject(err) + } else { + resolve(buf) + } + }) + }) +let customAlphabet = (alphabet, defaultSize = 21) => { + let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1 + let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length) + let tick = (id, size = defaultSize) => + random(step).then(bytes => { + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + return tick(id, size) + }) + return size => tick('', size) +} +let nanoid = (size = 21) => + random(size).then(bytes => { + let id = '' + while (size--) { + id += urlAlphabet[bytes[size] & 63] + } + return id + }) +module.exports = { nanoid, customAlphabet, random } diff --git a/node_modules/nanoid/async/index.d.ts b/node_modules/nanoid/async/index.d.ts new file mode 100644 index 0000000..9e91965 --- /dev/null +++ b/node_modules/nanoid/async/index.d.ts @@ -0,0 +1,56 @@ +/** + * Generate secure URL-friendly unique ID. The non-blocking version. + * + * By default, the ID will have 21 symbols to have a collision probability + * similar to UUID v4. + * + * ```js + * import { nanoid } from 'nanoid/async' + * nanoid().then(id => { + * model.id = id + * }) + * ``` + * + * @param size Size of the ID. The default size is 21. + * @returns A promise with a random string. + */ +export function nanoid(size?: number): Promise + +/** + * A low-level function. + * Generate secure unique ID with custom alphabet. The non-blocking version. + * + * Alphabet must contain 256 symbols or less. Otherwise, the generator + * will not be secure. + * + * @param alphabet Alphabet used to generate the ID. + * @param defaultSize Size of the ID. The default size is 21. + * @returns A function that returns a promise with a random string. + * + * ```js + * import { customAlphabet } from 'nanoid/async' + * const nanoid = customAlphabet('0123456789абвгдеё', 5) + * nanoid().then(id => { + * model.id = id //=> "8ё56а" + * }) + * ``` + */ +export function customAlphabet( + alphabet: string, + defaultSize?: number +): (size?: number) => Promise + +/** + * Generate an array of random bytes collected from hardware noise. + * + * ```js + * import { random } from 'nanoid/async' + * random(5).then(bytes => { + * bytes //=> [10, 67, 212, 67, 89] + * }) + * ``` + * + * @param bytes Size of the array. + * @returns A promise with a random bytes array. + */ +export function random(bytes: number): Promise diff --git a/node_modules/nanoid/async/index.js b/node_modules/nanoid/async/index.js new file mode 100644 index 0000000..803fad6 --- /dev/null +++ b/node_modules/nanoid/async/index.js @@ -0,0 +1,35 @@ +import crypto from 'crypto' +import { urlAlphabet } from '../url-alphabet/index.js' +let random = bytes => + new Promise((resolve, reject) => { + crypto.randomFill(Buffer.allocUnsafe(bytes), (err, buf) => { + if (err) { + reject(err) + } else { + resolve(buf) + } + }) + }) +let customAlphabet = (alphabet, defaultSize = 21) => { + let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1 + let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length) + let tick = (id, size = defaultSize) => + random(step).then(bytes => { + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + return tick(id, size) + }) + return size => tick('', size) +} +let nanoid = (size = 21) => + random(size).then(bytes => { + let id = '' + while (size--) { + id += urlAlphabet[bytes[size] & 63] + } + return id + }) +export { nanoid, customAlphabet, random } diff --git a/node_modules/nanoid/async/index.native.js b/node_modules/nanoid/async/index.native.js new file mode 100644 index 0000000..5cb3d57 --- /dev/null +++ b/node_modules/nanoid/async/index.native.js @@ -0,0 +1,26 @@ +import { getRandomBytesAsync } from 'expo-random' +import { urlAlphabet } from '../url-alphabet/index.js' +let random = getRandomBytesAsync +let customAlphabet = (alphabet, defaultSize = 21) => { + let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1 + let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length) + let tick = (id, size = defaultSize) => + random(step).then(bytes => { + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + return tick(id, size) + }) + return size => tick('', size) +} +let nanoid = (size = 21) => + random(size).then(bytes => { + let id = '' + while (size--) { + id += urlAlphabet[bytes[size] & 63] + } + return id + }) +export { nanoid, customAlphabet, random } diff --git a/node_modules/nanoid/async/package.json b/node_modules/nanoid/async/package.json new file mode 100644 index 0000000..578cdb4 --- /dev/null +++ b/node_modules/nanoid/async/package.json @@ -0,0 +1,12 @@ +{ + "type": "module", + "main": "index.cjs", + "module": "index.js", + "react-native": { + "./index.js": "./index.native.js" + }, + "browser": { + "./index.js": "./index.browser.js", + "./index.cjs": "./index.browser.cjs" + } +} \ No newline at end of file diff --git a/node_modules/nanoid/bin/nanoid.cjs b/node_modules/nanoid/bin/nanoid.cjs new file mode 100755 index 0000000..c76db0f --- /dev/null +++ b/node_modules/nanoid/bin/nanoid.cjs @@ -0,0 +1,55 @@ +#!/usr/bin/env node + +let { nanoid, customAlphabet } = require('..') + +function print(msg) { + process.stdout.write(msg + '\n') +} + +function error(msg) { + process.stderr.write(msg + '\n') + process.exit(1) +} + +if (process.argv.includes('--help') || process.argv.includes('-h')) { + print(` + Usage + $ nanoid [options] + + Options + -s, --size Generated ID size + -a, --alphabet Alphabet to use + -h, --help Show this help + + Examples + $ nanoid --s 15 + S9sBF77U6sDB8Yg + + $ nanoid --size 10 --alphabet abc + bcabababca`) + process.exit() +} + +let alphabet, size +for (let i = 2; i < process.argv.length; i++) { + let arg = process.argv[i] + if (arg === '--size' || arg === '-s') { + size = Number(process.argv[i + 1]) + i += 1 + if (Number.isNaN(size) || size <= 0) { + error('Size must be positive integer') + } + } else if (arg === '--alphabet' || arg === '-a') { + alphabet = process.argv[i + 1] + i += 1 + } else { + error('Unknown argument ' + arg) + } +} + +if (alphabet) { + let customNanoid = customAlphabet(alphabet, size) + print(customNanoid()) +} else { + print(nanoid(size)) +} diff --git a/node_modules/nanoid/index.browser.cjs b/node_modules/nanoid/index.browser.cjs new file mode 100644 index 0000000..f800d6f --- /dev/null +++ b/node_modules/nanoid/index.browser.cjs @@ -0,0 +1,34 @@ +let { urlAlphabet } = require('./url-alphabet/index.cjs') +let random = bytes => crypto.getRandomValues(new Uint8Array(bytes)) +let customRandom = (alphabet, defaultSize, getRandom) => { + let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1 + let step = -~((1.6 * mask * defaultSize) / alphabet.length) + return (size = defaultSize) => { + let id = '' + while (true) { + let bytes = getRandom(step) + let j = step + while (j--) { + id += alphabet[bytes[j] & mask] || '' + if (id.length === size) return id + } + } + } +} +let customAlphabet = (alphabet, size = 21) => + customRandom(alphabet, size, random) +let nanoid = (size = 21) => + crypto.getRandomValues(new Uint8Array(size)).reduce((id, byte) => { + byte &= 63 + if (byte < 36) { + id += byte.toString(36) + } else if (byte < 62) { + id += (byte - 26).toString(36).toUpperCase() + } else if (byte > 62) { + id += '-' + } else { + id += '_' + } + return id + }, '') +module.exports = { nanoid, customAlphabet, customRandom, urlAlphabet, random } diff --git a/node_modules/nanoid/index.browser.js b/node_modules/nanoid/index.browser.js new file mode 100644 index 0000000..8b3139b --- /dev/null +++ b/node_modules/nanoid/index.browser.js @@ -0,0 +1,34 @@ +import { urlAlphabet } from './url-alphabet/index.js' +let random = bytes => crypto.getRandomValues(new Uint8Array(bytes)) +let customRandom = (alphabet, defaultSize, getRandom) => { + let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1 + let step = -~((1.6 * mask * defaultSize) / alphabet.length) + return (size = defaultSize) => { + let id = '' + while (true) { + let bytes = getRandom(step) + let j = step + while (j--) { + id += alphabet[bytes[j] & mask] || '' + if (id.length === size) return id + } + } + } +} +let customAlphabet = (alphabet, size = 21) => + customRandom(alphabet, size, random) +let nanoid = (size = 21) => + crypto.getRandomValues(new Uint8Array(size)).reduce((id, byte) => { + byte &= 63 + if (byte < 36) { + id += byte.toString(36) + } else if (byte < 62) { + id += (byte - 26).toString(36).toUpperCase() + } else if (byte > 62) { + id += '-' + } else { + id += '_' + } + return id + }, '') +export { nanoid, customAlphabet, customRandom, urlAlphabet, random } diff --git a/node_modules/nanoid/index.cjs b/node_modules/nanoid/index.cjs new file mode 100644 index 0000000..0fa85e9 --- /dev/null +++ b/node_modules/nanoid/index.cjs @@ -0,0 +1,45 @@ +let crypto = require('crypto') +let { urlAlphabet } = require('./url-alphabet/index.cjs') +const POOL_SIZE_MULTIPLIER = 128 +let pool, poolOffset +let fillPool = bytes => { + if (!pool || pool.length < bytes) { + pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER) + crypto.randomFillSync(pool) + poolOffset = 0 + } else if (poolOffset + bytes > pool.length) { + crypto.randomFillSync(pool) + poolOffset = 0 + } + poolOffset += bytes +} +let random = bytes => { + fillPool((bytes -= 0)) + return pool.subarray(poolOffset - bytes, poolOffset) +} +let customRandom = (alphabet, defaultSize, getRandom) => { + let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1 + let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length) + return (size = defaultSize) => { + let id = '' + while (true) { + let bytes = getRandom(step) + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + } + } +} +let customAlphabet = (alphabet, size = 21) => + customRandom(alphabet, size, random) +let nanoid = (size = 21) => { + fillPool((size -= 0)) + let id = '' + for (let i = poolOffset - size; i < poolOffset; i++) { + id += urlAlphabet[pool[i] & 63] + } + return id +} +module.exports = { nanoid, customAlphabet, customRandom, urlAlphabet, random } diff --git a/node_modules/nanoid/index.d.cts b/node_modules/nanoid/index.d.cts new file mode 100644 index 0000000..3e111a3 --- /dev/null +++ b/node_modules/nanoid/index.d.cts @@ -0,0 +1,91 @@ +/** + * Generate secure URL-friendly unique ID. + * + * By default, the ID will have 21 symbols to have a collision probability + * similar to UUID v4. + * + * ```js + * import { nanoid } from 'nanoid' + * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL" + * ``` + * + * @param size Size of the ID. The default size is 21. + * @returns A random string. + */ +export function nanoid(size?: number): string + +/** + * Generate secure unique ID with custom alphabet. + * + * Alphabet must contain 256 symbols or less. Otherwise, the generator + * will not be secure. + * + * @param alphabet Alphabet used to generate the ID. + * @param defaultSize Size of the ID. The default size is 21. + * @returns A random string generator. + * + * ```js + * const { customAlphabet } = require('nanoid') + * const nanoid = customAlphabet('0123456789абвгдеё', 5) + * nanoid() //=> "8ё56а" + * ``` + */ +export function customAlphabet( + alphabet: string, + defaultSize?: number +): (size?: number) => string + +/** + * Generate unique ID with custom random generator and alphabet. + * + * Alphabet must contain 256 symbols or less. Otherwise, the generator + * will not be secure. + * + * ```js + * import { customRandom } from 'nanoid/format' + * + * const nanoid = customRandom('abcdef', 5, size => { + * const random = [] + * for (let i = 0; i < size; i++) { + * random.push(randomByte()) + * } + * return random + * }) + * + * nanoid() //=> "fbaef" + * ``` + * + * @param alphabet Alphabet used to generate a random string. + * @param size Size of the random string. + * @param random A random bytes generator. + * @returns A random string generator. + */ +export function customRandom( + alphabet: string, + size: number, + random: (bytes: number) => Uint8Array +): () => string + +/** + * URL safe symbols. + * + * ```js + * import { urlAlphabet } from 'nanoid' + * const nanoid = customAlphabet(urlAlphabet, 10) + * nanoid() //=> "Uakgb_J5m9" + * ``` + */ +export const urlAlphabet: string + +/** + * Generate an array of random bytes collected from hardware noise. + * + * ```js + * import { customRandom, random } from 'nanoid' + * const nanoid = customRandom("abcdef", 5, random) + * ``` + * + * @param bytes Size of the array. + * @returns An array of random bytes. + */ +export function random(bytes: number): Uint8Array diff --git a/node_modules/nanoid/index.d.ts b/node_modules/nanoid/index.d.ts new file mode 100644 index 0000000..3e111a3 --- /dev/null +++ b/node_modules/nanoid/index.d.ts @@ -0,0 +1,91 @@ +/** + * Generate secure URL-friendly unique ID. + * + * By default, the ID will have 21 symbols to have a collision probability + * similar to UUID v4. + * + * ```js + * import { nanoid } from 'nanoid' + * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL" + * ``` + * + * @param size Size of the ID. The default size is 21. + * @returns A random string. + */ +export function nanoid(size?: number): string + +/** + * Generate secure unique ID with custom alphabet. + * + * Alphabet must contain 256 symbols or less. Otherwise, the generator + * will not be secure. + * + * @param alphabet Alphabet used to generate the ID. + * @param defaultSize Size of the ID. The default size is 21. + * @returns A random string generator. + * + * ```js + * const { customAlphabet } = require('nanoid') + * const nanoid = customAlphabet('0123456789абвгдеё', 5) + * nanoid() //=> "8ё56а" + * ``` + */ +export function customAlphabet( + alphabet: string, + defaultSize?: number +): (size?: number) => string + +/** + * Generate unique ID with custom random generator and alphabet. + * + * Alphabet must contain 256 symbols or less. Otherwise, the generator + * will not be secure. + * + * ```js + * import { customRandom } from 'nanoid/format' + * + * const nanoid = customRandom('abcdef', 5, size => { + * const random = [] + * for (let i = 0; i < size; i++) { + * random.push(randomByte()) + * } + * return random + * }) + * + * nanoid() //=> "fbaef" + * ``` + * + * @param alphabet Alphabet used to generate a random string. + * @param size Size of the random string. + * @param random A random bytes generator. + * @returns A random string generator. + */ +export function customRandom( + alphabet: string, + size: number, + random: (bytes: number) => Uint8Array +): () => string + +/** + * URL safe symbols. + * + * ```js + * import { urlAlphabet } from 'nanoid' + * const nanoid = customAlphabet(urlAlphabet, 10) + * nanoid() //=> "Uakgb_J5m9" + * ``` + */ +export const urlAlphabet: string + +/** + * Generate an array of random bytes collected from hardware noise. + * + * ```js + * import { customRandom, random } from 'nanoid' + * const nanoid = customRandom("abcdef", 5, random) + * ``` + * + * @param bytes Size of the array. + * @returns An array of random bytes. + */ +export function random(bytes: number): Uint8Array diff --git a/node_modules/nanoid/index.js b/node_modules/nanoid/index.js new file mode 100644 index 0000000..21e155f --- /dev/null +++ b/node_modules/nanoid/index.js @@ -0,0 +1,45 @@ +import crypto from 'crypto' +import { urlAlphabet } from './url-alphabet/index.js' +const POOL_SIZE_MULTIPLIER = 128 +let pool, poolOffset +let fillPool = bytes => { + if (!pool || pool.length < bytes) { + pool = Buffer.allocUnsafe(bytes * POOL_SIZE_MULTIPLIER) + crypto.randomFillSync(pool) + poolOffset = 0 + } else if (poolOffset + bytes > pool.length) { + crypto.randomFillSync(pool) + poolOffset = 0 + } + poolOffset += bytes +} +let random = bytes => { + fillPool((bytes -= 0)) + return pool.subarray(poolOffset - bytes, poolOffset) +} +let customRandom = (alphabet, defaultSize, getRandom) => { + let mask = (2 << (31 - Math.clz32((alphabet.length - 1) | 1))) - 1 + let step = Math.ceil((1.6 * mask * defaultSize) / alphabet.length) + return (size = defaultSize) => { + let id = '' + while (true) { + let bytes = getRandom(step) + let i = step + while (i--) { + id += alphabet[bytes[i] & mask] || '' + if (id.length === size) return id + } + } + } +} +let customAlphabet = (alphabet, size = 21) => + customRandom(alphabet, size, random) +let nanoid = (size = 21) => { + fillPool((size -= 0)) + let id = '' + for (let i = poolOffset - size; i < poolOffset; i++) { + id += urlAlphabet[pool[i] & 63] + } + return id +} +export { nanoid, customAlphabet, customRandom, urlAlphabet, random } diff --git a/node_modules/nanoid/nanoid.js b/node_modules/nanoid/nanoid.js new file mode 100644 index 0000000..ec242ea --- /dev/null +++ b/node_modules/nanoid/nanoid.js @@ -0,0 +1 @@ +export let nanoid=(t=21)=>crypto.getRandomValues(new Uint8Array(t)).reduce(((t,e)=>t+=(e&=63)<36?e.toString(36):e<62?(e-26).toString(36).toUpperCase():e<63?"_":"-"),""); \ No newline at end of file diff --git a/node_modules/nanoid/non-secure/index.cjs b/node_modules/nanoid/non-secure/index.cjs new file mode 100644 index 0000000..09d57cd --- /dev/null +++ b/node_modules/nanoid/non-secure/index.cjs @@ -0,0 +1,21 @@ +let urlAlphabet = + 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict' +let customAlphabet = (alphabet, defaultSize = 21) => { + return (size = defaultSize) => { + let id = '' + let i = size + while (i--) { + id += alphabet[(Math.random() * alphabet.length) | 0] + } + return id + } +} +let nanoid = (size = 21) => { + let id = '' + let i = size + while (i--) { + id += urlAlphabet[(Math.random() * 64) | 0] + } + return id +} +module.exports = { nanoid, customAlphabet } diff --git a/node_modules/nanoid/non-secure/index.d.ts b/node_modules/nanoid/non-secure/index.d.ts new file mode 100644 index 0000000..4965322 --- /dev/null +++ b/node_modules/nanoid/non-secure/index.d.ts @@ -0,0 +1,33 @@ +/** + * Generate URL-friendly unique ID. This method uses the non-secure + * predictable random generator with bigger collision probability. + * + * ```js + * import { nanoid } from 'nanoid/non-secure' + * model.id = nanoid() //=> "Uakgb_J5m9g-0JDMbcJqL" + * ``` + * + * @param size Size of the ID. The default size is 21. + * @returns A random string. + */ +export function nanoid(size?: number): string + +/** + * Generate a unique ID based on a custom alphabet. + * This method uses the non-secure predictable random generator + * with bigger collision probability. + * + * @param alphabet Alphabet used to generate the ID. + * @param defaultSize Size of the ID. The default size is 21. + * @returns A random string generator. + * + * ```js + * import { customAlphabet } from 'nanoid/non-secure' + * const nanoid = customAlphabet('0123456789абвгдеё', 5) + * model.id = //=> "8ё56а" + * ``` + */ +export function customAlphabet( + alphabet: string, + defaultSize?: number +): (size?: number) => string diff --git a/node_modules/nanoid/non-secure/index.js b/node_modules/nanoid/non-secure/index.js new file mode 100644 index 0000000..e7e19ad --- /dev/null +++ b/node_modules/nanoid/non-secure/index.js @@ -0,0 +1,21 @@ +let urlAlphabet = + 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict' +let customAlphabet = (alphabet, defaultSize = 21) => { + return (size = defaultSize) => { + let id = '' + let i = size + while (i--) { + id += alphabet[(Math.random() * alphabet.length) | 0] + } + return id + } +} +let nanoid = (size = 21) => { + let id = '' + let i = size + while (i--) { + id += urlAlphabet[(Math.random() * 64) | 0] + } + return id +} +export { nanoid, customAlphabet } diff --git a/node_modules/nanoid/non-secure/package.json b/node_modules/nanoid/non-secure/package.json new file mode 100644 index 0000000..9930d6a --- /dev/null +++ b/node_modules/nanoid/non-secure/package.json @@ -0,0 +1,6 @@ +{ + "type": "module", + "main": "index.cjs", + "module": "index.js", + "react-native": "index.js" +} \ No newline at end of file diff --git a/node_modules/nanoid/package.json b/node_modules/nanoid/package.json new file mode 100644 index 0000000..4f24d96 --- /dev/null +++ b/node_modules/nanoid/package.json @@ -0,0 +1,88 @@ +{ + "name": "nanoid", + "version": "3.3.7", + "description": "A tiny (116 bytes), secure URL-friendly unique string ID generator", + "keywords": [ + "uuid", + "random", + "id", + "url" + ], + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + }, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "author": "Andrey Sitnik ", + "license": "MIT", + "repository": "ai/nanoid", + "browser": { + "./index.js": "./index.browser.js", + "./async/index.js": "./async/index.browser.js", + "./async/index.cjs": "./async/index.browser.cjs", + "./index.cjs": "./index.browser.cjs" + }, + "react-native": "index.js", + "bin": "./bin/nanoid.cjs", + "sideEffects": false, + "types": "./index.d.ts", + "type": "module", + "main": "index.cjs", + "module": "index.js", + "exports": { + ".": { + "browser": "./index.browser.js", + "require": { + "types": "./index.d.cts", + "default": "./index.cjs" + }, + "import": { + "types": "./index.d.ts", + "default": "./index.js" + }, + "default": "./index.js" + }, + "./package.json": "./package.json", + "./async/package.json": "./async/package.json", + "./async": { + "browser": "./async/index.browser.js", + "require": { + "types": "./index.d.cts", + "default": "./async/index.cjs" + }, + "import": { + "types": "./index.d.ts", + "default": "./async/index.js" + }, + "default": "./async/index.js" + }, + "./non-secure/package.json": "./non-secure/package.json", + "./non-secure": { + "require": { + "types": "./index.d.cts", + "default": "./non-secure/index.cjs" + }, + "import": { + "types": "./index.d.ts", + "default": "./non-secure/index.js" + }, + "default": "./non-secure/index.js" + }, + "./url-alphabet/package.json": "./url-alphabet/package.json", + "./url-alphabet": { + "require": { + "types": "./index.d.cts", + "default": "./url-alphabet/index.cjs" + }, + "import": { + "types": "./index.d.ts", + "default": "./url-alphabet/index.js" + }, + "default": "./url-alphabet/index.js" + } + } +} \ No newline at end of file diff --git a/node_modules/nanoid/url-alphabet/index.cjs b/node_modules/nanoid/url-alphabet/index.cjs new file mode 100644 index 0000000..757b709 --- /dev/null +++ b/node_modules/nanoid/url-alphabet/index.cjs @@ -0,0 +1,3 @@ +let urlAlphabet = + 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict' +module.exports = { urlAlphabet } diff --git a/node_modules/nanoid/url-alphabet/index.js b/node_modules/nanoid/url-alphabet/index.js new file mode 100644 index 0000000..c2782e5 --- /dev/null +++ b/node_modules/nanoid/url-alphabet/index.js @@ -0,0 +1,3 @@ +let urlAlphabet = + 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict' +export { urlAlphabet } diff --git a/node_modules/nanoid/url-alphabet/package.json b/node_modules/nanoid/url-alphabet/package.json new file mode 100644 index 0000000..9930d6a --- /dev/null +++ b/node_modules/nanoid/url-alphabet/package.json @@ -0,0 +1,6 @@ +{ + "type": "module", + "main": "index.cjs", + "module": "index.js", + "react-native": "index.js" +} \ No newline at end of file diff --git a/node_modules/normalize-path/LICENSE b/node_modules/normalize-path/LICENSE new file mode 100644 index 0000000..d32ab44 --- /dev/null +++ b/node_modules/normalize-path/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2014-2018, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/normalize-path/README.md b/node_modules/normalize-path/README.md new file mode 100644 index 0000000..726d4d6 --- /dev/null +++ b/node_modules/normalize-path/README.md @@ -0,0 +1,127 @@ +# normalize-path [![NPM version](https://img.shields.io/npm/v/normalize-path.svg?style=flat)](https://www.npmjs.com/package/normalize-path) [![NPM monthly downloads](https://img.shields.io/npm/dm/normalize-path.svg?style=flat)](https://npmjs.org/package/normalize-path) [![NPM total downloads](https://img.shields.io/npm/dt/normalize-path.svg?style=flat)](https://npmjs.org/package/normalize-path) [![Linux Build Status](https://img.shields.io/travis/jonschlinkert/normalize-path.svg?style=flat&label=Travis)](https://travis-ci.org/jonschlinkert/normalize-path) + +> Normalize slashes in a file path to be posix/unix-like forward slashes. Also condenses repeat slashes to a single slash and removes and trailing slashes, unless disabled. + +Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support. + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +$ npm install --save normalize-path +``` + +## Usage + +```js +const normalize = require('normalize-path'); + +console.log(normalize('\\foo\\bar\\baz\\')); +//=> '/foo/bar/baz' +``` + +**win32 namespaces** + +```js +console.log(normalize('\\\\?\\UNC\\Server01\\user\\docs\\Letter.txt')); +//=> '//?/UNC/Server01/user/docs/Letter.txt' + +console.log(normalize('\\\\.\\CdRomX')); +//=> '//./CdRomX' +``` + +**Consecutive slashes** + +Condenses multiple consecutive forward slashes (except for leading slashes in win32 namespaces) to a single slash. + +```js +console.log(normalize('.//foo//bar///////baz/')); +//=> './foo/bar/baz' +``` + +### Trailing slashes + +By default trailing slashes are removed. Pass `false` as the last argument to disable this behavior and _**keep** trailing slashes_: + +```js +console.log(normalize('foo\\bar\\baz\\', false)); //=> 'foo/bar/baz/' +console.log(normalize('./foo/bar/baz/', false)); //=> './foo/bar/baz/' +``` + +## Release history + +### v3.0 + +No breaking changes in this release. + +* a check was added to ensure that [win32 namespaces](https://msdn.microsoft.com/library/windows/desktop/aa365247(v=vs.85).aspx#namespaces) are handled properly by win32 `path.parse()` after a path has been normalized by this library. +* a minor optimization was made to simplify how the trailing separator was handled + +## About + +
      +Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +
      + +
      +Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +$ npm install && npm test +``` + +
      + +
      +Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +$ npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
      + +### Related projects + +Other useful path-related libraries: + +* [contains-path](https://www.npmjs.com/package/contains-path): Return true if a file path contains the given path. | [homepage](https://github.com/jonschlinkert/contains-path "Return true if a file path contains the given path.") +* [is-absolute](https://www.npmjs.com/package/is-absolute): Returns true if a file path is absolute. Does not rely on the path module… [more](https://github.com/jonschlinkert/is-absolute) | [homepage](https://github.com/jonschlinkert/is-absolute "Returns true if a file path is absolute. Does not rely on the path module and can be used as a polyfill for node.js native `path.isAbolute`.") +* [is-relative](https://www.npmjs.com/package/is-relative): Returns `true` if the path appears to be relative. | [homepage](https://github.com/jonschlinkert/is-relative "Returns `true` if the path appears to be relative.") +* [parse-filepath](https://www.npmjs.com/package/parse-filepath): Pollyfill for node.js `path.parse`, parses a filepath into an object. | [homepage](https://github.com/jonschlinkert/parse-filepath "Pollyfill for node.js `path.parse`, parses a filepath into an object.") +* [path-ends-with](https://www.npmjs.com/package/path-ends-with): Return `true` if a file path ends with the given string/suffix. | [homepage](https://github.com/jonschlinkert/path-ends-with "Return `true` if a file path ends with the given string/suffix.") +* [unixify](https://www.npmjs.com/package/unixify): Convert Windows file paths to unix paths. | [homepage](https://github.com/jonschlinkert/unixify "Convert Windows file paths to unix paths.") + +### Contributors + +| **Commits** | **Contributor** | +| --- | --- | +| 35 | [jonschlinkert](https://github.com/jonschlinkert) | +| 1 | [phated](https://github.com/phated) | + +### Author + +**Jon Schlinkert** + +* [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) +* [GitHub Profile](https://github.com/jonschlinkert) +* [Twitter Profile](https://twitter.com/jonschlinkert) + +### License + +Copyright © 2018, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). + +*** + +_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.6.0, on April 19, 2018._ \ No newline at end of file diff --git a/node_modules/normalize-path/index.js b/node_modules/normalize-path/index.js new file mode 100644 index 0000000..6fac553 --- /dev/null +++ b/node_modules/normalize-path/index.js @@ -0,0 +1,35 @@ +/*! + * normalize-path + * + * Copyright (c) 2014-2018, Jon Schlinkert. + * Released under the MIT License. + */ + +module.exports = function(path, stripTrailing) { + if (typeof path !== 'string') { + throw new TypeError('expected path to be a string'); + } + + if (path === '\\' || path === '/') return '/'; + + var len = path.length; + if (len <= 1) return path; + + // ensure that win32 namespaces has two leading slashes, so that the path is + // handled properly by the win32 version of path.parse() after being normalized + // https://msdn.microsoft.com/library/windows/desktop/aa365247(v=vs.85).aspx#namespaces + var prefix = ''; + if (len > 4 && path[3] === '\\') { + var ch = path[2]; + if ((ch === '?' || ch === '.') && path.slice(0, 2) === '\\\\') { + path = path.slice(2); + prefix = '//'; + } + } + + var segs = path.split(/[/\\]+/); + if (stripTrailing !== false && segs[segs.length - 1] === '') { + segs.pop(); + } + return prefix + segs.join('/'); +}; diff --git a/node_modules/normalize-path/package.json b/node_modules/normalize-path/package.json new file mode 100644 index 0000000..ad61098 --- /dev/null +++ b/node_modules/normalize-path/package.json @@ -0,0 +1,77 @@ +{ + "name": "normalize-path", + "description": "Normalize slashes in a file path to be posix/unix-like forward slashes. Also condenses repeat slashes to a single slash and removes and trailing slashes, unless disabled.", + "version": "3.0.0", + "homepage": "https://github.com/jonschlinkert/normalize-path", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "contributors": [ + "Blaine Bublitz (https://twitter.com/BlaineBublitz)", + "Jon Schlinkert (http://twitter.com/jonschlinkert)" + ], + "repository": "jonschlinkert/normalize-path", + "bugs": { + "url": "https://github.com/jonschlinkert/normalize-path/issues" + }, + "license": "MIT", + "files": [ + "index.js" + ], + "main": "index.js", + "engines": { + "node": ">=0.10.0" + }, + "scripts": { + "test": "mocha" + }, + "devDependencies": { + "gulp-format-md": "^1.0.0", + "minimist": "^1.2.0", + "mocha": "^3.5.3" + }, + "keywords": [ + "absolute", + "backslash", + "delimiter", + "file", + "file-path", + "filepath", + "fix", + "forward", + "fp", + "fs", + "normalize", + "path", + "relative", + "separator", + "slash", + "slashes", + "trailing", + "unix", + "urix" + ], + "verb": { + "toc": false, + "layout": "default", + "tasks": [ + "readme" + ], + "plugins": [ + "gulp-format-md" + ], + "related": { + "description": "Other useful path-related libraries:", + "list": [ + "contains-path", + "is-absolute", + "is-relative", + "parse-filepath", + "path-ends-with", + "path-ends-with", + "unixify" + ] + }, + "lint": { + "reflinks": true + } + } +} diff --git a/node_modules/object-hash/LICENSE b/node_modules/object-hash/LICENSE new file mode 100644 index 0000000..6ea185f --- /dev/null +++ b/node_modules/object-hash/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2014 object-hash contributors + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/node_modules/object-hash/dist/object_hash.js b/node_modules/object-hash/dist/object_hash.js new file mode 100644 index 0000000..2e584c5 --- /dev/null +++ b/node_modules/object-hash/dist/object_hash.js @@ -0,0 +1 @@ +!function(e){var t;"object"==typeof exports?module.exports=e():"function"==typeof define&&define.amd?define(e):("undefined"!=typeof window?t=window:"undefined"!=typeof global?t=global:"undefined"!=typeof self&&(t=self),t.objectHash=e())}(function(){return function r(o,i,u){function s(n,e){if(!i[n]){if(!o[n]){var t="function"==typeof require&&require;if(!e&&t)return t(n,!0);if(a)return a(n,!0);throw new Error("Cannot find module '"+n+"'")}e=i[n]={exports:{}};o[n][0].call(e.exports,function(e){var t=o[n][1][e];return s(t||e)},e,e.exports,r,o,i,u)}return i[n].exports}for(var a="function"==typeof require&&require,e=0;e>16),s((65280&n)>>8),s(255&n);return 2==r?s(255&(n=f(e.charAt(t))<<2|f(e.charAt(t+1))>>4)):1==r&&(s((n=f(e.charAt(t))<<10|f(e.charAt(t+1))<<4|f(e.charAt(t+2))>>2)>>8&255),s(255&n)),o},e.fromByteArray=function(e){var t,n,r,o,i=e.length%3,u="";function s(e){return"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".charAt(e)}for(t=0,r=e.length-i;t>18&63)+s(o>>12&63)+s(o>>6&63)+s(63&o);switch(i){case 1:u=(u+=s((n=e[e.length-1])>>2))+s(n<<4&63)+"==";break;case 2:u=(u=(u+=s((n=(e[e.length-2]<<8)+e[e.length-1])>>10))+s(n>>4&63))+s(n<<2&63)+"="}return u}}(void 0===f?this.base64js={}:f)}.call(this,e("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/base64-js/lib/b64.js","/node_modules/gulp-browserify/node_modules/base64-js/lib")},{buffer:3,lYpoI2:11}],3:[function(O,e,H){!function(e,n,f,r,h,p,g,y,w){var a=O("base64-js"),i=O("ieee754");function f(e,t,n){if(!(this instanceof f))return new f(e,t,n);var r,o,i,u,s=typeof e;if("base64"===t&&"string"==s)for(e=(u=e).trim?u.trim():u.replace(/^\s+|\s+$/g,"");e.length%4!=0;)e+="=";if("number"==s)r=j(e);else if("string"==s)r=f.byteLength(e,t);else{if("object"!=s)throw new Error("First argument needs to be a number, array or string.");r=j(e.length)}if(f._useTypedArrays?o=f._augment(new Uint8Array(r)):((o=this).length=r,o._isBuffer=!0),f._useTypedArrays&&"number"==typeof e.byteLength)o._set(e);else if(C(u=e)||f.isBuffer(u)||u&&"object"==typeof u&&"number"==typeof u.length)for(i=0;i>8,n=n%256,r.push(n),r.push(t);return r}(t),e,n,r)}function v(e,t,n){var r="";n=Math.min(e.length,n);for(var o=t;o>>0)):(t+1>>0),o}function _(e,t,n,r){if(r||(d("boolean"==typeof n,"missing or invalid endian"),d(null!=t,"missing offset"),d(t+1>>8*(r?i:1-i)}function l(e,t,n,r,o){o||(d(null!=t,"missing value"),d("boolean"==typeof r,"missing or invalid endian"),d(null!=n,"missing offset"),d(n+3>>8*(r?i:3-i)&255}function B(e,t,n,r,o){o||(d(null!=t,"missing value"),d("boolean"==typeof r,"missing or invalid endian"),d(null!=n,"missing offset"),d(n+1this.length&&(r=this.length);var o=(r=e.length-t=this.length))return this[e]},f.prototype.readUInt16LE=function(e,t){return o(this,e,!0,t)},f.prototype.readUInt16BE=function(e,t){return o(this,e,!1,t)},f.prototype.readUInt32LE=function(e,t){return u(this,e,!0,t)},f.prototype.readUInt32BE=function(e,t){return u(this,e,!1,t)},f.prototype.readInt8=function(e,t){if(t||(d(null!=e,"missing offset"),d(e=this.length))return 128&this[e]?-1*(255-this[e]+1):this[e]},f.prototype.readInt16LE=function(e,t){return _(this,e,!0,t)},f.prototype.readInt16BE=function(e,t){return _(this,e,!1,t)},f.prototype.readInt32LE=function(e,t){return E(this,e,!0,t)},f.prototype.readInt32BE=function(e,t){return E(this,e,!1,t)},f.prototype.readFloatLE=function(e,t){return I(this,e,!0,t)},f.prototype.readFloatBE=function(e,t){return I(this,e,!1,t)},f.prototype.readDoubleLE=function(e,t){return A(this,e,!0,t)},f.prototype.readDoubleBE=function(e,t){return A(this,e,!1,t)},f.prototype.writeUInt8=function(e,t,n){n||(d(null!=e,"missing value"),d(null!=t,"missing offset"),d(t=this.length||(this[t]=e)},f.prototype.writeUInt16LE=function(e,t,n){s(this,e,t,!0,n)},f.prototype.writeUInt16BE=function(e,t,n){s(this,e,t,!1,n)},f.prototype.writeUInt32LE=function(e,t,n){l(this,e,t,!0,n)},f.prototype.writeUInt32BE=function(e,t,n){l(this,e,t,!1,n)},f.prototype.writeInt8=function(e,t,n){n||(d(null!=e,"missing value"),d(null!=t,"missing offset"),d(t=this.length||(0<=e?this.writeUInt8(e,t,n):this.writeUInt8(255+e+1,t,n))},f.prototype.writeInt16LE=function(e,t,n){B(this,e,t,!0,n)},f.prototype.writeInt16BE=function(e,t,n){B(this,e,t,!1,n)},f.prototype.writeInt32LE=function(e,t,n){L(this,e,t,!0,n)},f.prototype.writeInt32BE=function(e,t,n){L(this,e,t,!1,n)},f.prototype.writeFloatLE=function(e,t,n){U(this,e,t,!0,n)},f.prototype.writeFloatBE=function(e,t,n){U(this,e,t,!1,n)},f.prototype.writeDoubleLE=function(e,t,n){x(this,e,t,!0,n)},f.prototype.writeDoubleBE=function(e,t,n){x(this,e,t,!1,n)},f.prototype.fill=function(e,t,n){if(t=t||0,n=n||this.length,d("number"==typeof(e="string"==typeof(e=e||0)?e.charCodeAt(0):e)&&!isNaN(e),"value is not a number"),d(t<=n,"end < start"),n!==t&&0!==this.length){d(0<=t&&t"},f.prototype.toArrayBuffer=function(){if("undefined"==typeof Uint8Array)throw new Error("Buffer.toArrayBuffer not supported in this browser");if(f._useTypedArrays)return new f(this).buffer;for(var e=new Uint8Array(this.length),t=0,n=e.length;t=t.length||o>=e.length);o++)t[o+n]=e[o];return o}function N(e){try{return decodeURIComponent(e)}catch(e){return String.fromCharCode(65533)}}function Y(e,t){d("number"==typeof e,"cannot write a non-number as a number"),d(0<=e,"specified a negative value for writing an unsigned value"),d(e<=t,"value is larger than maximum value for type"),d(Math.floor(e)===e,"value has a fractional component")}function F(e,t,n){d("number"==typeof e,"cannot write a non-number as a number"),d(e<=t,"value larger than maximum allowed value"),d(n<=e,"value smaller than minimum allowed value"),d(Math.floor(e)===e,"value has a fractional component")}function D(e,t,n){d("number"==typeof e,"cannot write a non-number as a number"),d(e<=t,"value larger than maximum allowed value"),d(n<=e,"value smaller than minimum allowed value")}function d(e,t){if(!e)throw new Error(t||"Failed assertion")}f._augment=function(e){return e._isBuffer=!0,e._get=e.get,e._set=e.set,e.get=t.get,e.set=t.set,e.write=t.write,e.toString=t.toString,e.toLocaleString=t.toString,e.toJSON=t.toJSON,e.copy=t.copy,e.slice=t.slice,e.readUInt8=t.readUInt8,e.readUInt16LE=t.readUInt16LE,e.readUInt16BE=t.readUInt16BE,e.readUInt32LE=t.readUInt32LE,e.readUInt32BE=t.readUInt32BE,e.readInt8=t.readInt8,e.readInt16LE=t.readInt16LE,e.readInt16BE=t.readInt16BE,e.readInt32LE=t.readInt32LE,e.readInt32BE=t.readInt32BE,e.readFloatLE=t.readFloatLE,e.readFloatBE=t.readFloatBE,e.readDoubleLE=t.readDoubleLE,e.readDoubleBE=t.readDoubleBE,e.writeUInt8=t.writeUInt8,e.writeUInt16LE=t.writeUInt16LE,e.writeUInt16BE=t.writeUInt16BE,e.writeUInt32LE=t.writeUInt32LE,e.writeUInt32BE=t.writeUInt32BE,e.writeInt8=t.writeInt8,e.writeInt16LE=t.writeInt16LE,e.writeInt16BE=t.writeInt16BE,e.writeInt32LE=t.writeInt32LE,e.writeInt32BE=t.writeInt32BE,e.writeFloatLE=t.writeFloatLE,e.writeFloatBE=t.writeFloatBE,e.writeDoubleLE=t.writeDoubleLE,e.writeDoubleBE=t.writeDoubleBE,e.fill=t.fill,e.inspect=t.inspect,e.toArrayBuffer=t.toArrayBuffer,e}}.call(this,O("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},O("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/buffer/index.js","/node_modules/gulp-browserify/node_modules/buffer")},{"base64-js":2,buffer:3,ieee754:10,lYpoI2:11}],4:[function(c,d,e){!function(e,t,a,n,r,o,i,u,s){var a=c("buffer").Buffer,f=4,l=new a(f);l.fill(0);d.exports={hash:function(e,t,n,r){for(var o=t(function(e,t){e.length%f!=0&&(n=e.length+(f-e.length%f),e=a.concat([e,l],n));for(var n,r=[],o=t?e.readInt32BE:e.readInt32LE,i=0;is?t=e(t):t.length>5]|=128<>>9<<4)]=t;for(var n=1732584193,r=-271733879,o=-1732584194,i=271733878,u=0;u>>32-o,n)}function c(e,t,n,r,o,i,u){return s(t&n|~t&r,e,t,o,i,u)}function d(e,t,n,r,o,i,u){return s(t&r|n&~r,e,t,o,i,u)}function h(e,t,n,r,o,i,u){return s(t^n^r,e,t,o,i,u)}function p(e,t,n,r,o,i,u){return s(n^(t|~r),e,t,o,i,u)}function g(e,t){var n=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(n>>16)<<16|65535&n}b.exports=function(e){return t.hash(e,n,16)}}.call(this,w("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},w("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/crypto-browserify/md5.js","/node_modules/gulp-browserify/node_modules/crypto-browserify")},{"./helpers":4,buffer:3,lYpoI2:11}],7:[function(e,l,t){!function(e,t,n,r,o,i,u,s,f){var a;l.exports=a||function(e){for(var t,n=new Array(e),r=0;r>>((3&r)<<3)&255;return n}}.call(this,e("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/crypto-browserify/rng.js","/node_modules/gulp-browserify/node_modules/crypto-browserify")},{buffer:3,lYpoI2:11}],8:[function(c,d,e){!function(e,t,n,r,o,s,a,f,l){var i=c("./helpers");function u(l,c){l[c>>5]|=128<<24-c%32,l[15+(c+64>>9<<4)]=c;for(var e,t,n,r=Array(80),o=1732584193,i=-271733879,u=-1732584194,s=271733878,d=-1009589776,h=0;h>16)+(t>>16)+(n>>16)<<16|65535&n}function v(e,t){return e<>>32-t}d.exports=function(e){return i.hash(e,u,20,!0)}}.call(this,c("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},c("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/crypto-browserify/sha.js","/node_modules/gulp-browserify/node_modules/crypto-browserify")},{"./helpers":4,buffer:3,lYpoI2:11}],9:[function(c,d,e){!function(e,t,n,r,u,s,a,f,l){function b(e,t){var n=(65535&e)+(65535&t);return(e>>16)+(t>>16)+(n>>16)<<16|65535&n}function o(e,l){var c,d=new Array(1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298),t=new Array(1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225),n=new Array(64);e[l>>5]|=128<<24-l%32,e[15+(l+64>>9<<4)]=l;for(var r,o,h=0;h>>t|e<<32-t},v=function(e,t){return e>>>t};d.exports=function(e){return i.hash(e,o,32,!0)}}.call(this,c("lYpoI2"),"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},c("buffer").Buffer,arguments[3],arguments[4],arguments[5],arguments[6],"/node_modules/gulp-browserify/node_modules/crypto-browserify/sha256.js","/node_modules/gulp-browserify/node_modules/crypto-browserify")},{"./helpers":4,buffer:3,lYpoI2:11}],10:[function(e,t,f){!function(e,t,n,r,o,i,u,s,a){f.read=function(e,t,n,r,o){var i,u,l=8*o-r-1,c=(1<>1,s=-7,a=n?o-1:0,f=n?-1:1,o=e[t+a];for(a+=f,i=o&(1<<-s)-1,o>>=-s,s+=l;0>=-s,s+=r;0>1,d=23===r?Math.pow(2,-24)-Math.pow(2,-77):0,f=n?0:c-1,h=n?1:-1,c=t<0||0===t&&1/t<0?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(i=isNaN(t)?1:0,o=s):(o=Math.floor(Math.log(t)/Math.LN2),t*(n=Math.pow(2,-o))<1&&(o--,n*=2),2<=(t+=1<=o+a?d/n:d*Math.pow(2,1-a))*n&&(o++,n/=2),s<=o+a?(i=0,o=s):1<=o+a?(i=(t*n-1)*Math.pow(2,r),o+=a):(i=t*Math.pow(2,a-1)*Math.pow(2,r),o=0));8<=r;e[l+f]=255&i,f+=h,i/=256,r-=8);for(o=o<", type, " -> ", "_" + type); + + return this['_' + type](value); + }, + _object: function(object) { + var pattern = (/\[object (.*)\]/i); + var objString = Object.prototype.toString.call(object); + var objType = pattern.exec(objString); + if (!objType) { // object type did not match [object ...] + objType = 'unknown:[' + objString + ']'; + } else { + objType = objType[1]; // take only the class name + } + + objType = objType.toLowerCase(); + + var objectNumber = null; + + if ((objectNumber = context.indexOf(object)) >= 0) { + return this.dispatch('[CIRCULAR:' + objectNumber + ']'); + } else { + context.push(object); + } + + if (typeof Buffer !== 'undefined' && Buffer.isBuffer && Buffer.isBuffer(object)) { + write('buffer:'); + return write(object); + } + + if(objType !== 'object' && objType !== 'function' && objType !== 'asyncfunction') { + if(this['_' + objType]) { + this['_' + objType](object); + } else if (options.ignoreUnknown) { + return write('[' + objType + ']'); + } else { + throw new Error('Unknown object type "' + objType + '"'); + } + }else{ + var keys = Object.keys(object); + if (options.unorderedObjects) { + keys = keys.sort(); + } + // Make sure to incorporate special properties, so + // Types with different prototypes will produce + // a different hash and objects derived from + // different functions (`new Foo`, `new Bar`) will + // produce different hashes. + // We never do this for native functions since some + // seem to break because of that. + if (options.respectType !== false && !isNativeFunction(object)) { + keys.splice(0, 0, 'prototype', '__proto__', 'constructor'); + } + + if (options.excludeKeys) { + keys = keys.filter(function(key) { return !options.excludeKeys(key); }); + } + + write('object:' + keys.length + ':'); + var self = this; + return keys.forEach(function(key){ + self.dispatch(key); + write(':'); + if(!options.excludeValues) { + self.dispatch(object[key]); + } + write(','); + }); + } + }, + _array: function(arr, unordered){ + unordered = typeof unordered !== 'undefined' ? unordered : + options.unorderedArrays !== false; // default to options.unorderedArrays + + var self = this; + write('array:' + arr.length + ':'); + if (!unordered || arr.length <= 1) { + return arr.forEach(function(entry) { + return self.dispatch(entry); + }); + } + + // the unordered case is a little more complicated: + // since there is no canonical ordering on objects, + // i.e. {a:1} < {a:2} and {a:1} > {a:2} are both false, + // we first serialize each entry using a PassThrough stream + // before sorting. + // also: we can’t use the same context array for all entries + // since the order of hashing should *not* matter. instead, + // we keep track of the additions to a copy of the context array + // and add all of them to the global context array when we’re done + var contextAdditions = []; + var entries = arr.map(function(entry) { + var strm = new PassThrough(); + var localContext = context.slice(); // make copy + var hasher = typeHasher(options, strm, localContext); + hasher.dispatch(entry); + // take only what was added to localContext and append it to contextAdditions + contextAdditions = contextAdditions.concat(localContext.slice(context.length)); + return strm.read().toString(); + }); + context = context.concat(contextAdditions); + entries.sort(); + return this._array(entries, false); + }, + _date: function(date){ + return write('date:' + date.toJSON()); + }, + _symbol: function(sym){ + return write('symbol:' + sym.toString()); + }, + _error: function(err){ + return write('error:' + err.toString()); + }, + _boolean: function(bool){ + return write('bool:' + bool.toString()); + }, + _string: function(string){ + write('string:' + string.length + ':'); + write(string.toString()); + }, + _function: function(fn){ + write('fn:'); + if (isNativeFunction(fn)) { + this.dispatch('[native]'); + } else { + this.dispatch(fn.toString()); + } + + if (options.respectFunctionNames !== false) { + // Make sure we can still distinguish native functions + // by their name, otherwise String and Function will + // have the same hash + this.dispatch("function-name:" + String(fn.name)); + } + + if (options.respectFunctionProperties) { + this._object(fn); + } + }, + _number: function(number){ + return write('number:' + number.toString()); + }, + _xml: function(xml){ + return write('xml:' + xml.toString()); + }, + _null: function() { + return write('Null'); + }, + _undefined: function() { + return write('Undefined'); + }, + _regexp: function(regex){ + return write('regex:' + regex.toString()); + }, + _uint8array: function(arr){ + write('uint8array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _uint8clampedarray: function(arr){ + write('uint8clampedarray:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _int8array: function(arr){ + write('int8array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _uint16array: function(arr){ + write('uint16array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _int16array: function(arr){ + write('int16array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _uint32array: function(arr){ + write('uint32array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _int32array: function(arr){ + write('int32array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _float32array: function(arr){ + write('float32array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _float64array: function(arr){ + write('float64array:'); + return this.dispatch(Array.prototype.slice.call(arr)); + }, + _arraybuffer: function(arr){ + write('arraybuffer:'); + return this.dispatch(new Uint8Array(arr)); + }, + _url: function(url) { + return write('url:' + url.toString(), 'utf8'); + }, + _map: function(map) { + write('map:'); + var arr = Array.from(map); + return this._array(arr, options.unorderedSets !== false); + }, + _set: function(set) { + write('set:'); + var arr = Array.from(set); + return this._array(arr, options.unorderedSets !== false); + }, + _file: function(file) { + write('file:'); + return this.dispatch([file.name, file.size, file.type, file.lastModfied]); + }, + _blob: function() { + if (options.ignoreUnknown) { + return write('[blob]'); + } + + throw Error('Hashing Blob objects is currently not supported\n' + + '(see https://github.com/puleos/object-hash/issues/26)\n' + + 'Use "options.replacer" or "options.ignoreUnknown"\n'); + }, + _domwindow: function() { return write('domwindow'); }, + _bigint: function(number){ + return write('bigint:' + number.toString()); + }, + /* Node.js standard native objects */ + _process: function() { return write('process'); }, + _timer: function() { return write('timer'); }, + _pipe: function() { return write('pipe'); }, + _tcp: function() { return write('tcp'); }, + _udp: function() { return write('udp'); }, + _tty: function() { return write('tty'); }, + _statwatcher: function() { return write('statwatcher'); }, + _securecontext: function() { return write('securecontext'); }, + _connection: function() { return write('connection'); }, + _zlib: function() { return write('zlib'); }, + _context: function() { return write('context'); }, + _nodescript: function() { return write('nodescript'); }, + _httpparser: function() { return write('httpparser'); }, + _dataview: function() { return write('dataview'); }, + _signal: function() { return write('signal'); }, + _fsevent: function() { return write('fsevent'); }, + _tlswrap: function() { return write('tlswrap'); }, + }; +} + +// Mini-implementation of stream.PassThrough +// We are far from having need for the full implementation, and we can +// make assumptions like "many writes, then only one final read" +// and we can ignore encoding specifics +function PassThrough() { + return { + buf: '', + + write: function(b) { + this.buf += b; + }, + + end: function(b) { + this.buf += b; + }, + + read: function() { + return this.buf; + } + }; +} diff --git a/node_modules/object-hash/package.json b/node_modules/object-hash/package.json new file mode 100644 index 0000000..a72557f --- /dev/null +++ b/node_modules/object-hash/package.json @@ -0,0 +1,53 @@ +{ + "name": "object-hash", + "version": "3.0.0", + "description": "Generate hashes from javascript objects in node and the browser.", + "homepage": "https://github.com/puleos/object-hash", + "repository": { + "type": "git", + "url": "https://github.com/puleos/object-hash" + }, + "keywords": [ + "object", + "hash", + "sha1", + "md5" + ], + "bugs": { + "url": "https://github.com/puleos/object-hash/issues" + }, + "scripts": { + "test": "node ./node_modules/.bin/mocha test", + "prepublish": "gulp dist" + }, + "author": "Scott Puleo ", + "files": [ + "index.js", + "dist/object_hash.js" + ], + "license": "MIT", + "devDependencies": { + "browserify": "^16.2.3", + "gulp": "^4.0.0", + "gulp-browserify": "^0.5.1", + "gulp-coveralls": "^0.1.4", + "gulp-exec": "^3.0.1", + "gulp-istanbul": "^1.1.3", + "gulp-jshint": "^2.0.0", + "gulp-mocha": "^5.0.0", + "gulp-rename": "^1.2.0", + "gulp-replace": "^1.0.0", + "gulp-uglify": "^3.0.0", + "jshint": "^2.8.0", + "jshint-stylish": "^2.1.0", + "karma": "^4.2.0", + "karma-chrome-launcher": "^2.2.0", + "karma-mocha": "^1.3.0", + "mocha": "^6.2.0" + }, + "engines": { + "node": ">= 6" + }, + "main": "./index.js", + "browser": "./dist/object_hash.js" +} diff --git a/node_modules/object-hash/readme.markdown b/node_modules/object-hash/readme.markdown new file mode 100644 index 0000000..c507cf8 --- /dev/null +++ b/node_modules/object-hash/readme.markdown @@ -0,0 +1,198 @@ +# object-hash + +Generate hashes from objects and values in node and the browser. Uses node.js +crypto module for hashing. Supports SHA1 and many others (depending on the platform) +as well as custom streams (e.g. CRC32). + +[![NPM](https://nodei.co/npm/object-hash.png?downloads=true&downloadRank=true)](https://www.npmjs.com/package/object-hash) + +[![Travis CI](https://secure.travis-ci.org/puleos/object-hash.png?branch=master)](https://secure.travis-ci.org/puleos/object-hash?branch=master) +[![Coverage Status](https://coveralls.io/repos/puleos/object-hash/badge.svg?branch=master&service=github)](https://coveralls.io/github/puleos/object-hash?branch=master) + +* Hash values of any type. +* Supports a keys only option for grouping similar objects with different values. + +```js +var hash = require('object-hash'); + +hash({foo: 'bar'}) // => '67b69634f9880a282c14a0f0cb7ba20cf5d677e9' +hash([1, 2, 2.718, 3.14159]) // => '136b9b88375971dff9f1af09d7356e3e04281951' +``` + +## Versioning Disclaimer + +Starting with version `1.1.8` (released April 2017), new versions will consider +the exact returned hash part of the API contract, i.e. changes that will affect +hash values will be considered `semver-major`. Previous versions may violate +that expectation. + +For more information, see [this discussion](https://github.com/puleos/object-hash/issues/30). + +## hash(value, options) + +Generate a hash from any object or type. Defaults to sha1 with hex encoding. + +* `algorithm` hash algo to be used: 'sha1', 'md5', 'passthrough'. default: sha1 + * This supports the algorithms returned by `crypto.getHashes()`. Note that the default of SHA-1 is not considered secure, and a stronger algorithm should be used if a cryptographical hash is desired. + * This also supports the `passthrough` algorith, which will return the information that would otherwise have been hashed. +* `excludeValues` {true|false} hash object keys, values ignored. default: false +* `encoding` hash encoding, supports 'buffer', 'hex', 'binary', 'base64'. default: hex +* `ignoreUnknown` {true|*false} ignore unknown object types. default: false +* `replacer` optional function that replaces values before hashing. default: accept all values +* `respectFunctionProperties` {true|false} Whether properties on functions are considered when hashing. default: true +* `respectFunctionNames` {true|false} consider `name` property of functions for hashing. default: true +* `respectType` {true|false} Whether special type attributes (`.prototype`, `.__proto__`, `.constructor`) + are hashed. default: true +* `unorderedArrays` {true|false} Sort all arrays before hashing. Note that this affects *all* collections, + i.e. including typed arrays, Sets, Maps, etc. default: false +* `unorderedSets` {true|false} Sort `Set` and `Map` instances before hashing, i.e. make + `hash(new Set([1, 2])) == hash(new Set([2, 1]))` return `true`. default: true +* `unorderedObjects` {true|false} Sort objects before hashing, i.e. make `hash({ x: 1, y: 2 }) === hash({ y: 2, x: 1 })`. default: true +* `excludeKeys` optional function for excluding specific key(s) from hashing, if true is returned then exclude from hash. default: include all keys + +## hash.sha1(value) + +Hash using the sha1 algorithm. + +Note that SHA-1 is not considered secure, and a stronger algorithm should be used if a cryptographical hash is desired. + +*Sugar method, equivalent to* `hash(value, {algorithm: 'sha1'})` + +## hash.keys(value) + +Hash object keys using the sha1 algorithm, values ignored. + +*Sugar method, equivalent to* `hash(value, {excludeValues: true})` + +## hash.MD5(value) + +Hash using the md5 algorithm. + +Note that the MD5 algorithm is not considered secure, and a stronger algorithm should be used if a cryptographical hash is desired. + +*Sugar method, equivalent to* `hash(value, {algorithm: 'md5'})` + +## hash.keysMD5(value) + +Hash object keys using the md5 algorithm, values ignored. + +Note that the MD5 algorithm is not considered secure, and a stronger algorithm should be used if a cryptographical hash is desired. + +*Sugar method, equivalent to* `hash(value, {algorithm: 'md5', excludeValues: true})` + +## hash.writeToStream(value, [options,] stream) + +Write the information that would otherwise have been hashed to a stream, e.g.: + +```js +hash.writeToStream({foo: 'bar', a: 42}, {respectType: false}, process.stdout) +// => e.g. 'object:a:number:42foo:string:bar' +``` + +## Installation + +node: + +```js +npm install object-hash +``` + +browser: */dist/object_hash.js* + +```html + + + +``` + +## Example usage + +```js +var hash = require('object-hash'); + +var peter = { name: 'Peter', stapler: false, friends: ['Joanna', 'Michael', 'Samir'] }; +var michael = { name: 'Michael', stapler: false, friends: ['Peter', 'Samir'] }; +var bob = { name: 'Bob', stapler: true, friends: [] }; + +/*** + * sha1 hex encoding (default) + */ +hash(peter); +// 14fa461bf4b98155e82adc86532938553b4d33a9 +hash(michael); +// 4b2b30e27699979ce46714253bc2213010db039c +hash(bob); +// 38d96106bc8ef3d8bd369b99bb6972702c9826d5 + +/*** + * hash object keys, values ignored + */ +hash(peter, { excludeValues: true }); +// 48f370a772c7496f6c9d2e6d92e920c87dd00a5c +hash(michael, { excludeValues: true }); +// 48f370a772c7496f6c9d2e6d92e920c87dd00a5c +hash.keys(bob); +// 48f370a772c7496f6c9d2e6d92e920c87dd00a5c + +/*** + * hash object, ignore specific key(s) + */ +hash(peter, { excludeKeys: function(key) { + if ( key === 'friends') { + return true; + } + return false; + } +}); +// 66b7d7e64871aa9fda1bdc8e88a28df797648d80 + +/*** + * md5 base64 encoding + */ +hash(peter, { algorithm: 'md5', encoding: 'base64' }); +// 6rkWaaDiG3NynWw4svGH7g== +hash(michael, { algorithm: 'md5', encoding: 'base64' }); +// djXaWpuWVJeOF8Sb6SFFNg== +hash(bob, { algorithm: 'md5', encoding: 'base64' }); +// lFzkw/IJ8/12jZI0rQeS3w== +``` + +## Legacy Browser Support + +IE <= 8 and Opera <= 11 support dropped in version 0.3.0. If you require +legacy browser support you must either use an ES5 shim or use version 0.2.5 +of this module. + +## Development + +```sh-session +git clone https://github.com/puleos/object-hash +``` + +## Node Docker Wrapper + +If you want to stand this up in a docker container, you should take at look +at the [![node-object-hash](https://github.com/bean5/node-object-hash)](https://github.com/bean5/node-object-hash) project. + +### gulp tasks + +* `gulp watch` (default) watch files, test and lint on change/add +* `gulp test` unit tests +* `gulp karma` browser unit tests +* `gulp lint` jshint +* `gulp dist` create browser version in /dist + +## License + +MIT + +## Changelog + +### v2.0.0 + +Only Node.js versions `>= 6.0.0` are being tested in CI now. +No other breaking changes were introduced. diff --git a/node_modules/path-parse/LICENSE b/node_modules/path-parse/LICENSE new file mode 100644 index 0000000..810f3db --- /dev/null +++ b/node_modules/path-parse/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2015 Javier Blanco + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/path-parse/README.md b/node_modules/path-parse/README.md new file mode 100644 index 0000000..05097f8 --- /dev/null +++ b/node_modules/path-parse/README.md @@ -0,0 +1,42 @@ +# path-parse [![Build Status](https://travis-ci.org/jbgutierrez/path-parse.svg?branch=master)](https://travis-ci.org/jbgutierrez/path-parse) + +> Node.js [`path.parse(pathString)`](https://nodejs.org/api/path.html#path_path_parse_pathstring) [ponyfill](https://ponyfill.com). + +## Install + +``` +$ npm install --save path-parse +``` + +## Usage + +```js +var pathParse = require('path-parse'); + +pathParse('/home/user/dir/file.txt'); +//=> { +// root : "/", +// dir : "/home/user/dir", +// base : "file.txt", +// ext : ".txt", +// name : "file" +// } +``` + +## API + +See [`path.parse(pathString)`](https://nodejs.org/api/path.html#path_path_parse_pathstring) docs. + +### pathParse(path) + +### pathParse.posix(path) + +The Posix specific version. + +### pathParse.win32(path) + +The Windows specific version. + +## License + +MIT © [Javier Blanco](http://jbgutierrez.info) diff --git a/node_modules/path-parse/index.js b/node_modules/path-parse/index.js new file mode 100644 index 0000000..f062d0a --- /dev/null +++ b/node_modules/path-parse/index.js @@ -0,0 +1,75 @@ +'use strict'; + +var isWindows = process.platform === 'win32'; + +// Regex to split a windows path into into [dir, root, basename, name, ext] +var splitWindowsRe = + /^(((?:[a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?[\\\/]?)(?:[^\\\/]*[\\\/])*)((\.{1,2}|[^\\\/]+?|)(\.[^.\/\\]*|))[\\\/]*$/; + +var win32 = {}; + +function win32SplitPath(filename) { + return splitWindowsRe.exec(filename).slice(1); +} + +win32.parse = function(pathString) { + if (typeof pathString !== 'string') { + throw new TypeError( + "Parameter 'pathString' must be a string, not " + typeof pathString + ); + } + var allParts = win32SplitPath(pathString); + if (!allParts || allParts.length !== 5) { + throw new TypeError("Invalid path '" + pathString + "'"); + } + return { + root: allParts[1], + dir: allParts[0] === allParts[1] ? allParts[0] : allParts[0].slice(0, -1), + base: allParts[2], + ext: allParts[4], + name: allParts[3] + }; +}; + + + +// Split a filename into [dir, root, basename, name, ext], unix version +// 'root' is just a slash, or nothing. +var splitPathRe = + /^((\/?)(?:[^\/]*\/)*)((\.{1,2}|[^\/]+?|)(\.[^.\/]*|))[\/]*$/; +var posix = {}; + + +function posixSplitPath(filename) { + return splitPathRe.exec(filename).slice(1); +} + + +posix.parse = function(pathString) { + if (typeof pathString !== 'string') { + throw new TypeError( + "Parameter 'pathString' must be a string, not " + typeof pathString + ); + } + var allParts = posixSplitPath(pathString); + if (!allParts || allParts.length !== 5) { + throw new TypeError("Invalid path '" + pathString + "'"); + } + + return { + root: allParts[1], + dir: allParts[0].slice(0, -1), + base: allParts[2], + ext: allParts[4], + name: allParts[3], + }; +}; + + +if (isWindows) + module.exports = win32.parse; +else /* posix */ + module.exports = posix.parse; + +module.exports.posix = posix.parse; +module.exports.win32 = win32.parse; diff --git a/node_modules/path-parse/package.json b/node_modules/path-parse/package.json new file mode 100644 index 0000000..36c23f8 --- /dev/null +++ b/node_modules/path-parse/package.json @@ -0,0 +1,33 @@ +{ + "name": "path-parse", + "version": "1.0.7", + "description": "Node.js path.parse() ponyfill", + "main": "index.js", + "scripts": { + "test": "node test.js" + }, + "repository": { + "type": "git", + "url": "https://github.com/jbgutierrez/path-parse.git" + }, + "keywords": [ + "path", + "paths", + "file", + "dir", + "parse", + "built-in", + "util", + "utils", + "core", + "ponyfill", + "polyfill", + "shim" + ], + "author": "Javier Blanco ", + "license": "MIT", + "bugs": { + "url": "https://github.com/jbgutierrez/path-parse/issues" + }, + "homepage": "https://github.com/jbgutierrez/path-parse#readme" +} diff --git a/node_modules/picocolors/LICENSE b/node_modules/picocolors/LICENSE new file mode 100644 index 0000000..496098c --- /dev/null +++ b/node_modules/picocolors/LICENSE @@ -0,0 +1,15 @@ +ISC License + +Copyright (c) 2021 Alexey Raspopov, Kostiantyn Denysov, Anton Verinov + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/node_modules/picocolors/README.md b/node_modules/picocolors/README.md new file mode 100644 index 0000000..8e47aa8 --- /dev/null +++ b/node_modules/picocolors/README.md @@ -0,0 +1,21 @@ +# picocolors + +The tiniest and the fastest library for terminal output formatting with ANSI colors. + +```javascript +import pc from "picocolors" + +console.log( + pc.green(`How are ${pc.italic(`you`)} doing?`) +) +``` + +- **No dependencies.** +- **14 times** smaller and **2 times** faster than chalk. +- Used by popular tools like PostCSS, SVGO, Stylelint, and Browserslist. +- Node.js v6+ & browsers support. Support for both CJS and ESM projects. +- TypeScript type declarations included. +- [`NO_COLOR`](https://no-color.org/) friendly. + +## Docs +Read **[full docs](https://github.com/alexeyraspopov/picocolors#readme)** on GitHub. diff --git a/node_modules/picocolors/package.json b/node_modules/picocolors/package.json new file mode 100644 index 0000000..85a12d5 --- /dev/null +++ b/node_modules/picocolors/package.json @@ -0,0 +1,25 @@ +{ + "name": "picocolors", + "version": "1.0.0", + "main": "./picocolors.js", + "types": "./picocolors.d.ts", + "browser": { + "./picocolors.js": "./picocolors.browser.js" + }, + "sideEffects": false, + "description": "The tiniest and the fastest library for terminal output formatting with ANSI colors", + "files": [ + "picocolors.*", + "types.ts" + ], + "keywords": [ + "terminal", + "colors", + "formatting", + "cli", + "console" + ], + "author": "Alexey Raspopov", + "repository": "alexeyraspopov/picocolors", + "license": "ISC" +} diff --git a/node_modules/picocolors/picocolors.browser.js b/node_modules/picocolors/picocolors.browser.js new file mode 100644 index 0000000..5eb9fbe --- /dev/null +++ b/node_modules/picocolors/picocolors.browser.js @@ -0,0 +1,4 @@ +var x=String; +var create=function() {return {isColorSupported:false,reset:x,bold:x,dim:x,italic:x,underline:x,inverse:x,hidden:x,strikethrough:x,black:x,red:x,green:x,yellow:x,blue:x,magenta:x,cyan:x,white:x,gray:x,bgBlack:x,bgRed:x,bgGreen:x,bgYellow:x,bgBlue:x,bgMagenta:x,bgCyan:x,bgWhite:x}}; +module.exports=create(); +module.exports.createColors = create; diff --git a/node_modules/picocolors/picocolors.d.ts b/node_modules/picocolors/picocolors.d.ts new file mode 100644 index 0000000..94e146a --- /dev/null +++ b/node_modules/picocolors/picocolors.d.ts @@ -0,0 +1,5 @@ +import { Colors } from "./types" + +declare const picocolors: Colors & { createColors: (enabled?: boolean) => Colors } + +export = picocolors diff --git a/node_modules/picocolors/picocolors.js b/node_modules/picocolors/picocolors.js new file mode 100644 index 0000000..fdb6304 --- /dev/null +++ b/node_modules/picocolors/picocolors.js @@ -0,0 +1,58 @@ +let tty = require("tty") + +let isColorSupported = + !("NO_COLOR" in process.env || process.argv.includes("--no-color")) && + ("FORCE_COLOR" in process.env || + process.argv.includes("--color") || + process.platform === "win32" || + (tty.isatty(1) && process.env.TERM !== "dumb") || + "CI" in process.env) + +let formatter = + (open, close, replace = open) => + input => { + let string = "" + input + let index = string.indexOf(close, open.length) + return ~index + ? open + replaceClose(string, close, replace, index) + close + : open + string + close + } + +let replaceClose = (string, close, replace, index) => { + let start = string.substring(0, index) + replace + let end = string.substring(index + close.length) + let nextIndex = end.indexOf(close) + return ~nextIndex ? start + replaceClose(end, close, replace, nextIndex) : start + end +} + +let createColors = (enabled = isColorSupported) => ({ + isColorSupported: enabled, + reset: enabled ? s => `\x1b[0m${s}\x1b[0m` : String, + bold: enabled ? formatter("\x1b[1m", "\x1b[22m", "\x1b[22m\x1b[1m") : String, + dim: enabled ? formatter("\x1b[2m", "\x1b[22m", "\x1b[22m\x1b[2m") : String, + italic: enabled ? formatter("\x1b[3m", "\x1b[23m") : String, + underline: enabled ? formatter("\x1b[4m", "\x1b[24m") : String, + inverse: enabled ? formatter("\x1b[7m", "\x1b[27m") : String, + hidden: enabled ? formatter("\x1b[8m", "\x1b[28m") : String, + strikethrough: enabled ? formatter("\x1b[9m", "\x1b[29m") : String, + black: enabled ? formatter("\x1b[30m", "\x1b[39m") : String, + red: enabled ? formatter("\x1b[31m", "\x1b[39m") : String, + green: enabled ? formatter("\x1b[32m", "\x1b[39m") : String, + yellow: enabled ? formatter("\x1b[33m", "\x1b[39m") : String, + blue: enabled ? formatter("\x1b[34m", "\x1b[39m") : String, + magenta: enabled ? formatter("\x1b[35m", "\x1b[39m") : String, + cyan: enabled ? formatter("\x1b[36m", "\x1b[39m") : String, + white: enabled ? formatter("\x1b[37m", "\x1b[39m") : String, + gray: enabled ? formatter("\x1b[90m", "\x1b[39m") : String, + bgBlack: enabled ? formatter("\x1b[40m", "\x1b[49m") : String, + bgRed: enabled ? formatter("\x1b[41m", "\x1b[49m") : String, + bgGreen: enabled ? formatter("\x1b[42m", "\x1b[49m") : String, + bgYellow: enabled ? formatter("\x1b[43m", "\x1b[49m") : String, + bgBlue: enabled ? formatter("\x1b[44m", "\x1b[49m") : String, + bgMagenta: enabled ? formatter("\x1b[45m", "\x1b[49m") : String, + bgCyan: enabled ? formatter("\x1b[46m", "\x1b[49m") : String, + bgWhite: enabled ? formatter("\x1b[47m", "\x1b[49m") : String, +}) + +module.exports = createColors() +module.exports.createColors = createColors diff --git a/node_modules/picocolors/types.ts b/node_modules/picocolors/types.ts new file mode 100644 index 0000000..b4bacee --- /dev/null +++ b/node_modules/picocolors/types.ts @@ -0,0 +1,30 @@ +export type Formatter = (input: string | number | null | undefined) => string + +export interface Colors { + isColorSupported: boolean + reset: Formatter + bold: Formatter + dim: Formatter + italic: Formatter + underline: Formatter + inverse: Formatter + hidden: Formatter + strikethrough: Formatter + black: Formatter + red: Formatter + green: Formatter + yellow: Formatter + blue: Formatter + magenta: Formatter + cyan: Formatter + white: Formatter + gray: Formatter + bgBlack: Formatter + bgRed: Formatter + bgGreen: Formatter + bgYellow: Formatter + bgBlue: Formatter + bgMagenta: Formatter + bgCyan: Formatter + bgWhite: Formatter +} diff --git a/node_modules/picomatch/CHANGELOG.md b/node_modules/picomatch/CHANGELOG.md new file mode 100644 index 0000000..8ccc6c1 --- /dev/null +++ b/node_modules/picomatch/CHANGELOG.md @@ -0,0 +1,136 @@ +# Release history + +**All notable changes to this project will be documented in this file.** + +The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) +and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). + +
      + Guiding Principles + +- Changelogs are for humans, not machines. +- There should be an entry for every single version. +- The same types of changes should be grouped. +- Versions and sections should be linkable. +- The latest version comes first. +- The release date of each versions is displayed. +- Mention whether you follow Semantic Versioning. + +
      + +
      + Types of changes + +Changelog entries are classified using the following labels _(from [keep-a-changelog](http://keepachangelog.com/)_): + +- `Added` for new features. +- `Changed` for changes in existing functionality. +- `Deprecated` for soon-to-be removed features. +- `Removed` for now removed features. +- `Fixed` for any bug fixes. +- `Security` in case of vulnerabilities. + +
      + +## 2.3.1 (2022-01-02) + +### Fixed + +* Fixes bug when a pattern containing an expression after the closing parenthesis (`/!(*.d).{ts,tsx}`) was incorrectly converted to regexp ([9f241ef](https://github.com/micromatch/picomatch/commit/9f241ef)). + +### Changed + +* Some documentation improvements ([f81d236](https://github.com/micromatch/picomatch/commit/f81d236), [421e0e7](https://github.com/micromatch/picomatch/commit/421e0e7)). + +## 2.3.0 (2021-05-21) + +### Fixed + +* Fixes bug where file names with two dots were not being matched consistently with negation extglobs containing a star ([56083ef](https://github.com/micromatch/picomatch/commit/56083ef)) + +## 2.2.3 (2021-04-10) + +### Fixed + +* Do not skip pattern seperator for square brackets ([fb08a30](https://github.com/micromatch/picomatch/commit/fb08a30)). +* Set negatedExtGlob also if it does not span the whole pattern ([032e3f5](https://github.com/micromatch/picomatch/commit/032e3f5)). + +## 2.2.2 (2020-03-21) + +### Fixed + +* Correctly handle parts of the pattern after parentheses in the `scan` method ([e15b920](https://github.com/micromatch/picomatch/commit/e15b920)). + +## 2.2.1 (2020-01-04) + +* Fixes [#49](https://github.com/micromatch/picomatch/issues/49), so that braces with no sets or ranges are now propertly treated as literals. + +## 2.2.0 (2020-01-04) + +* Disable fastpaths mode for the parse method ([5b8d33f](https://github.com/micromatch/picomatch/commit/5b8d33f)) +* Add `tokens`, `slashes`, and `parts` to the object returned by `picomatch.scan()`. + +## 2.1.0 (2019-10-31) + +* add benchmarks for scan ([4793b92](https://github.com/micromatch/picomatch/commit/4793b92)) +* Add eslint object-curly-spacing rule ([707c650](https://github.com/micromatch/picomatch/commit/707c650)) +* Add prefer-const eslint rule ([5c7501c](https://github.com/micromatch/picomatch/commit/5c7501c)) +* Add support for nonegate in scan API ([275c9b9](https://github.com/micromatch/picomatch/commit/275c9b9)) +* Change lets to consts. Move root import up. ([4840625](https://github.com/micromatch/picomatch/commit/4840625)) +* closes https://github.com/micromatch/picomatch/issues/21 ([766bcb0](https://github.com/micromatch/picomatch/commit/766bcb0)) +* Fix "Extglobs" table in readme ([eb19da8](https://github.com/micromatch/picomatch/commit/eb19da8)) +* fixes https://github.com/micromatch/picomatch/issues/20 ([9caca07](https://github.com/micromatch/picomatch/commit/9caca07)) +* fixes https://github.com/micromatch/picomatch/issues/26 ([fa58f45](https://github.com/micromatch/picomatch/commit/fa58f45)) +* Lint test ([d433a34](https://github.com/micromatch/picomatch/commit/d433a34)) +* lint unit tests ([0159b55](https://github.com/micromatch/picomatch/commit/0159b55)) +* Make scan work with noext ([6c02e03](https://github.com/micromatch/picomatch/commit/6c02e03)) +* minor linting ([c2a2b87](https://github.com/micromatch/picomatch/commit/c2a2b87)) +* minor parser improvements ([197671d](https://github.com/micromatch/picomatch/commit/197671d)) +* remove eslint since it... ([07876fa](https://github.com/micromatch/picomatch/commit/07876fa)) +* remove funding file ([8ebe96d](https://github.com/micromatch/picomatch/commit/8ebe96d)) +* Remove unused funks ([cbc6d54](https://github.com/micromatch/picomatch/commit/cbc6d54)) +* Run eslint during pretest, fix existing eslint findings ([0682367](https://github.com/micromatch/picomatch/commit/0682367)) +* support `noparen` in scan ([3d37569](https://github.com/micromatch/picomatch/commit/3d37569)) +* update changelog ([7b34e77](https://github.com/micromatch/picomatch/commit/7b34e77)) +* update travis ([777f038](https://github.com/micromatch/picomatch/commit/777f038)) +* Use eslint-disable-next-line instead of eslint-disable ([4e7c1fd](https://github.com/micromatch/picomatch/commit/4e7c1fd)) + +## 2.0.7 (2019-05-14) + +* 2.0.7 ([9eb9a71](https://github.com/micromatch/picomatch/commit/9eb9a71)) +* supports lookbehinds ([1f63f7e](https://github.com/micromatch/picomatch/commit/1f63f7e)) +* update .verb.md file with typo change ([2741279](https://github.com/micromatch/picomatch/commit/2741279)) +* fix: typo in README ([0753e44](https://github.com/micromatch/picomatch/commit/0753e44)) + +## 2.0.4 (2019-04-10) + +### Fixed + +- Readme link [fixed](https://github.com/micromatch/picomatch/pull/13/commits/a96ab3aa2b11b6861c23289964613d85563b05df) by @danez. +- `options.capture` now works as expected when fastpaths are enabled. See https://github.com/micromatch/picomatch/pull/12/commits/26aefd71f1cfaf95c37f1c1fcab68a693b037304. Thanks to @DrPizza. + +## 2.0.0 (2019-04-10) + +### Added + +- Adds support for `options.onIgnore`. See the readme for details +- Adds support for `options.onResult`. See the readme for details + +### Breaking changes + +- The unixify option was renamed to `windows` +- caching and all related options and methods have been removed + +## 1.0.0 (2018-11-05) + +- adds `.onMatch` option +- improvements to `.scan` method +- numerous improvements and optimizations for matching and parsing +- better windows path handling + +## 0.1.0 - 2017-04-13 + +First release. + + +[keep-a-changelog]: https://github.com/olivierlacan/keep-a-changelog diff --git a/node_modules/picomatch/LICENSE b/node_modules/picomatch/LICENSE new file mode 100644 index 0000000..3608dca --- /dev/null +++ b/node_modules/picomatch/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2017-present, Jon Schlinkert. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/picomatch/README.md b/node_modules/picomatch/README.md new file mode 100644 index 0000000..b0526e2 --- /dev/null +++ b/node_modules/picomatch/README.md @@ -0,0 +1,708 @@ +

      Picomatch

      + +

      + +version + + +test status + + +coverage status + + +downloads + +

      + +
      +
      + +

      +Blazing fast and accurate glob matcher written in JavaScript.
      +No dependencies and full support for standard and extended Bash glob features, including braces, extglobs, POSIX brackets, and regular expressions. +

      + +
      +
      + +## Why picomatch? + +* **Lightweight** - No dependencies +* **Minimal** - Tiny API surface. Main export is a function that takes a glob pattern and returns a matcher function. +* **Fast** - Loads in about 2ms (that's several times faster than a [single frame of a HD movie](http://www.endmemo.com/sconvert/framespersecondframespermillisecond.php) at 60fps) +* **Performant** - Use the returned matcher function to speed up repeat matching (like when watching files) +* **Accurate matching** - Using wildcards (`*` and `?`), globstars (`**`) for nested directories, [advanced globbing](#advanced-globbing) with extglobs, braces, and POSIX brackets, and support for escaping special characters with `\` or quotes. +* **Well tested** - Thousands of unit tests + +See the [library comparison](#library-comparisons) to other libraries. + +
      +
      + +## Table of Contents + +
      Click to expand + +- [Install](#install) +- [Usage](#usage) +- [API](#api) + * [picomatch](#picomatch) + * [.test](#test) + * [.matchBase](#matchbase) + * [.isMatch](#ismatch) + * [.parse](#parse) + * [.scan](#scan) + * [.compileRe](#compilere) + * [.makeRe](#makere) + * [.toRegex](#toregex) +- [Options](#options) + * [Picomatch options](#picomatch-options) + * [Scan Options](#scan-options) + * [Options Examples](#options-examples) +- [Globbing features](#globbing-features) + * [Basic globbing](#basic-globbing) + * [Advanced globbing](#advanced-globbing) + * [Braces](#braces) + * [Matching special characters as literals](#matching-special-characters-as-literals) +- [Library Comparisons](#library-comparisons) +- [Benchmarks](#benchmarks) +- [Philosophies](#philosophies) +- [About](#about) + * [Author](#author) + * [License](#license) + +_(TOC generated by [verb](https://github.com/verbose/verb) using [markdown-toc](https://github.com/jonschlinkert/markdown-toc))_ + +
      + +
      +
      + +## Install + +Install with [npm](https://www.npmjs.com/): + +```sh +npm install --save picomatch +``` + +
      + +## Usage + +The main export is a function that takes a glob pattern and an options object and returns a function for matching strings. + +```js +const pm = require('picomatch'); +const isMatch = pm('*.js'); + +console.log(isMatch('abcd')); //=> false +console.log(isMatch('a.js')); //=> true +console.log(isMatch('a.md')); //=> false +console.log(isMatch('a/b.js')); //=> false +``` + +
      + +## API + +### [picomatch](lib/picomatch.js#L32) + +Creates a matcher function from one or more glob patterns. The returned function takes a string to match as its first argument, and returns true if the string is a match. The returned matcher function also takes a boolean as the second argument that, when true, returns an object with additional information. + +**Params** + +* `globs` **{String|Array}**: One or more glob patterns. +* `options` **{Object=}** +* `returns` **{Function=}**: Returns a matcher function. + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch(glob[, options]); + +const isMatch = picomatch('*.!(*a)'); +console.log(isMatch('a.a')); //=> false +console.log(isMatch('a.b')); //=> true +``` + +### [.test](lib/picomatch.js#L117) + +Test `input` with the given `regex`. This is used by the main `picomatch()` function to test the input string. + +**Params** + +* `input` **{String}**: String to test. +* `regex` **{RegExp}** +* `returns` **{Object}**: Returns an object with matching info. + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch.test(input, regex[, options]); + +console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\/([^/]*?))$/)); +// { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' } +``` + +### [.matchBase](lib/picomatch.js#L161) + +Match the basename of a filepath. + +**Params** + +* `input` **{String}**: String to test. +* `glob` **{RegExp|String}**: Glob pattern or regex created by [.makeRe](#makeRe). +* `returns` **{Boolean}** + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch.matchBase(input, glob[, options]); +console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true +``` + +### [.isMatch](lib/picomatch.js#L183) + +Returns true if **any** of the given glob `patterns` match the specified `string`. + +**Params** + +* **{String|Array}**: str The string to test. +* **{String|Array}**: patterns One or more glob patterns to use for matching. +* **{Object}**: See available [options](#options). +* `returns` **{Boolean}**: Returns true if any patterns match `str` + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch.isMatch(string, patterns[, options]); + +console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true +console.log(picomatch.isMatch('a.a', 'b.*')); //=> false +``` + +### [.parse](lib/picomatch.js#L199) + +Parse a glob pattern to create the source string for a regular expression. + +**Params** + +* `pattern` **{String}** +* `options` **{Object}** +* `returns` **{Object}**: Returns an object with useful properties and output to be used as a regex source string. + +**Example** + +```js +const picomatch = require('picomatch'); +const result = picomatch.parse(pattern[, options]); +``` + +### [.scan](lib/picomatch.js#L231) + +Scan a glob pattern to separate the pattern into segments. + +**Params** + +* `input` **{String}**: Glob pattern to scan. +* `options` **{Object}** +* `returns` **{Object}**: Returns an object with + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch.scan(input[, options]); + +const result = picomatch.scan('!./foo/*.js'); +console.log(result); +{ prefix: '!./', + input: '!./foo/*.js', + start: 3, + base: 'foo', + glob: '*.js', + isBrace: false, + isBracket: false, + isGlob: true, + isExtglob: false, + isGlobstar: false, + negated: true } +``` + +### [.compileRe](lib/picomatch.js#L245) + +Compile a regular expression from the `state` object returned by the +[parse()](#parse) method. + +**Params** + +* `state` **{Object}** +* `options` **{Object}** +* `returnOutput` **{Boolean}**: Intended for implementors, this argument allows you to return the raw output from the parser. +* `returnState` **{Boolean}**: Adds the state to a `state` property on the returned regex. Useful for implementors and debugging. +* `returns` **{RegExp}** + +### [.makeRe](lib/picomatch.js#L286) + +Create a regular expression from a parsed glob pattern. + +**Params** + +* `state` **{String}**: The object returned from the `.parse` method. +* `options` **{Object}** +* `returnOutput` **{Boolean}**: Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result. +* `returnState` **{Boolean}**: Implementors may use this argument to return the state from the parsed glob with the returned regular expression. +* `returns` **{RegExp}**: Returns a regex created from the given pattern. + +**Example** + +```js +const picomatch = require('picomatch'); +const state = picomatch.parse('*.js'); +// picomatch.compileRe(state[, options]); + +console.log(picomatch.compileRe(state)); +//=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ +``` + +### [.toRegex](lib/picomatch.js#L321) + +Create a regular expression from the given regex source string. + +**Params** + +* `source` **{String}**: Regular expression source string. +* `options` **{Object}** +* `returns` **{RegExp}** + +**Example** + +```js +const picomatch = require('picomatch'); +// picomatch.toRegex(source[, options]); + +const { output } = picomatch.parse('*.js'); +console.log(picomatch.toRegex(output)); +//=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ +``` + +
      + +## Options + +### Picomatch options + +The following options may be used with the main `picomatch()` function or any of the methods on the picomatch API. + +| **Option** | **Type** | **Default value** | **Description** | +| --- | --- | --- | --- | +| `basename` | `boolean` | `false` | If set, then patterns without slashes will be matched against the basename of the path if it contains slashes. For example, `a?b` would match the path `/xyz/123/acb`, but not `/xyz/acb/123`. | +| `bash` | `boolean` | `false` | Follow bash matching rules more strictly - disallows backslashes as escape characters, and treats single stars as globstars (`**`). | +| `capture` | `boolean` | `undefined` | Return regex matches in supporting methods. | +| `contains` | `boolean` | `undefined` | Allows glob to match any part of the given string(s). | +| `cwd` | `string` | `process.cwd()` | Current working directory. Used by `picomatch.split()` | +| `debug` | `boolean` | `undefined` | Debug regular expressions when an error is thrown. | +| `dot` | `boolean` | `false` | Enable dotfile matching. By default, dotfiles are ignored unless a `.` is explicitly defined in the pattern, or `options.dot` is true | +| `expandRange` | `function` | `undefined` | Custom function for expanding ranges in brace patterns, such as `{a..z}`. The function receives the range values as two arguments, and it must return a string to be used in the generated regex. It's recommended that returned strings be wrapped in parentheses. | +| `failglob` | `boolean` | `false` | Throws an error if no matches are found. Based on the bash option of the same name. | +| `fastpaths` | `boolean` | `true` | To speed up processing, full parsing is skipped for a handful common glob patterns. Disable this behavior by setting this option to `false`. | +| `flags` | `string` | `undefined` | Regex flags to use in the generated regex. If defined, the `nocase` option will be overridden. | +| [format](#optionsformat) | `function` | `undefined` | Custom function for formatting the returned string. This is useful for removing leading slashes, converting Windows paths to Posix paths, etc. | +| `ignore` | `array\|string` | `undefined` | One or more glob patterns for excluding strings that should not be matched from the result. | +| `keepQuotes` | `boolean` | `false` | Retain quotes in the generated regex, since quotes may also be used as an alternative to backslashes. | +| `literalBrackets` | `boolean` | `undefined` | When `true`, brackets in the glob pattern will be escaped so that only literal brackets will be matched. | +| `matchBase` | `boolean` | `false` | Alias for `basename` | +| `maxLength` | `boolean` | `65536` | Limit the max length of the input string. An error is thrown if the input string is longer than this value. | +| `nobrace` | `boolean` | `false` | Disable brace matching, so that `{a,b}` and `{1..3}` would be treated as literal characters. | +| `nobracket` | `boolean` | `undefined` | Disable matching with regex brackets. | +| `nocase` | `boolean` | `false` | Make matching case-insensitive. Equivalent to the regex `i` flag. Note that this option is overridden by the `flags` option. | +| `nodupes` | `boolean` | `true` | Deprecated, use `nounique` instead. This option will be removed in a future major release. By default duplicates are removed. Disable uniquification by setting this option to false. | +| `noext` | `boolean` | `false` | Alias for `noextglob` | +| `noextglob` | `boolean` | `false` | Disable support for matching with extglobs (like `+(a\|b)`) | +| `noglobstar` | `boolean` | `false` | Disable support for matching nested directories with globstars (`**`) | +| `nonegate` | `boolean` | `false` | Disable support for negating with leading `!` | +| `noquantifiers` | `boolean` | `false` | Disable support for regex quantifiers (like `a{1,2}`) and treat them as brace patterns to be expanded. | +| [onIgnore](#optionsonIgnore) | `function` | `undefined` | Function to be called on ignored items. | +| [onMatch](#optionsonMatch) | `function` | `undefined` | Function to be called on matched items. | +| [onResult](#optionsonResult) | `function` | `undefined` | Function to be called on all items, regardless of whether or not they are matched or ignored. | +| `posix` | `boolean` | `false` | Support POSIX character classes ("posix brackets"). | +| `posixSlashes` | `boolean` | `undefined` | Convert all slashes in file paths to forward slashes. This does not convert slashes in the glob pattern itself | +| `prepend` | `boolean` | `undefined` | String to prepend to the generated regex used for matching. | +| `regex` | `boolean` | `false` | Use regular expression rules for `+` (instead of matching literal `+`), and for stars that follow closing parentheses or brackets (as in `)*` and `]*`). | +| `strictBrackets` | `boolean` | `undefined` | Throw an error if brackets, braces, or parens are imbalanced. | +| `strictSlashes` | `boolean` | `undefined` | When true, picomatch won't match trailing slashes with single stars. | +| `unescape` | `boolean` | `undefined` | Remove backslashes preceding escaped characters in the glob pattern. By default, backslashes are retained. | +| `unixify` | `boolean` | `undefined` | Alias for `posixSlashes`, for backwards compatibility. | + +picomatch has automatic detection for regex positive and negative lookbehinds. If the pattern contains a negative lookbehind, you must be using Node.js >= 8.10 or else picomatch will throw an error. + +### Scan Options + +In addition to the main [picomatch options](#picomatch-options), the following options may also be used with the [.scan](#scan) method. + +| **Option** | **Type** | **Default value** | **Description** | +| --- | --- | --- | --- | +| `tokens` | `boolean` | `false` | When `true`, the returned object will include an array of tokens (objects), representing each path "segment" in the scanned glob pattern | +| `parts` | `boolean` | `false` | When `true`, the returned object will include an array of strings representing each path "segment" in the scanned glob pattern. This is automatically enabled when `options.tokens` is true | + +**Example** + +```js +const picomatch = require('picomatch'); +const result = picomatch.scan('!./foo/*.js', { tokens: true }); +console.log(result); +// { +// prefix: '!./', +// input: '!./foo/*.js', +// start: 3, +// base: 'foo', +// glob: '*.js', +// isBrace: false, +// isBracket: false, +// isGlob: true, +// isExtglob: false, +// isGlobstar: false, +// negated: true, +// maxDepth: 2, +// tokens: [ +// { value: '!./', depth: 0, isGlob: false, negated: true, isPrefix: true }, +// { value: 'foo', depth: 1, isGlob: false }, +// { value: '*.js', depth: 1, isGlob: true } +// ], +// slashes: [ 2, 6 ], +// parts: [ 'foo', '*.js' ] +// } +``` + +
      + +### Options Examples + +#### options.expandRange + +**Type**: `function` + +**Default**: `undefined` + +Custom function for expanding ranges in brace patterns. The [fill-range](https://github.com/jonschlinkert/fill-range) library is ideal for this purpose, or you can use custom code to do whatever you need. + +**Example** + +The following example shows how to create a glob that matches a folder + +```js +const fill = require('fill-range'); +const regex = pm.makeRe('foo/{01..25}/bar', { + expandRange(a, b) { + return `(${fill(a, b, { toRegex: true })})`; + } +}); + +console.log(regex); +//=> /^(?:foo\/((?:0[1-9]|1[0-9]|2[0-5]))\/bar)$/ + +console.log(regex.test('foo/00/bar')) // false +console.log(regex.test('foo/01/bar')) // true +console.log(regex.test('foo/10/bar')) // true +console.log(regex.test('foo/22/bar')) // true +console.log(regex.test('foo/25/bar')) // true +console.log(regex.test('foo/26/bar')) // false +``` + +#### options.format + +**Type**: `function` + +**Default**: `undefined` + +Custom function for formatting strings before they're matched. + +**Example** + +```js +// strip leading './' from strings +const format = str => str.replace(/^\.\//, ''); +const isMatch = picomatch('foo/*.js', { format }); +console.log(isMatch('./foo/bar.js')); //=> true +``` + +#### options.onMatch + +```js +const onMatch = ({ glob, regex, input, output }) => { + console.log({ glob, regex, input, output }); +}; + +const isMatch = picomatch('*', { onMatch }); +isMatch('foo'); +isMatch('bar'); +isMatch('baz'); +``` + +#### options.onIgnore + +```js +const onIgnore = ({ glob, regex, input, output }) => { + console.log({ glob, regex, input, output }); +}; + +const isMatch = picomatch('*', { onIgnore, ignore: 'f*' }); +isMatch('foo'); +isMatch('bar'); +isMatch('baz'); +``` + +#### options.onResult + +```js +const onResult = ({ glob, regex, input, output }) => { + console.log({ glob, regex, input, output }); +}; + +const isMatch = picomatch('*', { onResult, ignore: 'f*' }); +isMatch('foo'); +isMatch('bar'); +isMatch('baz'); +``` + +
      +
      + +## Globbing features + +* [Basic globbing](#basic-globbing) (Wildcard matching) +* [Advanced globbing](#advanced-globbing) (extglobs, posix brackets, brace matching) + +### Basic globbing + +| **Character** | **Description** | +| --- | --- | +| `*` | Matches any character zero or more times, excluding path separators. Does _not match_ path separators or hidden files or directories ("dotfiles"), unless explicitly enabled by setting the `dot` option to `true`. | +| `**` | Matches any character zero or more times, including path separators. Note that `**` will only match path separators (`/`, and `\\` on Windows) when they are the only characters in a path segment. Thus, `foo**/bar` is equivalent to `foo*/bar`, and `foo/a**b/bar` is equivalent to `foo/a*b/bar`, and _more than two_ consecutive stars in a glob path segment are regarded as _a single star_. Thus, `foo/***/bar` is equivalent to `foo/*/bar`. | +| `?` | Matches any character excluding path separators one time. Does _not match_ path separators or leading dots. | +| `[abc]` | Matches any characters inside the brackets. For example, `[abc]` would match the characters `a`, `b` or `c`, and nothing else. | + +#### Matching behavior vs. Bash + +Picomatch's matching features and expected results in unit tests are based on Bash's unit tests and the Bash 4.3 specification, with the following exceptions: + +* Bash will match `foo/bar/baz` with `*`. Picomatch only matches nested directories with `**`. +* Bash greedily matches with negated extglobs. For example, Bash 4.3 says that `!(foo)*` should match `foo` and `foobar`, since the trailing `*` bracktracks to match the preceding pattern. This is very memory-inefficient, and IMHO, also incorrect. Picomatch would return `false` for both `foo` and `foobar`. + +
      + +### Advanced globbing + +* [extglobs](#extglobs) +* [POSIX brackets](#posix-brackets) +* [Braces](#brace-expansion) + +#### Extglobs + +| **Pattern** | **Description** | +| --- | --- | +| `@(pattern)` | Match _only one_ consecutive occurrence of `pattern` | +| `*(pattern)` | Match _zero or more_ consecutive occurrences of `pattern` | +| `+(pattern)` | Match _one or more_ consecutive occurrences of `pattern` | +| `?(pattern)` | Match _zero or **one**_ consecutive occurrences of `pattern` | +| `!(pattern)` | Match _anything but_ `pattern` | + +**Examples** + +```js +const pm = require('picomatch'); + +// *(pattern) matches ZERO or more of "pattern" +console.log(pm.isMatch('a', 'a*(z)')); // true +console.log(pm.isMatch('az', 'a*(z)')); // true +console.log(pm.isMatch('azzz', 'a*(z)')); // true + +// +(pattern) matches ONE or more of "pattern" +console.log(pm.isMatch('a', 'a*(z)')); // true +console.log(pm.isMatch('az', 'a*(z)')); // true +console.log(pm.isMatch('azzz', 'a*(z)')); // true + +// supports multiple extglobs +console.log(pm.isMatch('foo.bar', '!(foo).!(bar)')); // false + +// supports nested extglobs +console.log(pm.isMatch('foo.bar', '!(!(foo)).!(!(bar))')); // true +``` + +#### POSIX brackets + +POSIX classes are disabled by default. Enable this feature by setting the `posix` option to true. + +**Enable POSIX bracket support** + +```js +console.log(pm.makeRe('[[:word:]]+', { posix: true })); +//=> /^(?:(?=.)[A-Za-z0-9_]+\/?)$/ +``` + +**Supported POSIX classes** + +The following named POSIX bracket expressions are supported: + +* `[:alnum:]` - Alphanumeric characters, equ `[a-zA-Z0-9]` +* `[:alpha:]` - Alphabetical characters, equivalent to `[a-zA-Z]`. +* `[:ascii:]` - ASCII characters, equivalent to `[\\x00-\\x7F]`. +* `[:blank:]` - Space and tab characters, equivalent to `[ \\t]`. +* `[:cntrl:]` - Control characters, equivalent to `[\\x00-\\x1F\\x7F]`. +* `[:digit:]` - Numerical digits, equivalent to `[0-9]`. +* `[:graph:]` - Graph characters, equivalent to `[\\x21-\\x7E]`. +* `[:lower:]` - Lowercase letters, equivalent to `[a-z]`. +* `[:print:]` - Print characters, equivalent to `[\\x20-\\x7E ]`. +* `[:punct:]` - Punctuation and symbols, equivalent to `[\\-!"#$%&\'()\\*+,./:;<=>?@[\\]^_`{|}~]`. +* `[:space:]` - Extended space characters, equivalent to `[ \\t\\r\\n\\v\\f]`. +* `[:upper:]` - Uppercase letters, equivalent to `[A-Z]`. +* `[:word:]` - Word characters (letters, numbers and underscores), equivalent to `[A-Za-z0-9_]`. +* `[:xdigit:]` - Hexadecimal digits, equivalent to `[A-Fa-f0-9]`. + +See the [Bash Reference Manual](https://www.gnu.org/software/bash/manual/html_node/Pattern-Matching.html) for more information. + +### Braces + +Picomatch does not do brace expansion. For [brace expansion](https://www.gnu.org/software/bash/manual/html_node/Brace-Expansion.html) and advanced matching with braces, use [micromatch](https://github.com/micromatch/micromatch) instead. Picomatch has very basic support for braces. + +### Matching special characters as literals + +If you wish to match the following special characters in a filepath, and you want to use these characters in your glob pattern, they must be escaped with backslashes or quotes: + +**Special Characters** + +Some characters that are used for matching in regular expressions are also regarded as valid file path characters on some platforms. + +To match any of the following characters as literals: `$^*+?()[] + +Examples: + +```js +console.log(pm.makeRe('foo/bar \\(1\\)')); +console.log(pm.makeRe('foo/bar \\(1\\)')); +``` + +
      +
      + +## Library Comparisons + +The following table shows which features are supported by [minimatch](https://github.com/isaacs/minimatch), [micromatch](https://github.com/micromatch/micromatch), [picomatch](https://github.com/micromatch/picomatch), [nanomatch](https://github.com/micromatch/nanomatch), [extglob](https://github.com/micromatch/extglob), [braces](https://github.com/micromatch/braces), and [expand-brackets](https://github.com/micromatch/expand-brackets). + +| **Feature** | `minimatch` | `micromatch` | `picomatch` | `nanomatch` | `extglob` | `braces` | `expand-brackets` | +| --- | --- | --- | --- | --- | --- | --- | --- | +| Wildcard matching (`*?+`) | ✔ | ✔ | ✔ | ✔ | - | - | - | +| Advancing globbing | ✔ | ✔ | ✔ | - | - | - | - | +| Brace _matching_ | ✔ | ✔ | ✔ | - | - | ✔ | - | +| Brace _expansion_ | ✔ | ✔ | - | - | - | ✔ | - | +| Extglobs | partial | ✔ | ✔ | - | ✔ | - | - | +| Posix brackets | - | ✔ | ✔ | - | - | - | ✔ | +| Regular expression syntax | - | ✔ | ✔ | ✔ | ✔ | - | ✔ | +| File system operations | - | - | - | - | - | - | - | + +
      +
      + +## Benchmarks + +Performance comparison of picomatch and minimatch. + +``` +# .makeRe star + picomatch x 1,993,050 ops/sec ±0.51% (91 runs sampled) + minimatch x 627,206 ops/sec ±1.96% (87 runs sampled)) + +# .makeRe star; dot=true + picomatch x 1,436,640 ops/sec ±0.62% (91 runs sampled) + minimatch x 525,876 ops/sec ±0.60% (88 runs sampled) + +# .makeRe globstar + picomatch x 1,592,742 ops/sec ±0.42% (90 runs sampled) + minimatch x 962,043 ops/sec ±1.76% (91 runs sampled)d) + +# .makeRe globstars + picomatch x 1,615,199 ops/sec ±0.35% (94 runs sampled) + minimatch x 477,179 ops/sec ±1.33% (91 runs sampled) + +# .makeRe with leading star + picomatch x 1,220,856 ops/sec ±0.40% (92 runs sampled) + minimatch x 453,564 ops/sec ±1.43% (94 runs sampled) + +# .makeRe - basic braces + picomatch x 392,067 ops/sec ±0.70% (90 runs sampled) + minimatch x 99,532 ops/sec ±2.03% (87 runs sampled)) +``` + +
      +
      + +## Philosophies + +The goal of this library is to be blazing fast, without compromising on accuracy. + +**Accuracy** + +The number one of goal of this library is accuracy. However, it's not unusual for different glob implementations to have different rules for matching behavior, even with simple wildcard matching. It gets increasingly more complicated when combinations of different features are combined, like when extglobs are combined with globstars, braces, slashes, and so on: `!(**/{a,b,*/c})`. + +Thus, given that there is no canonical glob specification to use as a single source of truth when differences of opinion arise regarding behavior, sometimes we have to implement our best judgement and rely on feedback from users to make improvements. + +**Performance** + +Although this library performs well in benchmarks, and in most cases it's faster than other popular libraries we benchmarked against, we will always choose accuracy over performance. It's not helpful to anyone if our library is faster at returning the wrong answer. + +
      +
      + +## About + +
      +Contributing + +Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new). + +Please read the [contributing guide](.github/contributing.md) for advice on opening issues, pull requests, and coding standards. + +
      + +
      +Running Tests + +Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command: + +```sh +npm install && npm test +``` + +
      + +
      +Building docs + +_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_ + +To generate the readme, run the following command: + +```sh +npm install -g verbose/verb#dev verb-generate-readme && verb +``` + +
      + +### Author + +**Jon Schlinkert** + +* [GitHub Profile](https://github.com/jonschlinkert) +* [Twitter Profile](https://twitter.com/jonschlinkert) +* [LinkedIn Profile](https://linkedin.com/in/jonschlinkert) + +### License + +Copyright © 2017-present, [Jon Schlinkert](https://github.com/jonschlinkert). +Released under the [MIT License](LICENSE). diff --git a/node_modules/picomatch/index.js b/node_modules/picomatch/index.js new file mode 100644 index 0000000..d2f2bc5 --- /dev/null +++ b/node_modules/picomatch/index.js @@ -0,0 +1,3 @@ +'use strict'; + +module.exports = require('./lib/picomatch'); diff --git a/node_modules/picomatch/lib/constants.js b/node_modules/picomatch/lib/constants.js new file mode 100644 index 0000000..a62ef38 --- /dev/null +++ b/node_modules/picomatch/lib/constants.js @@ -0,0 +1,179 @@ +'use strict'; + +const path = require('path'); +const WIN_SLASH = '\\\\/'; +const WIN_NO_SLASH = `[^${WIN_SLASH}]`; + +/** + * Posix glob regex + */ + +const DOT_LITERAL = '\\.'; +const PLUS_LITERAL = '\\+'; +const QMARK_LITERAL = '\\?'; +const SLASH_LITERAL = '\\/'; +const ONE_CHAR = '(?=.)'; +const QMARK = '[^/]'; +const END_ANCHOR = `(?:${SLASH_LITERAL}|$)`; +const START_ANCHOR = `(?:^|${SLASH_LITERAL})`; +const DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`; +const NO_DOT = `(?!${DOT_LITERAL})`; +const NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`; +const NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`; +const NO_DOTS_SLASH = `(?!${DOTS_SLASH})`; +const QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`; +const STAR = `${QMARK}*?`; + +const POSIX_CHARS = { + DOT_LITERAL, + PLUS_LITERAL, + QMARK_LITERAL, + SLASH_LITERAL, + ONE_CHAR, + QMARK, + END_ANCHOR, + DOTS_SLASH, + NO_DOT, + NO_DOTS, + NO_DOT_SLASH, + NO_DOTS_SLASH, + QMARK_NO_DOT, + STAR, + START_ANCHOR +}; + +/** + * Windows glob regex + */ + +const WINDOWS_CHARS = { + ...POSIX_CHARS, + + SLASH_LITERAL: `[${WIN_SLASH}]`, + QMARK: WIN_NO_SLASH, + STAR: `${WIN_NO_SLASH}*?`, + DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`, + NO_DOT: `(?!${DOT_LITERAL})`, + NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`, + NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`, + NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`, + QMARK_NO_DOT: `[^.${WIN_SLASH}]`, + START_ANCHOR: `(?:^|[${WIN_SLASH}])`, + END_ANCHOR: `(?:[${WIN_SLASH}]|$)` +}; + +/** + * POSIX Bracket Regex + */ + +const POSIX_REGEX_SOURCE = { + alnum: 'a-zA-Z0-9', + alpha: 'a-zA-Z', + ascii: '\\x00-\\x7F', + blank: ' \\t', + cntrl: '\\x00-\\x1F\\x7F', + digit: '0-9', + graph: '\\x21-\\x7E', + lower: 'a-z', + print: '\\x20-\\x7E ', + punct: '\\-!"#$%&\'()\\*+,./:;<=>?@[\\]^_`{|}~', + space: ' \\t\\r\\n\\v\\f', + upper: 'A-Z', + word: 'A-Za-z0-9_', + xdigit: 'A-Fa-f0-9' +}; + +module.exports = { + MAX_LENGTH: 1024 * 64, + POSIX_REGEX_SOURCE, + + // regular expressions + REGEX_BACKSLASH: /\\(?![*+?^${}(|)[\]])/g, + REGEX_NON_SPECIAL_CHARS: /^[^@![\].,$*+?^{}()|\\/]+/, + REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\]]/, + REGEX_SPECIAL_CHARS_BACKREF: /(\\?)((\W)(\3*))/g, + REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\]])/g, + REGEX_REMOVE_BACKSLASH: /(?:\[.*?[^\\]\]|\\(?=.))/g, + + // Replace globs with equivalent patterns to reduce parsing time. + REPLACEMENTS: { + '***': '*', + '**/**': '**', + '**/**/**': '**' + }, + + // Digits + CHAR_0: 48, /* 0 */ + CHAR_9: 57, /* 9 */ + + // Alphabet chars. + CHAR_UPPERCASE_A: 65, /* A */ + CHAR_LOWERCASE_A: 97, /* a */ + CHAR_UPPERCASE_Z: 90, /* Z */ + CHAR_LOWERCASE_Z: 122, /* z */ + + CHAR_LEFT_PARENTHESES: 40, /* ( */ + CHAR_RIGHT_PARENTHESES: 41, /* ) */ + + CHAR_ASTERISK: 42, /* * */ + + // Non-alphabetic chars. + CHAR_AMPERSAND: 38, /* & */ + CHAR_AT: 64, /* @ */ + CHAR_BACKWARD_SLASH: 92, /* \ */ + CHAR_CARRIAGE_RETURN: 13, /* \r */ + CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */ + CHAR_COLON: 58, /* : */ + CHAR_COMMA: 44, /* , */ + CHAR_DOT: 46, /* . */ + CHAR_DOUBLE_QUOTE: 34, /* " */ + CHAR_EQUAL: 61, /* = */ + CHAR_EXCLAMATION_MARK: 33, /* ! */ + CHAR_FORM_FEED: 12, /* \f */ + CHAR_FORWARD_SLASH: 47, /* / */ + CHAR_GRAVE_ACCENT: 96, /* ` */ + CHAR_HASH: 35, /* # */ + CHAR_HYPHEN_MINUS: 45, /* - */ + CHAR_LEFT_ANGLE_BRACKET: 60, /* < */ + CHAR_LEFT_CURLY_BRACE: 123, /* { */ + CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */ + CHAR_LINE_FEED: 10, /* \n */ + CHAR_NO_BREAK_SPACE: 160, /* \u00A0 */ + CHAR_PERCENT: 37, /* % */ + CHAR_PLUS: 43, /* + */ + CHAR_QUESTION_MARK: 63, /* ? */ + CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */ + CHAR_RIGHT_CURLY_BRACE: 125, /* } */ + CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */ + CHAR_SEMICOLON: 59, /* ; */ + CHAR_SINGLE_QUOTE: 39, /* ' */ + CHAR_SPACE: 32, /* */ + CHAR_TAB: 9, /* \t */ + CHAR_UNDERSCORE: 95, /* _ */ + CHAR_VERTICAL_LINE: 124, /* | */ + CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \uFEFF */ + + SEP: path.sep, + + /** + * Create EXTGLOB_CHARS + */ + + extglobChars(chars) { + return { + '!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` }, + '?': { type: 'qmark', open: '(?:', close: ')?' }, + '+': { type: 'plus', open: '(?:', close: ')+' }, + '*': { type: 'star', open: '(?:', close: ')*' }, + '@': { type: 'at', open: '(?:', close: ')' } + }; + }, + + /** + * Create GLOB_CHARS + */ + + globChars(win32) { + return win32 === true ? WINDOWS_CHARS : POSIX_CHARS; + } +}; diff --git a/node_modules/picomatch/lib/parse.js b/node_modules/picomatch/lib/parse.js new file mode 100644 index 0000000..58269d0 --- /dev/null +++ b/node_modules/picomatch/lib/parse.js @@ -0,0 +1,1091 @@ +'use strict'; + +const constants = require('./constants'); +const utils = require('./utils'); + +/** + * Constants + */ + +const { + MAX_LENGTH, + POSIX_REGEX_SOURCE, + REGEX_NON_SPECIAL_CHARS, + REGEX_SPECIAL_CHARS_BACKREF, + REPLACEMENTS +} = constants; + +/** + * Helpers + */ + +const expandRange = (args, options) => { + if (typeof options.expandRange === 'function') { + return options.expandRange(...args, options); + } + + args.sort(); + const value = `[${args.join('-')}]`; + + try { + /* eslint-disable-next-line no-new */ + new RegExp(value); + } catch (ex) { + return args.map(v => utils.escapeRegex(v)).join('..'); + } + + return value; +}; + +/** + * Create the message for a syntax error + */ + +const syntaxError = (type, char) => { + return `Missing ${type}: "${char}" - use "\\\\${char}" to match literal characters`; +}; + +/** + * Parse the given input string. + * @param {String} input + * @param {Object} options + * @return {Object} + */ + +const parse = (input, options) => { + if (typeof input !== 'string') { + throw new TypeError('Expected a string'); + } + + input = REPLACEMENTS[input] || input; + + const opts = { ...options }; + const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; + + let len = input.length; + if (len > max) { + throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`); + } + + const bos = { type: 'bos', value: '', output: opts.prepend || '' }; + const tokens = [bos]; + + const capture = opts.capture ? '' : '?:'; + const win32 = utils.isWindows(options); + + // create constants based on platform, for windows or posix + const PLATFORM_CHARS = constants.globChars(win32); + const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS); + + const { + DOT_LITERAL, + PLUS_LITERAL, + SLASH_LITERAL, + ONE_CHAR, + DOTS_SLASH, + NO_DOT, + NO_DOT_SLASH, + NO_DOTS_SLASH, + QMARK, + QMARK_NO_DOT, + STAR, + START_ANCHOR + } = PLATFORM_CHARS; + + const globstar = opts => { + return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`; + }; + + const nodot = opts.dot ? '' : NO_DOT; + const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT; + let star = opts.bash === true ? globstar(opts) : STAR; + + if (opts.capture) { + star = `(${star})`; + } + + // minimatch options support + if (typeof opts.noext === 'boolean') { + opts.noextglob = opts.noext; + } + + const state = { + input, + index: -1, + start: 0, + dot: opts.dot === true, + consumed: '', + output: '', + prefix: '', + backtrack: false, + negated: false, + brackets: 0, + braces: 0, + parens: 0, + quotes: 0, + globstar: false, + tokens + }; + + input = utils.removePrefix(input, state); + len = input.length; + + const extglobs = []; + const braces = []; + const stack = []; + let prev = bos; + let value; + + /** + * Tokenizing helpers + */ + + const eos = () => state.index === len - 1; + const peek = state.peek = (n = 1) => input[state.index + n]; + const advance = state.advance = () => input[++state.index] || ''; + const remaining = () => input.slice(state.index + 1); + const consume = (value = '', num = 0) => { + state.consumed += value; + state.index += num; + }; + + const append = token => { + state.output += token.output != null ? token.output : token.value; + consume(token.value); + }; + + const negate = () => { + let count = 1; + + while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) { + advance(); + state.start++; + count++; + } + + if (count % 2 === 0) { + return false; + } + + state.negated = true; + state.start++; + return true; + }; + + const increment = type => { + state[type]++; + stack.push(type); + }; + + const decrement = type => { + state[type]--; + stack.pop(); + }; + + /** + * Push tokens onto the tokens array. This helper speeds up + * tokenizing by 1) helping us avoid backtracking as much as possible, + * and 2) helping us avoid creating extra tokens when consecutive + * characters are plain text. This improves performance and simplifies + * lookbehinds. + */ + + const push = tok => { + if (prev.type === 'globstar') { + const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace'); + const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren')); + + if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) { + state.output = state.output.slice(0, -prev.output.length); + prev.type = 'star'; + prev.value = '*'; + prev.output = star; + state.output += prev.output; + } + } + + if (extglobs.length && tok.type !== 'paren') { + extglobs[extglobs.length - 1].inner += tok.value; + } + + if (tok.value || tok.output) append(tok); + if (prev && prev.type === 'text' && tok.type === 'text') { + prev.value += tok.value; + prev.output = (prev.output || '') + tok.value; + return; + } + + tok.prev = prev; + tokens.push(tok); + prev = tok; + }; + + const extglobOpen = (type, value) => { + const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' }; + + token.prev = prev; + token.parens = state.parens; + token.output = state.output; + const output = (opts.capture ? '(' : '') + token.open; + + increment('parens'); + push({ type, value, output: state.output ? '' : ONE_CHAR }); + push({ type: 'paren', extglob: true, value: advance(), output }); + extglobs.push(token); + }; + + const extglobClose = token => { + let output = token.close + (opts.capture ? ')' : ''); + let rest; + + if (token.type === 'negate') { + let extglobStar = star; + + if (token.inner && token.inner.length > 1 && token.inner.includes('/')) { + extglobStar = globstar(opts); + } + + if (extglobStar !== star || eos() || /^\)+$/.test(remaining())) { + output = token.close = `)$))${extglobStar}`; + } + + if (token.inner.includes('*') && (rest = remaining()) && /^\.[^\\/.]+$/.test(rest)) { + // Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis. + // In this case, we need to parse the string and use it in the output of the original pattern. + // Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`. + // + // Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`. + const expression = parse(rest, { ...options, fastpaths: false }).output; + + output = token.close = `)${expression})${extglobStar})`; + } + + if (token.prev.type === 'bos') { + state.negatedExtglob = true; + } + } + + push({ type: 'paren', extglob: true, value, output }); + decrement('parens'); + }; + + /** + * Fast paths + */ + + if (opts.fastpaths !== false && !/(^[*!]|[/()[\]{}"])/.test(input)) { + let backslashes = false; + + let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => { + if (first === '\\') { + backslashes = true; + return m; + } + + if (first === '?') { + if (esc) { + return esc + first + (rest ? QMARK.repeat(rest.length) : ''); + } + if (index === 0) { + return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : ''); + } + return QMARK.repeat(chars.length); + } + + if (first === '.') { + return DOT_LITERAL.repeat(chars.length); + } + + if (first === '*') { + if (esc) { + return esc + first + (rest ? star : ''); + } + return star; + } + return esc ? m : `\\${m}`; + }); + + if (backslashes === true) { + if (opts.unescape === true) { + output = output.replace(/\\/g, ''); + } else { + output = output.replace(/\\+/g, m => { + return m.length % 2 === 0 ? '\\\\' : (m ? '\\' : ''); + }); + } + } + + if (output === input && opts.contains === true) { + state.output = input; + return state; + } + + state.output = utils.wrapOutput(output, state, options); + return state; + } + + /** + * Tokenize input until we reach end-of-string + */ + + while (!eos()) { + value = advance(); + + if (value === '\u0000') { + continue; + } + + /** + * Escaped characters + */ + + if (value === '\\') { + const next = peek(); + + if (next === '/' && opts.bash !== true) { + continue; + } + + if (next === '.' || next === ';') { + continue; + } + + if (!next) { + value += '\\'; + push({ type: 'text', value }); + continue; + } + + // collapse slashes to reduce potential for exploits + const match = /^\\+/.exec(remaining()); + let slashes = 0; + + if (match && match[0].length > 2) { + slashes = match[0].length; + state.index += slashes; + if (slashes % 2 !== 0) { + value += '\\'; + } + } + + if (opts.unescape === true) { + value = advance(); + } else { + value += advance(); + } + + if (state.brackets === 0) { + push({ type: 'text', value }); + continue; + } + } + + /** + * If we're inside a regex character class, continue + * until we reach the closing bracket. + */ + + if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) { + if (opts.posix !== false && value === ':') { + const inner = prev.value.slice(1); + if (inner.includes('[')) { + prev.posix = true; + + if (inner.includes(':')) { + const idx = prev.value.lastIndexOf('['); + const pre = prev.value.slice(0, idx); + const rest = prev.value.slice(idx + 2); + const posix = POSIX_REGEX_SOURCE[rest]; + if (posix) { + prev.value = pre + posix; + state.backtrack = true; + advance(); + + if (!bos.output && tokens.indexOf(prev) === 1) { + bos.output = ONE_CHAR; + } + continue; + } + } + } + } + + if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) { + value = `\\${value}`; + } + + if (value === ']' && (prev.value === '[' || prev.value === '[^')) { + value = `\\${value}`; + } + + if (opts.posix === true && value === '!' && prev.value === '[') { + value = '^'; + } + + prev.value += value; + append({ value }); + continue; + } + + /** + * If we're inside a quoted string, continue + * until we reach the closing double quote. + */ + + if (state.quotes === 1 && value !== '"') { + value = utils.escapeRegex(value); + prev.value += value; + append({ value }); + continue; + } + + /** + * Double quotes + */ + + if (value === '"') { + state.quotes = state.quotes === 1 ? 0 : 1; + if (opts.keepQuotes === true) { + push({ type: 'text', value }); + } + continue; + } + + /** + * Parentheses + */ + + if (value === '(') { + increment('parens'); + push({ type: 'paren', value }); + continue; + } + + if (value === ')') { + if (state.parens === 0 && opts.strictBrackets === true) { + throw new SyntaxError(syntaxError('opening', '(')); + } + + const extglob = extglobs[extglobs.length - 1]; + if (extglob && state.parens === extglob.parens + 1) { + extglobClose(extglobs.pop()); + continue; + } + + push({ type: 'paren', value, output: state.parens ? ')' : '\\)' }); + decrement('parens'); + continue; + } + + /** + * Square brackets + */ + + if (value === '[') { + if (opts.nobracket === true || !remaining().includes(']')) { + if (opts.nobracket !== true && opts.strictBrackets === true) { + throw new SyntaxError(syntaxError('closing', ']')); + } + + value = `\\${value}`; + } else { + increment('brackets'); + } + + push({ type: 'bracket', value }); + continue; + } + + if (value === ']') { + if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) { + push({ type: 'text', value, output: `\\${value}` }); + continue; + } + + if (state.brackets === 0) { + if (opts.strictBrackets === true) { + throw new SyntaxError(syntaxError('opening', '[')); + } + + push({ type: 'text', value, output: `\\${value}` }); + continue; + } + + decrement('brackets'); + + const prevValue = prev.value.slice(1); + if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) { + value = `/${value}`; + } + + prev.value += value; + append({ value }); + + // when literal brackets are explicitly disabled + // assume we should match with a regex character class + if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) { + continue; + } + + const escaped = utils.escapeRegex(prev.value); + state.output = state.output.slice(0, -prev.value.length); + + // when literal brackets are explicitly enabled + // assume we should escape the brackets to match literal characters + if (opts.literalBrackets === true) { + state.output += escaped; + prev.value = escaped; + continue; + } + + // when the user specifies nothing, try to match both + prev.value = `(${capture}${escaped}|${prev.value})`; + state.output += prev.value; + continue; + } + + /** + * Braces + */ + + if (value === '{' && opts.nobrace !== true) { + increment('braces'); + + const open = { + type: 'brace', + value, + output: '(', + outputIndex: state.output.length, + tokensIndex: state.tokens.length + }; + + braces.push(open); + push(open); + continue; + } + + if (value === '}') { + const brace = braces[braces.length - 1]; + + if (opts.nobrace === true || !brace) { + push({ type: 'text', value, output: value }); + continue; + } + + let output = ')'; + + if (brace.dots === true) { + const arr = tokens.slice(); + const range = []; + + for (let i = arr.length - 1; i >= 0; i--) { + tokens.pop(); + if (arr[i].type === 'brace') { + break; + } + if (arr[i].type !== 'dots') { + range.unshift(arr[i].value); + } + } + + output = expandRange(range, opts); + state.backtrack = true; + } + + if (brace.comma !== true && brace.dots !== true) { + const out = state.output.slice(0, brace.outputIndex); + const toks = state.tokens.slice(brace.tokensIndex); + brace.value = brace.output = '\\{'; + value = output = '\\}'; + state.output = out; + for (const t of toks) { + state.output += (t.output || t.value); + } + } + + push({ type: 'brace', value, output }); + decrement('braces'); + braces.pop(); + continue; + } + + /** + * Pipes + */ + + if (value === '|') { + if (extglobs.length > 0) { + extglobs[extglobs.length - 1].conditions++; + } + push({ type: 'text', value }); + continue; + } + + /** + * Commas + */ + + if (value === ',') { + let output = value; + + const brace = braces[braces.length - 1]; + if (brace && stack[stack.length - 1] === 'braces') { + brace.comma = true; + output = '|'; + } + + push({ type: 'comma', value, output }); + continue; + } + + /** + * Slashes + */ + + if (value === '/') { + // if the beginning of the glob is "./", advance the start + // to the current index, and don't add the "./" characters + // to the state. This greatly simplifies lookbehinds when + // checking for BOS characters like "!" and "." (not "./") + if (prev.type === 'dot' && state.index === state.start + 1) { + state.start = state.index + 1; + state.consumed = ''; + state.output = ''; + tokens.pop(); + prev = bos; // reset "prev" to the first token + continue; + } + + push({ type: 'slash', value, output: SLASH_LITERAL }); + continue; + } + + /** + * Dots + */ + + if (value === '.') { + if (state.braces > 0 && prev.type === 'dot') { + if (prev.value === '.') prev.output = DOT_LITERAL; + const brace = braces[braces.length - 1]; + prev.type = 'dots'; + prev.output += value; + prev.value += value; + brace.dots = true; + continue; + } + + if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') { + push({ type: 'text', value, output: DOT_LITERAL }); + continue; + } + + push({ type: 'dot', value, output: DOT_LITERAL }); + continue; + } + + /** + * Question marks + */ + + if (value === '?') { + const isGroup = prev && prev.value === '('; + if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { + extglobOpen('qmark', value); + continue; + } + + if (prev && prev.type === 'paren') { + const next = peek(); + let output = value; + + if (next === '<' && !utils.supportsLookbehinds()) { + throw new Error('Node.js v10 or higher is required for regex lookbehinds'); + } + + if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\w+>)/.test(remaining()))) { + output = `\\${value}`; + } + + push({ type: 'text', value, output }); + continue; + } + + if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) { + push({ type: 'qmark', value, output: QMARK_NO_DOT }); + continue; + } + + push({ type: 'qmark', value, output: QMARK }); + continue; + } + + /** + * Exclamation + */ + + if (value === '!') { + if (opts.noextglob !== true && peek() === '(') { + if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) { + extglobOpen('negate', value); + continue; + } + } + + if (opts.nonegate !== true && state.index === 0) { + negate(); + continue; + } + } + + /** + * Plus + */ + + if (value === '+') { + if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { + extglobOpen('plus', value); + continue; + } + + if ((prev && prev.value === '(') || opts.regex === false) { + push({ type: 'plus', value, output: PLUS_LITERAL }); + continue; + } + + if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) { + push({ type: 'plus', value }); + continue; + } + + push({ type: 'plus', value: PLUS_LITERAL }); + continue; + } + + /** + * Plain text + */ + + if (value === '@') { + if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') { + push({ type: 'at', extglob: true, value, output: '' }); + continue; + } + + push({ type: 'text', value }); + continue; + } + + /** + * Plain text + */ + + if (value !== '*') { + if (value === '$' || value === '^') { + value = `\\${value}`; + } + + const match = REGEX_NON_SPECIAL_CHARS.exec(remaining()); + if (match) { + value += match[0]; + state.index += match[0].length; + } + + push({ type: 'text', value }); + continue; + } + + /** + * Stars + */ + + if (prev && (prev.type === 'globstar' || prev.star === true)) { + prev.type = 'star'; + prev.star = true; + prev.value += value; + prev.output = star; + state.backtrack = true; + state.globstar = true; + consume(value); + continue; + } + + let rest = remaining(); + if (opts.noextglob !== true && /^\([^?]/.test(rest)) { + extglobOpen('star', value); + continue; + } + + if (prev.type === 'star') { + if (opts.noglobstar === true) { + consume(value); + continue; + } + + const prior = prev.prev; + const before = prior.prev; + const isStart = prior.type === 'slash' || prior.type === 'bos'; + const afterStar = before && (before.type === 'star' || before.type === 'globstar'); + + if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) { + push({ type: 'star', value, output: '' }); + continue; + } + + const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace'); + const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren'); + if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) { + push({ type: 'star', value, output: '' }); + continue; + } + + // strip consecutive `/**/` + while (rest.slice(0, 3) === '/**') { + const after = input[state.index + 4]; + if (after && after !== '/') { + break; + } + rest = rest.slice(3); + consume('/**', 3); + } + + if (prior.type === 'bos' && eos()) { + prev.type = 'globstar'; + prev.value += value; + prev.output = globstar(opts); + state.output = prev.output; + state.globstar = true; + consume(value); + continue; + } + + if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) { + state.output = state.output.slice(0, -(prior.output + prev.output).length); + prior.output = `(?:${prior.output}`; + + prev.type = 'globstar'; + prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)'); + prev.value += value; + state.globstar = true; + state.output += prior.output + prev.output; + consume(value); + continue; + } + + if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') { + const end = rest[1] !== void 0 ? '|$' : ''; + + state.output = state.output.slice(0, -(prior.output + prev.output).length); + prior.output = `(?:${prior.output}`; + + prev.type = 'globstar'; + prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`; + prev.value += value; + + state.output += prior.output + prev.output; + state.globstar = true; + + consume(value + advance()); + + push({ type: 'slash', value: '/', output: '' }); + continue; + } + + if (prior.type === 'bos' && rest[0] === '/') { + prev.type = 'globstar'; + prev.value += value; + prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`; + state.output = prev.output; + state.globstar = true; + consume(value + advance()); + push({ type: 'slash', value: '/', output: '' }); + continue; + } + + // remove single star from output + state.output = state.output.slice(0, -prev.output.length); + + // reset previous token to globstar + prev.type = 'globstar'; + prev.output = globstar(opts); + prev.value += value; + + // reset output with globstar + state.output += prev.output; + state.globstar = true; + consume(value); + continue; + } + + const token = { type: 'star', value, output: star }; + + if (opts.bash === true) { + token.output = '.*?'; + if (prev.type === 'bos' || prev.type === 'slash') { + token.output = nodot + token.output; + } + push(token); + continue; + } + + if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) { + token.output = value; + push(token); + continue; + } + + if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') { + if (prev.type === 'dot') { + state.output += NO_DOT_SLASH; + prev.output += NO_DOT_SLASH; + + } else if (opts.dot === true) { + state.output += NO_DOTS_SLASH; + prev.output += NO_DOTS_SLASH; + + } else { + state.output += nodot; + prev.output += nodot; + } + + if (peek() !== '*') { + state.output += ONE_CHAR; + prev.output += ONE_CHAR; + } + } + + push(token); + } + + while (state.brackets > 0) { + if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']')); + state.output = utils.escapeLast(state.output, '['); + decrement('brackets'); + } + + while (state.parens > 0) { + if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')')); + state.output = utils.escapeLast(state.output, '('); + decrement('parens'); + } + + while (state.braces > 0) { + if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}')); + state.output = utils.escapeLast(state.output, '{'); + decrement('braces'); + } + + if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) { + push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` }); + } + + // rebuild the output if we had to backtrack at any point + if (state.backtrack === true) { + state.output = ''; + + for (const token of state.tokens) { + state.output += token.output != null ? token.output : token.value; + + if (token.suffix) { + state.output += token.suffix; + } + } + } + + return state; +}; + +/** + * Fast paths for creating regular expressions for common glob patterns. + * This can significantly speed up processing and has very little downside + * impact when none of the fast paths match. + */ + +parse.fastpaths = (input, options) => { + const opts = { ...options }; + const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH; + const len = input.length; + if (len > max) { + throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`); + } + + input = REPLACEMENTS[input] || input; + const win32 = utils.isWindows(options); + + // create constants based on platform, for windows or posix + const { + DOT_LITERAL, + SLASH_LITERAL, + ONE_CHAR, + DOTS_SLASH, + NO_DOT, + NO_DOTS, + NO_DOTS_SLASH, + STAR, + START_ANCHOR + } = constants.globChars(win32); + + const nodot = opts.dot ? NO_DOTS : NO_DOT; + const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT; + const capture = opts.capture ? '' : '?:'; + const state = { negated: false, prefix: '' }; + let star = opts.bash === true ? '.*?' : STAR; + + if (opts.capture) { + star = `(${star})`; + } + + const globstar = opts => { + if (opts.noglobstar === true) return star; + return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`; + }; + + const create = str => { + switch (str) { + case '*': + return `${nodot}${ONE_CHAR}${star}`; + + case '.*': + return `${DOT_LITERAL}${ONE_CHAR}${star}`; + + case '*.*': + return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`; + + case '*/*': + return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`; + + case '**': + return nodot + globstar(opts); + + case '**/*': + return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`; + + case '**/*.*': + return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`; + + case '**/.*': + return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`; + + default: { + const match = /^(.*?)\.(\w+)$/.exec(str); + if (!match) return; + + const source = create(match[1]); + if (!source) return; + + return source + DOT_LITERAL + match[2]; + } + } + }; + + const output = utils.removePrefix(input, state); + let source = create(output); + + if (source && opts.strictSlashes !== true) { + source += `${SLASH_LITERAL}?`; + } + + return source; +}; + +module.exports = parse; diff --git a/node_modules/picomatch/lib/picomatch.js b/node_modules/picomatch/lib/picomatch.js new file mode 100644 index 0000000..782d809 --- /dev/null +++ b/node_modules/picomatch/lib/picomatch.js @@ -0,0 +1,342 @@ +'use strict'; + +const path = require('path'); +const scan = require('./scan'); +const parse = require('./parse'); +const utils = require('./utils'); +const constants = require('./constants'); +const isObject = val => val && typeof val === 'object' && !Array.isArray(val); + +/** + * Creates a matcher function from one or more glob patterns. The + * returned function takes a string to match as its first argument, + * and returns true if the string is a match. The returned matcher + * function also takes a boolean as the second argument that, when true, + * returns an object with additional information. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch(glob[, options]); + * + * const isMatch = picomatch('*.!(*a)'); + * console.log(isMatch('a.a')); //=> false + * console.log(isMatch('a.b')); //=> true + * ``` + * @name picomatch + * @param {String|Array} `globs` One or more glob patterns. + * @param {Object=} `options` + * @return {Function=} Returns a matcher function. + * @api public + */ + +const picomatch = (glob, options, returnState = false) => { + if (Array.isArray(glob)) { + const fns = glob.map(input => picomatch(input, options, returnState)); + const arrayMatcher = str => { + for (const isMatch of fns) { + const state = isMatch(str); + if (state) return state; + } + return false; + }; + return arrayMatcher; + } + + const isState = isObject(glob) && glob.tokens && glob.input; + + if (glob === '' || (typeof glob !== 'string' && !isState)) { + throw new TypeError('Expected pattern to be a non-empty string'); + } + + const opts = options || {}; + const posix = utils.isWindows(options); + const regex = isState + ? picomatch.compileRe(glob, options) + : picomatch.makeRe(glob, options, false, true); + + const state = regex.state; + delete regex.state; + + let isIgnored = () => false; + if (opts.ignore) { + const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null }; + isIgnored = picomatch(opts.ignore, ignoreOpts, returnState); + } + + const matcher = (input, returnObject = false) => { + const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix }); + const result = { glob, state, regex, posix, input, output, match, isMatch }; + + if (typeof opts.onResult === 'function') { + opts.onResult(result); + } + + if (isMatch === false) { + result.isMatch = false; + return returnObject ? result : false; + } + + if (isIgnored(input)) { + if (typeof opts.onIgnore === 'function') { + opts.onIgnore(result); + } + result.isMatch = false; + return returnObject ? result : false; + } + + if (typeof opts.onMatch === 'function') { + opts.onMatch(result); + } + return returnObject ? result : true; + }; + + if (returnState) { + matcher.state = state; + } + + return matcher; +}; + +/** + * Test `input` with the given `regex`. This is used by the main + * `picomatch()` function to test the input string. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch.test(input, regex[, options]); + * + * console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\/([^/]*?))$/)); + * // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' } + * ``` + * @param {String} `input` String to test. + * @param {RegExp} `regex` + * @return {Object} Returns an object with matching info. + * @api public + */ + +picomatch.test = (input, regex, options, { glob, posix } = {}) => { + if (typeof input !== 'string') { + throw new TypeError('Expected input to be a string'); + } + + if (input === '') { + return { isMatch: false, output: '' }; + } + + const opts = options || {}; + const format = opts.format || (posix ? utils.toPosixSlashes : null); + let match = input === glob; + let output = (match && format) ? format(input) : input; + + if (match === false) { + output = format ? format(input) : input; + match = output === glob; + } + + if (match === false || opts.capture === true) { + if (opts.matchBase === true || opts.basename === true) { + match = picomatch.matchBase(input, regex, options, posix); + } else { + match = regex.exec(output); + } + } + + return { isMatch: Boolean(match), match, output }; +}; + +/** + * Match the basename of a filepath. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch.matchBase(input, glob[, options]); + * console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true + * ``` + * @param {String} `input` String to test. + * @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe). + * @return {Boolean} + * @api public + */ + +picomatch.matchBase = (input, glob, options, posix = utils.isWindows(options)) => { + const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options); + return regex.test(path.basename(input)); +}; + +/** + * Returns true if **any** of the given glob `patterns` match the specified `string`. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch.isMatch(string, patterns[, options]); + * + * console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true + * console.log(picomatch.isMatch('a.a', 'b.*')); //=> false + * ``` + * @param {String|Array} str The string to test. + * @param {String|Array} patterns One or more glob patterns to use for matching. + * @param {Object} [options] See available [options](#options). + * @return {Boolean} Returns true if any patterns match `str` + * @api public + */ + +picomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str); + +/** + * Parse a glob pattern to create the source string for a regular + * expression. + * + * ```js + * const picomatch = require('picomatch'); + * const result = picomatch.parse(pattern[, options]); + * ``` + * @param {String} `pattern` + * @param {Object} `options` + * @return {Object} Returns an object with useful properties and output to be used as a regex source string. + * @api public + */ + +picomatch.parse = (pattern, options) => { + if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options)); + return parse(pattern, { ...options, fastpaths: false }); +}; + +/** + * Scan a glob pattern to separate the pattern into segments. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch.scan(input[, options]); + * + * const result = picomatch.scan('!./foo/*.js'); + * console.log(result); + * { prefix: '!./', + * input: '!./foo/*.js', + * start: 3, + * base: 'foo', + * glob: '*.js', + * isBrace: false, + * isBracket: false, + * isGlob: true, + * isExtglob: false, + * isGlobstar: false, + * negated: true } + * ``` + * @param {String} `input` Glob pattern to scan. + * @param {Object} `options` + * @return {Object} Returns an object with + * @api public + */ + +picomatch.scan = (input, options) => scan(input, options); + +/** + * Compile a regular expression from the `state` object returned by the + * [parse()](#parse) method. + * + * @param {Object} `state` + * @param {Object} `options` + * @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser. + * @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging. + * @return {RegExp} + * @api public + */ + +picomatch.compileRe = (state, options, returnOutput = false, returnState = false) => { + if (returnOutput === true) { + return state.output; + } + + const opts = options || {}; + const prepend = opts.contains ? '' : '^'; + const append = opts.contains ? '' : '$'; + + let source = `${prepend}(?:${state.output})${append}`; + if (state && state.negated === true) { + source = `^(?!${source}).*$`; + } + + const regex = picomatch.toRegex(source, options); + if (returnState === true) { + regex.state = state; + } + + return regex; +}; + +/** + * Create a regular expression from a parsed glob pattern. + * + * ```js + * const picomatch = require('picomatch'); + * const state = picomatch.parse('*.js'); + * // picomatch.compileRe(state[, options]); + * + * console.log(picomatch.compileRe(state)); + * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ + * ``` + * @param {String} `state` The object returned from the `.parse` method. + * @param {Object} `options` + * @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result. + * @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression. + * @return {RegExp} Returns a regex created from the given pattern. + * @api public + */ + +picomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => { + if (!input || typeof input !== 'string') { + throw new TypeError('Expected a non-empty string'); + } + + let parsed = { negated: false, fastpaths: true }; + + if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) { + parsed.output = parse.fastpaths(input, options); + } + + if (!parsed.output) { + parsed = parse(input, options); + } + + return picomatch.compileRe(parsed, options, returnOutput, returnState); +}; + +/** + * Create a regular expression from the given regex source string. + * + * ```js + * const picomatch = require('picomatch'); + * // picomatch.toRegex(source[, options]); + * + * const { output } = picomatch.parse('*.js'); + * console.log(picomatch.toRegex(output)); + * //=> /^(?:(?!\.)(?=.)[^/]*?\.js)$/ + * ``` + * @param {String} `source` Regular expression source string. + * @param {Object} `options` + * @return {RegExp} + * @api public + */ + +picomatch.toRegex = (source, options) => { + try { + const opts = options || {}; + return new RegExp(source, opts.flags || (opts.nocase ? 'i' : '')); + } catch (err) { + if (options && options.debug === true) throw err; + return /$^/; + } +}; + +/** + * Picomatch constants. + * @return {Object} + */ + +picomatch.constants = constants; + +/** + * Expose "picomatch" + */ + +module.exports = picomatch; diff --git a/node_modules/picomatch/lib/scan.js b/node_modules/picomatch/lib/scan.js new file mode 100644 index 0000000..e59cd7a --- /dev/null +++ b/node_modules/picomatch/lib/scan.js @@ -0,0 +1,391 @@ +'use strict'; + +const utils = require('./utils'); +const { + CHAR_ASTERISK, /* * */ + CHAR_AT, /* @ */ + CHAR_BACKWARD_SLASH, /* \ */ + CHAR_COMMA, /* , */ + CHAR_DOT, /* . */ + CHAR_EXCLAMATION_MARK, /* ! */ + CHAR_FORWARD_SLASH, /* / */ + CHAR_LEFT_CURLY_BRACE, /* { */ + CHAR_LEFT_PARENTHESES, /* ( */ + CHAR_LEFT_SQUARE_BRACKET, /* [ */ + CHAR_PLUS, /* + */ + CHAR_QUESTION_MARK, /* ? */ + CHAR_RIGHT_CURLY_BRACE, /* } */ + CHAR_RIGHT_PARENTHESES, /* ) */ + CHAR_RIGHT_SQUARE_BRACKET /* ] */ +} = require('./constants'); + +const isPathSeparator = code => { + return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH; +}; + +const depth = token => { + if (token.isPrefix !== true) { + token.depth = token.isGlobstar ? Infinity : 1; + } +}; + +/** + * Quickly scans a glob pattern and returns an object with a handful of + * useful properties, like `isGlob`, `path` (the leading non-glob, if it exists), + * `glob` (the actual pattern), `negated` (true if the path starts with `!` but not + * with `!(`) and `negatedExtglob` (true if the path starts with `!(`). + * + * ```js + * const pm = require('picomatch'); + * console.log(pm.scan('foo/bar/*.js')); + * { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' } + * ``` + * @param {String} `str` + * @param {Object} `options` + * @return {Object} Returns an object with tokens and regex source string. + * @api public + */ + +const scan = (input, options) => { + const opts = options || {}; + + const length = input.length - 1; + const scanToEnd = opts.parts === true || opts.scanToEnd === true; + const slashes = []; + const tokens = []; + const parts = []; + + let str = input; + let index = -1; + let start = 0; + let lastIndex = 0; + let isBrace = false; + let isBracket = false; + let isGlob = false; + let isExtglob = false; + let isGlobstar = false; + let braceEscaped = false; + let backslashes = false; + let negated = false; + let negatedExtglob = false; + let finished = false; + let braces = 0; + let prev; + let code; + let token = { value: '', depth: 0, isGlob: false }; + + const eos = () => index >= length; + const peek = () => str.charCodeAt(index + 1); + const advance = () => { + prev = code; + return str.charCodeAt(++index); + }; + + while (index < length) { + code = advance(); + let next; + + if (code === CHAR_BACKWARD_SLASH) { + backslashes = token.backslashes = true; + code = advance(); + + if (code === CHAR_LEFT_CURLY_BRACE) { + braceEscaped = true; + } + continue; + } + + if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) { + braces++; + + while (eos() !== true && (code = advance())) { + if (code === CHAR_BACKWARD_SLASH) { + backslashes = token.backslashes = true; + advance(); + continue; + } + + if (code === CHAR_LEFT_CURLY_BRACE) { + braces++; + continue; + } + + if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) { + isBrace = token.isBrace = true; + isGlob = token.isGlob = true; + finished = true; + + if (scanToEnd === true) { + continue; + } + + break; + } + + if (braceEscaped !== true && code === CHAR_COMMA) { + isBrace = token.isBrace = true; + isGlob = token.isGlob = true; + finished = true; + + if (scanToEnd === true) { + continue; + } + + break; + } + + if (code === CHAR_RIGHT_CURLY_BRACE) { + braces--; + + if (braces === 0) { + braceEscaped = false; + isBrace = token.isBrace = true; + finished = true; + break; + } + } + } + + if (scanToEnd === true) { + continue; + } + + break; + } + + if (code === CHAR_FORWARD_SLASH) { + slashes.push(index); + tokens.push(token); + token = { value: '', depth: 0, isGlob: false }; + + if (finished === true) continue; + if (prev === CHAR_DOT && index === (start + 1)) { + start += 2; + continue; + } + + lastIndex = index + 1; + continue; + } + + if (opts.noext !== true) { + const isExtglobChar = code === CHAR_PLUS + || code === CHAR_AT + || code === CHAR_ASTERISK + || code === CHAR_QUESTION_MARK + || code === CHAR_EXCLAMATION_MARK; + + if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) { + isGlob = token.isGlob = true; + isExtglob = token.isExtglob = true; + finished = true; + if (code === CHAR_EXCLAMATION_MARK && index === start) { + negatedExtglob = true; + } + + if (scanToEnd === true) { + while (eos() !== true && (code = advance())) { + if (code === CHAR_BACKWARD_SLASH) { + backslashes = token.backslashes = true; + code = advance(); + continue; + } + + if (code === CHAR_RIGHT_PARENTHESES) { + isGlob = token.isGlob = true; + finished = true; + break; + } + } + continue; + } + break; + } + } + + if (code === CHAR_ASTERISK) { + if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true; + isGlob = token.isGlob = true; + finished = true; + + if (scanToEnd === true) { + continue; + } + break; + } + + if (code === CHAR_QUESTION_MARK) { + isGlob = token.isGlob = true; + finished = true; + + if (scanToEnd === true) { + continue; + } + break; + } + + if (code === CHAR_LEFT_SQUARE_BRACKET) { + while (eos() !== true && (next = advance())) { + if (next === CHAR_BACKWARD_SLASH) { + backslashes = token.backslashes = true; + advance(); + continue; + } + + if (next === CHAR_RIGHT_SQUARE_BRACKET) { + isBracket = token.isBracket = true; + isGlob = token.isGlob = true; + finished = true; + break; + } + } + + if (scanToEnd === true) { + continue; + } + + break; + } + + if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) { + negated = token.negated = true; + start++; + continue; + } + + if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) { + isGlob = token.isGlob = true; + + if (scanToEnd === true) { + while (eos() !== true && (code = advance())) { + if (code === CHAR_LEFT_PARENTHESES) { + backslashes = token.backslashes = true; + code = advance(); + continue; + } + + if (code === CHAR_RIGHT_PARENTHESES) { + finished = true; + break; + } + } + continue; + } + break; + } + + if (isGlob === true) { + finished = true; + + if (scanToEnd === true) { + continue; + } + + break; + } + } + + if (opts.noext === true) { + isExtglob = false; + isGlob = false; + } + + let base = str; + let prefix = ''; + let glob = ''; + + if (start > 0) { + prefix = str.slice(0, start); + str = str.slice(start); + lastIndex -= start; + } + + if (base && isGlob === true && lastIndex > 0) { + base = str.slice(0, lastIndex); + glob = str.slice(lastIndex); + } else if (isGlob === true) { + base = ''; + glob = str; + } else { + base = str; + } + + if (base && base !== '' && base !== '/' && base !== str) { + if (isPathSeparator(base.charCodeAt(base.length - 1))) { + base = base.slice(0, -1); + } + } + + if (opts.unescape === true) { + if (glob) glob = utils.removeBackslashes(glob); + + if (base && backslashes === true) { + base = utils.removeBackslashes(base); + } + } + + const state = { + prefix, + input, + start, + base, + glob, + isBrace, + isBracket, + isGlob, + isExtglob, + isGlobstar, + negated, + negatedExtglob + }; + + if (opts.tokens === true) { + state.maxDepth = 0; + if (!isPathSeparator(code)) { + tokens.push(token); + } + state.tokens = tokens; + } + + if (opts.parts === true || opts.tokens === true) { + let prevIndex; + + for (let idx = 0; idx < slashes.length; idx++) { + const n = prevIndex ? prevIndex + 1 : start; + const i = slashes[idx]; + const value = input.slice(n, i); + if (opts.tokens) { + if (idx === 0 && start !== 0) { + tokens[idx].isPrefix = true; + tokens[idx].value = prefix; + } else { + tokens[idx].value = value; + } + depth(tokens[idx]); + state.maxDepth += tokens[idx].depth; + } + if (idx !== 0 || value !== '') { + parts.push(value); + } + prevIndex = i; + } + + if (prevIndex && prevIndex + 1 < input.length) { + const value = input.slice(prevIndex + 1); + parts.push(value); + + if (opts.tokens) { + tokens[tokens.length - 1].value = value; + depth(tokens[tokens.length - 1]); + state.maxDepth += tokens[tokens.length - 1].depth; + } + } + + state.slashes = slashes; + state.parts = parts; + } + + return state; +}; + +module.exports = scan; diff --git a/node_modules/picomatch/lib/utils.js b/node_modules/picomatch/lib/utils.js new file mode 100644 index 0000000..c3ca766 --- /dev/null +++ b/node_modules/picomatch/lib/utils.js @@ -0,0 +1,64 @@ +'use strict'; + +const path = require('path'); +const win32 = process.platform === 'win32'; +const { + REGEX_BACKSLASH, + REGEX_REMOVE_BACKSLASH, + REGEX_SPECIAL_CHARS, + REGEX_SPECIAL_CHARS_GLOBAL +} = require('./constants'); + +exports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val); +exports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str); +exports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str); +exports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\$1'); +exports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/'); + +exports.removeBackslashes = str => { + return str.replace(REGEX_REMOVE_BACKSLASH, match => { + return match === '\\' ? '' : match; + }); +}; + +exports.supportsLookbehinds = () => { + const segs = process.version.slice(1).split('.').map(Number); + if (segs.length === 3 && segs[0] >= 9 || (segs[0] === 8 && segs[1] >= 10)) { + return true; + } + return false; +}; + +exports.isWindows = options => { + if (options && typeof options.windows === 'boolean') { + return options.windows; + } + return win32 === true || path.sep === '\\'; +}; + +exports.escapeLast = (input, char, lastIdx) => { + const idx = input.lastIndexOf(char, lastIdx); + if (idx === -1) return input; + if (input[idx - 1] === '\\') return exports.escapeLast(input, char, idx - 1); + return `${input.slice(0, idx)}\\${input.slice(idx)}`; +}; + +exports.removePrefix = (input, state = {}) => { + let output = input; + if (output.startsWith('./')) { + output = output.slice(2); + state.prefix = './'; + } + return output; +}; + +exports.wrapOutput = (input, state = {}, options = {}) => { + const prepend = options.contains ? '' : '^'; + const append = options.contains ? '' : '$'; + + let output = `${prepend}(?:${input})${append}`; + if (state.negated === true) { + output = `(?:^(?!${output}).*$)`; + } + return output; +}; diff --git a/node_modules/picomatch/package.json b/node_modules/picomatch/package.json new file mode 100644 index 0000000..3db22d4 --- /dev/null +++ b/node_modules/picomatch/package.json @@ -0,0 +1,81 @@ +{ + "name": "picomatch", + "description": "Blazing fast and accurate glob matcher written in JavaScript, with no dependencies and full support for standard and extended Bash glob features, including braces, extglobs, POSIX brackets, and regular expressions.", + "version": "2.3.1", + "homepage": "https://github.com/micromatch/picomatch", + "author": "Jon Schlinkert (https://github.com/jonschlinkert)", + "funding": "https://github.com/sponsors/jonschlinkert", + "repository": "micromatch/picomatch", + "bugs": { + "url": "https://github.com/micromatch/picomatch/issues" + }, + "license": "MIT", + "files": [ + "index.js", + "lib" + ], + "main": "index.js", + "engines": { + "node": ">=8.6" + }, + "scripts": { + "lint": "eslint --cache --cache-location node_modules/.cache/.eslintcache --report-unused-disable-directives --ignore-path .gitignore .", + "mocha": "mocha --reporter dot", + "test": "npm run lint && npm run mocha", + "test:ci": "npm run test:cover", + "test:cover": "nyc npm run mocha" + }, + "devDependencies": { + "eslint": "^6.8.0", + "fill-range": "^7.0.1", + "gulp-format-md": "^2.0.0", + "mocha": "^6.2.2", + "nyc": "^15.0.0", + "time-require": "github:jonschlinkert/time-require" + }, + "keywords": [ + "glob", + "match", + "picomatch" + ], + "nyc": { + "reporter": [ + "html", + "lcov", + "text-summary" + ] + }, + "verb": { + "toc": { + "render": true, + "method": "preWrite", + "maxdepth": 3 + }, + "layout": "empty", + "tasks": [ + "readme" + ], + "plugins": [ + "gulp-format-md" + ], + "lint": { + "reflinks": true + }, + "related": { + "list": [ + "braces", + "micromatch" + ] + }, + "reflinks": [ + "braces", + "expand-brackets", + "extglob", + "fill-range", + "micromatch", + "minimatch", + "nanomatch", + "picomatch" + ] + } +} diff --git a/node_modules/pify/index.js b/node_modules/pify/index.js new file mode 100644 index 0000000..7c720eb --- /dev/null +++ b/node_modules/pify/index.js @@ -0,0 +1,68 @@ +'use strict'; + +var processFn = function (fn, P, opts) { + return function () { + var that = this; + var args = new Array(arguments.length); + + for (var i = 0; i < arguments.length; i++) { + args[i] = arguments[i]; + } + + return new P(function (resolve, reject) { + args.push(function (err, result) { + if (err) { + reject(err); + } else if (opts.multiArgs) { + var results = new Array(arguments.length - 1); + + for (var i = 1; i < arguments.length; i++) { + results[i - 1] = arguments[i]; + } + + resolve(results); + } else { + resolve(result); + } + }); + + fn.apply(that, args); + }); + }; +}; + +var pify = module.exports = function (obj, P, opts) { + if (typeof P !== 'function') { + opts = P; + P = Promise; + } + + opts = opts || {}; + opts.exclude = opts.exclude || [/.+Sync$/]; + + var filter = function (key) { + var match = function (pattern) { + return typeof pattern === 'string' ? key === pattern : pattern.test(key); + }; + + return opts.include ? opts.include.some(match) : !opts.exclude.some(match); + }; + + var ret = typeof obj === 'function' ? function () { + if (opts.excludeMain) { + return obj.apply(this, arguments); + } + + return processFn(obj, P, opts).apply(this, arguments); + } : {}; + + return Object.keys(obj).reduce(function (ret, key) { + var x = obj[key]; + + ret[key] = typeof x === 'function' && filter(key) ? processFn(x, P, opts) : x; + + return ret; + }, ret); +}; + +pify.all = pify; diff --git a/node_modules/pify/license b/node_modules/pify/license new file mode 100644 index 0000000..654d0bf --- /dev/null +++ b/node_modules/pify/license @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/node_modules/pify/package.json b/node_modules/pify/package.json new file mode 100644 index 0000000..311d198 --- /dev/null +++ b/node_modules/pify/package.json @@ -0,0 +1,48 @@ +{ + "name": "pify", + "version": "2.3.0", + "description": "Promisify a callback-style function", + "license": "MIT", + "repository": "sindresorhus/pify", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "sindresorhus.com" + }, + "engines": { + "node": ">=0.10.0" + }, + "scripts": { + "test": "xo && ava && npm run optimization-test", + "optimization-test": "node --allow-natives-syntax optimization-test.js" + }, + "files": [ + "index.js" + ], + "keywords": [ + "promise", + "promises", + "promisify", + "denodify", + "denodeify", + "callback", + "cb", + "node", + "then", + "thenify", + "convert", + "transform", + "wrap", + "wrapper", + "bind", + "to", + "async", + "es2015" + ], + "devDependencies": { + "ava": "*", + "pinkie-promise": "^1.0.0", + "v8-natives": "0.0.2", + "xo": "*" + } +} diff --git a/node_modules/pify/readme.md b/node_modules/pify/readme.md new file mode 100644 index 0000000..c79ca8b --- /dev/null +++ b/node_modules/pify/readme.md @@ -0,0 +1,119 @@ +# pify [![Build Status](https://travis-ci.org/sindresorhus/pify.svg?branch=master)](https://travis-ci.org/sindresorhus/pify) + +> Promisify a callback-style function + + +## Install + +``` +$ npm install --save pify +``` + + +## Usage + +```js +const fs = require('fs'); +const pify = require('pify'); + +// promisify a single function + +pify(fs.readFile)('package.json', 'utf8').then(data => { + console.log(JSON.parse(data).name); + //=> 'pify' +}); + +// or promisify all methods in a module + +pify(fs).readFile('package.json', 'utf8').then(data => { + console.log(JSON.parse(data).name); + //=> 'pify' +}); +``` + + +## API + +### pify(input, [promiseModule], [options]) + +Returns a promise wrapped version of the supplied function or module. + +#### input + +Type: `function`, `object` + +Callback-style function or module whose methods you want to promisify. + +#### promiseModule + +Type: `function` + +Custom promise module to use instead of the native one. + +Check out [`pinkie-promise`](https://github.com/floatdrop/pinkie-promise) if you need a tiny promise polyfill. + +#### options + +##### multiArgs + +Type: `boolean` +Default: `false` + +By default, the promisified function will only return the second argument from the callback, which works fine for most APIs. This option can be useful for modules like `request` that return multiple arguments. Turning this on will make it return an array of all arguments from the callback, excluding the error argument, instead of just the second argument. + +```js +const request = require('request'); +const pify = require('pify'); + +pify(request, {multiArgs: true})('https://sindresorhus.com').then(result => { + const [httpResponse, body] = result; +}); +``` + +##### include + +Type: `array` of (`string`|`regex`) + +Methods in a module to promisify. Remaining methods will be left untouched. + +##### exclude + +Type: `array` of (`string`|`regex`) +Default: `[/.+Sync$/]` + +Methods in a module **not** to promisify. Methods with names ending with `'Sync'` are excluded by default. + +##### excludeMain + +Type: `boolean` +Default: `false` + +By default, if given module is a function itself, this function will be promisified. Turn this option on if you want to promisify only methods of the module. + +```js +const pify = require('pify'); + +function fn() { + return true; +} + +fn.method = (data, callback) => { + setImmediate(() => { + callback(data, null); + }); +}; + +// promisify methods but not fn() +const promiseFn = pify(fn, {excludeMain: true}); + +if (promiseFn()) { + promiseFn.method('hi').then(data => { + console.log(data); + }); +} +``` + + +## License + +MIT © [Sindre Sorhus](http://sindresorhus.com) diff --git a/node_modules/postcss-import/LICENSE b/node_modules/postcss-import/LICENSE new file mode 100755 index 0000000..13983fb --- /dev/null +++ b/node_modules/postcss-import/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) 2014 Maxime Thirouin, Jason Campbell & Kevin Mårtensson + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-import/README.md b/node_modules/postcss-import/README.md new file mode 100644 index 0000000..f0ce11e --- /dev/null +++ b/node_modules/postcss-import/README.md @@ -0,0 +1,227 @@ +# postcss-import + +[![Build](https://img.shields.io/travis/postcss/postcss-import/master)](https://travis-ci.org/postcss/postcss-import) +[![Version](https://img.shields.io/npm/v/postcss-import)](https://github.com/postcss/postcss-import/blob/master/CHANGELOG.md) +[![postcss compatibility](https://img.shields.io/npm/dependency-version/postcss-import/peer/postcss)](https://postcss.org/) + +> [PostCSS](https://github.com/postcss/postcss) plugin to transform `@import` +rules by inlining content. + +This plugin can consume local files, node modules or web_modules. +To resolve path of an `@import` rule, it can look into root directory +(by default `process.cwd()`), `web_modules`, `node_modules` +or local modules. +_When importing a module, it will look for `index.css` or file referenced in +`package.json` in the `style` or `main` fields._ +You can also provide manually multiples paths where to look at. + +**Notes:** + +- **This plugin should probably be used as the first plugin of your list. +This way, other plugins will work on the AST as if there were only a single file +to process, and will probably work as you can expect**. +- This plugin works great with +[postcss-url](https://github.com/postcss/postcss-url) plugin, +which will allow you to adjust assets `url()` (or even inline them) after +inlining imported files. +- In order to optimize output, **this plugin will only import a file once** on +a given scope (root, media query...). +Tests are made from the path & the content of imported files (using a hash +table). +If this behavior is not what you want, look at `skipDuplicates` option +- If you are looking for **Glob Imports**, you can use [postcss-import-ext-glob](https://github.com/dimitrinicolas/postcss-import-ext-glob) to extend postcss-import. +- Imports which are not modified (by `options.filter` or because they are remote + imports) are moved to the top of the output. +- **This plugin attempts to follow the CSS `@import` spec**; `@import` + statements must precede all other statements (besides `@charset`). + +## Installation + +```console +$ npm install -D postcss-import +``` + +## Usage + +Unless your stylesheet is in the same place where you run postcss +(`process.cwd()`), you will need to use `from` option to make relative imports +work. + +```js +// dependencies +const fs = require("fs") +const postcss = require("postcss") +const atImport = require("postcss-import") + +// css to be processed +const css = fs.readFileSync("css/input.css", "utf8") + +// process css +postcss() + .use(atImport()) + .process(css, { + // `from` option is needed here + from: "css/input.css" + }) + .then((result) => { + const output = result.css + + console.log(output) + }) +``` + +`css/input.css`: + +```css +/* can consume `node_modules`, `web_modules` or local modules */ +@import "cssrecipes-defaults"; /* == @import "../node_modules/cssrecipes-defaults/index.css"; */ +@import "normalize.css"; /* == @import "../node_modules/normalize.css/normalize.css"; */ + +@import "foo.css"; /* relative to css/ according to `from` option above */ + +@import "bar.css" (min-width: 25em); + +body { + background: black; +} +``` + +will give you: + +```css +/* ... content of ../node_modules/cssrecipes-defaults/index.css */ +/* ... content of ../node_modules/normalize.css/normalize.css */ + +/* ... content of css/foo.css */ + +@media (min-width: 25em) { +/* ... content of css/bar.css */ +} + +body { + background: black; +} +``` + +Checkout the [tests](test) for more examples. + +### Options + +### `filter` +Type: `Function` +Default: `() => true` + +Only transform imports for which the test function returns `true`. Imports for +which the test function returns `false` will be left as is. The function gets +the path to import as an argument and should return a boolean. + +#### `root` + +Type: `String` +Default: `process.cwd()` or _dirname of +[the postcss `from`](https://github.com/postcss/postcss#node-source)_ + +Define the root where to resolve path (eg: place where `node_modules` are). +Should not be used that much. +_Note: nested `@import` will additionally benefit of the relative dirname of +imported files._ + +#### `path` + +Type: `String|Array` +Default: `[]` + +A string or an array of paths in where to look for files. + +#### `plugins` + +Type: `Array` +Default: `undefined` + +An array of plugins to be applied on each imported files. + +#### `resolve` + +Type: `Function` +Default: `null` + +You can provide a custom path resolver with this option. This function gets +`(id, basedir, importOptions)` arguments and should return a path, an array of +paths or a promise resolving to the path(s). If you do not return an absolute +path, your path will be resolved to an absolute path using the default +resolver. +You can use [resolve](https://github.com/substack/node-resolve) for this. + +#### `load` + +Type: `Function` +Default: null + +You can overwrite the default loading way by setting this option. +This function gets `(filename, importOptions)` arguments and returns content or +promised content. + +#### `skipDuplicates` + +Type: `Boolean` +Default: `true` + +By default, similar files (based on the same content) are being skipped. +It's to optimize output and skip similar files like `normalize.css` for example. +If this behavior is not what you want, just set this option to `false` to +disable it. + +#### `addModulesDirectories` + +Type: `Array` +Default: `[]` + +An array of folder names to add to [Node's resolver](https://github.com/substack/node-resolve). +Values will be appended to the default resolve directories: +`["node_modules", "web_modules"]`. + +This option is only for adding additional directories to default resolver. If +you provide your own resolver via the `resolve` configuration option above, then +this value will be ignored. + +#### Example with some options + +```js +const postcss = require("postcss") +const atImport = require("postcss-import") + +postcss() + .use(atImport({ + path: ["src/css"], + })) + .process(cssString) + .then((result) => { + const { css } = result + }) +``` + +## `dependency` Message Support + +`postcss-import` adds a message to `result.messages` for each `@import`. Messages are in the following format: + +``` +{ + type: 'dependency', + file: absoluteFilePath, + parent: fileContainingTheImport +} +``` + +This is mainly for use by postcss runners that implement file watching. + +--- + +## CONTRIBUTING + +* ⇄ Pull requests and ★ Stars are always welcome. +* For bugs and feature requests, please create an issue. +* Pull requests must be accompanied by passing automated tests (`$ npm test`). + +## [Changelog](CHANGELOG.md) + +## [License](LICENSE) diff --git a/node_modules/postcss-import/index.js b/node_modules/postcss-import/index.js new file mode 100755 index 0000000..e6a3dc3 --- /dev/null +++ b/node_modules/postcss-import/index.js @@ -0,0 +1,344 @@ +"use strict" +// builtin tooling +const path = require("path") + +// internal tooling +const joinMedia = require("./lib/join-media") +const joinLayer = require("./lib/join-layer") +const resolveId = require("./lib/resolve-id") +const loadContent = require("./lib/load-content") +const processContent = require("./lib/process-content") +const parseStatements = require("./lib/parse-statements") + +function AtImport(options) { + options = { + root: process.cwd(), + path: [], + skipDuplicates: true, + resolve: resolveId, + load: loadContent, + plugins: [], + addModulesDirectories: [], + ...options, + } + + options.root = path.resolve(options.root) + + // convert string to an array of a single element + if (typeof options.path === "string") options.path = [options.path] + + if (!Array.isArray(options.path)) options.path = [] + + options.path = options.path.map(p => path.resolve(options.root, p)) + + return { + postcssPlugin: "postcss-import", + Once(styles, { result, atRule, postcss }) { + const state = { + importedFiles: {}, + hashFiles: {}, + } + + if (styles.source && styles.source.input && styles.source.input.file) { + state.importedFiles[styles.source.input.file] = {} + } + + if (options.plugins && !Array.isArray(options.plugins)) { + throw new Error("plugins option must be an array") + } + + return parseStyles(result, styles, options, state, [], []).then( + bundle => { + applyRaws(bundle) + applyMedia(bundle) + applyStyles(bundle, styles) + } + ) + + function applyRaws(bundle) { + bundle.forEach((stmt, index) => { + if (index === 0) return + + if (stmt.parent) { + const { before } = stmt.parent.node.raws + if (stmt.type === "nodes") stmt.nodes[0].raws.before = before + else stmt.node.raws.before = before + } else if (stmt.type === "nodes") { + stmt.nodes[0].raws.before = stmt.nodes[0].raws.before || "\n" + } + }) + } + + function applyMedia(bundle) { + bundle.forEach(stmt => { + if ( + (!stmt.media.length && !stmt.layer.length) || + stmt.type === "charset" + ) { + return + } + + if (stmt.type === "import") { + stmt.node.params = `${stmt.fullUri} ${stmt.media.join(", ")}` + } else if (stmt.type === "media") { + stmt.node.params = stmt.media.join(", ") + } else { + const { nodes } = stmt + const { parent } = nodes[0] + + let outerAtRule + let innerAtRule + if (stmt.media.length && stmt.layer.length) { + const mediaNode = atRule({ + name: "media", + params: stmt.media.join(", "), + source: parent.source, + }) + + const layerNode = atRule({ + name: "layer", + params: stmt.layer.filter(layer => layer !== "").join("."), + source: parent.source, + }) + + mediaNode.append(layerNode) + innerAtRule = layerNode + outerAtRule = mediaNode + } else if (stmt.media.length) { + const mediaNode = atRule({ + name: "media", + params: stmt.media.join(", "), + source: parent.source, + }) + + innerAtRule = mediaNode + outerAtRule = mediaNode + } else if (stmt.layer.length) { + const layerNode = atRule({ + name: "layer", + params: stmt.layer.filter(layer => layer !== "").join("."), + source: parent.source, + }) + + innerAtRule = layerNode + outerAtRule = layerNode + } + + parent.insertBefore(nodes[0], outerAtRule) + + // remove nodes + nodes.forEach(node => { + node.parent = undefined + }) + + // better output + nodes[0].raws.before = nodes[0].raws.before || "\n" + + // wrap new rules with media query and/or layer at rule + innerAtRule.append(nodes) + + stmt.type = "media" + stmt.node = outerAtRule + delete stmt.nodes + } + }) + } + + function applyStyles(bundle, styles) { + styles.nodes = [] + + // Strip additional statements. + bundle.forEach(stmt => { + if (["charset", "import", "media"].includes(stmt.type)) { + stmt.node.parent = undefined + styles.append(stmt.node) + } else if (stmt.type === "nodes") { + stmt.nodes.forEach(node => { + node.parent = undefined + styles.append(node) + }) + } + }) + } + + function parseStyles(result, styles, options, state, media, layer) { + const statements = parseStatements(result, styles) + + return Promise.resolve(statements) + .then(stmts => { + // process each statement in series + return stmts.reduce((promise, stmt) => { + return promise.then(() => { + stmt.media = joinMedia(media, stmt.media || []) + stmt.layer = joinLayer(layer, stmt.layer || []) + + // skip protocol base uri (protocol://url) or protocol-relative + if ( + stmt.type !== "import" || + /^(?:[a-z]+:)?\/\//i.test(stmt.uri) + ) { + return + } + + if (options.filter && !options.filter(stmt.uri)) { + // rejected by filter + return + } + + return resolveImportId(result, stmt, options, state) + }) + }, Promise.resolve()) + }) + .then(() => { + let charset + const imports = [] + const bundle = [] + + function handleCharset(stmt) { + if (!charset) charset = stmt + // charsets aren't case-sensitive, so convert to lower case to compare + else if ( + stmt.node.params.toLowerCase() !== + charset.node.params.toLowerCase() + ) { + throw new Error( + `Incompatable @charset statements: + ${stmt.node.params} specified in ${stmt.node.source.input.file} + ${charset.node.params} specified in ${charset.node.source.input.file}` + ) + } + } + + // squash statements and their children + statements.forEach(stmt => { + if (stmt.type === "charset") handleCharset(stmt) + else if (stmt.type === "import") { + if (stmt.children) { + stmt.children.forEach((child, index) => { + if (child.type === "import") imports.push(child) + else if (child.type === "charset") handleCharset(child) + else bundle.push(child) + // For better output + if (index === 0) child.parent = stmt + }) + } else imports.push(stmt) + } else if (stmt.type === "media" || stmt.type === "nodes") { + bundle.push(stmt) + } + }) + + return charset + ? [charset, ...imports.concat(bundle)] + : imports.concat(bundle) + }) + } + + function resolveImportId(result, stmt, options, state) { + const atRule = stmt.node + let sourceFile + if (atRule.source && atRule.source.input && atRule.source.input.file) { + sourceFile = atRule.source.input.file + } + const base = sourceFile + ? path.dirname(atRule.source.input.file) + : options.root + + return Promise.resolve(options.resolve(stmt.uri, base, options)) + .then(paths => { + if (!Array.isArray(paths)) paths = [paths] + // Ensure that each path is absolute: + return Promise.all( + paths.map(file => { + return !path.isAbsolute(file) + ? resolveId(file, base, options) + : file + }) + ) + }) + .then(resolved => { + // Add dependency messages: + resolved.forEach(file => { + result.messages.push({ + type: "dependency", + plugin: "postcss-import", + file, + parent: sourceFile, + }) + }) + + return Promise.all( + resolved.map(file => { + return loadImportContent(result, stmt, file, options, state) + }) + ) + }) + .then(result => { + // Merge loaded statements + stmt.children = result.reduce((result, statements) => { + return statements ? result.concat(statements) : result + }, []) + }) + } + + function loadImportContent(result, stmt, filename, options, state) { + const atRule = stmt.node + const { media, layer } = stmt + if (options.skipDuplicates) { + // skip files already imported at the same scope + if ( + state.importedFiles[filename] && + state.importedFiles[filename][media] + ) { + return + } + + // save imported files to skip them next time + if (!state.importedFiles[filename]) state.importedFiles[filename] = {} + state.importedFiles[filename][media] = true + } + + return Promise.resolve(options.load(filename, options)).then( + content => { + if (content.trim() === "") { + result.warn(`${filename} is empty`, { node: atRule }) + return + } + + // skip previous imported files not containing @import rules + if (state.hashFiles[content] && state.hashFiles[content][media]) + return + + return processContent( + result, + content, + filename, + options, + postcss + ).then(importedResult => { + const styles = importedResult.root + result.messages = result.messages.concat(importedResult.messages) + + if (options.skipDuplicates) { + const hasImport = styles.some(child => { + return child.type === "atrule" && child.name === "import" + }) + if (!hasImport) { + // save hash files to skip them next time + if (!state.hashFiles[content]) state.hashFiles[content] = {} + state.hashFiles[content][media] = true + } + } + + // recursion: import @import from imported file + return parseStyles(result, styles, options, state, media, layer) + }) + } + ) + } + }, + } +} + +AtImport.postcss = true + +module.exports = AtImport diff --git a/node_modules/postcss-import/lib/join-layer.js b/node_modules/postcss-import/lib/join-layer.js new file mode 100644 index 0000000..9d91519 --- /dev/null +++ b/node_modules/postcss-import/lib/join-layer.js @@ -0,0 +1,9 @@ +"use strict" + +module.exports = function (parentLayer, childLayer) { + if (!parentLayer.length && childLayer.length) return childLayer + if (parentLayer.length && !childLayer.length) return parentLayer + if (!parentLayer.length && !childLayer.length) return [] + + return parentLayer.concat(childLayer) +} diff --git a/node_modules/postcss-import/lib/join-media.js b/node_modules/postcss-import/lib/join-media.js new file mode 100644 index 0000000..5780de9 --- /dev/null +++ b/node_modules/postcss-import/lib/join-media.js @@ -0,0 +1,17 @@ +"use strict" + +module.exports = function (parentMedia, childMedia) { + if (!parentMedia.length && childMedia.length) return childMedia + if (parentMedia.length && !childMedia.length) return parentMedia + if (!parentMedia.length && !childMedia.length) return [] + + const media = [] + + parentMedia.forEach(parentItem => { + childMedia.forEach(childItem => { + if (parentItem !== childItem) media.push(`${parentItem} and ${childItem}`) + }) + }) + + return media +} diff --git a/node_modules/postcss-import/lib/load-content.js b/node_modules/postcss-import/lib/load-content.js new file mode 100644 index 0000000..de61155 --- /dev/null +++ b/node_modules/postcss-import/lib/load-content.js @@ -0,0 +1,5 @@ +"use strict" + +const readCache = require("read-cache") + +module.exports = filename => readCache(filename, "utf-8") diff --git a/node_modules/postcss-import/lib/parse-statements.js b/node_modules/postcss-import/lib/parse-statements.js new file mode 100644 index 0000000..0c94e5a --- /dev/null +++ b/node_modules/postcss-import/lib/parse-statements.js @@ -0,0 +1,172 @@ +"use strict" + +// external tooling +const valueParser = require("postcss-value-parser") + +// extended tooling +const { stringify } = valueParser + +function split(params, start) { + const list = [] + const last = params.reduce((item, node, index) => { + if (index < start) return "" + if (node.type === "div" && node.value === ",") { + list.push(item) + return "" + } + return item + stringify(node) + }, "") + list.push(last) + return list +} + +module.exports = function (result, styles) { + const statements = [] + let nodes = [] + + styles.each(node => { + let stmt + if (node.type === "atrule") { + if (node.name === "import") stmt = parseImport(result, node) + else if (node.name === "media") stmt = parseMedia(result, node) + else if (node.name === "charset") stmt = parseCharset(result, node) + } + + if (stmt) { + if (nodes.length) { + statements.push({ + type: "nodes", + nodes, + media: [], + layer: [], + }) + nodes = [] + } + statements.push(stmt) + } else nodes.push(node) + }) + + if (nodes.length) { + statements.push({ + type: "nodes", + nodes, + media: [], + layer: [], + }) + } + + return statements +} + +function parseMedia(result, atRule) { + const params = valueParser(atRule.params).nodes + return { + type: "media", + node: atRule, + media: split(params, 0), + layer: [], + } +} + +function parseCharset(result, atRule) { + if (atRule.prev()) { + return result.warn("@charset must precede all other statements", { + node: atRule, + }) + } + return { + type: "charset", + node: atRule, + media: [], + layer: [], + } +} + +function parseImport(result, atRule) { + let prev = atRule.prev() + if (prev) { + do { + if ( + prev.type !== "comment" && + (prev.type !== "atrule" || + (prev.name !== "import" && + prev.name !== "charset" && + !(prev.name === "layer" && !prev.nodes))) + ) { + return result.warn( + "@import must precede all other statements (besides @charset or empty @layer)", + { node: atRule } + ) + } + prev = prev.prev() + } while (prev) + } + + if (atRule.nodes) { + return result.warn( + "It looks like you didn't end your @import statement correctly. " + + "Child nodes are attached to it.", + { node: atRule } + ) + } + + const params = valueParser(atRule.params).nodes + const stmt = { + type: "import", + node: atRule, + media: [], + layer: [], + } + + // prettier-ignore + if ( + !params.length || + ( + params[0].type !== "string" || + !params[0].value + ) && + ( + params[0].type !== "function" || + params[0].value !== "url" || + !params[0].nodes.length || + !params[0].nodes[0].value + ) + ) { + return result.warn(`Unable to find uri in '${ atRule.toString() }'`, { + node: atRule, + }) + } + + if (params[0].type === "string") stmt.uri = params[0].value + else stmt.uri = params[0].nodes[0].value + stmt.fullUri = stringify(params[0]) + + let remainder = params + if (remainder.length > 2) { + if ( + (remainder[2].type === "word" || remainder[2].type === "function") && + remainder[2].value === "layer" + ) { + if (remainder[1].type !== "space") { + return result.warn("Invalid import layer statement", { node: atRule }) + } + + if (remainder[2].nodes) { + stmt.layer = [stringify(remainder[2].nodes)] + } else { + stmt.layer = [""] + } + remainder = remainder.slice(2) + } + } + + if (remainder.length > 2) { + if (remainder[1].type !== "space") { + return result.warn("Invalid import media statement", { node: atRule }) + } + + stmt.media = split(remainder, 2) + } + + return stmt +} diff --git a/node_modules/postcss-import/lib/process-content.js b/node_modules/postcss-import/lib/process-content.js new file mode 100644 index 0000000..beaa3f0 --- /dev/null +++ b/node_modules/postcss-import/lib/process-content.js @@ -0,0 +1,59 @@ +"use strict" + +// builtin tooling +const path = require("path") + +// placeholder tooling +let sugarss + +module.exports = function processContent( + result, + content, + filename, + options, + postcss +) { + const { plugins } = options + const ext = path.extname(filename) + + const parserList = [] + + // SugarSS support: + if (ext === ".sss") { + if (!sugarss) { + try { + sugarss = require("sugarss") + } catch {} // Ignore + } + if (sugarss) + return runPostcss(postcss, content, filename, plugins, [sugarss]) + } + + // Syntax support: + if (result.opts.syntax && result.opts.syntax.parse) { + parserList.push(result.opts.syntax.parse) + } + + // Parser support: + if (result.opts.parser) parserList.push(result.opts.parser) + // Try the default as a last resort: + parserList.push(null) + + return runPostcss(postcss, content, filename, plugins, parserList) +} + +function runPostcss(postcss, content, filename, plugins, parsers, index) { + if (!index) index = 0 + return postcss(plugins) + .process(content, { + from: filename, + parser: parsers[index], + }) + .catch(err => { + // If there's an error, try the next parser + index++ + // If there are no parsers left, throw it + if (index === parsers.length) throw err + return runPostcss(postcss, content, filename, plugins, parsers, index) + }) +} diff --git a/node_modules/postcss-import/lib/resolve-id.js b/node_modules/postcss-import/lib/resolve-id.js new file mode 100644 index 0000000..ffef034 --- /dev/null +++ b/node_modules/postcss-import/lib/resolve-id.js @@ -0,0 +1,42 @@ +"use strict" + +// external tooling +const resolve = require("resolve") + +const moduleDirectories = ["web_modules", "node_modules"] + +function resolveModule(id, opts) { + return new Promise((res, rej) => { + resolve(id, opts, (err, path) => (err ? rej(err) : res(path))) + }) +} + +module.exports = function (id, base, options) { + const paths = options.path + + const resolveOpts = { + basedir: base, + moduleDirectory: moduleDirectories.concat(options.addModulesDirectories), + paths, + extensions: [".css"], + packageFilter: function processPackage(pkg) { + if (pkg.style) pkg.main = pkg.style + else if (!pkg.main || !/\.css$/.test(pkg.main)) pkg.main = "index.css" + return pkg + }, + preserveSymlinks: false, + } + + return resolveModule(`./${id}`, resolveOpts) + .catch(() => resolveModule(id, resolveOpts)) + .catch(() => { + if (paths.indexOf(base) === -1) paths.unshift(base) + + throw new Error( + `Failed to find '${id}' + in [ + ${paths.join(",\n ")} + ]` + ) + }) +} diff --git a/node_modules/postcss-import/package.json b/node_modules/postcss-import/package.json new file mode 100644 index 0000000..46767be --- /dev/null +++ b/node_modules/postcss-import/package.json @@ -0,0 +1,65 @@ +{ + "name": "postcss-import", + "version": "14.1.0", + "description": "PostCSS plugin to import CSS files", + "keywords": [ + "css", + "postcss", + "postcss-plugin", + "import", + "node modules", + "npm" + ], + "author": "Maxime Thirouin", + "license": "MIT", + "repository": "https://github.com/postcss/postcss-import.git", + "files": [ + "index.js", + "lib" + ], + "engines": { + "node": ">=10.0.0" + }, + "dependencies": { + "postcss-value-parser": "^4.0.0", + "read-cache": "^1.0.0", + "resolve": "^1.1.7" + }, + "devDependencies": { + "ava": "^3.0.0", + "eslint": "^7.0.0", + "eslint-config-problems": "^5.0.0", + "eslint-plugin-prettier": "^4.0.0", + "postcss": "^8.0.0", + "postcss-scss": "^4.0.0", + "prettier": "~2.6.0", + "sugarss": "^4.0.0" + }, + "peerDependencies": { + "postcss": "^8.0.0" + }, + "scripts": { + "ci": "eslint . && ava", + "lint": "eslint . --fix", + "pretest": "npm run lint", + "test": "ava" + }, + "eslintConfig": { + "extends": "eslint-config-problems", + "env": { + "node": true + }, + "plugins": [ + "prettier" + ], + "rules": { + "prettier/prettier": [ + "error", + { + "semi": false, + "arrowParens": "avoid" + } + ] + } + } +} diff --git a/node_modules/postcss-js/LICENSE b/node_modules/postcss-js/LICENSE new file mode 100644 index 0000000..d3bd672 --- /dev/null +++ b/node_modules/postcss-js/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright 2015 Andrey Sitnik + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-js/README.md b/node_modules/postcss-js/README.md new file mode 100644 index 0000000..469b3be --- /dev/null +++ b/node_modules/postcss-js/README.md @@ -0,0 +1,22 @@ +# PostCSS JS + + + +[PostCSS] for for CSS-in-JS and styles in JS objects. + +For example, to use [Stylelint] or [RTLCSS] plugins in your workflow. + + + Sponsored by Evil Martians + + +[Stylelint]: https://github.com/stylelint/stylelint +[PostCSS]: https://github.com/postcss/postcss +[RTLCSS]: https://github.com/MohammadYounes/rtlcss + + +## Docs +Read **[full docs](https://github.com/postcss/postcss-js#readme)** on GitHub. diff --git a/node_modules/postcss-js/async.js b/node_modules/postcss-js/async.js new file mode 100644 index 0000000..4c2f3c6 --- /dev/null +++ b/node_modules/postcss-js/async.js @@ -0,0 +1,15 @@ +let postcss = require('postcss') + +let processResult = require('./process-result') +let parse = require('./parser') + +module.exports = function async(plugins) { + let processor = postcss(plugins) + return async input => { + let result = await processor.process(input, { + parser: parse, + from: undefined + }) + return processResult(result) + } +} diff --git a/node_modules/postcss-js/index.js b/node_modules/postcss-js/index.js new file mode 100644 index 0000000..8a4274e --- /dev/null +++ b/node_modules/postcss-js/index.js @@ -0,0 +1,11 @@ +let objectify = require('./objectifier') +let parse = require('./parser') +let async = require('./async') +let sync = require('./sync') + +module.exports = { + objectify, + parse, + async, + sync +} diff --git a/node_modules/postcss-js/index.mjs b/node_modules/postcss-js/index.mjs new file mode 100644 index 0000000..d14b61c --- /dev/null +++ b/node_modules/postcss-js/index.mjs @@ -0,0 +1,8 @@ +import index from './index.js' + +export default index + +export const objectify = index.objectify +export const parse = index.parse +export const async = index.async +export const sync = index.sync diff --git a/node_modules/postcss-js/objectifier.js b/node_modules/postcss-js/objectifier.js new file mode 100644 index 0000000..ae43e43 --- /dev/null +++ b/node_modules/postcss-js/objectifier.js @@ -0,0 +1,83 @@ +let camelcase = require('camelcase-css') + +let UNITLESS = { + boxFlex: true, + boxFlexGroup: true, + columnCount: true, + flex: true, + flexGrow: true, + flexPositive: true, + flexShrink: true, + flexNegative: true, + fontWeight: true, + lineClamp: true, + lineHeight: true, + opacity: true, + order: true, + orphans: true, + tabSize: true, + widows: true, + zIndex: true, + zoom: true, + fillOpacity: true, + strokeDashoffset: true, + strokeOpacity: true, + strokeWidth: true +} + +function atRule(node) { + if (typeof node.nodes === 'undefined') { + return true + } else { + return process(node) + } +} + +function process(node) { + let name + let result = {} + + node.each(child => { + if (child.type === 'atrule') { + name = '@' + child.name + if (child.params) name += ' ' + child.params + if (typeof result[name] === 'undefined') { + result[name] = atRule(child) + } else if (Array.isArray(result[name])) { + result[name].push(atRule(child)) + } else { + result[name] = [result[name], atRule(child)] + } + } else if (child.type === 'rule') { + let body = process(child) + if (result[child.selector]) { + for (let i in body) { + result[child.selector][i] = body[i] + } + } else { + result[child.selector] = body + } + } else if (child.type === 'decl') { + if (child.prop[0] === '-' && child.prop[1] === '-') { + name = child.prop + } else { + name = camelcase(child.prop) + } + let value = child.value + if (!isNaN(child.value) && UNITLESS[name]) { + value = parseFloat(child.value) + } + if (child.important) value += ' !important' + if (typeof result[name] === 'undefined') { + result[name] = value + } else if (Array.isArray(result[name])) { + result[name].push(value) + } else { + result[name] = [result[name], value] + } + } + }) + return result +} + +module.exports = process diff --git a/node_modules/postcss-js/package.json b/node_modules/postcss-js/package.json new file mode 100644 index 0000000..575047b --- /dev/null +++ b/node_modules/postcss-js/package.json @@ -0,0 +1,42 @@ +{ + "name": "postcss-js", + "version": "4.0.0", + "description": "PostCSS for CSS-in-JS and styles in JS objects", + "keywords": [ + "postcss", + "postcss-runner", + "js", + "inline", + "react", + "css", + "cssinjs" + ], + "author": "Andrey Sitnik ", + "license": "MIT", + "repository": "postcss/postcss-js", + "engines": { + "node": "^12 || ^14 || >= 16" + }, + "exports": { + ".": { + "require": "./index.js", + "import": "./index.mjs" + }, + "./package.json": "./package.json", + "./async": "./async.js", + "./objectifier": "./objectifier.js", + "./parser": "./parser.js", + "./process-result": "./process-result.js", + "./sync": "./sync.js" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.3.3" + }, + "dependencies": { + "camelcase-css": "^2.0.1" + } +} diff --git a/node_modules/postcss-js/parser.js b/node_modules/postcss-js/parser.js new file mode 100644 index 0000000..17ae264 --- /dev/null +++ b/node_modules/postcss-js/parser.js @@ -0,0 +1,104 @@ +let postcss = require('postcss') + +let IMPORTANT = /\s*!important\s*$/i + +let UNITLESS = { + 'box-flex': true, + 'box-flex-group': true, + 'column-count': true, + 'flex': true, + 'flex-grow': true, + 'flex-positive': true, + 'flex-shrink': true, + 'flex-negative': true, + 'font-weight': true, + 'line-clamp': true, + 'line-height': true, + 'opacity': true, + 'order': true, + 'orphans': true, + 'tab-size': true, + 'widows': true, + 'z-index': true, + 'zoom': true, + 'fill-opacity': true, + 'stroke-dashoffset': true, + 'stroke-opacity': true, + 'stroke-width': true +} + +function dashify(str) { + return str + .replace(/([A-Z])/g, '-$1') + .replace(/^ms-/, '-ms-') + .toLowerCase() +} + +function decl(parent, name, value) { + if (value === false || value === null) return + + if (!name.startsWith('--')) { + name = dashify(name) + } + + if (typeof value === 'number') { + if (value === 0 || UNITLESS[name]) { + value = value.toString() + } else { + value += 'px' + } + } + + if (name === 'css-float') name = 'float' + + if (IMPORTANT.test(value)) { + value = value.replace(IMPORTANT, '') + parent.push(postcss.decl({ prop: name, value, important: true })) + } else { + parent.push(postcss.decl({ prop: name, value })) + } +} + +function atRule(parent, parts, value) { + let node = postcss.atRule({ name: parts[1], params: parts[3] || '' }) + if (typeof value === 'object') { + node.nodes = [] + parse(value, node) + } + parent.push(node) +} + +function parse(obj, parent) { + let name, value, node + for (name in obj) { + value = obj[name] + if (value === null || typeof value === 'undefined') { + continue + } else if (name[0] === '@') { + let parts = name.match(/@(\S+)(\s+([\W\w]*)\s*)?/) + if (Array.isArray(value)) { + for (let i of value) { + atRule(parent, parts, i) + } + } else { + atRule(parent, parts, value) + } + } else if (Array.isArray(value)) { + for (let i of value) { + decl(parent, name, i) + } + } else if (typeof value === 'object') { + node = postcss.rule({ selector: name }) + parse(value, node) + parent.push(node) + } else { + decl(parent, name, value) + } + } +} + +module.exports = function (obj) { + let root = postcss.root() + parse(obj, root) + return root +} diff --git a/node_modules/postcss-js/process-result.js b/node_modules/postcss-js/process-result.js new file mode 100644 index 0000000..215a95c --- /dev/null +++ b/node_modules/postcss-js/process-result.js @@ -0,0 +1,11 @@ +let objectify = require('./objectifier') + +module.exports = function processResult(result) { + if (console && console.warn) { + result.warnings().forEach(warn => { + let source = warn.plugin || 'PostCSS' + console.warn(source + ': ' + warn.text) + }) + } + return objectify(result.root) +} diff --git a/node_modules/postcss-js/sync.js b/node_modules/postcss-js/sync.js new file mode 100644 index 0000000..745bd27 --- /dev/null +++ b/node_modules/postcss-js/sync.js @@ -0,0 +1,12 @@ +let postcss = require('postcss') + +let processResult = require('./process-result') +let parse = require('./parser') + +module.exports = function (plugins) { + let processor = postcss(plugins) + return input => { + let result = processor.process(input, { parser: parse, from: undefined }) + return processResult(result) + } +} diff --git a/node_modules/postcss-load-config/LICENSE b/node_modules/postcss-load-config/LICENSE new file mode 100644 index 0000000..458e8a3 --- /dev/null +++ b/node_modules/postcss-load-config/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright Michael Ciniawsky + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-load-config/README.md b/node_modules/postcss-load-config/README.md new file mode 100644 index 0000000..741ddd3 --- /dev/null +++ b/node_modules/postcss-load-config/README.md @@ -0,0 +1,500 @@ +[![npm][npm]][npm-url] +[![node][node]][node-url] +[![deps][deps]][deps-url] +[![test][test]][test-url] +[![coverage][cover]][cover-url] +[![code style][style]][style-url] +[![chat][chat]][chat-url] + +
      + + + + + +

      Load Config

      +
      + +

      Install

      + +```bash +npm i -D postcss-load-config +``` + +

      Usage

      + +```bash +npm i -S|-D postcss-plugin +``` + +Install all required PostCSS plugins and save them to your **package.json** `dependencies`/`devDependencies` + +Then create a PostCSS config file by choosing one of the following formats + +### `package.json` + +Create a **`postcss`** section in your project's **`package.json`** + +``` +Project (Root) + |– client + |– public + | + |- package.json +``` + +```json +{ + "postcss": { + "parser": "sugarss", + "map": false, + "plugins": { + "postcss-plugin": {} + } + } +} +``` + +### `.postcssrc` + +Create a **`.postcssrc`** file in JSON or YAML format + +> ℹ️ It's recommended to use an extension (e.g **`.postcssrc.json`** or **`.postcssrc.yml`**) instead of `.postcssrc` + +``` +Project (Root) + |– client + |– public + | + |- (.postcssrc|.postcssrc.json|.postcssrc.yml) + |- package.json +``` + +**`.postcssrc.json`** +```json +{ + "parser": "sugarss", + "map": false, + "plugins": { + "postcss-plugin": {} + } +} +``` + +**`.postcssrc.yml`** +```yaml +parser: sugarss +map: false +plugins: + postcss-plugin: {} +``` + +### `.postcssrc.js` or `postcss.config.js` + +You may need some logic within your config. In this case create JS file named **`.postcssrc.js`** or **`postcss.config.js`** + +``` +Project (Root) + |– client + |– public + | + |- (.postcssrc.js|postcss.config.js) + |- package.json +``` + +You can export the config as an `{Object}` + +**.postcssrc.js** +```js +module.exports = { + parser: 'sugarss', + map: false, + plugins: { + 'postcss-plugin': {} + } +} +``` + +Or export a `{Function}` that returns the config (more about the `ctx` param below) + +**.postcssrc.js** +```js +module.exports = (ctx) => ({ + parser: ctx.parser ? 'sugarss' : false, + map: ctx.env === 'development' ? ctx.map : false, + plugins: { + 'postcss-plugin': ctx.options.plugin + } +}) +``` + +Plugins can be loaded either using an `{Object}` or an `{Array}` + +#### `{Object}` + +**.postcssrc.js** +```js +module.exports = ({ env }) => ({ + ...options, + plugins: { + 'postcss-plugin': env === 'production' ? {} : false + } +}) +``` + +> ℹ️ When using an `{Object}`, the key can be a Node.js module name, a path to a JavaScript file that is relative to the directory of the PostCSS config file, or an absolute path to a JavaScript file. + +#### `{Array}` + +**.postcssrc.js** +```js +module.exports = ({ env }) => ({ + ...options, + plugins: [ + env === 'production' ? require('postcss-plugin')() : false + ] +}) +``` +> :warning: When using an `{Array}`, make sure to `require()` each plugin + +

      Options

      + +|Name|Type|Default|Description| +|:--:|:--:|:-----:|:----------| +|[**`to`**](#to)|`{String}`|`undefined`|Destination File Path| +|[**`map`**](#map)|`{String\|Object}`|`false`|Enable/Disable Source Maps| +|[**`from`**](#from)|`{String}`|`undefined`|Source File Path| +|[**`parser`**](#parser)|`{String\|Function}`|`false`|Custom PostCSS Parser| +|[**`syntax`**](#syntax)|`{String\|Function}`|`false`|Custom PostCSS Syntax| +|[**`stringifier`**](#stringifier)|`{String\|Function}`|`false`|Custom PostCSS Stringifier| + +### `parser` + +**.postcssrc.js** +```js +module.exports = { + parser: 'sugarss' +} +``` + +### `syntax` + +**.postcssrc.js** +```js +module.exports = { + syntax: 'postcss-scss' +} +``` + +### `stringifier` + +**.postcssrc.js** +```js +module.exports = { + stringifier: 'midas' +} +``` + +### [**`map`**](https://github.com/postcss/postcss/blob/master/docs/source-maps.md) + +**.postcssrc.js** +```js +module.exports = { + map: 'inline' +} +``` + +> :warning: In most cases `options.from` && `options.to` are set by the third-party which integrates this package (CLI, gulp, webpack). It's unlikely one needs to set/use `options.from` && `options.to` within a config file. Unless you're a third-party plugin author using this module and its Node API directly **dont't set `options.from` && `options.to` yourself** + +### `to` + +```js +module.exports = { + to: 'path/to/dest.css' +} +``` + +### `from` + +```js +module.exports = { + from: 'path/to/src.css' +} +``` + +

      Plugins

      + +### `{} || null` + +The plugin will be loaded with defaults + +```js +'postcss-plugin': {} || null +``` + +**.postcssrc.js** +```js +module.exports = { + plugins: { + 'postcss-plugin': {} || null + } +} +``` + +> :warning: `{}` must be an **empty** `{Object}` literal + +### `{Object}` + +The plugin will be loaded with given options + +```js +'postcss-plugin': { option: '', option: '' } +``` + +**.postcssrc.js** +```js +module.exports = { + plugins: { + 'postcss-plugin': { option: '', option: '' } + } +} +``` + +### `false` + +The plugin will not be loaded + +```js +'postcss-plugin': false +``` + +**.postcssrc.js** +```js +module.exports = { + plugins: { + 'postcss-plugin': false + } +} +``` + +### `Ordering` + +Plugin **execution order** is determined by declaration in the plugins section (**top-down**) + +```js +{ + plugins: { + 'postcss-plugin': {}, // [0] + 'postcss-plugin': {}, // [1] + 'postcss-plugin': {} // [2] + } +} +``` + +

      Context

      + +When using a `{Function}` (`postcss.config.js` or `.postcssrc.js`), it's possible to pass context to `postcss-load-config`, which will be evaluated while loading your config. By default `ctx.env (process.env.NODE_ENV)` and `ctx.cwd (process.cwd())` are available on the `ctx` `{Object}` + +> ℹ️ Most third-party integrations add additional properties to the `ctx` (e.g `postcss-loader`). Check the specific module's README for more information about what is available on the respective `ctx` + +

      Examples

      + +**postcss.config.js** + +```js +module.exports = (ctx) => ({ + parser: ctx.parser ? 'sugarss' : false, + map: ctx.env === 'development' ? ctx.map : false, + plugins: { + 'postcss-import': {}, + 'postcss-nested': {}, + cssnano: ctx.env === 'production' ? {} : false + } +}) +``` + +
      + +
      + +```json +"scripts": { + "build": "NODE_ENV=production node postcss", + "start": "NODE_ENV=development node postcss" +} +``` + +### `Async` + +```js +const { readFileSync } = require('fs') + +const postcss = require('postcss') +const postcssrc = require('postcss-load-config') + +const css = readFileSync('index.sss', 'utf8') + +const ctx = { parser: true, map: 'inline' } + +postcssrc(ctx).then(({ plugins, options }) => { + postcss(plugins) + .process(css, options) + .then((result) => console.log(result.css)) +}) +``` + +### `Sync` + +```js +const { readFileSync } = require('fs') + +const postcss = require('postcss') +const postcssrc = require('postcss-load-config') + +const css = readFileSync('index.sss', 'utf8') + +const ctx = { parser: true, map: 'inline' } + +const { plugins, options } = postcssrc.sync(ctx) +``` + +
      + +
      + +```json +"scripts": { + "build": "NODE_ENV=production gulp", + "start": "NODE_ENV=development gulp" +} +``` + +```js +const { task, src, dest, series, watch } = require('gulp') + +const postcss = require('gulp-postcssrc') + +const css = () => { + src('src/*.css') + .pipe(postcss()) + .pipe(dest('dest')) +}) + +task('watch', () => { + watch(['src/*.css', 'postcss.config.js'], css) +}) + +task('default', series(css, 'watch')) +``` + +
      + +
      + +```json +"scripts": { + "build": "NODE_ENV=production webpack", + "start": "NODE_ENV=development webpack-dev-server" +} +``` + +**webpack.config.js** +```js +module.exports = (env) => ({ + module: { + rules: [ + { + test: /\.css$/, + use: [ + 'style-loader', + 'css-loader', + 'postcss-loader' + ] + } + ] + } +}) +``` + +

      Maintainers

      + + + + + + + + +
      + +
      + Michael Ciniawsky +
      + +
      + Mateusz Derks +
      + +

      Contributors

      + + + + + + + + + + +
      + +
      + Ryan Dunckel +
      + +
      + Patrick Gilday +
      + +
      + Dalton Santos +
      + +
      + François Wouts +
      + + +[npm]: https://img.shields.io/npm/v/postcss-load-config.svg +[npm-url]: https://npmjs.com/package/postcss-load-config + +[node]: https://img.shields.io/node/v/postcss-load-plugins.svg +[node-url]: https://nodejs.org/ + +[deps]: https://david-dm.org/michael-ciniawsky/postcss-load-config.svg +[deps-url]: https://david-dm.org/michael-ciniawsky/postcss-load-config + +[test]: http://img.shields.io/travis/michael-ciniawsky/postcss-load-config.svg +[test-url]: https://travis-ci.org/michael-ciniawsky/postcss-load-config + +[cover]: https://coveralls.io/repos/github/michael-ciniawsky/postcss-load-config/badge.svg +[cover-url]: https://coveralls.io/github/michael-ciniawsky/postcss-load-config + +[style]: https://img.shields.io/badge/code%20style-standard-yellow.svg +[style-url]: http://standardjs.com/ + +[chat]: https://img.shields.io/gitter/room/postcss/postcss.svg +[chat-url]: https://gitter.im/postcss/postcss + +## Security Contact + +To report a security vulnerability, please use the [Tidelift security contact]. +Tidelift will coordinate the fix and disclosure. + +[Tidelift security contact]: https://tidelift.com/security diff --git a/node_modules/postcss-load-config/package.json b/node_modules/postcss-load-config/package.json new file mode 100644 index 0000000..01f611b --- /dev/null +++ b/node_modules/postcss-load-config/package.json @@ -0,0 +1,48 @@ +{ + "name": "postcss-load-config", + "version": "3.1.4", + "description": "Autoload Config for PostCSS", + "main": "src/index.js", + "types": "src/index.d.ts", + "files": [ + "src" + ], + "engines": { + "node": ">= 10" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "dependencies": { + "lilconfig": "^2.0.5", + "yaml": "^1.10.2" + }, + "peerDependencies": { + "postcss": ">=8.0.9", + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "ts-node": { + "optional": true + }, + "postcss": { + "optional": true + } + }, + "keywords": [ + "postcss", + "postcssrc", + "postcss.config.js" + ], + "author": "Michael Ciniawky ", + "contributors": [ + "Ryan Dunckel", + "Mateusz Derks", + "Dalton Santos", + "Patrick Gilday", + "François Wouts" + ], + "repository": "postcss/postcss-load-config", + "license": "MIT" +} diff --git a/node_modules/postcss-load-config/src/index.d.ts b/node_modules/postcss-load-config/src/index.d.ts new file mode 100644 index 0000000..c2c4cfe --- /dev/null +++ b/node_modules/postcss-load-config/src/index.d.ts @@ -0,0 +1,71 @@ +// based on @types/postcss-load-config@2.0.1 +// Type definitions for postcss-load-config 2.1 +import Processor from 'postcss/lib/processor'; +import { Plugin, ProcessOptions, Transformer } from 'postcss'; +import { Options as ConfigOptions } from "lilconfig"; + +declare function postcssrc( + ctx?: postcssrc.ConfigContext, + path?: string, + options?: ConfigOptions +): Promise; + +declare namespace postcssrc { + function sync( + ctx?: ConfigContext, + path?: string, + options?: ConfigOptions + ): Result; + + // In the ConfigContext, these three options can be instances of the + // appropriate class, or strings. If they are strings, postcss-load-config will + // require() them and pass the instances along. + export interface ProcessOptionsPreload { + parser?: string | ProcessOptions['parser']; + stringifier?: string | ProcessOptions['stringifier']; + syntax?: string | ProcessOptions['syntax']; + } + + // The remaining ProcessOptions, sans the three above. + export type RemainingProcessOptions = Pick< + ProcessOptions, + Exclude + >; + + // Additional context options that postcss-load-config understands. + export interface Context { + cwd?: string; + env?: string; + } + + // The full shape of the ConfigContext. + export type ConfigContext = Context & + ProcessOptionsPreload & + RemainingProcessOptions; + + // Result of postcssrc is a Promise containing the filename plus the options + // and plugins that are ready to pass on to postcss. + export type ResultPlugin = Plugin | Transformer | Processor; + + export interface Result { + file: string; + options: ProcessOptions; + plugins: ResultPlugin[]; + } + + export type ConfigPlugin = Transformer | Plugin | Processor; + + export interface Config { + parser?: string | ProcessOptions['parser'] | false; + stringifier?: string | ProcessOptions['stringifier'] | false; + syntax?: string | ProcessOptions['syntax'] | false; + map?: string | false; + from?: string; + to?: string; + plugins?: Array | Record; + } + + export type ConfigFn = (ctx: ConfigContext) => Config | Promise; +} + +export = postcssrc; diff --git a/node_modules/postcss-load-config/src/index.js b/node_modules/postcss-load-config/src/index.js new file mode 100644 index 0000000..db5c40e --- /dev/null +++ b/node_modules/postcss-load-config/src/index.js @@ -0,0 +1,188 @@ +'use strict' + +const resolve = require('path').resolve + +const config = require('lilconfig') +const yaml = require('yaml') + +const loadOptions = require('./options.js') +const loadPlugins = require('./plugins.js') + +/* istanbul ignore next */ +const interopRequireDefault = (obj) => obj && obj.__esModule ? obj : { default: obj } + +/** + * Process the result from cosmiconfig + * + * @param {Object} ctx Config Context + * @param {Object} result Cosmiconfig result + * + * @return {Object} PostCSS Config + */ +const processResult = (ctx, result) => { + const file = result.filepath || '' + let config = interopRequireDefault(result.config).default || {} + + if (typeof config === 'function') { + config = config(ctx) + } else { + config = Object.assign({}, config, ctx) + } + + if (!config.plugins) { + config.plugins = [] + } + + return { + plugins: loadPlugins(config, file), + options: loadOptions(config, file), + file: file + } +} + +/** + * Builds the Config Context + * + * @param {Object} ctx Config Context + * + * @return {Object} Config Context + */ +const createContext = (ctx) => { + /** + * @type {Object} + * + * @prop {String} cwd=process.cwd() Config search start location + * @prop {String} env=process.env.NODE_ENV Config Enviroment, will be set to `development` by `postcss-load-config` if `process.env.NODE_ENV` is `undefined` + */ + ctx = Object.assign({ + cwd: process.cwd(), + env: process.env.NODE_ENV + }, ctx) + + if (!ctx.env) { + process.env.NODE_ENV = 'development' + } + + return ctx +} + +const addTypeScriptLoader = (options = {}, loader) => { + const moduleName = 'postcss' + + return { + ...options, + searchPlaces: [ + ...(options.searchPlaces || []), + 'package.json', + `.${moduleName}rc`, + `.${moduleName}rc.json`, + `.${moduleName}rc.yaml`, + `.${moduleName}rc.yml`, + `.${moduleName}rc.ts`, + `.${moduleName}rc.js`, + `.${moduleName}rc.cjs`, + `${moduleName}.config.ts`, + `${moduleName}.config.js`, + `${moduleName}.config.cjs` + ], + loaders: { + ...options.loaders, + '.yaml': (filepath, content) => yaml.parse(content), + '.yml': (filepath, content) => yaml.parse(content), + '.ts': loader + } + } +} + +const withTypeScriptLoader = (rcFunc) => { + return (ctx, path, options) => { + return rcFunc(ctx, path, addTypeScriptLoader(options, (configFile) => { + let registerer = { enabled () {} } + + try { + // Register TypeScript compiler instance + registerer = require('ts-node').register() + + return require(configFile) + } catch (err) { + if (err.code === 'MODULE_NOT_FOUND') { + throw new Error( + `'ts-node' is required for the TypeScript configuration files. Make sure it is installed\nError: ${err.message}` + ) + } + + throw err + } finally { + registerer.enabled(false) + } + })) + } +} + +/** + * Load Config + * + * @method rc + * + * @param {Object} ctx Config Context + * @param {String} path Config Path + * @param {Object} options Config Options + * + * @return {Promise} config PostCSS Config + */ +const rc = withTypeScriptLoader((ctx, path, options) => { + /** + * @type {Object} The full Config Context + */ + ctx = createContext(ctx) + + /** + * @type {String} `process.cwd()` + */ + path = path ? resolve(path) : process.cwd() + + return config.lilconfig('postcss', options) + .search(path) + .then((result) => { + if (!result) { + throw new Error(`No PostCSS Config found in: ${path}`) + } + + return processResult(ctx, result) + }) +}) + +rc.sync = withTypeScriptLoader((ctx, path, options) => { + /** + * @type {Object} The full Config Context + */ + ctx = createContext(ctx) + + /** + * @type {String} `process.cwd()` + */ + path = path ? resolve(path) : process.cwd() + + const result = config.lilconfigSync('postcss', options).search(path) + + if (!result) { + throw new Error(`No PostCSS Config found in: ${path}`) + } + + return processResult(ctx, result) +}) + +/** + * Autoload Config for PostCSS + * + * @author Michael Ciniawsky @michael-ciniawsky + * @license MIT + * + * @module postcss-load-config + * @version 2.1.0 + * + * @requires comsiconfig + * @requires ./options + * @requires ./plugins + */ +module.exports = rc diff --git a/node_modules/postcss-load-config/src/options.js b/node_modules/postcss-load-config/src/options.js new file mode 100644 index 0000000..d3ef2d6 --- /dev/null +++ b/node_modules/postcss-load-config/src/options.js @@ -0,0 +1,47 @@ +'use strict' + +const req = require('./req.js') + +/** + * Load Options + * + * @private + * @method options + * + * @param {Object} config PostCSS Config + * + * @return {Object} options PostCSS Options + */ +const options = (config, file) => { + if (config.parser && typeof config.parser === 'string') { + try { + config.parser = req(config.parser, file) + } catch (err) { + throw new Error(`Loading PostCSS Parser failed: ${err.message}\n\n(@${file})`) + } + } + + if (config.syntax && typeof config.syntax === 'string') { + try { + config.syntax = req(config.syntax, file) + } catch (err) { + throw new Error(`Loading PostCSS Syntax failed: ${err.message}\n\n(@${file})`) + } + } + + if (config.stringifier && typeof config.stringifier === 'string') { + try { + config.stringifier = req(config.stringifier, file) + } catch (err) { + throw new Error(`Loading PostCSS Stringifier failed: ${err.message}\n\n(@${file})`) + } + } + + if (config.plugins) { + delete config.plugins + } + + return config +} + +module.exports = options diff --git a/node_modules/postcss-load-config/src/plugins.js b/node_modules/postcss-load-config/src/plugins.js new file mode 100644 index 0000000..6cb994b --- /dev/null +++ b/node_modules/postcss-load-config/src/plugins.js @@ -0,0 +1,85 @@ +'use strict' + +const req = require('./req.js') + +/** + * Plugin Loader + * + * @private + * @method load + * + * @param {String} plugin PostCSS Plugin Name + * @param {Object} options PostCSS Plugin Options + * + * @return {Function} PostCSS Plugin + */ +const load = (plugin, options, file) => { + try { + if ( + options === null || + options === undefined || + Object.keys(options).length === 0 + ) { + return req(plugin, file) + } else { + return req(plugin, file)(options) + } + } catch (err) { + throw new Error(`Loading PostCSS Plugin failed: ${err.message}\n\n(@${file})`) + } +} + +/** + * Load Plugins + * + * @private + * @method plugins + * + * @param {Object} config PostCSS Config Plugins + * + * @return {Array} plugins PostCSS Plugins + */ +const plugins = (config, file) => { + let plugins = [] + + if (Array.isArray(config.plugins)) { + plugins = config.plugins.filter(Boolean) + } else { + plugins = Object.keys(config.plugins) + .filter((plugin) => { + return config.plugins[plugin] !== false ? plugin : '' + }) + .map((plugin) => { + return load(plugin, config.plugins[plugin], file) + }) + } + + if (plugins.length && plugins.length > 0) { + plugins.forEach((plugin, i) => { + if (plugin.default) { + plugin = plugin.default + } + + if (plugin.postcss === true) { + plugin = plugin() + } else if (plugin.postcss) { + plugin = plugin.postcss + } + + if ( + // eslint-disable-next-line + !( + (typeof plugin === 'object' && Array.isArray(plugin.plugins)) || + (typeof plugin === 'object' && plugin.postcssPlugin) || + (typeof plugin === 'function') + ) + ) { + throw new TypeError(`Invalid PostCSS Plugin found at: plugins[${i}]\n\n(@${file})`) + } + }) + } + + return plugins +} + +module.exports = plugins diff --git a/node_modules/postcss-load-config/src/req.js b/node_modules/postcss-load-config/src/req.js new file mode 100644 index 0000000..ad6a332 --- /dev/null +++ b/node_modules/postcss-load-config/src/req.js @@ -0,0 +1,10 @@ +// eslint-disable-next-line node/no-deprecated-api +const { createRequire, createRequireFromPath } = require('module') + +function req (name, rootFile) { + const create = createRequire || createRequireFromPath + const require = create(rootFile) + return require(name) +} + +module.exports = req diff --git a/node_modules/postcss-nested/LICENSE b/node_modules/postcss-nested/LICENSE new file mode 100644 index 0000000..1ae47a2 --- /dev/null +++ b/node_modules/postcss-nested/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright 2014 Andrey Sitnik + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-nested/README.md b/node_modules/postcss-nested/README.md new file mode 100644 index 0000000..118ae20 --- /dev/null +++ b/node_modules/postcss-nested/README.md @@ -0,0 +1,198 @@ +# PostCSS Nested + + + +[PostCSS] plugin to unwrap nested rules like how Sass does it. + +```css +.phone { + &_title { + width: 500px; + @media (max-width: 500px) { + width: auto; + } + body.is_dark & { + color: white; + } + } + img { + display: block; + } +} + +.title { + font-size: var(--font); + + @at-root html { + --font: 16px + } +} +``` + +will be processed to: + +```css +.phone_title { + width: 500px; +} +@media (max-width: 500px) { + .phone_title { + width: auto; + } +} +body.is_dark .phone_title { + color: white; +} +.phone img { + display: block; +} + +.title { + font-size: var(--font); +} +html { + --font: 16px +} +``` + +Related plugins: + +* Use [`postcss-atroot`] for `@at-root` at-rule to move nested child + to the CSS root. +* Use [`postcss-current-selector`] **after** this plugin if you want + to use current selector in properties or variables values. +* Use [`postcss-nested-ancestors`] **before** this plugin if you want + to reference any ancestor element directly in your selectors with `^&`. + +Alternatives: + +* See also [`postcss-nesting`], which implements [CSSWG draft] + (requires the `&` and introduces `@nest`). +* [`postcss-nested-props`] for nested properties like `font-size`. + + + Sponsored by Evil Martians + + +[`postcss-atroot`]: https://github.com/OEvgeny/postcss-atroot +[`postcss-current-selector`]: https://github.com/komlev/postcss-current-selector +[`postcss-nested-ancestors`]: https://github.com/toomuchdesign/postcss-nested-ancestors +[`postcss-nested-props`]: https://github.com/jedmao/postcss-nested-props +[`postcss-nesting`]: https://github.com/jonathantneal/postcss-nesting +[CSSWG draft]: https://drafts.csswg.org/css-nesting-1/ +[PostCSS]: https://github.com/postcss/postcss + + +## Usage + +**Step 1:** Install plugin: + +```sh +npm install --save-dev postcss postcss-nested +``` + +**Step 2:** Check your project for existing PostCSS config: `postcss.config.js` +in the project root, `"postcss"` section in `package.json` +or `postcss` in bundle config. + +If you do not use PostCSS, add it according to [official docs] +and set this plugin in settings. + +**Step 3:** Add the plugin to plugins list: + +```diff +module.exports = { + plugins: [ ++ require('postcss-nested'), + require('autoprefixer') + ] +} +``` + +[official docs]: https://github.com/postcss/postcss#usage + + +## Options + +### `bubble` + +By default, plugin will bubble only `@media` and `@supports` at-rules. +You can add your custom at-rules to this list by `bubble` option: + +```js +postcss([ require('postcss-nested')({ bubble: ['phone'] }) ]) +``` + +```css +/* input */ +a { + color: white; + @phone { + color: black; + } +} +/* output */ +a { + color: white; +} +@phone { + a { + color: black; + } +} +``` + + +### `unwrap` + +By default, plugin will unwrap only `@font-face`, `@keyframes` and `@document` +at-rules. You can add your custom at-rules to this list by `unwrap` option: + +```js +postcss([ require('postcss-nested')({ unwrap: ['phone'] }) ]) +``` + +```css +/* input */ +a { + color: white; + @phone { + color: black; + } +} +/* output */ +a { + color: white; +} +@phone { + color: black; +} +``` + + +### `preserveEmpty` + +By default, plugin will strip out any empty selector generated by intermediate +nesting levels. You can set `preserveEmpty` to `true` to preserve them. + +```css +.a { + .b { + color: black; + } +} +``` + +Will be compiled to: + +```css +.a { } +.a .b { + color: black; +} +``` + +This is especially useful if you want to export the empty classes with `postcss-modules`. diff --git a/node_modules/postcss-nested/index.d.ts b/node_modules/postcss-nested/index.d.ts new file mode 100644 index 0000000..d22bcdd --- /dev/null +++ b/node_modules/postcss-nested/index.d.ts @@ -0,0 +1,34 @@ +// Original definitions (@types/postcss-nested) +// by Maxim Vorontsov + +import { PluginCreator } from 'postcss' + +declare namespace nested { + interface Options { + /** + * By default, plugin will bubble only `@media` and `@supports` at-rules. + * You can add your custom at-rules to this list by this option. + */ + bubble?: string[] + + /** + * By default, plugin will unwrap only `@font-face`, `@keyframes`, + * and `@document` at-rules. You can add your custom at-rules + * to this list by this option. + */ + unwrap?: string[] + + /** + * By default, plugin will strip out any empty selector generated + * by intermediate nesting levels. You can set this option to `true` + * to preserve them. + */ + preserveEmpty?: boolean + } + + type Nested = PluginCreator +} + +declare const nested: nested.Nested + +export = nested diff --git a/node_modules/postcss-nested/index.js b/node_modules/postcss-nested/index.js new file mode 100644 index 0000000..e6ebd92 --- /dev/null +++ b/node_modules/postcss-nested/index.js @@ -0,0 +1,214 @@ +let parser = require('postcss-selector-parser') + +function parse (str, rule) { + let nodes + let saver = parser(parsed => { + nodes = parsed + }) + try { + saver.processSync(str) + } catch (e) { + if (str.includes(':')) { + throw rule ? rule.error('Missed semicolon') : e + } else { + throw rule ? rule.error(e.message) : e + } + } + return nodes.at(0) +} + +function replace (nodes, parent) { + let replaced = false + nodes.each(i => { + if (i.type === 'nesting') { + let clonedParent = parent.clone() + if (i.value !== '&') { + i.replaceWith(parse(i.value.replace('&', clonedParent.toString()))) + } else { + i.replaceWith(clonedParent) + } + replaced = true + } else if (i.nodes) { + if (replace(i, parent)) { + replaced = true + } + } + }) + return replaced +} + +function selectors (parent, child) { + let result = [] + parent.selectors.forEach(i => { + let parentNode = parse(i, parent) + + child.selectors.forEach(j => { + if (j.length) { + let node = parse(j, child) + let replaced = replace(node, parentNode) + if (!replaced) { + node.prepend(parser.combinator({ value: ' ' })) + node.prepend(parentNode.clone()) + } + result.push(node.toString()) + } + }) + }) + return result +} + +function pickComment (comment, after) { + if (comment && comment.type === 'comment') { + after.after(comment) + return comment + } else { + return after + } +} + +function createFnAtruleChilds (bubble) { + return function atruleChilds (rule, atrule, bubbling) { + let children = [] + atrule.each(child => { + if (child.type === 'comment') { + children.push(child) + } else if (child.type === 'decl') { + children.push(child) + } else if (child.type === 'rule' && bubbling) { + child.selectors = selectors(rule, child) + } else if (child.type === 'atrule') { + if (child.nodes && bubble[child.name]) { + atruleChilds(rule, child, true) + } else { + children.push(child) + } + } + }) + if (bubbling) { + if (children.length) { + let clone = rule.clone({ nodes: [] }) + for (let child of children) { + clone.append(child) + } + atrule.prepend(clone) + } + } + } +} + +function pickDeclarations (selector, declarations, after, Rule) { + let parent = new Rule({ + selector, + nodes: [] + }) + + for (let declaration of declarations) { + parent.append(declaration) + } + + after.after(parent) + return parent +} + +function atruleNames (defaults, custom) { + let list = {} + for (let i of defaults) { + list[i] = true + } + if (custom) { + for (let i of custom) { + let name = i.replace(/^@/, '') + list[name] = true + } + } + return list +} + +module.exports = (opts = {}) => { + let bubble = atruleNames(['media', 'supports'], opts.bubble) + let atruleChilds = createFnAtruleChilds(bubble) + let unwrap = atruleNames( + [ + 'document', + 'font-face', + 'keyframes', + '-webkit-keyframes', + '-moz-keyframes' + ], + opts.unwrap + ) + let preserveEmpty = opts.preserveEmpty + + return { + postcssPlugin: 'postcss-nested', + Rule (rule, { Rule }) { + let unwrapped = false + let after = rule + let copyDeclarations = false + let declarations = [] + + rule.each(child => { + if (child.type === 'rule') { + if (declarations.length) { + after = pickDeclarations(rule.selector, declarations, after, Rule) + declarations = [] + } + + copyDeclarations = true + unwrapped = true + child.selectors = selectors(rule, child) + after = pickComment(child.prev(), after) + after.after(child) + after = child + } else if (child.type === 'atrule') { + if (declarations.length) { + after = pickDeclarations(rule.selector, declarations, after, Rule) + declarations = [] + } + + if (child.name === 'at-root') { + unwrapped = true + atruleChilds(rule, child, false) + + let nodes = child.nodes + if (child.params) { + nodes = new Rule({ selector: child.params, nodes }) + } + + after.after(nodes) + after = nodes + child.remove() + } else if (bubble[child.name]) { + copyDeclarations = true + unwrapped = true + atruleChilds(rule, child, true) + after = pickComment(child.prev(), after) + after.after(child) + after = child + } else if (unwrap[child.name]) { + copyDeclarations = true + unwrapped = true + atruleChilds(rule, child, false) + after = pickComment(child.prev(), after) + after.after(child) + after = child + } else if (copyDeclarations) { + declarations.push(child) + } + } else if (child.type === 'decl' && copyDeclarations) { + declarations.push(child) + } + }) + + if (declarations.length) { + after = pickDeclarations(rule.selector, declarations, after, Rule) + } + + if (unwrapped && preserveEmpty !== true) { + rule.raws.semicolon = true + if (rule.nodes.length === 0) rule.remove() + } + } + } +} +module.exports.postcss = true diff --git a/node_modules/postcss-nested/package.json b/node_modules/postcss-nested/package.json new file mode 100644 index 0000000..29090bd --- /dev/null +++ b/node_modules/postcss-nested/package.json @@ -0,0 +1,28 @@ +{ + "name": "postcss-nested", + "version": "5.0.6", + "description": "PostCSS plugin to unwrap nested rules like how Sass does it", + "keywords": [ + "postcss", + "css", + "postcss-plugin", + "sass", + "nested" + ], + "author": "Andrey Sitnik ", + "license": "MIT", + "repository": "postcss/postcss-nested", + "engines": { + "node": ">=12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.2.14" + }, + "dependencies": { + "postcss-selector-parser": "^6.0.6" + } +} diff --git a/node_modules/postcss-selector-parser/API.md b/node_modules/postcss-selector-parser/API.md new file mode 100644 index 0000000..6aa1f14 --- /dev/null +++ b/node_modules/postcss-selector-parser/API.md @@ -0,0 +1,873 @@ +# API Documentation + +*Please use only this documented API when working with the parser. Methods +not documented here are subject to change at any point.* + +## `parser` function + +This is the module's main entry point. + +```js +const parser = require('postcss-selector-parser'); +``` + +### `parser([transform], [options])` + +Creates a new `processor` instance + +```js +const processor = parser(); +``` + +Or, with optional transform function + +```js +const transform = selectors => { + selectors.walkUniversals(selector => { + selector.remove(); + }); +}; + +const processor = parser(transform) + +// Example +const result = processor.processSync('*.class'); +// => .class +``` + +[See processor documentation](#processor) + +Arguments: + +* `transform (function)`: Provide a function to work with the parsed AST. +* `options (object)`: Provide default options for all calls on the returned `Processor`. + +### `parser.attribute([props])` + +Creates a new attribute selector. + +```js +parser.attribute({attribute: 'href'}); +// => [href] +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.className([props])` + +Creates a new class selector. + +```js +parser.className({value: 'button'}); +// => .button +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.combinator([props])` + +Creates a new selector combinator. + +```js +parser.combinator({value: '+'}); +// => + +``` + +Arguments: + +* `props (object)`: The new node's properties. + +Notes: +* **Descendant Combinators** The value of descendant combinators created by the + parser always just a single space (`" "`). For descendant selectors with no + comments, additional space is now stored in `node.spaces.before`. Depending + on the location of comments, additional spaces may be stored in + `node.raws.spaces.before`, `node.raws.spaces.after`, or `node.raws.value`. +* **Named Combinators** Although, nonstandard and unlikely to ever become a standard, + named combinators like `/deep/` and `/for/` are parsed as combinators. The + `node.value` is name after being unescaped and normalized as lowercase. The + original value for the combinator name is stored in `node.raws.value`. + + +### `parser.comment([props])` + +Creates a new comment. + +```js +parser.comment({value: '/* Affirmative, Dave. I read you. */'}); +// => /* Affirmative, Dave. I read you. */ +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.id([props])` + +Creates a new id selector. + +```js +parser.id({value: 'search'}); +// => #search +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.nesting([props])` + +Creates a new nesting selector. + +```js +parser.nesting(); +// => & +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.pseudo([props])` + +Creates a new pseudo selector. + +```js +parser.pseudo({value: '::before'}); +// => ::before +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.root([props])` + +Creates a new root node. + +```js +parser.root(); +// => (empty) +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.selector([props])` + +Creates a new selector node. + +```js +parser.selector(); +// => (empty) +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.string([props])` + +Creates a new string node. + +```js +parser.string(); +// => (empty) +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.tag([props])` + +Creates a new tag selector. + +```js +parser.tag({value: 'button'}); +// => button +``` + +Arguments: + +* `props (object)`: The new node's properties. + +### `parser.universal([props])` + +Creates a new universal selector. + +```js +parser.universal(); +// => * +``` + +Arguments: + +* `props (object)`: The new node's properties. + +## Node types + +### `node.type` + +A string representation of the selector type. It can be one of the following; +`attribute`, `class`, `combinator`, `comment`, `id`, `nesting`, `pseudo`, +`root`, `selector`, `string`, `tag`, or `universal`. Note that for convenience, +these constants are exposed on the main `parser` as uppercased keys. So for +example you can get `id` by querying `parser.ID`. + +```js +parser.attribute({attribute: 'href'}).type; +// => 'attribute' +``` + +### `node.parent` + +Returns the parent node. + +```js +root.nodes[0].parent === root; +``` + +### `node.toString()`, `String(node)`, or `'' + node` + +Returns a string representation of the node. + +```js +const id = parser.id({value: 'search'}); +console.log(String(id)); +// => #search +``` + +### `node.next()` & `node.prev()` + +Returns the next/previous child of the parent node. + +```js +const next = id.next(); +if (next && next.type !== 'combinator') { + throw new Error('Qualified IDs are not allowed!'); +} +``` + +### `node.replaceWith(node)` + +Replace a node with another. + +```js +const attr = selectors.first.first; +const className = parser.className({value: 'test'}); +attr.replaceWith(className); +``` + +Arguments: + +* `node`: The node to substitute the original with. + +### `node.remove()` + +Removes the node from its parent node. + +```js +if (node.type === 'id') { + node.remove(); +} +``` + +### `node.clone()` + +Returns a copy of a node, detached from any parent containers that the +original might have had. + +```js +const cloned = parser.id({value: 'search'}); +String(cloned); + +// => #search +``` + +### `node.isAtPosition(line, column)` + +Return a `boolean` indicating whether this node includes the character at the +position of the given line and column. Returns `undefined` if the nodes lack +sufficient source metadata to determine the position. + +Arguments: + +* `line`: 1-index based line number relative to the start of the selector. +* `column`: 1-index based column number relative to the start of the selector. + +### `node.spaces` + +Extra whitespaces around the node will be moved into `node.spaces.before` and +`node.spaces.after`. So for example, these spaces will be moved as they have +no semantic meaning: + +```css + h1 , h2 {} +``` + +For descendent selectors, the value is always a single space. + +```css +h1 h2 {} +``` + +Additional whitespace is found in either the `node.spaces.before` and `node.spaces.after` depending on the presence of comments or other whitespace characters. If the actual whitespace does not start or end with a single space, the node's raw value is set to the actual space(s) found in the source. + +### `node.source` + +An object describing the node's start/end, line/column source position. + +Within the following CSS, the `.bar` class node ... + +```css +.foo, + .bar {} +``` + +... will contain the following `source` object. + +```js +source: { + start: { + line: 2, + column: 3 + }, + end: { + line: 2, + column: 6 + } +} +``` + +### `node.sourceIndex` + +The zero-based index of the node within the original source string. + +Within the following CSS, the `.baz` class node will have a `sourceIndex` of `12`. + +```css +.foo, .bar, .baz {} +``` + +## Container types + +The `root`, `selector`, and `pseudo` nodes have some helper methods for working +with their children. + +### `container.nodes` + +An array of the container's children. + +```js +// Input: h1 h2 +selectors.at(0).nodes.length // => 3 +selectors.at(0).nodes[0].value // => 'h1' +selectors.at(0).nodes[1].value // => ' ' +``` + +### `container.first` & `container.last` + +The first/last child of the container. + +```js +selector.first === selector.nodes[0]; +selector.last === selector.nodes[selector.nodes.length - 1]; +``` + +### `container.at(index)` + +Returns the node at position `index`. + +```js +selector.at(0) === selector.first; +selector.at(0) === selector.nodes[0]; +``` + +Arguments: + +* `index`: The index of the node to return. + +### `container.atPosition(line, column)` + +Returns the node at the source position `index`. + +```js +selector.at(0) === selector.first; +selector.at(0) === selector.nodes[0]; +``` + +Arguments: + +* `index`: The index of the node to return. + +### `container.index(node)` + +Return the index of the node within its container. + +```js +selector.index(selector.nodes[2]) // => 2 +``` + +Arguments: + +* `node`: A node within the current container. + +### `container.length` + +Proxy to the length of the container's nodes. + +```js +container.length === container.nodes.length +``` + +### `container` Array iterators + +The container class provides proxies to certain Array methods; these are: + +* `container.map === container.nodes.map` +* `container.reduce === container.nodes.reduce` +* `container.every === container.nodes.every` +* `container.some === container.nodes.some` +* `container.filter === container.nodes.filter` +* `container.sort === container.nodes.sort` + +Note that these methods only work on a container's immediate children; recursive +iteration is provided by `container.walk`. + +### `container.each(callback)` + +Iterate the container's immediate children, calling `callback` for each child. +You may return `false` within the callback to break the iteration. + +```js +let className; +selectors.each((selector, index) => { + if (selector.type === 'class') { + className = selector.value; + return false; + } +}); +``` + +Note that unlike `Array#forEach()`, this iterator is safe to use whilst adding +or removing nodes from the container. + +Arguments: + +* `callback (function)`: A function to call for each node, which receives `node` + and `index` arguments. + +### `container.walk(callback)` + +Like `container#each`, but will also iterate child nodes as long as they are +`container` types. + +```js +selectors.walk((selector, index) => { + // all nodes +}); +``` + +Arguments: + +* `callback (function)`: A function to call for each node, which receives `node` + and `index` arguments. + +This iterator is safe to use whilst mutating `container.nodes`, +like `container#each`. + +### `container.walk` proxies + +The container class provides proxy methods for iterating over types of nodes, +so that it is easier to write modules that target specific selectors. Those +methods are: + +* `container.walkAttributes` +* `container.walkClasses` +* `container.walkCombinators` +* `container.walkComments` +* `container.walkIds` +* `container.walkNesting` +* `container.walkPseudos` +* `container.walkTags` +* `container.walkUniversals` + +### `container.split(callback)` + +This method allows you to split a group of nodes by returning `true` from +a callback. It returns an array of arrays, where each inner array corresponds +to the groups that you created via the callback. + +```js +// (input) => h1 h2>>h3 +const list = selectors.first.split(selector => { + return selector.type === 'combinator'; +}); + +// (node values) => [['h1', ' '], ['h2', '>>'], ['h3']] +``` + +Arguments: + +* `callback (function)`: A function to call for each node, which receives `node` + as an argument. + +### `container.prepend(node)` & `container.append(node)` + +Add a node to the start/end of the container. Note that doing so will set +the parent property of the node to this container. + +```js +const id = parser.id({value: 'search'}); +selector.append(id); +``` + +Arguments: + +* `node`: The node to add. + +### `container.insertBefore(old, new)` & `container.insertAfter(old, new)` + +Add a node before or after an existing node in a container: + +```js +selectors.walk(selector => { + if (selector.type !== 'class') { + const className = parser.className({value: 'theme-name'}); + selector.parent.insertAfter(selector, className); + } +}); +``` + +Arguments: + +* `old`: The existing node in the container. +* `new`: The new node to add before/after the existing node. + +### `container.removeChild(node)` + +Remove the node from the container. Note that you can also use +`node.remove()` if you would like to remove just a single node. + +```js +selector.length // => 2 +selector.remove(id) +selector.length // => 1; +id.parent // undefined +``` + +Arguments: + +* `node`: The node to remove. + +### `container.removeAll()` or `container.empty()` + +Remove all children from the container. + +```js +selector.removeAll(); +selector.length // => 0 +``` + +## Root nodes + +A root node represents a comma separated list of selectors. Indeed, all +a root's `toString()` method does is join its selector children with a ','. +Other than this, it has no special functionality and acts like a container. + +### `root.trailingComma` + +This will be set to `true` if the input has a trailing comma, in order to +support parsing of legacy CSS hacks. + +## Selector nodes + +A selector node represents a single complex selector. For example, this +selector string `h1 h2 h3, [href] > p`, is represented as two selector nodes. +It has no special functionality of its own. + +## Pseudo nodes + +A pseudo selector extends a container node; if it has any parameters of its +own (such as `h1:not(h2, h3)`), they will be its children. Note that the pseudo +`value` will always contain the colons preceding the pseudo identifier. This +is so that both `:before` and `::before` are properly represented in the AST. + +## Attribute nodes + +### `attribute.quoted` + +Returns `true` if the attribute's value is wrapped in quotation marks, false if it is not. +Remains `undefined` if there is no attribute value. + +```css +[href=foo] /* false */ +[href='foo'] /* true */ +[href="foo"] /* true */ +[href] /* undefined */ +``` + +### `attribute.qualifiedAttribute` + +Returns the attribute name qualified with the namespace if one is given. + +### `attribute.offsetOf(part)` + + Returns the offset of the attribute part specified relative to the + start of the node of the output string. This is useful in raising + error messages about a specific part of the attribute, especially + in combination with `attribute.sourceIndex`. + + Returns `-1` if the name is invalid or the value doesn't exist in this + attribute. + + The legal values for `part` are: + + * `"ns"` - alias for "namespace" + * `"namespace"` - the namespace if it exists. + * `"attribute"` - the attribute name + * `"attributeNS"` - the start of the attribute or its namespace + * `"operator"` - the match operator of the attribute + * `"value"` - The value (string or identifier) + * `"insensitive"` - the case insensitivity flag + +### `attribute.raws.unquoted` + +Returns the unquoted content of the attribute's value. +Remains `undefined` if there is no attribute value. + +```css +[href=foo] /* foo */ +[href='foo'] /* foo */ +[href="foo"] /* foo */ +[href] /* undefined */ +``` + +### `attribute.spaces` + +Like `node.spaces` with the `before` and `after` values containing the spaces +around the element, the parts of the attribute can also have spaces before +and after them. The for each of `attribute`, `operator`, `value` and +`insensitive` there is corresponding property of the same nam in +`node.spaces` that has an optional `before` or `after` string containing only +whitespace. + +Note that corresponding values in `attributes.raws.spaces` contain values +including any comments. If set, these values will override the +`attribute.spaces` value. Take care to remove them if changing +`attribute.spaces`. + +### `attribute.raws` + +The raws object stores comments and other information necessary to re-render +the node exactly as it was in the source. + +If a comment is embedded within the identifiers for the `namespace`, `attribute` +or `value` then a property is placed in the raws for that value containing the full source of the propery including comments. + +If a comment is embedded within the space between parts of the attribute +then the raw for that space is set accordingly. + +Setting an attribute's property `raws` value to be deleted. + +For now, changing the spaces required also updating or removing any of the +raws values that override them. + +Example: `[ /*before*/ href /* after-attr */ = /* after-operator */ te/*inside-value*/st/* wow */ /*omg*/i/*bbq*/ /*whodoesthis*/]` would parse as: + +```js +{ + attribute: "href", + operator: "=", + value: "test", + spaces: { + before: '', + after: '', + attribute: { before: ' ', after: ' ' }, + operator: { after: ' ' }, + value: { after: ' ' }, + insensitive: { after: ' ' } + }, + raws: { + spaces: { + attribute: { before: ' /*before*/ ', after: ' /* after-attr */ ' }, + operator: { after: ' /* after-operator */ ' }, + value: { after: '/* wow */ /*omg*/' }, + insensitive: { after: '/*bbq*/ /*whodoesthis*/' } + }, + unquoted: 'test', + value: 'te/*inside-value*/st' + } +} +``` + +## `Processor` + +### `ProcessorOptions` + +* `lossless` - When `true`, whitespace is preserved. Defaults to `true`. +* `updateSelector` - When `true`, if any processor methods are passed a postcss + `Rule` node instead of a string, then that Rule's selector is updated + with the results of the processing. Defaults to `true`. + +### `process|processSync(selectors, [options])` + +Processes the `selectors`, returning a string from the result of processing. + +Note: when the `updateSelector` option is set, the rule's selector +will be updated with the resulting string. + +**Example:** + +```js +const parser = require("postcss-selector-parser"); +const processor = parser(); + +let result = processor.processSync(' .class'); +console.log(result); +// => .class + +// Asynchronous operation +let promise = processor.process(' .class').then(result => { + console.log(result) + // => .class +}); + +// To have the parser normalize whitespace values, utilize the options +result = processor.processSync(' .class ', {lossless: false}); +console.log(result); +// => .class + +// For better syntax errors, pass a PostCSS Rule node. +const postcss = require('postcss'); +rule = postcss.rule({selector: ' #foo > a, .class '}); +processor.process(rule, {lossless: false, updateSelector: true}).then(result => { + console.log(result); + // => #foo>a,.class + console.log("rule:", rule.selector); + // => rule: #foo>a,.class +}) +``` + +Arguments: + +* `selectors (string|postcss.Rule)`: Either a selector string or a PostCSS Rule + node. +* `[options] (object)`: Process options + + +### `ast|astSync(selectors, [options])` + +Like `process()` and `processSync()` but after +processing the `selectors` these methods return the `Root` node of the result +instead of a string. + +Note: when the `updateSelector` option is set, the rule's selector +will be updated with the resulting string. + +### `transform|transformSync(selectors, [options])` + +Like `process()` and `processSync()` but after +processing the `selectors` these methods return the value returned by the +processor callback. + +Note: when the `updateSelector` option is set, the rule's selector +will be updated with the resulting string. + +### Error Handling Within Selector Processors + +The root node passed to the selector processor callback +has a method `error(message, options)` that returns an +error object. This method should always be used to raise +errors relating to the syntax of selectors. The options +to this method are passed to postcss's error constructor +([documentation](http://api.postcss.org/Container.html#error)). + +#### Async Error Example + +```js +let processor = (root) => { + return new Promise((resolve, reject) => { + root.walkClasses((classNode) => { + if (/^(.*)[-_]/.test(classNode.value)) { + let msg = "classes may not have underscores or dashes in them"; + reject(root.error(msg, { + index: classNode.sourceIndex + RegExp.$1.length + 1, + word: classNode.value + })); + } + }); + resolve(); + }); +}; + +const postcss = require("postcss"); +const parser = require("postcss-selector-parser"); +const selectorProcessor = parser(processor); +const plugin = postcss.plugin('classValidator', (options) => { + return (root) => { + let promises = []; + root.walkRules(rule => { + promises.push(selectorProcessor.process(rule)); + }); + return Promise.all(promises); + }; +}); +postcss(plugin()).process(` +.foo-bar { + color: red; +} +`.trim(), {from: 'test.css'}).catch((e) => console.error(e.toString())); + +// CssSyntaxError: classValidator: ./test.css:1:5: classes may not have underscores or dashes in them +// +// > 1 | .foo-bar { +// | ^ +// 2 | color: red; +// 3 | } +``` + +#### Synchronous Error Example + +```js +let processor = (root) => { + root.walkClasses((classNode) => { + if (/.*[-_]/.test(classNode.value)) { + let msg = "classes may not have underscores or dashes in them"; + throw root.error(msg, { + index: classNode.sourceIndex, + word: classNode.value + }); + } + }); +}; + +const postcss = require("postcss"); +const parser = require("postcss-selector-parser"); +const selectorProcessor = parser(processor); +const plugin = postcss.plugin('classValidator', (options) => { + return (root) => { + root.walkRules(rule => { + selectorProcessor.processSync(rule); + }); + }; +}); +postcss(plugin()).process(` +.foo-bar { + color: red; +} +`.trim(), {from: 'test.css'}).catch((e) => console.error(e.toString())); + +// CssSyntaxError: classValidator: ./test.css:1:5: classes may not have underscores or dashes in them +// +// > 1 | .foo-bar { +// | ^ +// 2 | color: red; +// 3 | } +``` diff --git a/node_modules/postcss-selector-parser/CHANGELOG.md b/node_modules/postcss-selector-parser/CHANGELOG.md new file mode 100644 index 0000000..f2fdfea --- /dev/null +++ b/node_modules/postcss-selector-parser/CHANGELOG.md @@ -0,0 +1,513 @@ +# 6.0.10 + +- Fixed: `isPseudoElement()` supports `:first-letter` and `:first-line` + +# 6.0.9 + +- Fixed: `Combinator.raws` property type + +# 6.0.8 + +- Fixed: reduced size + +# 6.0.7 + +- Fixed: parse animation percents + +# 6.0.6 + +- Fixed: parse quoted attributes containing a newline correctly + +# 6.0.5 + +- Perf: rework unesc for a 63+% performance boost + +# 6.0.4 + +- Fixed: ts errors + +# 6.0.3 + +- Fixed: replace node built-in "util" module with "util-deprecate" +- Fixed: handle uppercase pseudo elements +- Fixed: do not create invalid combinator before comment + +# 6.0.2 + +- Fixed an issue with parsing and stringifying an empty attribute value + +# 6.0.1 + +- Fixed an issue with unicode surrogate pair parsing + +# 6.0.0 + +- Updated: `cssesc` to 3.0.0 (major) +- Fixed: Issues with escaped `id` and `class` selectors + +# 5.0.0 + +- Allow escaped dot within class name. +- Update PostCSS to 7.0.7 (patch) + +# 5.0.0-rc.4 + +- Fixed an issue where comments immediately after an insensitive (in attribute) + were not parsed correctly. +- Updated `cssesc` to 2.0.0 (major). +- Removed outdated integration tests. +- Added tests for custom selectors, tags with attributes, the universal + selector with pseudos, and tokens after combinators. + +# 5.0.0-rc.1 + +To ease adoption of the v5.0 release, we have relaxed the node version +check performed by npm at installation time to allow for node 4, which +remains officially unsupported, but likely to continue working for the +time being. + +# 5.0.0-rc.0 + +This release has **BREAKING CHANGES** that were required to fix regressions +in 4.0.0 and to make the Combinator Node API consistent for all combinator +types. Please read carefully. + +## Summary of Changes + +* The way a descendent combinator that isn't a single space character (E.g. `.a .b`) is stored in the AST has changed. +* Named Combinators (E.g. `.a /for/ .b`) are now properly parsed as a combinator. +* It is now possible to look up a node based on the source location of a character in that node and to query nodes if they contain some character. +* Several bug fixes that caused the parser to hang and run out of memory when a `/` was encountered have been fixed. +* The minimum supported version of Node is now `v6.0.0`. + +### Changes to the Descendent Combinator + +In prior releases, the value of a descendant combinator with multiple spaces included all the spaces. + +* `.a .b`: Extra spaces are now stored as space before. + - Old & Busted: + - `combinator.value === " "` + - New hotness: + - `combinator.value === " " && combinator.spaces.before === " "` +* `.a /*comment*/.b`: A comment at the end of the combinator causes extra space to become after space. + - Old & Busted: + - `combinator.value === " "` + - `combinator.raws.value === " /*comment/"` + - New hotness: + - `combinator.value === " "` + - `combinator.spaces.after === " "` + - `combinator.raws.spaces.after === " /*comment*/"` +* `.a.b`: whitespace that doesn't start or end with a single space character is stored as a raw value. + - Old & Busted: + - `combinator.value === "\n"` + - `combinator.raws.value === undefined` + - New hotness: + - `combinator.value === " "` + - `combinator.raws.value === "\n"` + +### Support for "Named Combinators" + +Although, nonstandard and unlikely to ever become a standard, combinators like `/deep/` and `/for/` are now properly supported. + +Because they've been taken off the standardization track, there is no spec-official name for combinators of the form `//`. However, I talked to [Tab Atkins](https://twitter.com/tabatkins) and we agreed to call them "named combinators" so now they are called that. + +Before this release such named combinators were parsed without intention and generated three nodes of type `"tag"` where the first and last nodes had a value of `"/"`. + +* `.a /for/ .b` is parsed as a combinator. + - Old & Busted: + - `root.nodes[0].nodes[1].type === "tag"` + - `root.nodes[0].nodes[1].value === "/"` + - New hotness: + - `root.nodes[0].nodes[1].type === "combinator"` + - `root.nodes[0].nodes[1].value === "/for/"` +* `.a /F\6fR/ .b` escapes are handled and uppercase is normalized. + - Old & Busted: + - `root.nodes[0].nodes[2].type === "tag"` + - `root.nodes[0].nodes[2].value === "F\\6fR"` + - New hotness: + - `root.nodes[0].nodes[1].type === "combinator"` + - `root.nodes[0].nodes[1].value === "/for/"` + - `root.nodes[0].nodes[1].raws.value === "/F\\6fR/"` + +### Source position checks and lookups + +A new API was added to look up a node based on the source location. + +```js +const selectorParser = require("postcss-selector-parser"); +// You can find the most specific node for any given character +let combinator = selectorParser.astSync(".a > .b").atPosition(1,4); +combinator.toString() === " > "; +// You can check if a node includes a specific character +// Whitespace surrounding the node that is owned by that node +// is included in the check. +[2,3,4,5,6].map(column => combinator.isAtPosition(1, column)); +// => [false, true, true, true, false] +``` + +# 4.0.0 + +This release has **BREAKING CHANGES** that were required to fix bugs regarding values with escape sequences. Please read carefully. + +* **Identifiers with escapes** - CSS escape sequences are now hidden from the public API by default. + The normal value of a node like a class name or ID, or an aspect of a node such as attribute + selector's value, is unescaped. Escapes representing Non-ascii characters are unescaped into + unicode characters. For example: `bu\tton, .\31 00, #i\2764\FE0Fu, [attr="value is \"quoted\""]` + will parse respectively to the values `button`, `100`, `i❤️u`, `value is "quoted"`. + The original escape sequences for these values can be found in the corresponding property name + in `node.raws`. Where possible, deprecation warnings were added, but the nature + of escape handling makes it impossible to detect what is escaped or not. Our expectation is + that most users are neither expecting nor handling escape sequences in their use of this library, + and so for them, this is a bug fix. Users who are taking care to handle escapes correctly can + now update their code to remove the escape handling and let us do it for them. + +* **Mutating values with escapes** - When you make an update to a node property that has escape handling + The value is assumed to be unescaped, and any special characters are escaped automatically and + the corresponding `raws` value is immediately updated. This can result in changes to the original + escape format. Where the exact value of the escape sequence is important there are methods that + allow both values to be set in conjunction. There are a number of new convenience methods for + manipulating values that involve escapes, especially for attributes values where the quote mark + is involved. See https://github.com/postcss/postcss-selector-parser/pull/133 for an extensive + write-up on these changes. + + +**Upgrade/API Example** + +In `3.x` there was no unescape handling and internal consistency of several properties was the caller's job to maintain. It was very easy for the developer +to create a CSS file that did not parse correctly when some types of values +were in use. + +```js +const selectorParser = require("postcss-selector-parser"); +let attr = selectorParser.attribute({attribute: "id", operator: "=", value: "a-value"}); +attr.value; // => "a-value" +attr.toString(); // => [id=a-value] +// Add quotes to an attribute's value. +// All these values have to be set by the caller to be consistent: +// no internal consistency is maintained. +attr.raws.unquoted = attr.value +attr.value = "'" + attr.value + "'"; +attr.value; // => "'a-value'" +attr.quoted = true; +attr.toString(); // => "[id='a-value']" +``` + +In `4.0` there is a convenient API for setting and mutating values +that may need escaping. Especially for attributes. + +```js +const selectorParser = require("postcss-selector-parser"); + +// The constructor requires you specify the exact escape sequence +let className = selectorParser.className({value: "illegal class name", raws: {value: "illegal\\ class\\ name"}}); +className.toString(); // => '.illegal\\ class\\ name' + +// So it's better to set the value as a property +className = selectorParser.className(); +// Most properties that deal with identifiers work like this +className.value = "escape for me"; +className.value; // => 'escape for me' +className.toString(); // => '.escape\\ for\\ me' + +// emoji and all non-ascii are escaped to ensure it works in every css file. +className.value = "😱🦄😍"; +className.value; // => '😱🦄😍' +className.toString(); // => '.\\1F631\\1F984\\1F60D' + +// you can control the escape sequence if you want, or do bad bad things +className.setPropertyAndEscape('value', 'xxxx', 'yyyy'); +className.value; // => "xxxx" +className.toString(); // => ".yyyy" + +// Pass a value directly through to the css output without escaping it. +className.setPropertyWithoutEscape('value', '$REPLACE_ME$'); +className.value; // => "$REPLACE_ME$" +className.toString(); // => ".$REPLACE_ME$" + +// The biggest changes are to the Attribute class +// passing quoteMark explicitly is required to avoid a deprecation warning. +let attr = selectorParser.attribute({attribute: "id", operator: "=", value: "a-value", quoteMark: null}); +attr.toString(); // => "[id=a-value]" +// Get the value with quotes on it and any necessary escapes. +// This is the same as reading attr.value in 3.x. +attr.getQuotedValue(); // => "a-value"; +attr.quoteMark; // => null + +// Add quotes to an attribute's value. +attr.quoteMark = "'"; // This is all that's required. +attr.toString(); // => "[id='a-value']" +attr.quoted; // => true +// The value is still the same, only the quotes have changed. +attr.value; // => a-value +attr.getQuotedValue(); // => "'a-value'"; + +// deprecated assignment, no warning because there's no escapes +attr.value = "new-value"; +// no quote mark is needed so it is removed +attr.getQuotedValue(); // => "new-value"; + +// deprecated assignment, +attr.value = "\"a 'single quoted' value\""; +// > (node:27859) DeprecationWarning: Assigning an attribute a value containing characters that might need to be escaped is deprecated. Call attribute.setValue() instead. +attr.getQuotedValue(); // => '"a \'single quoted\' value"'; +// quote mark inferred from first and last characters. +attr.quoteMark; // => '"' + +// setValue takes options to make manipulating the value simple. +attr.setValue('foo', {smart: true}); +// foo doesn't require any escapes or quotes. +attr.toString(); // => '[id=foo]' +attr.quoteMark; // => null + +// An explicit quote mark can be specified +attr.setValue('foo', {quoteMark: '"'}); +attr.toString(); // => '[id="foo"]' + +// preserves quote mark by default +attr.setValue('bar'); +attr.toString(); // => '[id="bar"]' +attr.quoteMark = null; +attr.toString(); // => '[id=bar]' + +// with no arguments, it preserves quote mark even when it's not a great idea +attr.setValue('a value \n that should be quoted'); +attr.toString(); // => '[id=a\\ value\\ \\A\\ that\\ should\\ be\\ quoted]' + +// smart preservation with a specified default +attr.setValue('a value \n that should be quoted', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"}); +// => "[id='a value \\A that should be quoted']" +attr.quoteMark = '"'; +// => '[id="a value \\A that should be quoted"]' + +// this keeps double quotes because it wants to quote the value and the existing value has double quotes. +attr.setValue('this should be quoted', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"}); +// => '[id="this should be quoted"]' + +// picks single quotes because the value has double quotes +attr.setValue('a "double quoted" value', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"}); +// => "[id='a "double quoted" value']" + +// setPropertyAndEscape lets you do anything you want. Even things that are a bad idea and illegal. +attr.setPropertyAndEscape('value', 'xxxx', 'the password is 42'); +attr.value; // => "xxxx" +attr.toString(); // => "[id=the password is 42]" + +// Pass a value directly through to the css output without escaping it. +attr.setPropertyWithoutEscape('value', '$REPLACEMENT$'); +attr.value; // => "$REPLACEMENT$" +attr.toString(); // => "[id=$REPLACEMENT$]" +``` + +# 3.1.2 + +* Fix: Removed dot-prop dependency since it's no longer written in es5. + +# 3.1.1 + +* Fix: typescript definitions weren't in the published package. + +# 3.1.0 + +* Fixed numerous bugs in attribute nodes relating to the handling of comments + and whitespace. There's significant changes to `attrNode.spaces` and `attrNode.raws` since the `3.0.0` release. +* Added `Attribute#offsetOf(part)` to get the offset location of + attribute parts like `"operator"` and `"value"`. This is most + often added to `Attribute#sourceIndex` for error reporting. + +# 3.0.0 + +## Breaking changes + +* Some tweaks to the tokenizer/attribute selector parsing mean that whitespace + locations might be slightly different to the 2.x code. +* Better attribute selector parsing with more validation; postcss-selector-parser + no longer uses regular expressions to parse attribute selectors. +* Added an async API (thanks to @jacobp100); the default `process` API is now + async, and the sync API is now accessed through `processSync` instead. +* `process()` and `processSync()` now return a string instead of the Processor + instance. +* Tweaks handling of Less interpolation (thanks to @jwilsson). +* Removes support for Node 0.12. + +## Other changes + +* `ast()` and `astSync()` methods have been added to the `Processor`. These + return the `Root` node of the selectors after processing them. +* `transform()` and `transformSync()` methods have been added to the + `Processor`. These return the value returned by the processor callback + after processing the selectors. +* Set the parent when inserting a node (thanks to @chriseppstein). +* Correctly adjust indices when using insertBefore/insertAfter (thanks to @tivac). +* Fixes handling of namespaces with qualified tag selectors. +* `process`, `ast` and `transform` (and their sync variants) now accept a + `postcss` rule node. When provided, better errors are generated and selector + processing is automatically set back to the rule selector (unless the `updateSelector` option is set to `false`.) +* Now more memory efficient when tokenizing selectors. + +### Upgrade hints + +The pattern of: + +`rule.selector = processor.process(rule.selector).result.toString();` + +is now: + +`processor.processSync(rule)` + +# 2.2.3 + +* Resolves an issue where the parser would not reduce multiple spaces between an + ampersand and another simple selector in lossy mode (thanks to @adam-26). + +# 2.2.2 + +* No longer hangs on an unescaped semicolon; instead the parser will throw + an exception for these cases. + +# 2.2.1 + +* Allows a consumer to specify whitespace tokens when creating a new Node + (thanks to @Semigradsky). + +# 2.2.0 + +* Added a new option to normalize whitespace when parsing the selector string + (thanks to @adam-26). + +# 2.1.1 + +* Better unquoted value handling within attribute selectors + (thanks to @evilebottnawi). + +# 2.1.0 + +* Added: Use string constants for all node types & expose them on the main + parser instance (thanks to @Aweary). + +# 2.0.0 + +This release contains the following breaking changes: + +* Renamed all `eachInside` iterators to `walk`. For example, `eachTag` is now + `walkTags`, and `eachInside` is now `walk`. +* Renamed `Node#removeSelf()` to `Node#remove()`. +* Renamed `Container#remove()` to `Container#removeChild()`. +* Renamed `Node#raw` to `Node#raws` (thanks to @davidtheclark). +* Now parses `&` as the *nesting* selector, rather than a *tag* selector. +* Fixes misinterpretation of Sass interpolation (e.g. `#{foo}`) as an + id selector (thanks to @davidtheclark). + +and; + +* Fixes parsing of attribute selectors with equals signs in them + (e.g. `[data-attr="foo=bar"]`) (thanks to @montmanu). +* Adds `quoted` and `raw.unquoted` properties to attribute nodes + (thanks to @davidtheclark). + +# 1.3.3 + +* Fixes an infinite loop on `)` and `]` tokens when they had no opening pairs. + Now postcss-selector-parser will throw when it encounters these lone tokens. + +# 1.3.2 + +* Now uses plain integers rather than `str.charCodeAt(0)` for compiled builds. + +# 1.3.1 + +* Update flatten to v1.x (thanks to @shinnn). + +# 1.3.0 + +* Adds a new node type, `String`, to fix a crash on selectors such as + `foo:bar("test")`. + +# 1.2.1 + +* Fixes a crash when the parser encountered a trailing combinator. + +# 1.2.0 + +* A more descriptive error is thrown when the parser expects to find a + pseudo-class/pseudo-element (thanks to @ashelley). +* Adds support for line/column locations for selector nodes, as well as a + `Node#sourceIndex` method (thanks to @davidtheclark). + +# 1.1.4 + +* Fixes a crash when a selector started with a `>` combinator. The module will + now no longer throw if a selector has a leading/trailing combinator node. + +# 1.1.3 + +* Fixes a crash on `@` tokens. + +# 1.1.2 + +* Fixes an infinite loop caused by using parentheses in a non-pseudo element + context. + +# 1.1.1 + +* Fixes a crash when a backslash ended a selector string. + +# 1.1.0 + +* Adds support for replacing multiple nodes at once with `replaceWith` + (thanks to @jonathantneal). +* Parser no longer throws on sequential IDs and trailing commas, to support + parsing of selector hacks. + +# 1.0.1 + +* Fixes using `insertAfter` and `insertBefore` during iteration. + +# 1.0.0 + +* Adds `clone` and `replaceWith` methods to nodes. +* Adds `insertBefore` and `insertAfter` to containers. +* Stabilises API. + +# 0.0.5 + +* Fixes crash on extra whitespace inside a pseudo selector's parentheses. +* Adds sort function to the container class. +* Enables the parser to pass its input through without transforming. +* Iteration-safe `each` and `eachInside`. + +# 0.0.4 + +* Tidy up redundant duplication. +* Fixes a bug where the parser would loop infinitely on universal selectors + inside pseudo selectors. +* Adds `length` getter and `eachInside`, `map`, `reduce` to the container class. +* When a selector has been removed from the tree, the root node will no longer + cast it to a string. +* Adds node type iterators to the container class (e.g. `eachComment`). +* Adds filter function to the container class. +* Adds split function to the container class. +* Create new node types by doing `parser.id(opts)` etc. +* Adds support for pseudo classes anywhere in the selector. + +# 0.0.3 + +* Adds `next` and `prev` to the node class. +* Adds `first` and `last` getters to the container class. +* Adds `every` and `some` iterators to the container class. +* Add `empty` alias for `removeAll`. +* Combinators are now types of node. +* Fixes the at method so that it is not an alias for `index`. +* Tidy up creation of new nodes in the parser. +* Refactors how namespaces are handled for consistency & less redundant code. +* Refactors AST to use `nodes` exclusively, and eliminates excessive nesting. +* Fixes nested pseudo parsing. +* Fixes whitespace parsing. + +# 0.0.2 + +* Adds support for namespace selectors. +* Adds support for selectors joined by escaped spaces - such as `.\31\ 0`. + +# 0.0.1 + +* Initial release. diff --git a/node_modules/postcss-selector-parser/LICENSE-MIT b/node_modules/postcss-selector-parser/LICENSE-MIT new file mode 100644 index 0000000..fd0e863 --- /dev/null +++ b/node_modules/postcss-selector-parser/LICENSE-MIT @@ -0,0 +1,22 @@ +Copyright (c) Ben Briggs (http://beneb.info) + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-selector-parser/README.md b/node_modules/postcss-selector-parser/README.md new file mode 100644 index 0000000..18a01c5 --- /dev/null +++ b/node_modules/postcss-selector-parser/README.md @@ -0,0 +1,49 @@ +# postcss-selector-parser [![Build Status](https://travis-ci.org/postcss/postcss-selector-parser.svg?branch=master)](https://travis-ci.org/postcss/postcss-selector-parser) + +> Selector parser with built in methods for working with selector strings. + +## Install + +With [npm](https://npmjs.com/package/postcss-selector-parser) do: + +``` +npm install postcss-selector-parser +``` + +## Quick Start + +```js +const parser = require('postcss-selector-parser'); +const transform = selectors => { + selectors.walk(selector => { + // do something with the selector + console.log(String(selector)) + }); +}; + +const transformed = parser(transform).processSync('h1, h2, h3'); +``` + +To normalize selector whitespace: + +```js +const parser = require('postcss-selector-parser'); +const normalized = parser().processSync('h1, h2, h3', {lossless: false}); +// -> h1,h2,h3 +``` + +Async support is provided through `parser.process` and will resolve a Promise +with the resulting selector string. + +## API + +Please see [API.md](API.md). + +## Credits + +* Huge thanks to Andrey Sitnik (@ai) for work on PostCSS which helped + accelerate this module's development. + +## License + +MIT diff --git a/node_modules/postcss-selector-parser/dist/index.js b/node_modules/postcss-selector-parser/dist/index.js new file mode 100644 index 0000000..6e76a32 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/index.js @@ -0,0 +1,24 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _processor = _interopRequireDefault(require("./processor")); + +var selectors = _interopRequireWildcard(require("./selectors")); + +function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +var parser = function parser(processor) { + return new _processor["default"](processor); +}; + +Object.assign(parser, selectors); +delete parser.__esModule; +var _default = parser; +exports["default"] = _default; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/parser.js b/node_modules/postcss-selector-parser/dist/parser.js new file mode 100644 index 0000000..e0451de --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/parser.js @@ -0,0 +1,1243 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _root = _interopRequireDefault(require("./selectors/root")); + +var _selector = _interopRequireDefault(require("./selectors/selector")); + +var _className = _interopRequireDefault(require("./selectors/className")); + +var _comment = _interopRequireDefault(require("./selectors/comment")); + +var _id = _interopRequireDefault(require("./selectors/id")); + +var _tag = _interopRequireDefault(require("./selectors/tag")); + +var _string = _interopRequireDefault(require("./selectors/string")); + +var _pseudo = _interopRequireDefault(require("./selectors/pseudo")); + +var _attribute = _interopRequireWildcard(require("./selectors/attribute")); + +var _universal = _interopRequireDefault(require("./selectors/universal")); + +var _combinator = _interopRequireDefault(require("./selectors/combinator")); + +var _nesting = _interopRequireDefault(require("./selectors/nesting")); + +var _sortAscending = _interopRequireDefault(require("./sortAscending")); + +var _tokenize = _interopRequireWildcard(require("./tokenize")); + +var tokens = _interopRequireWildcard(require("./tokenTypes")); + +var types = _interopRequireWildcard(require("./selectors/types")); + +var _util = require("./util"); + +var _WHITESPACE_TOKENS, _Object$assign; + +function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +var WHITESPACE_TOKENS = (_WHITESPACE_TOKENS = {}, _WHITESPACE_TOKENS[tokens.space] = true, _WHITESPACE_TOKENS[tokens.cr] = true, _WHITESPACE_TOKENS[tokens.feed] = true, _WHITESPACE_TOKENS[tokens.newline] = true, _WHITESPACE_TOKENS[tokens.tab] = true, _WHITESPACE_TOKENS); +var WHITESPACE_EQUIV_TOKENS = Object.assign({}, WHITESPACE_TOKENS, (_Object$assign = {}, _Object$assign[tokens.comment] = true, _Object$assign)); + +function tokenStart(token) { + return { + line: token[_tokenize.FIELDS.START_LINE], + column: token[_tokenize.FIELDS.START_COL] + }; +} + +function tokenEnd(token) { + return { + line: token[_tokenize.FIELDS.END_LINE], + column: token[_tokenize.FIELDS.END_COL] + }; +} + +function getSource(startLine, startColumn, endLine, endColumn) { + return { + start: { + line: startLine, + column: startColumn + }, + end: { + line: endLine, + column: endColumn + } + }; +} + +function getTokenSource(token) { + return getSource(token[_tokenize.FIELDS.START_LINE], token[_tokenize.FIELDS.START_COL], token[_tokenize.FIELDS.END_LINE], token[_tokenize.FIELDS.END_COL]); +} + +function getTokenSourceSpan(startToken, endToken) { + if (!startToken) { + return undefined; + } + + return getSource(startToken[_tokenize.FIELDS.START_LINE], startToken[_tokenize.FIELDS.START_COL], endToken[_tokenize.FIELDS.END_LINE], endToken[_tokenize.FIELDS.END_COL]); +} + +function unescapeProp(node, prop) { + var value = node[prop]; + + if (typeof value !== "string") { + return; + } + + if (value.indexOf("\\") !== -1) { + (0, _util.ensureObject)(node, 'raws'); + node[prop] = (0, _util.unesc)(value); + + if (node.raws[prop] === undefined) { + node.raws[prop] = value; + } + } + + return node; +} + +function indexesOf(array, item) { + var i = -1; + var indexes = []; + + while ((i = array.indexOf(item, i + 1)) !== -1) { + indexes.push(i); + } + + return indexes; +} + +function uniqs() { + var list = Array.prototype.concat.apply([], arguments); + return list.filter(function (item, i) { + return i === list.indexOf(item); + }); +} + +var Parser = /*#__PURE__*/function () { + function Parser(rule, options) { + if (options === void 0) { + options = {}; + } + + this.rule = rule; + this.options = Object.assign({ + lossy: false, + safe: false + }, options); + this.position = 0; + this.css = typeof this.rule === 'string' ? this.rule : this.rule.selector; + this.tokens = (0, _tokenize["default"])({ + css: this.css, + error: this._errorGenerator(), + safe: this.options.safe + }); + var rootSource = getTokenSourceSpan(this.tokens[0], this.tokens[this.tokens.length - 1]); + this.root = new _root["default"]({ + source: rootSource + }); + this.root.errorGenerator = this._errorGenerator(); + var selector = new _selector["default"]({ + source: { + start: { + line: 1, + column: 1 + } + } + }); + this.root.append(selector); + this.current = selector; + this.loop(); + } + + var _proto = Parser.prototype; + + _proto._errorGenerator = function _errorGenerator() { + var _this = this; + + return function (message, errorOptions) { + if (typeof _this.rule === 'string') { + return new Error(message); + } + + return _this.rule.error(message, errorOptions); + }; + }; + + _proto.attribute = function attribute() { + var attr = []; + var startingToken = this.currToken; + this.position++; + + while (this.position < this.tokens.length && this.currToken[_tokenize.FIELDS.TYPE] !== tokens.closeSquare) { + attr.push(this.currToken); + this.position++; + } + + if (this.currToken[_tokenize.FIELDS.TYPE] !== tokens.closeSquare) { + return this.expected('closing square bracket', this.currToken[_tokenize.FIELDS.START_POS]); + } + + var len = attr.length; + var node = { + source: getSource(startingToken[1], startingToken[2], this.currToken[3], this.currToken[4]), + sourceIndex: startingToken[_tokenize.FIELDS.START_POS] + }; + + if (len === 1 && !~[tokens.word].indexOf(attr[0][_tokenize.FIELDS.TYPE])) { + return this.expected('attribute', attr[0][_tokenize.FIELDS.START_POS]); + } + + var pos = 0; + var spaceBefore = ''; + var commentBefore = ''; + var lastAdded = null; + var spaceAfterMeaningfulToken = false; + + while (pos < len) { + var token = attr[pos]; + var content = this.content(token); + var next = attr[pos + 1]; + + switch (token[_tokenize.FIELDS.TYPE]) { + case tokens.space: + // if ( + // len === 1 || + // pos === 0 && this.content(next) === '|' + // ) { + // return this.expected('attribute', token[TOKEN.START_POS], content); + // } + spaceAfterMeaningfulToken = true; + + if (this.options.lossy) { + break; + } + + if (lastAdded) { + (0, _util.ensureObject)(node, 'spaces', lastAdded); + var prevContent = node.spaces[lastAdded].after || ''; + node.spaces[lastAdded].after = prevContent + content; + var existingComment = (0, _util.getProp)(node, 'raws', 'spaces', lastAdded, 'after') || null; + + if (existingComment) { + node.raws.spaces[lastAdded].after = existingComment + content; + } + } else { + spaceBefore = spaceBefore + content; + commentBefore = commentBefore + content; + } + + break; + + case tokens.asterisk: + if (next[_tokenize.FIELDS.TYPE] === tokens.equals) { + node.operator = content; + lastAdded = 'operator'; + } else if ((!node.namespace || lastAdded === "namespace" && !spaceAfterMeaningfulToken) && next) { + if (spaceBefore) { + (0, _util.ensureObject)(node, 'spaces', 'attribute'); + node.spaces.attribute.before = spaceBefore; + spaceBefore = ''; + } + + if (commentBefore) { + (0, _util.ensureObject)(node, 'raws', 'spaces', 'attribute'); + node.raws.spaces.attribute.before = spaceBefore; + commentBefore = ''; + } + + node.namespace = (node.namespace || "") + content; + var rawValue = (0, _util.getProp)(node, 'raws', 'namespace') || null; + + if (rawValue) { + node.raws.namespace += content; + } + + lastAdded = 'namespace'; + } + + spaceAfterMeaningfulToken = false; + break; + + case tokens.dollar: + if (lastAdded === "value") { + var oldRawValue = (0, _util.getProp)(node, 'raws', 'value'); + node.value += "$"; + + if (oldRawValue) { + node.raws.value = oldRawValue + "$"; + } + + break; + } + + // Falls through + + case tokens.caret: + if (next[_tokenize.FIELDS.TYPE] === tokens.equals) { + node.operator = content; + lastAdded = 'operator'; + } + + spaceAfterMeaningfulToken = false; + break; + + case tokens.combinator: + if (content === '~' && next[_tokenize.FIELDS.TYPE] === tokens.equals) { + node.operator = content; + lastAdded = 'operator'; + } + + if (content !== '|') { + spaceAfterMeaningfulToken = false; + break; + } + + if (next[_tokenize.FIELDS.TYPE] === tokens.equals) { + node.operator = content; + lastAdded = 'operator'; + } else if (!node.namespace && !node.attribute) { + node.namespace = true; + } + + spaceAfterMeaningfulToken = false; + break; + + case tokens.word: + if (next && this.content(next) === '|' && attr[pos + 2] && attr[pos + 2][_tokenize.FIELDS.TYPE] !== tokens.equals && // this look-ahead probably fails with comment nodes involved. + !node.operator && !node.namespace) { + node.namespace = content; + lastAdded = 'namespace'; + } else if (!node.attribute || lastAdded === "attribute" && !spaceAfterMeaningfulToken) { + if (spaceBefore) { + (0, _util.ensureObject)(node, 'spaces', 'attribute'); + node.spaces.attribute.before = spaceBefore; + spaceBefore = ''; + } + + if (commentBefore) { + (0, _util.ensureObject)(node, 'raws', 'spaces', 'attribute'); + node.raws.spaces.attribute.before = commentBefore; + commentBefore = ''; + } + + node.attribute = (node.attribute || "") + content; + + var _rawValue = (0, _util.getProp)(node, 'raws', 'attribute') || null; + + if (_rawValue) { + node.raws.attribute += content; + } + + lastAdded = 'attribute'; + } else if (!node.value && node.value !== "" || lastAdded === "value" && !spaceAfterMeaningfulToken) { + var _unescaped = (0, _util.unesc)(content); + + var _oldRawValue = (0, _util.getProp)(node, 'raws', 'value') || ''; + + var oldValue = node.value || ''; + node.value = oldValue + _unescaped; + node.quoteMark = null; + + if (_unescaped !== content || _oldRawValue) { + (0, _util.ensureObject)(node, 'raws'); + node.raws.value = (_oldRawValue || oldValue) + content; + } + + lastAdded = 'value'; + } else { + var insensitive = content === 'i' || content === "I"; + + if ((node.value || node.value === '') && (node.quoteMark || spaceAfterMeaningfulToken)) { + node.insensitive = insensitive; + + if (!insensitive || content === "I") { + (0, _util.ensureObject)(node, 'raws'); + node.raws.insensitiveFlag = content; + } + + lastAdded = 'insensitive'; + + if (spaceBefore) { + (0, _util.ensureObject)(node, 'spaces', 'insensitive'); + node.spaces.insensitive.before = spaceBefore; + spaceBefore = ''; + } + + if (commentBefore) { + (0, _util.ensureObject)(node, 'raws', 'spaces', 'insensitive'); + node.raws.spaces.insensitive.before = commentBefore; + commentBefore = ''; + } + } else if (node.value || node.value === '') { + lastAdded = 'value'; + node.value += content; + + if (node.raws.value) { + node.raws.value += content; + } + } + } + + spaceAfterMeaningfulToken = false; + break; + + case tokens.str: + if (!node.attribute || !node.operator) { + return this.error("Expected an attribute followed by an operator preceding the string.", { + index: token[_tokenize.FIELDS.START_POS] + }); + } + + var _unescapeValue = (0, _attribute.unescapeValue)(content), + unescaped = _unescapeValue.unescaped, + quoteMark = _unescapeValue.quoteMark; + + node.value = unescaped; + node.quoteMark = quoteMark; + lastAdded = 'value'; + (0, _util.ensureObject)(node, 'raws'); + node.raws.value = content; + spaceAfterMeaningfulToken = false; + break; + + case tokens.equals: + if (!node.attribute) { + return this.expected('attribute', token[_tokenize.FIELDS.START_POS], content); + } + + if (node.value) { + return this.error('Unexpected "=" found; an operator was already defined.', { + index: token[_tokenize.FIELDS.START_POS] + }); + } + + node.operator = node.operator ? node.operator + content : content; + lastAdded = 'operator'; + spaceAfterMeaningfulToken = false; + break; + + case tokens.comment: + if (lastAdded) { + if (spaceAfterMeaningfulToken || next && next[_tokenize.FIELDS.TYPE] === tokens.space || lastAdded === 'insensitive') { + var lastComment = (0, _util.getProp)(node, 'spaces', lastAdded, 'after') || ''; + var rawLastComment = (0, _util.getProp)(node, 'raws', 'spaces', lastAdded, 'after') || lastComment; + (0, _util.ensureObject)(node, 'raws', 'spaces', lastAdded); + node.raws.spaces[lastAdded].after = rawLastComment + content; + } else { + var lastValue = node[lastAdded] || ''; + var rawLastValue = (0, _util.getProp)(node, 'raws', lastAdded) || lastValue; + (0, _util.ensureObject)(node, 'raws'); + node.raws[lastAdded] = rawLastValue + content; + } + } else { + commentBefore = commentBefore + content; + } + + break; + + default: + return this.error("Unexpected \"" + content + "\" found.", { + index: token[_tokenize.FIELDS.START_POS] + }); + } + + pos++; + } + + unescapeProp(node, "attribute"); + unescapeProp(node, "namespace"); + this.newNode(new _attribute["default"](node)); + this.position++; + } + /** + * return a node containing meaningless garbage up to (but not including) the specified token position. + * if the token position is negative, all remaining tokens are consumed. + * + * This returns an array containing a single string node if all whitespace, + * otherwise an array of comment nodes with space before and after. + * + * These tokens are not added to the current selector, the caller can add them or use them to amend + * a previous node's space metadata. + * + * In lossy mode, this returns only comments. + */ + ; + + _proto.parseWhitespaceEquivalentTokens = function parseWhitespaceEquivalentTokens(stopPosition) { + if (stopPosition < 0) { + stopPosition = this.tokens.length; + } + + var startPosition = this.position; + var nodes = []; + var space = ""; + var lastComment = undefined; + + do { + if (WHITESPACE_TOKENS[this.currToken[_tokenize.FIELDS.TYPE]]) { + if (!this.options.lossy) { + space += this.content(); + } + } else if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.comment) { + var spaces = {}; + + if (space) { + spaces.before = space; + space = ""; + } + + lastComment = new _comment["default"]({ + value: this.content(), + source: getTokenSource(this.currToken), + sourceIndex: this.currToken[_tokenize.FIELDS.START_POS], + spaces: spaces + }); + nodes.push(lastComment); + } + } while (++this.position < stopPosition); + + if (space) { + if (lastComment) { + lastComment.spaces.after = space; + } else if (!this.options.lossy) { + var firstToken = this.tokens[startPosition]; + var lastToken = this.tokens[this.position - 1]; + nodes.push(new _string["default"]({ + value: '', + source: getSource(firstToken[_tokenize.FIELDS.START_LINE], firstToken[_tokenize.FIELDS.START_COL], lastToken[_tokenize.FIELDS.END_LINE], lastToken[_tokenize.FIELDS.END_COL]), + sourceIndex: firstToken[_tokenize.FIELDS.START_POS], + spaces: { + before: space, + after: '' + } + })); + } + } + + return nodes; + } + /** + * + * @param {*} nodes + */ + ; + + _proto.convertWhitespaceNodesToSpace = function convertWhitespaceNodesToSpace(nodes, requiredSpace) { + var _this2 = this; + + if (requiredSpace === void 0) { + requiredSpace = false; + } + + var space = ""; + var rawSpace = ""; + nodes.forEach(function (n) { + var spaceBefore = _this2.lossySpace(n.spaces.before, requiredSpace); + + var rawSpaceBefore = _this2.lossySpace(n.rawSpaceBefore, requiredSpace); + + space += spaceBefore + _this2.lossySpace(n.spaces.after, requiredSpace && spaceBefore.length === 0); + rawSpace += spaceBefore + n.value + _this2.lossySpace(n.rawSpaceAfter, requiredSpace && rawSpaceBefore.length === 0); + }); + + if (rawSpace === space) { + rawSpace = undefined; + } + + var result = { + space: space, + rawSpace: rawSpace + }; + return result; + }; + + _proto.isNamedCombinator = function isNamedCombinator(position) { + if (position === void 0) { + position = this.position; + } + + return this.tokens[position + 0] && this.tokens[position + 0][_tokenize.FIELDS.TYPE] === tokens.slash && this.tokens[position + 1] && this.tokens[position + 1][_tokenize.FIELDS.TYPE] === tokens.word && this.tokens[position + 2] && this.tokens[position + 2][_tokenize.FIELDS.TYPE] === tokens.slash; + }; + + _proto.namedCombinator = function namedCombinator() { + if (this.isNamedCombinator()) { + var nameRaw = this.content(this.tokens[this.position + 1]); + var name = (0, _util.unesc)(nameRaw).toLowerCase(); + var raws = {}; + + if (name !== nameRaw) { + raws.value = "/" + nameRaw + "/"; + } + + var node = new _combinator["default"]({ + value: "/" + name + "/", + source: getSource(this.currToken[_tokenize.FIELDS.START_LINE], this.currToken[_tokenize.FIELDS.START_COL], this.tokens[this.position + 2][_tokenize.FIELDS.END_LINE], this.tokens[this.position + 2][_tokenize.FIELDS.END_COL]), + sourceIndex: this.currToken[_tokenize.FIELDS.START_POS], + raws: raws + }); + this.position = this.position + 3; + return node; + } else { + this.unexpected(); + } + }; + + _proto.combinator = function combinator() { + var _this3 = this; + + if (this.content() === '|') { + return this.namespace(); + } // We need to decide between a space that's a descendant combinator and meaningless whitespace at the end of a selector. + + + var nextSigTokenPos = this.locateNextMeaningfulToken(this.position); + + if (nextSigTokenPos < 0 || this.tokens[nextSigTokenPos][_tokenize.FIELDS.TYPE] === tokens.comma) { + var nodes = this.parseWhitespaceEquivalentTokens(nextSigTokenPos); + + if (nodes.length > 0) { + var last = this.current.last; + + if (last) { + var _this$convertWhitespa = this.convertWhitespaceNodesToSpace(nodes), + space = _this$convertWhitespa.space, + rawSpace = _this$convertWhitespa.rawSpace; + + if (rawSpace !== undefined) { + last.rawSpaceAfter += rawSpace; + } + + last.spaces.after += space; + } else { + nodes.forEach(function (n) { + return _this3.newNode(n); + }); + } + } + + return; + } + + var firstToken = this.currToken; + var spaceOrDescendantSelectorNodes = undefined; + + if (nextSigTokenPos > this.position) { + spaceOrDescendantSelectorNodes = this.parseWhitespaceEquivalentTokens(nextSigTokenPos); + } + + var node; + + if (this.isNamedCombinator()) { + node = this.namedCombinator(); + } else if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.combinator) { + node = new _combinator["default"]({ + value: this.content(), + source: getTokenSource(this.currToken), + sourceIndex: this.currToken[_tokenize.FIELDS.START_POS] + }); + this.position++; + } else if (WHITESPACE_TOKENS[this.currToken[_tokenize.FIELDS.TYPE]]) {// pass + } else if (!spaceOrDescendantSelectorNodes) { + this.unexpected(); + } + + if (node) { + if (spaceOrDescendantSelectorNodes) { + var _this$convertWhitespa2 = this.convertWhitespaceNodesToSpace(spaceOrDescendantSelectorNodes), + _space = _this$convertWhitespa2.space, + _rawSpace = _this$convertWhitespa2.rawSpace; + + node.spaces.before = _space; + node.rawSpaceBefore = _rawSpace; + } + } else { + // descendant combinator + var _this$convertWhitespa3 = this.convertWhitespaceNodesToSpace(spaceOrDescendantSelectorNodes, true), + _space2 = _this$convertWhitespa3.space, + _rawSpace2 = _this$convertWhitespa3.rawSpace; + + if (!_rawSpace2) { + _rawSpace2 = _space2; + } + + var spaces = {}; + var raws = { + spaces: {} + }; + + if (_space2.endsWith(' ') && _rawSpace2.endsWith(' ')) { + spaces.before = _space2.slice(0, _space2.length - 1); + raws.spaces.before = _rawSpace2.slice(0, _rawSpace2.length - 1); + } else if (_space2.startsWith(' ') && _rawSpace2.startsWith(' ')) { + spaces.after = _space2.slice(1); + raws.spaces.after = _rawSpace2.slice(1); + } else { + raws.value = _rawSpace2; + } + + node = new _combinator["default"]({ + value: ' ', + source: getTokenSourceSpan(firstToken, this.tokens[this.position - 1]), + sourceIndex: firstToken[_tokenize.FIELDS.START_POS], + spaces: spaces, + raws: raws + }); + } + + if (this.currToken && this.currToken[_tokenize.FIELDS.TYPE] === tokens.space) { + node.spaces.after = this.optionalSpace(this.content()); + this.position++; + } + + return this.newNode(node); + }; + + _proto.comma = function comma() { + if (this.position === this.tokens.length - 1) { + this.root.trailingComma = true; + this.position++; + return; + } + + this.current._inferEndPosition(); + + var selector = new _selector["default"]({ + source: { + start: tokenStart(this.tokens[this.position + 1]) + } + }); + this.current.parent.append(selector); + this.current = selector; + this.position++; + }; + + _proto.comment = function comment() { + var current = this.currToken; + this.newNode(new _comment["default"]({ + value: this.content(), + source: getTokenSource(current), + sourceIndex: current[_tokenize.FIELDS.START_POS] + })); + this.position++; + }; + + _proto.error = function error(message, opts) { + throw this.root.error(message, opts); + }; + + _proto.missingBackslash = function missingBackslash() { + return this.error('Expected a backslash preceding the semicolon.', { + index: this.currToken[_tokenize.FIELDS.START_POS] + }); + }; + + _proto.missingParenthesis = function missingParenthesis() { + return this.expected('opening parenthesis', this.currToken[_tokenize.FIELDS.START_POS]); + }; + + _proto.missingSquareBracket = function missingSquareBracket() { + return this.expected('opening square bracket', this.currToken[_tokenize.FIELDS.START_POS]); + }; + + _proto.unexpected = function unexpected() { + return this.error("Unexpected '" + this.content() + "'. Escaping special characters with \\ may help.", this.currToken[_tokenize.FIELDS.START_POS]); + }; + + _proto.namespace = function namespace() { + var before = this.prevToken && this.content(this.prevToken) || true; + + if (this.nextToken[_tokenize.FIELDS.TYPE] === tokens.word) { + this.position++; + return this.word(before); + } else if (this.nextToken[_tokenize.FIELDS.TYPE] === tokens.asterisk) { + this.position++; + return this.universal(before); + } + }; + + _proto.nesting = function nesting() { + if (this.nextToken) { + var nextContent = this.content(this.nextToken); + + if (nextContent === "|") { + this.position++; + return; + } + } + + var current = this.currToken; + this.newNode(new _nesting["default"]({ + value: this.content(), + source: getTokenSource(current), + sourceIndex: current[_tokenize.FIELDS.START_POS] + })); + this.position++; + }; + + _proto.parentheses = function parentheses() { + var last = this.current.last; + var unbalanced = 1; + this.position++; + + if (last && last.type === types.PSEUDO) { + var selector = new _selector["default"]({ + source: { + start: tokenStart(this.tokens[this.position - 1]) + } + }); + var cache = this.current; + last.append(selector); + this.current = selector; + + while (this.position < this.tokens.length && unbalanced) { + if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) { + unbalanced++; + } + + if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) { + unbalanced--; + } + + if (unbalanced) { + this.parse(); + } else { + this.current.source.end = tokenEnd(this.currToken); + this.current.parent.source.end = tokenEnd(this.currToken); + this.position++; + } + } + + this.current = cache; + } else { + // I think this case should be an error. It's used to implement a basic parse of media queries + // but I don't think it's a good idea. + var parenStart = this.currToken; + var parenValue = "("; + var parenEnd; + + while (this.position < this.tokens.length && unbalanced) { + if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) { + unbalanced++; + } + + if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) { + unbalanced--; + } + + parenEnd = this.currToken; + parenValue += this.parseParenthesisToken(this.currToken); + this.position++; + } + + if (last) { + last.appendToPropertyAndEscape("value", parenValue, parenValue); + } else { + this.newNode(new _string["default"]({ + value: parenValue, + source: getSource(parenStart[_tokenize.FIELDS.START_LINE], parenStart[_tokenize.FIELDS.START_COL], parenEnd[_tokenize.FIELDS.END_LINE], parenEnd[_tokenize.FIELDS.END_COL]), + sourceIndex: parenStart[_tokenize.FIELDS.START_POS] + })); + } + } + + if (unbalanced) { + return this.expected('closing parenthesis', this.currToken[_tokenize.FIELDS.START_POS]); + } + }; + + _proto.pseudo = function pseudo() { + var _this4 = this; + + var pseudoStr = ''; + var startingToken = this.currToken; + + while (this.currToken && this.currToken[_tokenize.FIELDS.TYPE] === tokens.colon) { + pseudoStr += this.content(); + this.position++; + } + + if (!this.currToken) { + return this.expected(['pseudo-class', 'pseudo-element'], this.position - 1); + } + + if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.word) { + this.splitWord(false, function (first, length) { + pseudoStr += first; + + _this4.newNode(new _pseudo["default"]({ + value: pseudoStr, + source: getTokenSourceSpan(startingToken, _this4.currToken), + sourceIndex: startingToken[_tokenize.FIELDS.START_POS] + })); + + if (length > 1 && _this4.nextToken && _this4.nextToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) { + _this4.error('Misplaced parenthesis.', { + index: _this4.nextToken[_tokenize.FIELDS.START_POS] + }); + } + }); + } else { + return this.expected(['pseudo-class', 'pseudo-element'], this.currToken[_tokenize.FIELDS.START_POS]); + } + }; + + _proto.space = function space() { + var content = this.content(); // Handle space before and after the selector + + if (this.position === 0 || this.prevToken[_tokenize.FIELDS.TYPE] === tokens.comma || this.prevToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis || this.current.nodes.every(function (node) { + return node.type === 'comment'; + })) { + this.spaces = this.optionalSpace(content); + this.position++; + } else if (this.position === this.tokens.length - 1 || this.nextToken[_tokenize.FIELDS.TYPE] === tokens.comma || this.nextToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) { + this.current.last.spaces.after = this.optionalSpace(content); + this.position++; + } else { + this.combinator(); + } + }; + + _proto.string = function string() { + var current = this.currToken; + this.newNode(new _string["default"]({ + value: this.content(), + source: getTokenSource(current), + sourceIndex: current[_tokenize.FIELDS.START_POS] + })); + this.position++; + }; + + _proto.universal = function universal(namespace) { + var nextToken = this.nextToken; + + if (nextToken && this.content(nextToken) === '|') { + this.position++; + return this.namespace(); + } + + var current = this.currToken; + this.newNode(new _universal["default"]({ + value: this.content(), + source: getTokenSource(current), + sourceIndex: current[_tokenize.FIELDS.START_POS] + }), namespace); + this.position++; + }; + + _proto.splitWord = function splitWord(namespace, firstCallback) { + var _this5 = this; + + var nextToken = this.nextToken; + var word = this.content(); + + while (nextToken && ~[tokens.dollar, tokens.caret, tokens.equals, tokens.word].indexOf(nextToken[_tokenize.FIELDS.TYPE])) { + this.position++; + var current = this.content(); + word += current; + + if (current.lastIndexOf('\\') === current.length - 1) { + var next = this.nextToken; + + if (next && next[_tokenize.FIELDS.TYPE] === tokens.space) { + word += this.requiredSpace(this.content(next)); + this.position++; + } + } + + nextToken = this.nextToken; + } + + var hasClass = indexesOf(word, '.').filter(function (i) { + // Allow escaped dot within class name + var escapedDot = word[i - 1] === '\\'; // Allow decimal numbers percent in @keyframes + + var isKeyframesPercent = /^\d+\.\d+%$/.test(word); + return !escapedDot && !isKeyframesPercent; + }); + var hasId = indexesOf(word, '#').filter(function (i) { + return word[i - 1] !== '\\'; + }); // Eliminate Sass interpolations from the list of id indexes + + var interpolations = indexesOf(word, '#{'); + + if (interpolations.length) { + hasId = hasId.filter(function (hashIndex) { + return !~interpolations.indexOf(hashIndex); + }); + } + + var indices = (0, _sortAscending["default"])(uniqs([0].concat(hasClass, hasId))); + indices.forEach(function (ind, i) { + var index = indices[i + 1] || word.length; + var value = word.slice(ind, index); + + if (i === 0 && firstCallback) { + return firstCallback.call(_this5, value, indices.length); + } + + var node; + var current = _this5.currToken; + var sourceIndex = current[_tokenize.FIELDS.START_POS] + indices[i]; + var source = getSource(current[1], current[2] + ind, current[3], current[2] + (index - 1)); + + if (~hasClass.indexOf(ind)) { + var classNameOpts = { + value: value.slice(1), + source: source, + sourceIndex: sourceIndex + }; + node = new _className["default"](unescapeProp(classNameOpts, "value")); + } else if (~hasId.indexOf(ind)) { + var idOpts = { + value: value.slice(1), + source: source, + sourceIndex: sourceIndex + }; + node = new _id["default"](unescapeProp(idOpts, "value")); + } else { + var tagOpts = { + value: value, + source: source, + sourceIndex: sourceIndex + }; + unescapeProp(tagOpts, "value"); + node = new _tag["default"](tagOpts); + } + + _this5.newNode(node, namespace); // Ensure that the namespace is used only once + + + namespace = null; + }); + this.position++; + }; + + _proto.word = function word(namespace) { + var nextToken = this.nextToken; + + if (nextToken && this.content(nextToken) === '|') { + this.position++; + return this.namespace(); + } + + return this.splitWord(namespace); + }; + + _proto.loop = function loop() { + while (this.position < this.tokens.length) { + this.parse(true); + } + + this.current._inferEndPosition(); + + return this.root; + }; + + _proto.parse = function parse(throwOnParenthesis) { + switch (this.currToken[_tokenize.FIELDS.TYPE]) { + case tokens.space: + this.space(); + break; + + case tokens.comment: + this.comment(); + break; + + case tokens.openParenthesis: + this.parentheses(); + break; + + case tokens.closeParenthesis: + if (throwOnParenthesis) { + this.missingParenthesis(); + } + + break; + + case tokens.openSquare: + this.attribute(); + break; + + case tokens.dollar: + case tokens.caret: + case tokens.equals: + case tokens.word: + this.word(); + break; + + case tokens.colon: + this.pseudo(); + break; + + case tokens.comma: + this.comma(); + break; + + case tokens.asterisk: + this.universal(); + break; + + case tokens.ampersand: + this.nesting(); + break; + + case tokens.slash: + case tokens.combinator: + this.combinator(); + break; + + case tokens.str: + this.string(); + break; + // These cases throw; no break needed. + + case tokens.closeSquare: + this.missingSquareBracket(); + + case tokens.semicolon: + this.missingBackslash(); + + default: + this.unexpected(); + } + } + /** + * Helpers + */ + ; + + _proto.expected = function expected(description, index, found) { + if (Array.isArray(description)) { + var last = description.pop(); + description = description.join(', ') + " or " + last; + } + + var an = /^[aeiou]/.test(description[0]) ? 'an' : 'a'; + + if (!found) { + return this.error("Expected " + an + " " + description + ".", { + index: index + }); + } + + return this.error("Expected " + an + " " + description + ", found \"" + found + "\" instead.", { + index: index + }); + }; + + _proto.requiredSpace = function requiredSpace(space) { + return this.options.lossy ? ' ' : space; + }; + + _proto.optionalSpace = function optionalSpace(space) { + return this.options.lossy ? '' : space; + }; + + _proto.lossySpace = function lossySpace(space, required) { + if (this.options.lossy) { + return required ? ' ' : ''; + } else { + return space; + } + }; + + _proto.parseParenthesisToken = function parseParenthesisToken(token) { + var content = this.content(token); + + if (token[_tokenize.FIELDS.TYPE] === tokens.space) { + return this.requiredSpace(content); + } else { + return content; + } + }; + + _proto.newNode = function newNode(node, namespace) { + if (namespace) { + if (/^ +$/.test(namespace)) { + if (!this.options.lossy) { + this.spaces = (this.spaces || '') + namespace; + } + + namespace = true; + } + + node.namespace = namespace; + unescapeProp(node, "namespace"); + } + + if (this.spaces) { + node.spaces.before = this.spaces; + this.spaces = ''; + } + + return this.current.append(node); + }; + + _proto.content = function content(token) { + if (token === void 0) { + token = this.currToken; + } + + return this.css.slice(token[_tokenize.FIELDS.START_POS], token[_tokenize.FIELDS.END_POS]); + }; + + /** + * returns the index of the next non-whitespace, non-comment token. + * returns -1 if no meaningful token is found. + */ + _proto.locateNextMeaningfulToken = function locateNextMeaningfulToken(startPosition) { + if (startPosition === void 0) { + startPosition = this.position + 1; + } + + var searchPosition = startPosition; + + while (searchPosition < this.tokens.length) { + if (WHITESPACE_EQUIV_TOKENS[this.tokens[searchPosition][_tokenize.FIELDS.TYPE]]) { + searchPosition++; + continue; + } else { + return searchPosition; + } + } + + return -1; + }; + + _createClass(Parser, [{ + key: "currToken", + get: function get() { + return this.tokens[this.position]; + } + }, { + key: "nextToken", + get: function get() { + return this.tokens[this.position + 1]; + } + }, { + key: "prevToken", + get: function get() { + return this.tokens[this.position - 1]; + } + }]); + + return Parser; +}(); + +exports["default"] = Parser; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/processor.js b/node_modules/postcss-selector-parser/dist/processor.js new file mode 100644 index 0000000..a00170c --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/processor.js @@ -0,0 +1,206 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _parser = _interopRequireDefault(require("./parser")); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +var Processor = /*#__PURE__*/function () { + function Processor(func, options) { + this.func = func || function noop() {}; + + this.funcRes = null; + this.options = options; + } + + var _proto = Processor.prototype; + + _proto._shouldUpdateSelector = function _shouldUpdateSelector(rule, options) { + if (options === void 0) { + options = {}; + } + + var merged = Object.assign({}, this.options, options); + + if (merged.updateSelector === false) { + return false; + } else { + return typeof rule !== "string"; + } + }; + + _proto._isLossy = function _isLossy(options) { + if (options === void 0) { + options = {}; + } + + var merged = Object.assign({}, this.options, options); + + if (merged.lossless === false) { + return true; + } else { + return false; + } + }; + + _proto._root = function _root(rule, options) { + if (options === void 0) { + options = {}; + } + + var parser = new _parser["default"](rule, this._parseOptions(options)); + return parser.root; + }; + + _proto._parseOptions = function _parseOptions(options) { + return { + lossy: this._isLossy(options) + }; + }; + + _proto._run = function _run(rule, options) { + var _this = this; + + if (options === void 0) { + options = {}; + } + + return new Promise(function (resolve, reject) { + try { + var root = _this._root(rule, options); + + Promise.resolve(_this.func(root)).then(function (transform) { + var string = undefined; + + if (_this._shouldUpdateSelector(rule, options)) { + string = root.toString(); + rule.selector = string; + } + + return { + transform: transform, + root: root, + string: string + }; + }).then(resolve, reject); + } catch (e) { + reject(e); + return; + } + }); + }; + + _proto._runSync = function _runSync(rule, options) { + if (options === void 0) { + options = {}; + } + + var root = this._root(rule, options); + + var transform = this.func(root); + + if (transform && typeof transform.then === "function") { + throw new Error("Selector processor returned a promise to a synchronous call."); + } + + var string = undefined; + + if (options.updateSelector && typeof rule !== "string") { + string = root.toString(); + rule.selector = string; + } + + return { + transform: transform, + root: root, + string: string + }; + } + /** + * Process rule into a selector AST. + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {Promise} The AST of the selector after processing it. + */ + ; + + _proto.ast = function ast(rule, options) { + return this._run(rule, options).then(function (result) { + return result.root; + }); + } + /** + * Process rule into a selector AST synchronously. + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {parser.Root} The AST of the selector after processing it. + */ + ; + + _proto.astSync = function astSync(rule, options) { + return this._runSync(rule, options).root; + } + /** + * Process a selector into a transformed value asynchronously + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {Promise} The value returned by the processor. + */ + ; + + _proto.transform = function transform(rule, options) { + return this._run(rule, options).then(function (result) { + return result.transform; + }); + } + /** + * Process a selector into a transformed value synchronously. + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {any} The value returned by the processor. + */ + ; + + _proto.transformSync = function transformSync(rule, options) { + return this._runSync(rule, options).transform; + } + /** + * Process a selector into a new selector string asynchronously. + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {string} the selector after processing. + */ + ; + + _proto.process = function process(rule, options) { + return this._run(rule, options).then(function (result) { + return result.string || result.root.toString(); + }); + } + /** + * Process a selector into a new selector string synchronously. + * + * @param rule {postcss.Rule | string} The css selector to be processed + * @param options The options for processing + * @returns {string} the selector after processing. + */ + ; + + _proto.processSync = function processSync(rule, options) { + var result = this._runSync(rule, options); + + return result.string || result.root.toString(); + }; + + return Processor; +}(); + +exports["default"] = Processor; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/attribute.js b/node_modules/postcss-selector-parser/dist/selectors/attribute.js new file mode 100644 index 0000000..8f535e5 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/attribute.js @@ -0,0 +1,515 @@ +"use strict"; + +exports.__esModule = true; +exports.unescapeValue = unescapeValue; +exports["default"] = void 0; + +var _cssesc = _interopRequireDefault(require("cssesc")); + +var _unesc = _interopRequireDefault(require("../util/unesc")); + +var _namespace = _interopRequireDefault(require("./namespace")); + +var _types = require("./types"); + +var _CSSESC_QUOTE_OPTIONS; + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var deprecate = require("util-deprecate"); + +var WRAPPED_IN_QUOTES = /^('|")([^]*)\1$/; +var warnOfDeprecatedValueAssignment = deprecate(function () {}, "Assigning an attribute a value containing characters that might need to be escaped is deprecated. " + "Call attribute.setValue() instead."); +var warnOfDeprecatedQuotedAssignment = deprecate(function () {}, "Assigning attr.quoted is deprecated and has no effect. Assign to attr.quoteMark instead."); +var warnOfDeprecatedConstructor = deprecate(function () {}, "Constructing an Attribute selector with a value without specifying quoteMark is deprecated. Note: The value should be unescaped now."); + +function unescapeValue(value) { + var deprecatedUsage = false; + var quoteMark = null; + var unescaped = value; + var m = unescaped.match(WRAPPED_IN_QUOTES); + + if (m) { + quoteMark = m[1]; + unescaped = m[2]; + } + + unescaped = (0, _unesc["default"])(unescaped); + + if (unescaped !== value) { + deprecatedUsage = true; + } + + return { + deprecatedUsage: deprecatedUsage, + unescaped: unescaped, + quoteMark: quoteMark + }; +} + +function handleDeprecatedContructorOpts(opts) { + if (opts.quoteMark !== undefined) { + return opts; + } + + if (opts.value === undefined) { + return opts; + } + + warnOfDeprecatedConstructor(); + + var _unescapeValue = unescapeValue(opts.value), + quoteMark = _unescapeValue.quoteMark, + unescaped = _unescapeValue.unescaped; + + if (!opts.raws) { + opts.raws = {}; + } + + if (opts.raws.value === undefined) { + opts.raws.value = opts.value; + } + + opts.value = unescaped; + opts.quoteMark = quoteMark; + return opts; +} + +var Attribute = /*#__PURE__*/function (_Namespace) { + _inheritsLoose(Attribute, _Namespace); + + function Attribute(opts) { + var _this; + + if (opts === void 0) { + opts = {}; + } + + _this = _Namespace.call(this, handleDeprecatedContructorOpts(opts)) || this; + _this.type = _types.ATTRIBUTE; + _this.raws = _this.raws || {}; + Object.defineProperty(_this.raws, 'unquoted', { + get: deprecate(function () { + return _this.value; + }, "attr.raws.unquoted is deprecated. Call attr.value instead."), + set: deprecate(function () { + return _this.value; + }, "Setting attr.raws.unquoted is deprecated and has no effect. attr.value is unescaped by default now.") + }); + _this._constructed = true; + return _this; + } + /** + * Returns the Attribute's value quoted such that it would be legal to use + * in the value of a css file. The original value's quotation setting + * used for stringification is left unchanged. See `setValue(value, options)` + * if you want to control the quote settings of a new value for the attribute. + * + * You can also change the quotation used for the current value by setting quoteMark. + * + * Options: + * * quoteMark {'"' | "'" | null} - Use this value to quote the value. If this + * option is not set, the original value for quoteMark will be used. If + * indeterminate, a double quote is used. The legal values are: + * * `null` - the value will be unquoted and characters will be escaped as necessary. + * * `'` - the value will be quoted with a single quote and single quotes are escaped. + * * `"` - the value will be quoted with a double quote and double quotes are escaped. + * * preferCurrentQuoteMark {boolean} - if true, prefer the source quote mark + * over the quoteMark option value. + * * smart {boolean} - if true, will select a quote mark based on the value + * and the other options specified here. See the `smartQuoteMark()` + * method. + **/ + + + var _proto = Attribute.prototype; + + _proto.getQuotedValue = function getQuotedValue(options) { + if (options === void 0) { + options = {}; + } + + var quoteMark = this._determineQuoteMark(options); + + var cssescopts = CSSESC_QUOTE_OPTIONS[quoteMark]; + var escaped = (0, _cssesc["default"])(this._value, cssescopts); + return escaped; + }; + + _proto._determineQuoteMark = function _determineQuoteMark(options) { + return options.smart ? this.smartQuoteMark(options) : this.preferredQuoteMark(options); + } + /** + * Set the unescaped value with the specified quotation options. The value + * provided must not include any wrapping quote marks -- those quotes will + * be interpreted as part of the value and escaped accordingly. + */ + ; + + _proto.setValue = function setValue(value, options) { + if (options === void 0) { + options = {}; + } + + this._value = value; + this._quoteMark = this._determineQuoteMark(options); + + this._syncRawValue(); + } + /** + * Intelligently select a quoteMark value based on the value's contents. If + * the value is a legal CSS ident, it will not be quoted. Otherwise a quote + * mark will be picked that minimizes the number of escapes. + * + * If there's no clear winner, the quote mark from these options is used, + * then the source quote mark (this is inverted if `preferCurrentQuoteMark` is + * true). If the quoteMark is unspecified, a double quote is used. + * + * @param options This takes the quoteMark and preferCurrentQuoteMark options + * from the quoteValue method. + */ + ; + + _proto.smartQuoteMark = function smartQuoteMark(options) { + var v = this.value; + var numSingleQuotes = v.replace(/[^']/g, '').length; + var numDoubleQuotes = v.replace(/[^"]/g, '').length; + + if (numSingleQuotes + numDoubleQuotes === 0) { + var escaped = (0, _cssesc["default"])(v, { + isIdentifier: true + }); + + if (escaped === v) { + return Attribute.NO_QUOTE; + } else { + var pref = this.preferredQuoteMark(options); + + if (pref === Attribute.NO_QUOTE) { + // pick a quote mark that isn't none and see if it's smaller + var quote = this.quoteMark || options.quoteMark || Attribute.DOUBLE_QUOTE; + var opts = CSSESC_QUOTE_OPTIONS[quote]; + var quoteValue = (0, _cssesc["default"])(v, opts); + + if (quoteValue.length < escaped.length) { + return quote; + } + } + + return pref; + } + } else if (numDoubleQuotes === numSingleQuotes) { + return this.preferredQuoteMark(options); + } else if (numDoubleQuotes < numSingleQuotes) { + return Attribute.DOUBLE_QUOTE; + } else { + return Attribute.SINGLE_QUOTE; + } + } + /** + * Selects the preferred quote mark based on the options and the current quote mark value. + * If you want the quote mark to depend on the attribute value, call `smartQuoteMark(opts)` + * instead. + */ + ; + + _proto.preferredQuoteMark = function preferredQuoteMark(options) { + var quoteMark = options.preferCurrentQuoteMark ? this.quoteMark : options.quoteMark; + + if (quoteMark === undefined) { + quoteMark = options.preferCurrentQuoteMark ? options.quoteMark : this.quoteMark; + } + + if (quoteMark === undefined) { + quoteMark = Attribute.DOUBLE_QUOTE; + } + + return quoteMark; + }; + + _proto._syncRawValue = function _syncRawValue() { + var rawValue = (0, _cssesc["default"])(this._value, CSSESC_QUOTE_OPTIONS[this.quoteMark]); + + if (rawValue === this._value) { + if (this.raws) { + delete this.raws.value; + } + } else { + this.raws.value = rawValue; + } + }; + + _proto._handleEscapes = function _handleEscapes(prop, value) { + if (this._constructed) { + var escaped = (0, _cssesc["default"])(value, { + isIdentifier: true + }); + + if (escaped !== value) { + this.raws[prop] = escaped; + } else { + delete this.raws[prop]; + } + } + }; + + _proto._spacesFor = function _spacesFor(name) { + var attrSpaces = { + before: '', + after: '' + }; + var spaces = this.spaces[name] || {}; + var rawSpaces = this.raws.spaces && this.raws.spaces[name] || {}; + return Object.assign(attrSpaces, spaces, rawSpaces); + }; + + _proto._stringFor = function _stringFor(name, spaceName, concat) { + if (spaceName === void 0) { + spaceName = name; + } + + if (concat === void 0) { + concat = defaultAttrConcat; + } + + var attrSpaces = this._spacesFor(spaceName); + + return concat(this.stringifyProperty(name), attrSpaces); + } + /** + * returns the offset of the attribute part specified relative to the + * start of the node of the output string. + * + * * "ns" - alias for "namespace" + * * "namespace" - the namespace if it exists. + * * "attribute" - the attribute name + * * "attributeNS" - the start of the attribute or its namespace + * * "operator" - the match operator of the attribute + * * "value" - The value (string or identifier) + * * "insensitive" - the case insensitivity flag; + * @param part One of the possible values inside an attribute. + * @returns -1 if the name is invalid or the value doesn't exist in this attribute. + */ + ; + + _proto.offsetOf = function offsetOf(name) { + var count = 1; + + var attributeSpaces = this._spacesFor("attribute"); + + count += attributeSpaces.before.length; + + if (name === "namespace" || name === "ns") { + return this.namespace ? count : -1; + } + + if (name === "attributeNS") { + return count; + } + + count += this.namespaceString.length; + + if (this.namespace) { + count += 1; + } + + if (name === "attribute") { + return count; + } + + count += this.stringifyProperty("attribute").length; + count += attributeSpaces.after.length; + + var operatorSpaces = this._spacesFor("operator"); + + count += operatorSpaces.before.length; + var operator = this.stringifyProperty("operator"); + + if (name === "operator") { + return operator ? count : -1; + } + + count += operator.length; + count += operatorSpaces.after.length; + + var valueSpaces = this._spacesFor("value"); + + count += valueSpaces.before.length; + var value = this.stringifyProperty("value"); + + if (name === "value") { + return value ? count : -1; + } + + count += value.length; + count += valueSpaces.after.length; + + var insensitiveSpaces = this._spacesFor("insensitive"); + + count += insensitiveSpaces.before.length; + + if (name === "insensitive") { + return this.insensitive ? count : -1; + } + + return -1; + }; + + _proto.toString = function toString() { + var _this2 = this; + + var selector = [this.rawSpaceBefore, '[']; + selector.push(this._stringFor('qualifiedAttribute', 'attribute')); + + if (this.operator && (this.value || this.value === '')) { + selector.push(this._stringFor('operator')); + selector.push(this._stringFor('value')); + selector.push(this._stringFor('insensitiveFlag', 'insensitive', function (attrValue, attrSpaces) { + if (attrValue.length > 0 && !_this2.quoted && attrSpaces.before.length === 0 && !(_this2.spaces.value && _this2.spaces.value.after)) { + attrSpaces.before = " "; + } + + return defaultAttrConcat(attrValue, attrSpaces); + })); + } + + selector.push(']'); + selector.push(this.rawSpaceAfter); + return selector.join(''); + }; + + _createClass(Attribute, [{ + key: "quoted", + get: function get() { + var qm = this.quoteMark; + return qm === "'" || qm === '"'; + }, + set: function set(value) { + warnOfDeprecatedQuotedAssignment(); + } + /** + * returns a single (`'`) or double (`"`) quote character if the value is quoted. + * returns `null` if the value is not quoted. + * returns `undefined` if the quotation state is unknown (this can happen when + * the attribute is constructed without specifying a quote mark.) + */ + + }, { + key: "quoteMark", + get: function get() { + return this._quoteMark; + } + /** + * Set the quote mark to be used by this attribute's value. + * If the quote mark changes, the raw (escaped) value at `attr.raws.value` of the attribute + * value is updated accordingly. + * + * @param {"'" | '"' | null} quoteMark The quote mark or `null` if the value should be unquoted. + */ + , + set: function set(quoteMark) { + if (!this._constructed) { + this._quoteMark = quoteMark; + return; + } + + if (this._quoteMark !== quoteMark) { + this._quoteMark = quoteMark; + + this._syncRawValue(); + } + } + }, { + key: "qualifiedAttribute", + get: function get() { + return this.qualifiedName(this.raws.attribute || this.attribute); + } + }, { + key: "insensitiveFlag", + get: function get() { + return this.insensitive ? 'i' : ''; + } + }, { + key: "value", + get: function get() { + return this._value; + } + /** + * Before 3.0, the value had to be set to an escaped value including any wrapped + * quote marks. In 3.0, the semantics of `Attribute.value` changed so that the value + * is unescaped during parsing and any quote marks are removed. + * + * Because the ambiguity of this semantic change, if you set `attr.value = newValue`, + * a deprecation warning is raised when the new value contains any characters that would + * require escaping (including if it contains wrapped quotes). + * + * Instead, you should call `attr.setValue(newValue, opts)` and pass options that describe + * how the new value is quoted. + */ + , + set: function set(v) { + if (this._constructed) { + var _unescapeValue2 = unescapeValue(v), + deprecatedUsage = _unescapeValue2.deprecatedUsage, + unescaped = _unescapeValue2.unescaped, + quoteMark = _unescapeValue2.quoteMark; + + if (deprecatedUsage) { + warnOfDeprecatedValueAssignment(); + } + + if (unescaped === this._value && quoteMark === this._quoteMark) { + return; + } + + this._value = unescaped; + this._quoteMark = quoteMark; + + this._syncRawValue(); + } else { + this._value = v; + } + } + }, { + key: "attribute", + get: function get() { + return this._attribute; + }, + set: function set(name) { + this._handleEscapes("attribute", name); + + this._attribute = name; + } + }]); + + return Attribute; +}(_namespace["default"]); + +exports["default"] = Attribute; +Attribute.NO_QUOTE = null; +Attribute.SINGLE_QUOTE = "'"; +Attribute.DOUBLE_QUOTE = '"'; +var CSSESC_QUOTE_OPTIONS = (_CSSESC_QUOTE_OPTIONS = { + "'": { + quotes: 'single', + wrap: true + }, + '"': { + quotes: 'double', + wrap: true + } +}, _CSSESC_QUOTE_OPTIONS[null] = { + isIdentifier: true +}, _CSSESC_QUOTE_OPTIONS); + +function defaultAttrConcat(attrValue, attrSpaces) { + return "" + attrSpaces.before + attrValue + attrSpaces.after; +} \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/className.js b/node_modules/postcss-selector-parser/dist/selectors/className.js new file mode 100644 index 0000000..2240991 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/className.js @@ -0,0 +1,69 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _cssesc = _interopRequireDefault(require("cssesc")); + +var _util = require("../util"); + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var ClassName = /*#__PURE__*/function (_Node) { + _inheritsLoose(ClassName, _Node); + + function ClassName(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.CLASS; + _this._constructed = true; + return _this; + } + + var _proto = ClassName.prototype; + + _proto.valueToString = function valueToString() { + return '.' + _Node.prototype.valueToString.call(this); + }; + + _createClass(ClassName, [{ + key: "value", + get: function get() { + return this._value; + }, + set: function set(v) { + if (this._constructed) { + var escaped = (0, _cssesc["default"])(v, { + isIdentifier: true + }); + + if (escaped !== v) { + (0, _util.ensureObject)(this, "raws"); + this.raws.value = escaped; + } else if (this.raws) { + delete this.raws.value; + } + } + + this._value = v; + } + }]); + + return ClassName; +}(_node["default"]); + +exports["default"] = ClassName; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/combinator.js b/node_modules/postcss-selector-parser/dist/selectors/combinator.js new file mode 100644 index 0000000..271ab4d --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/combinator.js @@ -0,0 +1,31 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Combinator = /*#__PURE__*/function (_Node) { + _inheritsLoose(Combinator, _Node); + + function Combinator(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.COMBINATOR; + return _this; + } + + return Combinator; +}(_node["default"]); + +exports["default"] = Combinator; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/comment.js b/node_modules/postcss-selector-parser/dist/selectors/comment.js new file mode 100644 index 0000000..e778094 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/comment.js @@ -0,0 +1,31 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Comment = /*#__PURE__*/function (_Node) { + _inheritsLoose(Comment, _Node); + + function Comment(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.COMMENT; + return _this; + } + + return Comment; +}(_node["default"]); + +exports["default"] = Comment; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/constructors.js b/node_modules/postcss-selector-parser/dist/selectors/constructors.js new file mode 100644 index 0000000..078023e --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/constructors.js @@ -0,0 +1,102 @@ +"use strict"; + +exports.__esModule = true; +exports.universal = exports.tag = exports.string = exports.selector = exports.root = exports.pseudo = exports.nesting = exports.id = exports.comment = exports.combinator = exports.className = exports.attribute = void 0; + +var _attribute = _interopRequireDefault(require("./attribute")); + +var _className = _interopRequireDefault(require("./className")); + +var _combinator = _interopRequireDefault(require("./combinator")); + +var _comment = _interopRequireDefault(require("./comment")); + +var _id = _interopRequireDefault(require("./id")); + +var _nesting = _interopRequireDefault(require("./nesting")); + +var _pseudo = _interopRequireDefault(require("./pseudo")); + +var _root = _interopRequireDefault(require("./root")); + +var _selector = _interopRequireDefault(require("./selector")); + +var _string = _interopRequireDefault(require("./string")); + +var _tag = _interopRequireDefault(require("./tag")); + +var _universal = _interopRequireDefault(require("./universal")); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +var attribute = function attribute(opts) { + return new _attribute["default"](opts); +}; + +exports.attribute = attribute; + +var className = function className(opts) { + return new _className["default"](opts); +}; + +exports.className = className; + +var combinator = function combinator(opts) { + return new _combinator["default"](opts); +}; + +exports.combinator = combinator; + +var comment = function comment(opts) { + return new _comment["default"](opts); +}; + +exports.comment = comment; + +var id = function id(opts) { + return new _id["default"](opts); +}; + +exports.id = id; + +var nesting = function nesting(opts) { + return new _nesting["default"](opts); +}; + +exports.nesting = nesting; + +var pseudo = function pseudo(opts) { + return new _pseudo["default"](opts); +}; + +exports.pseudo = pseudo; + +var root = function root(opts) { + return new _root["default"](opts); +}; + +exports.root = root; + +var selector = function selector(opts) { + return new _selector["default"](opts); +}; + +exports.selector = selector; + +var string = function string(opts) { + return new _string["default"](opts); +}; + +exports.string = string; + +var tag = function tag(opts) { + return new _tag["default"](opts); +}; + +exports.tag = tag; + +var universal = function universal(opts) { + return new _universal["default"](opts); +}; + +exports.universal = universal; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/container.js b/node_modules/postcss-selector-parser/dist/selectors/container.js new file mode 100644 index 0000000..2626fb8 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/container.js @@ -0,0 +1,395 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var types = _interopRequireWildcard(require("./types")); + +function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } it = o[Symbol.iterator](); return it.next.bind(it); } + +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } + +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Container = /*#__PURE__*/function (_Node) { + _inheritsLoose(Container, _Node); + + function Container(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + + if (!_this.nodes) { + _this.nodes = []; + } + + return _this; + } + + var _proto = Container.prototype; + + _proto.append = function append(selector) { + selector.parent = this; + this.nodes.push(selector); + return this; + }; + + _proto.prepend = function prepend(selector) { + selector.parent = this; + this.nodes.unshift(selector); + return this; + }; + + _proto.at = function at(index) { + return this.nodes[index]; + }; + + _proto.index = function index(child) { + if (typeof child === 'number') { + return child; + } + + return this.nodes.indexOf(child); + }; + + _proto.removeChild = function removeChild(child) { + child = this.index(child); + this.at(child).parent = undefined; + this.nodes.splice(child, 1); + var index; + + for (var id in this.indexes) { + index = this.indexes[id]; + + if (index >= child) { + this.indexes[id] = index - 1; + } + } + + return this; + }; + + _proto.removeAll = function removeAll() { + for (var _iterator = _createForOfIteratorHelperLoose(this.nodes), _step; !(_step = _iterator()).done;) { + var node = _step.value; + node.parent = undefined; + } + + this.nodes = []; + return this; + }; + + _proto.empty = function empty() { + return this.removeAll(); + }; + + _proto.insertAfter = function insertAfter(oldNode, newNode) { + newNode.parent = this; + var oldIndex = this.index(oldNode); + this.nodes.splice(oldIndex + 1, 0, newNode); + newNode.parent = this; + var index; + + for (var id in this.indexes) { + index = this.indexes[id]; + + if (oldIndex <= index) { + this.indexes[id] = index + 1; + } + } + + return this; + }; + + _proto.insertBefore = function insertBefore(oldNode, newNode) { + newNode.parent = this; + var oldIndex = this.index(oldNode); + this.nodes.splice(oldIndex, 0, newNode); + newNode.parent = this; + var index; + + for (var id in this.indexes) { + index = this.indexes[id]; + + if (index <= oldIndex) { + this.indexes[id] = index + 1; + } + } + + return this; + }; + + _proto._findChildAtPosition = function _findChildAtPosition(line, col) { + var found = undefined; + this.each(function (node) { + if (node.atPosition) { + var foundChild = node.atPosition(line, col); + + if (foundChild) { + found = foundChild; + return false; + } + } else if (node.isAtPosition(line, col)) { + found = node; + return false; + } + }); + return found; + } + /** + * Return the most specific node at the line and column number given. + * The source location is based on the original parsed location, locations aren't + * updated as selector nodes are mutated. + * + * Note that this location is relative to the location of the first character + * of the selector, and not the location of the selector in the overall document + * when used in conjunction with postcss. + * + * If not found, returns undefined. + * @param {number} line The line number of the node to find. (1-based index) + * @param {number} col The column number of the node to find. (1-based index) + */ + ; + + _proto.atPosition = function atPosition(line, col) { + if (this.isAtPosition(line, col)) { + return this._findChildAtPosition(line, col) || this; + } else { + return undefined; + } + }; + + _proto._inferEndPosition = function _inferEndPosition() { + if (this.last && this.last.source && this.last.source.end) { + this.source = this.source || {}; + this.source.end = this.source.end || {}; + Object.assign(this.source.end, this.last.source.end); + } + }; + + _proto.each = function each(callback) { + if (!this.lastEach) { + this.lastEach = 0; + } + + if (!this.indexes) { + this.indexes = {}; + } + + this.lastEach++; + var id = this.lastEach; + this.indexes[id] = 0; + + if (!this.length) { + return undefined; + } + + var index, result; + + while (this.indexes[id] < this.length) { + index = this.indexes[id]; + result = callback(this.at(index), index); + + if (result === false) { + break; + } + + this.indexes[id] += 1; + } + + delete this.indexes[id]; + + if (result === false) { + return false; + } + }; + + _proto.walk = function walk(callback) { + return this.each(function (node, i) { + var result = callback(node, i); + + if (result !== false && node.length) { + result = node.walk(callback); + } + + if (result === false) { + return false; + } + }); + }; + + _proto.walkAttributes = function walkAttributes(callback) { + var _this2 = this; + + return this.walk(function (selector) { + if (selector.type === types.ATTRIBUTE) { + return callback.call(_this2, selector); + } + }); + }; + + _proto.walkClasses = function walkClasses(callback) { + var _this3 = this; + + return this.walk(function (selector) { + if (selector.type === types.CLASS) { + return callback.call(_this3, selector); + } + }); + }; + + _proto.walkCombinators = function walkCombinators(callback) { + var _this4 = this; + + return this.walk(function (selector) { + if (selector.type === types.COMBINATOR) { + return callback.call(_this4, selector); + } + }); + }; + + _proto.walkComments = function walkComments(callback) { + var _this5 = this; + + return this.walk(function (selector) { + if (selector.type === types.COMMENT) { + return callback.call(_this5, selector); + } + }); + }; + + _proto.walkIds = function walkIds(callback) { + var _this6 = this; + + return this.walk(function (selector) { + if (selector.type === types.ID) { + return callback.call(_this6, selector); + } + }); + }; + + _proto.walkNesting = function walkNesting(callback) { + var _this7 = this; + + return this.walk(function (selector) { + if (selector.type === types.NESTING) { + return callback.call(_this7, selector); + } + }); + }; + + _proto.walkPseudos = function walkPseudos(callback) { + var _this8 = this; + + return this.walk(function (selector) { + if (selector.type === types.PSEUDO) { + return callback.call(_this8, selector); + } + }); + }; + + _proto.walkTags = function walkTags(callback) { + var _this9 = this; + + return this.walk(function (selector) { + if (selector.type === types.TAG) { + return callback.call(_this9, selector); + } + }); + }; + + _proto.walkUniversals = function walkUniversals(callback) { + var _this10 = this; + + return this.walk(function (selector) { + if (selector.type === types.UNIVERSAL) { + return callback.call(_this10, selector); + } + }); + }; + + _proto.split = function split(callback) { + var _this11 = this; + + var current = []; + return this.reduce(function (memo, node, index) { + var split = callback.call(_this11, node); + current.push(node); + + if (split) { + memo.push(current); + current = []; + } else if (index === _this11.length - 1) { + memo.push(current); + } + + return memo; + }, []); + }; + + _proto.map = function map(callback) { + return this.nodes.map(callback); + }; + + _proto.reduce = function reduce(callback, memo) { + return this.nodes.reduce(callback, memo); + }; + + _proto.every = function every(callback) { + return this.nodes.every(callback); + }; + + _proto.some = function some(callback) { + return this.nodes.some(callback); + }; + + _proto.filter = function filter(callback) { + return this.nodes.filter(callback); + }; + + _proto.sort = function sort(callback) { + return this.nodes.sort(callback); + }; + + _proto.toString = function toString() { + return this.map(String).join(''); + }; + + _createClass(Container, [{ + key: "first", + get: function get() { + return this.at(0); + } + }, { + key: "last", + get: function get() { + return this.at(this.length - 1); + } + }, { + key: "length", + get: function get() { + return this.nodes.length; + } + }]); + + return Container; +}(_node["default"]); + +exports["default"] = Container; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/guards.js b/node_modules/postcss-selector-parser/dist/selectors/guards.js new file mode 100644 index 0000000..c949af5 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/guards.js @@ -0,0 +1,64 @@ +"use strict"; + +exports.__esModule = true; +exports.isNode = isNode; +exports.isPseudoElement = isPseudoElement; +exports.isPseudoClass = isPseudoClass; +exports.isContainer = isContainer; +exports.isNamespace = isNamespace; +exports.isUniversal = exports.isTag = exports.isString = exports.isSelector = exports.isRoot = exports.isPseudo = exports.isNesting = exports.isIdentifier = exports.isComment = exports.isCombinator = exports.isClassName = exports.isAttribute = void 0; + +var _types = require("./types"); + +var _IS_TYPE; + +var IS_TYPE = (_IS_TYPE = {}, _IS_TYPE[_types.ATTRIBUTE] = true, _IS_TYPE[_types.CLASS] = true, _IS_TYPE[_types.COMBINATOR] = true, _IS_TYPE[_types.COMMENT] = true, _IS_TYPE[_types.ID] = true, _IS_TYPE[_types.NESTING] = true, _IS_TYPE[_types.PSEUDO] = true, _IS_TYPE[_types.ROOT] = true, _IS_TYPE[_types.SELECTOR] = true, _IS_TYPE[_types.STRING] = true, _IS_TYPE[_types.TAG] = true, _IS_TYPE[_types.UNIVERSAL] = true, _IS_TYPE); + +function isNode(node) { + return typeof node === "object" && IS_TYPE[node.type]; +} + +function isNodeType(type, node) { + return isNode(node) && node.type === type; +} + +var isAttribute = isNodeType.bind(null, _types.ATTRIBUTE); +exports.isAttribute = isAttribute; +var isClassName = isNodeType.bind(null, _types.CLASS); +exports.isClassName = isClassName; +var isCombinator = isNodeType.bind(null, _types.COMBINATOR); +exports.isCombinator = isCombinator; +var isComment = isNodeType.bind(null, _types.COMMENT); +exports.isComment = isComment; +var isIdentifier = isNodeType.bind(null, _types.ID); +exports.isIdentifier = isIdentifier; +var isNesting = isNodeType.bind(null, _types.NESTING); +exports.isNesting = isNesting; +var isPseudo = isNodeType.bind(null, _types.PSEUDO); +exports.isPseudo = isPseudo; +var isRoot = isNodeType.bind(null, _types.ROOT); +exports.isRoot = isRoot; +var isSelector = isNodeType.bind(null, _types.SELECTOR); +exports.isSelector = isSelector; +var isString = isNodeType.bind(null, _types.STRING); +exports.isString = isString; +var isTag = isNodeType.bind(null, _types.TAG); +exports.isTag = isTag; +var isUniversal = isNodeType.bind(null, _types.UNIVERSAL); +exports.isUniversal = isUniversal; + +function isPseudoElement(node) { + return isPseudo(node) && node.value && (node.value.startsWith("::") || node.value.toLowerCase() === ":before" || node.value.toLowerCase() === ":after" || node.value.toLowerCase() === ":first-letter" || node.value.toLowerCase() === ":first-line"); +} + +function isPseudoClass(node) { + return isPseudo(node) && !isPseudoElement(node); +} + +function isContainer(node) { + return !!(isNode(node) && node.walk); +} + +function isNamespace(node) { + return isAttribute(node) || isTag(node); +} \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/id.js b/node_modules/postcss-selector-parser/dist/selectors/id.js new file mode 100644 index 0000000..4e83147 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/id.js @@ -0,0 +1,37 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var ID = /*#__PURE__*/function (_Node) { + _inheritsLoose(ID, _Node); + + function ID(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.ID; + return _this; + } + + var _proto = ID.prototype; + + _proto.valueToString = function valueToString() { + return '#' + _Node.prototype.valueToString.call(this); + }; + + return ID; +}(_node["default"]); + +exports["default"] = ID; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/index.js b/node_modules/postcss-selector-parser/dist/selectors/index.js new file mode 100644 index 0000000..1fe9b13 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/index.js @@ -0,0 +1,27 @@ +"use strict"; + +exports.__esModule = true; + +var _types = require("./types"); + +Object.keys(_types).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _types[key]) return; + exports[key] = _types[key]; +}); + +var _constructors = require("./constructors"); + +Object.keys(_constructors).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _constructors[key]) return; + exports[key] = _constructors[key]; +}); + +var _guards = require("./guards"); + +Object.keys(_guards).forEach(function (key) { + if (key === "default" || key === "__esModule") return; + if (key in exports && exports[key] === _guards[key]) return; + exports[key] = _guards[key]; +}); \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/namespace.js b/node_modules/postcss-selector-parser/dist/selectors/namespace.js new file mode 100644 index 0000000..fd6c729 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/namespace.js @@ -0,0 +1,101 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _cssesc = _interopRequireDefault(require("cssesc")); + +var _util = require("../util"); + +var _node = _interopRequireDefault(require("./node")); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Namespace = /*#__PURE__*/function (_Node) { + _inheritsLoose(Namespace, _Node); + + function Namespace() { + return _Node.apply(this, arguments) || this; + } + + var _proto = Namespace.prototype; + + _proto.qualifiedName = function qualifiedName(value) { + if (this.namespace) { + return this.namespaceString + "|" + value; + } else { + return value; + } + }; + + _proto.valueToString = function valueToString() { + return this.qualifiedName(_Node.prototype.valueToString.call(this)); + }; + + _createClass(Namespace, [{ + key: "namespace", + get: function get() { + return this._namespace; + }, + set: function set(namespace) { + if (namespace === true || namespace === "*" || namespace === "&") { + this._namespace = namespace; + + if (this.raws) { + delete this.raws.namespace; + } + + return; + } + + var escaped = (0, _cssesc["default"])(namespace, { + isIdentifier: true + }); + this._namespace = namespace; + + if (escaped !== namespace) { + (0, _util.ensureObject)(this, "raws"); + this.raws.namespace = escaped; + } else if (this.raws) { + delete this.raws.namespace; + } + } + }, { + key: "ns", + get: function get() { + return this._namespace; + }, + set: function set(namespace) { + this.namespace = namespace; + } + }, { + key: "namespaceString", + get: function get() { + if (this.namespace) { + var ns = this.stringifyProperty("namespace"); + + if (ns === true) { + return ''; + } else { + return ns; + } + } else { + return ''; + } + } + }]); + + return Namespace; +}(_node["default"]); + +exports["default"] = Namespace; +; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/nesting.js b/node_modules/postcss-selector-parser/dist/selectors/nesting.js new file mode 100644 index 0000000..3288c78 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/nesting.js @@ -0,0 +1,32 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Nesting = /*#__PURE__*/function (_Node) { + _inheritsLoose(Nesting, _Node); + + function Nesting(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.NESTING; + _this.value = '&'; + return _this; + } + + return Nesting; +}(_node["default"]); + +exports["default"] = Nesting; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/node.js b/node_modules/postcss-selector-parser/dist/selectors/node.js new file mode 100644 index 0000000..e8eca11 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/node.js @@ -0,0 +1,239 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _util = require("../util"); + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +var cloneNode = function cloneNode(obj, parent) { + if (typeof obj !== 'object' || obj === null) { + return obj; + } + + var cloned = new obj.constructor(); + + for (var i in obj) { + if (!obj.hasOwnProperty(i)) { + continue; + } + + var value = obj[i]; + var type = typeof value; + + if (i === 'parent' && type === 'object') { + if (parent) { + cloned[i] = parent; + } + } else if (value instanceof Array) { + cloned[i] = value.map(function (j) { + return cloneNode(j, cloned); + }); + } else { + cloned[i] = cloneNode(value, cloned); + } + } + + return cloned; +}; + +var Node = /*#__PURE__*/function () { + function Node(opts) { + if (opts === void 0) { + opts = {}; + } + + Object.assign(this, opts); + this.spaces = this.spaces || {}; + this.spaces.before = this.spaces.before || ''; + this.spaces.after = this.spaces.after || ''; + } + + var _proto = Node.prototype; + + _proto.remove = function remove() { + if (this.parent) { + this.parent.removeChild(this); + } + + this.parent = undefined; + return this; + }; + + _proto.replaceWith = function replaceWith() { + if (this.parent) { + for (var index in arguments) { + this.parent.insertBefore(this, arguments[index]); + } + + this.remove(); + } + + return this; + }; + + _proto.next = function next() { + return this.parent.at(this.parent.index(this) + 1); + }; + + _proto.prev = function prev() { + return this.parent.at(this.parent.index(this) - 1); + }; + + _proto.clone = function clone(overrides) { + if (overrides === void 0) { + overrides = {}; + } + + var cloned = cloneNode(this); + + for (var name in overrides) { + cloned[name] = overrides[name]; + } + + return cloned; + } + /** + * Some non-standard syntax doesn't follow normal escaping rules for css. + * This allows non standard syntax to be appended to an existing property + * by specifying the escaped value. By specifying the escaped value, + * illegal characters are allowed to be directly inserted into css output. + * @param {string} name the property to set + * @param {any} value the unescaped value of the property + * @param {string} valueEscaped optional. the escaped value of the property. + */ + ; + + _proto.appendToPropertyAndEscape = function appendToPropertyAndEscape(name, value, valueEscaped) { + if (!this.raws) { + this.raws = {}; + } + + var originalValue = this[name]; + var originalEscaped = this.raws[name]; + this[name] = originalValue + value; // this may trigger a setter that updates raws, so it has to be set first. + + if (originalEscaped || valueEscaped !== value) { + this.raws[name] = (originalEscaped || originalValue) + valueEscaped; + } else { + delete this.raws[name]; // delete any escaped value that was created by the setter. + } + } + /** + * Some non-standard syntax doesn't follow normal escaping rules for css. + * This allows the escaped value to be specified directly, allowing illegal + * characters to be directly inserted into css output. + * @param {string} name the property to set + * @param {any} value the unescaped value of the property + * @param {string} valueEscaped the escaped value of the property. + */ + ; + + _proto.setPropertyAndEscape = function setPropertyAndEscape(name, value, valueEscaped) { + if (!this.raws) { + this.raws = {}; + } + + this[name] = value; // this may trigger a setter that updates raws, so it has to be set first. + + this.raws[name] = valueEscaped; + } + /** + * When you want a value to passed through to CSS directly. This method + * deletes the corresponding raw value causing the stringifier to fallback + * to the unescaped value. + * @param {string} name the property to set. + * @param {any} value The value that is both escaped and unescaped. + */ + ; + + _proto.setPropertyWithoutEscape = function setPropertyWithoutEscape(name, value) { + this[name] = value; // this may trigger a setter that updates raws, so it has to be set first. + + if (this.raws) { + delete this.raws[name]; + } + } + /** + * + * @param {number} line The number (starting with 1) + * @param {number} column The column number (starting with 1) + */ + ; + + _proto.isAtPosition = function isAtPosition(line, column) { + if (this.source && this.source.start && this.source.end) { + if (this.source.start.line > line) { + return false; + } + + if (this.source.end.line < line) { + return false; + } + + if (this.source.start.line === line && this.source.start.column > column) { + return false; + } + + if (this.source.end.line === line && this.source.end.column < column) { + return false; + } + + return true; + } + + return undefined; + }; + + _proto.stringifyProperty = function stringifyProperty(name) { + return this.raws && this.raws[name] || this[name]; + }; + + _proto.valueToString = function valueToString() { + return String(this.stringifyProperty("value")); + }; + + _proto.toString = function toString() { + return [this.rawSpaceBefore, this.valueToString(), this.rawSpaceAfter].join(''); + }; + + _createClass(Node, [{ + key: "rawSpaceBefore", + get: function get() { + var rawSpace = this.raws && this.raws.spaces && this.raws.spaces.before; + + if (rawSpace === undefined) { + rawSpace = this.spaces && this.spaces.before; + } + + return rawSpace || ""; + }, + set: function set(raw) { + (0, _util.ensureObject)(this, "raws", "spaces"); + this.raws.spaces.before = raw; + } + }, { + key: "rawSpaceAfter", + get: function get() { + var rawSpace = this.raws && this.raws.spaces && this.raws.spaces.after; + + if (rawSpace === undefined) { + rawSpace = this.spaces.after; + } + + return rawSpace || ""; + }, + set: function set(raw) { + (0, _util.ensureObject)(this, "raws", "spaces"); + this.raws.spaces.after = raw; + } + }]); + + return Node; +}(); + +exports["default"] = Node; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/pseudo.js b/node_modules/postcss-selector-parser/dist/selectors/pseudo.js new file mode 100644 index 0000000..a0e7bca --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/pseudo.js @@ -0,0 +1,38 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _container = _interopRequireDefault(require("./container")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Pseudo = /*#__PURE__*/function (_Container) { + _inheritsLoose(Pseudo, _Container); + + function Pseudo(opts) { + var _this; + + _this = _Container.call(this, opts) || this; + _this.type = _types.PSEUDO; + return _this; + } + + var _proto = Pseudo.prototype; + + _proto.toString = function toString() { + var params = this.length ? '(' + this.map(String).join(',') + ')' : ''; + return [this.rawSpaceBefore, this.stringifyProperty("value"), params, this.rawSpaceAfter].join(''); + }; + + return Pseudo; +}(_container["default"]); + +exports["default"] = Pseudo; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/root.js b/node_modules/postcss-selector-parser/dist/selectors/root.js new file mode 100644 index 0000000..be5c2cc --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/root.js @@ -0,0 +1,60 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _container = _interopRequireDefault(require("./container")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Root = /*#__PURE__*/function (_Container) { + _inheritsLoose(Root, _Container); + + function Root(opts) { + var _this; + + _this = _Container.call(this, opts) || this; + _this.type = _types.ROOT; + return _this; + } + + var _proto = Root.prototype; + + _proto.toString = function toString() { + var str = this.reduce(function (memo, selector) { + memo.push(String(selector)); + return memo; + }, []).join(','); + return this.trailingComma ? str + ',' : str; + }; + + _proto.error = function error(message, options) { + if (this._error) { + return this._error(message, options); + } else { + return new Error(message); + } + }; + + _createClass(Root, [{ + key: "errorGenerator", + set: function set(handler) { + this._error = handler; + } + }]); + + return Root; +}(_container["default"]); + +exports["default"] = Root; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/selector.js b/node_modules/postcss-selector-parser/dist/selectors/selector.js new file mode 100644 index 0000000..699eeb6 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/selector.js @@ -0,0 +1,31 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _container = _interopRequireDefault(require("./container")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Selector = /*#__PURE__*/function (_Container) { + _inheritsLoose(Selector, _Container); + + function Selector(opts) { + var _this; + + _this = _Container.call(this, opts) || this; + _this.type = _types.SELECTOR; + return _this; + } + + return Selector; +}(_container["default"]); + +exports["default"] = Selector; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/string.js b/node_modules/postcss-selector-parser/dist/selectors/string.js new file mode 100644 index 0000000..e61df30 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/string.js @@ -0,0 +1,31 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _node = _interopRequireDefault(require("./node")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var String = /*#__PURE__*/function (_Node) { + _inheritsLoose(String, _Node); + + function String(opts) { + var _this; + + _this = _Node.call(this, opts) || this; + _this.type = _types.STRING; + return _this; + } + + return String; +}(_node["default"]); + +exports["default"] = String; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/tag.js b/node_modules/postcss-selector-parser/dist/selectors/tag.js new file mode 100644 index 0000000..e298db1 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/tag.js @@ -0,0 +1,31 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _namespace = _interopRequireDefault(require("./namespace")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Tag = /*#__PURE__*/function (_Namespace) { + _inheritsLoose(Tag, _Namespace); + + function Tag(opts) { + var _this; + + _this = _Namespace.call(this, opts) || this; + _this.type = _types.TAG; + return _this; + } + + return Tag; +}(_namespace["default"]); + +exports["default"] = Tag; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/types.js b/node_modules/postcss-selector-parser/dist/selectors/types.js new file mode 100644 index 0000000..ab897b8 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/types.js @@ -0,0 +1,28 @@ +"use strict"; + +exports.__esModule = true; +exports.UNIVERSAL = exports.ATTRIBUTE = exports.CLASS = exports.COMBINATOR = exports.COMMENT = exports.ID = exports.NESTING = exports.PSEUDO = exports.ROOT = exports.SELECTOR = exports.STRING = exports.TAG = void 0; +var TAG = 'tag'; +exports.TAG = TAG; +var STRING = 'string'; +exports.STRING = STRING; +var SELECTOR = 'selector'; +exports.SELECTOR = SELECTOR; +var ROOT = 'root'; +exports.ROOT = ROOT; +var PSEUDO = 'pseudo'; +exports.PSEUDO = PSEUDO; +var NESTING = 'nesting'; +exports.NESTING = NESTING; +var ID = 'id'; +exports.ID = ID; +var COMMENT = 'comment'; +exports.COMMENT = COMMENT; +var COMBINATOR = 'combinator'; +exports.COMBINATOR = COMBINATOR; +var CLASS = 'class'; +exports.CLASS = CLASS; +var ATTRIBUTE = 'attribute'; +exports.ATTRIBUTE = ATTRIBUTE; +var UNIVERSAL = 'universal'; +exports.UNIVERSAL = UNIVERSAL; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/selectors/universal.js b/node_modules/postcss-selector-parser/dist/selectors/universal.js new file mode 100644 index 0000000..cf25473 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/selectors/universal.js @@ -0,0 +1,32 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = void 0; + +var _namespace = _interopRequireDefault(require("./namespace")); + +var _types = require("./types"); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } + +function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } + +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } + +var Universal = /*#__PURE__*/function (_Namespace) { + _inheritsLoose(Universal, _Namespace); + + function Universal(opts) { + var _this; + + _this = _Namespace.call(this, opts) || this; + _this.type = _types.UNIVERSAL; + _this.value = '*'; + return _this; + } + + return Universal; +}(_namespace["default"]); + +exports["default"] = Universal; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/sortAscending.js b/node_modules/postcss-selector-parser/dist/sortAscending.js new file mode 100644 index 0000000..3ef56ac --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/sortAscending.js @@ -0,0 +1,13 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = sortAscending; + +function sortAscending(list) { + return list.sort(function (a, b) { + return a - b; + }); +} + +; +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/tokenTypes.js b/node_modules/postcss-selector-parser/dist/tokenTypes.js new file mode 100644 index 0000000..48314b9 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/tokenTypes.js @@ -0,0 +1,95 @@ +"use strict"; + +exports.__esModule = true; +exports.combinator = exports.word = exports.comment = exports.str = exports.tab = exports.newline = exports.feed = exports.cr = exports.backslash = exports.bang = exports.slash = exports.doubleQuote = exports.singleQuote = exports.space = exports.greaterThan = exports.pipe = exports.equals = exports.plus = exports.caret = exports.tilde = exports.dollar = exports.closeSquare = exports.openSquare = exports.closeParenthesis = exports.openParenthesis = exports.semicolon = exports.colon = exports.comma = exports.at = exports.asterisk = exports.ampersand = void 0; +var ampersand = 38; // `&`.charCodeAt(0); + +exports.ampersand = ampersand; +var asterisk = 42; // `*`.charCodeAt(0); + +exports.asterisk = asterisk; +var at = 64; // `@`.charCodeAt(0); + +exports.at = at; +var comma = 44; // `,`.charCodeAt(0); + +exports.comma = comma; +var colon = 58; // `:`.charCodeAt(0); + +exports.colon = colon; +var semicolon = 59; // `;`.charCodeAt(0); + +exports.semicolon = semicolon; +var openParenthesis = 40; // `(`.charCodeAt(0); + +exports.openParenthesis = openParenthesis; +var closeParenthesis = 41; // `)`.charCodeAt(0); + +exports.closeParenthesis = closeParenthesis; +var openSquare = 91; // `[`.charCodeAt(0); + +exports.openSquare = openSquare; +var closeSquare = 93; // `]`.charCodeAt(0); + +exports.closeSquare = closeSquare; +var dollar = 36; // `$`.charCodeAt(0); + +exports.dollar = dollar; +var tilde = 126; // `~`.charCodeAt(0); + +exports.tilde = tilde; +var caret = 94; // `^`.charCodeAt(0); + +exports.caret = caret; +var plus = 43; // `+`.charCodeAt(0); + +exports.plus = plus; +var equals = 61; // `=`.charCodeAt(0); + +exports.equals = equals; +var pipe = 124; // `|`.charCodeAt(0); + +exports.pipe = pipe; +var greaterThan = 62; // `>`.charCodeAt(0); + +exports.greaterThan = greaterThan; +var space = 32; // ` `.charCodeAt(0); + +exports.space = space; +var singleQuote = 39; // `'`.charCodeAt(0); + +exports.singleQuote = singleQuote; +var doubleQuote = 34; // `"`.charCodeAt(0); + +exports.doubleQuote = doubleQuote; +var slash = 47; // `/`.charCodeAt(0); + +exports.slash = slash; +var bang = 33; // `!`.charCodeAt(0); + +exports.bang = bang; +var backslash = 92; // '\\'.charCodeAt(0); + +exports.backslash = backslash; +var cr = 13; // '\r'.charCodeAt(0); + +exports.cr = cr; +var feed = 12; // '\f'.charCodeAt(0); + +exports.feed = feed; +var newline = 10; // '\n'.charCodeAt(0); + +exports.newline = newline; +var tab = 9; // '\t'.charCodeAt(0); +// Expose aliases primarily for readability. + +exports.tab = tab; +var str = singleQuote; // No good single character representation! + +exports.str = str; +var comment = -1; +exports.comment = comment; +var word = -2; +exports.word = word; +var combinator = -3; +exports.combinator = combinator; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/tokenize.js b/node_modules/postcss-selector-parser/dist/tokenize.js new file mode 100644 index 0000000..bee9fee --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/tokenize.js @@ -0,0 +1,271 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = tokenize; +exports.FIELDS = void 0; + +var t = _interopRequireWildcard(require("./tokenTypes")); + +var _unescapable, _wordDelimiters; + +function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } + +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } + +var unescapable = (_unescapable = {}, _unescapable[t.tab] = true, _unescapable[t.newline] = true, _unescapable[t.cr] = true, _unescapable[t.feed] = true, _unescapable); +var wordDelimiters = (_wordDelimiters = {}, _wordDelimiters[t.space] = true, _wordDelimiters[t.tab] = true, _wordDelimiters[t.newline] = true, _wordDelimiters[t.cr] = true, _wordDelimiters[t.feed] = true, _wordDelimiters[t.ampersand] = true, _wordDelimiters[t.asterisk] = true, _wordDelimiters[t.bang] = true, _wordDelimiters[t.comma] = true, _wordDelimiters[t.colon] = true, _wordDelimiters[t.semicolon] = true, _wordDelimiters[t.openParenthesis] = true, _wordDelimiters[t.closeParenthesis] = true, _wordDelimiters[t.openSquare] = true, _wordDelimiters[t.closeSquare] = true, _wordDelimiters[t.singleQuote] = true, _wordDelimiters[t.doubleQuote] = true, _wordDelimiters[t.plus] = true, _wordDelimiters[t.pipe] = true, _wordDelimiters[t.tilde] = true, _wordDelimiters[t.greaterThan] = true, _wordDelimiters[t.equals] = true, _wordDelimiters[t.dollar] = true, _wordDelimiters[t.caret] = true, _wordDelimiters[t.slash] = true, _wordDelimiters); +var hex = {}; +var hexChars = "0123456789abcdefABCDEF"; + +for (var i = 0; i < hexChars.length; i++) { + hex[hexChars.charCodeAt(i)] = true; +} +/** + * Returns the last index of the bar css word + * @param {string} css The string in which the word begins + * @param {number} start The index into the string where word's first letter occurs + */ + + +function consumeWord(css, start) { + var next = start; + var code; + + do { + code = css.charCodeAt(next); + + if (wordDelimiters[code]) { + return next - 1; + } else if (code === t.backslash) { + next = consumeEscape(css, next) + 1; + } else { + // All other characters are part of the word + next++; + } + } while (next < css.length); + + return next - 1; +} +/** + * Returns the last index of the escape sequence + * @param {string} css The string in which the sequence begins + * @param {number} start The index into the string where escape character (`\`) occurs. + */ + + +function consumeEscape(css, start) { + var next = start; + var code = css.charCodeAt(next + 1); + + if (unescapable[code]) {// just consume the escape char + } else if (hex[code]) { + var hexDigits = 0; // consume up to 6 hex chars + + do { + next++; + hexDigits++; + code = css.charCodeAt(next + 1); + } while (hex[code] && hexDigits < 6); // if fewer than 6 hex chars, a trailing space ends the escape + + + if (hexDigits < 6 && code === t.space) { + next++; + } + } else { + // the next char is part of the current word + next++; + } + + return next; +} + +var FIELDS = { + TYPE: 0, + START_LINE: 1, + START_COL: 2, + END_LINE: 3, + END_COL: 4, + START_POS: 5, + END_POS: 6 +}; +exports.FIELDS = FIELDS; + +function tokenize(input) { + var tokens = []; + var css = input.css.valueOf(); + var _css = css, + length = _css.length; + var offset = -1; + var line = 1; + var start = 0; + var end = 0; + var code, content, endColumn, endLine, escaped, escapePos, last, lines, next, nextLine, nextOffset, quote, tokenType; + + function unclosed(what, fix) { + if (input.safe) { + // fyi: this is never set to true. + css += fix; + next = css.length - 1; + } else { + throw input.error('Unclosed ' + what, line, start - offset, start); + } + } + + while (start < length) { + code = css.charCodeAt(start); + + if (code === t.newline) { + offset = start; + line += 1; + } + + switch (code) { + case t.space: + case t.tab: + case t.newline: + case t.cr: + case t.feed: + next = start; + + do { + next += 1; + code = css.charCodeAt(next); + + if (code === t.newline) { + offset = next; + line += 1; + } + } while (code === t.space || code === t.newline || code === t.tab || code === t.cr || code === t.feed); + + tokenType = t.space; + endLine = line; + endColumn = next - offset - 1; + end = next; + break; + + case t.plus: + case t.greaterThan: + case t.tilde: + case t.pipe: + next = start; + + do { + next += 1; + code = css.charCodeAt(next); + } while (code === t.plus || code === t.greaterThan || code === t.tilde || code === t.pipe); + + tokenType = t.combinator; + endLine = line; + endColumn = start - offset; + end = next; + break; + // Consume these characters as single tokens. + + case t.asterisk: + case t.ampersand: + case t.bang: + case t.comma: + case t.equals: + case t.dollar: + case t.caret: + case t.openSquare: + case t.closeSquare: + case t.colon: + case t.semicolon: + case t.openParenthesis: + case t.closeParenthesis: + next = start; + tokenType = code; + endLine = line; + endColumn = start - offset; + end = next + 1; + break; + + case t.singleQuote: + case t.doubleQuote: + quote = code === t.singleQuote ? "'" : '"'; + next = start; + + do { + escaped = false; + next = css.indexOf(quote, next + 1); + + if (next === -1) { + unclosed('quote', quote); + } + + escapePos = next; + + while (css.charCodeAt(escapePos - 1) === t.backslash) { + escapePos -= 1; + escaped = !escaped; + } + } while (escaped); + + tokenType = t.str; + endLine = line; + endColumn = start - offset; + end = next + 1; + break; + + default: + if (code === t.slash && css.charCodeAt(start + 1) === t.asterisk) { + next = css.indexOf('*/', start + 2) + 1; + + if (next === 0) { + unclosed('comment', '*/'); + } + + content = css.slice(start, next + 1); + lines = content.split('\n'); + last = lines.length - 1; + + if (last > 0) { + nextLine = line + last; + nextOffset = next - lines[last].length; + } else { + nextLine = line; + nextOffset = offset; + } + + tokenType = t.comment; + line = nextLine; + endLine = nextLine; + endColumn = next - nextOffset; + } else if (code === t.slash) { + next = start; + tokenType = code; + endLine = line; + endColumn = start - offset; + end = next + 1; + } else { + next = consumeWord(css, start); + tokenType = t.word; + endLine = line; + endColumn = next - offset; + } + + end = next + 1; + break; + } // Ensure that the token structure remains consistent + + + tokens.push([tokenType, // [0] Token type + line, // [1] Starting line + start - offset, // [2] Starting column + endLine, // [3] Ending line + endColumn, // [4] Ending column + start, // [5] Start position / Source index + end // [6] End position + ]); // Reset offset for the next token + + if (nextOffset) { + offset = nextOffset; + nextOffset = null; + } + + start = end; + } + + return tokens; +} \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/util/ensureObject.js b/node_modules/postcss-selector-parser/dist/util/ensureObject.js new file mode 100644 index 0000000..3472e07 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/util/ensureObject.js @@ -0,0 +1,22 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = ensureObject; + +function ensureObject(obj) { + for (var _len = arguments.length, props = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + props[_key - 1] = arguments[_key]; + } + + while (props.length > 0) { + var prop = props.shift(); + + if (!obj[prop]) { + obj[prop] = {}; + } + + obj = obj[prop]; + } +} + +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/util/getProp.js b/node_modules/postcss-selector-parser/dist/util/getProp.js new file mode 100644 index 0000000..53e07c9 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/util/getProp.js @@ -0,0 +1,24 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = getProp; + +function getProp(obj) { + for (var _len = arguments.length, props = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + props[_key - 1] = arguments[_key]; + } + + while (props.length > 0) { + var prop = props.shift(); + + if (!obj[prop]) { + return undefined; + } + + obj = obj[prop]; + } + + return obj; +} + +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/util/index.js b/node_modules/postcss-selector-parser/dist/util/index.js new file mode 100644 index 0000000..043fda8 --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/util/index.js @@ -0,0 +1,22 @@ +"use strict"; + +exports.__esModule = true; +exports.stripComments = exports.ensureObject = exports.getProp = exports.unesc = void 0; + +var _unesc = _interopRequireDefault(require("./unesc")); + +exports.unesc = _unesc["default"]; + +var _getProp = _interopRequireDefault(require("./getProp")); + +exports.getProp = _getProp["default"]; + +var _ensureObject = _interopRequireDefault(require("./ensureObject")); + +exports.ensureObject = _ensureObject["default"]; + +var _stripComments = _interopRequireDefault(require("./stripComments")); + +exports.stripComments = _stripComments["default"]; + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/util/stripComments.js b/node_modules/postcss-selector-parser/dist/util/stripComments.js new file mode 100644 index 0000000..c74f1fe --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/util/stripComments.js @@ -0,0 +1,27 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = stripComments; + +function stripComments(str) { + var s = ""; + var commentStart = str.indexOf("/*"); + var lastEnd = 0; + + while (commentStart >= 0) { + s = s + str.slice(lastEnd, commentStart); + var commentEnd = str.indexOf("*/", commentStart + 2); + + if (commentEnd < 0) { + return s; + } + + lastEnd = commentEnd + 2; + commentStart = str.indexOf("/*", lastEnd); + } + + s = s + str.slice(lastEnd); + return s; +} + +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/dist/util/unesc.js b/node_modules/postcss-selector-parser/dist/util/unesc.js new file mode 100644 index 0000000..3136e7e --- /dev/null +++ b/node_modules/postcss-selector-parser/dist/util/unesc.js @@ -0,0 +1,93 @@ +"use strict"; + +exports.__esModule = true; +exports["default"] = unesc; + +// Many thanks for this post which made this migration much easier. +// https://mathiasbynens.be/notes/css-escapes + +/** + * + * @param {string} str + * @returns {[string, number]|undefined} + */ +function gobbleHex(str) { + var lower = str.toLowerCase(); + var hex = ''; + var spaceTerminated = false; + + for (var i = 0; i < 6 && lower[i] !== undefined; i++) { + var code = lower.charCodeAt(i); // check to see if we are dealing with a valid hex char [a-f|0-9] + + var valid = code >= 97 && code <= 102 || code >= 48 && code <= 57; // https://drafts.csswg.org/css-syntax/#consume-escaped-code-point + + spaceTerminated = code === 32; + + if (!valid) { + break; + } + + hex += lower[i]; + } + + if (hex.length === 0) { + return undefined; + } + + var codePoint = parseInt(hex, 16); + var isSurrogate = codePoint >= 0xD800 && codePoint <= 0xDFFF; // Add special case for + // "If this number is zero, or is for a surrogate, or is greater than the maximum allowed code point" + // https://drafts.csswg.org/css-syntax/#maximum-allowed-code-point + + if (isSurrogate || codePoint === 0x0000 || codePoint > 0x10FFFF) { + return ["\uFFFD", hex.length + (spaceTerminated ? 1 : 0)]; + } + + return [String.fromCodePoint(codePoint), hex.length + (spaceTerminated ? 1 : 0)]; +} + +var CONTAINS_ESCAPE = /\\/; + +function unesc(str) { + var needToProcess = CONTAINS_ESCAPE.test(str); + + if (!needToProcess) { + return str; + } + + var ret = ""; + + for (var i = 0; i < str.length; i++) { + if (str[i] === "\\") { + var gobbled = gobbleHex(str.slice(i + 1, i + 7)); + + if (gobbled !== undefined) { + ret += gobbled[0]; + i += gobbled[1]; + continue; + } // Retain a pair of \\ if double escaped `\\\\` + // https://github.com/postcss/postcss-selector-parser/commit/268c9a7656fb53f543dc620aa5b73a30ec3ff20e + + + if (str[i + 1] === "\\") { + ret += "\\"; + i++; + continue; + } // if \\ is at the end of the string retain it + // https://github.com/postcss/postcss-selector-parser/commit/01a6b346e3612ce1ab20219acc26abdc259ccefb + + + if (str.length === i + 1) { + ret += str[i]; + } + + continue; + } + + ret += str[i]; + } + + return ret; +} + +module.exports = exports.default; \ No newline at end of file diff --git a/node_modules/postcss-selector-parser/package.json b/node_modules/postcss-selector-parser/package.json new file mode 100644 index 0000000..a6f3358 --- /dev/null +++ b/node_modules/postcss-selector-parser/package.json @@ -0,0 +1,78 @@ +{ + "name": "postcss-selector-parser", + "version": "6.0.10", + "devDependencies": { + "@babel/cli": "^7.11.6", + "@babel/core": "^7.11.6", + "@babel/eslint-parser": "^7.11.5", + "@babel/eslint-plugin": "^7.11.5", + "@babel/plugin-proposal-class-properties": "^7.10.4", + "@babel/preset-env": "^7.11.5", + "@babel/register": "^7.11.5", + "ava": "^3.12.1", + "babel-plugin-add-module-exports": "^1.0.4", + "coveralls": "^3.1.0", + "del-cli": "^3.0.1", + "eslint": "^7.9.0", + "eslint-plugin-import": "^2.22.0", + "glob": "^7.1.6", + "minimist": "^1.2.5", + "nyc": "^15.1.0", + "postcss": "^8.0.0", + "semver": "^7.3.2", + "typescript": "^4.0.3" + }, + "main": "dist/index.js", + "types": "postcss-selector-parser.d.ts", + "files": [ + "API.md", + "CHANGELOG.md", + "LICENSE-MIT", + "dist", + "postcss-selector-parser.d.ts", + "!**/__tests__" + ], + "scripts": { + "pretest": "eslint src && tsc --noEmit postcss-selector-parser.d.ts", + "prepare": "del-cli dist && BABEL_ENV=publish babel src --out-dir dist --ignore /__tests__/", + "lintfix": "eslint --fix src", + "report": "nyc report --reporter=html", + "test": "nyc ava src/__tests__/*.js ", + "testone": "ava" + }, + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "license": "MIT", + "engines": { + "node": ">=4" + }, + "homepage": "https://github.com/postcss/postcss-selector-parser", + "contributors": [ + { + "name": "Ben Briggs", + "email": "beneb.info@gmail.com", + "url": "http://beneb.info" + }, + { + "name": "Chris Eppstein", + "email": "chris@eppsteins.net", + "url": "http://twitter.com/chriseppstein" + } + ], + "repository": "postcss/postcss-selector-parser", + "ava": { + "require": [ + "@babel/register" + ], + "concurrency": 5, + "timeout": "25s" + }, + "nyc": { + "exclude": [ + "node_modules", + "**/__tests__" + ] + } +} diff --git a/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts b/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts new file mode 100644 index 0000000..89a2c52 --- /dev/null +++ b/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts @@ -0,0 +1,555 @@ +// Type definitions for postcss-selector-parser 2.2.3 +// Definitions by: Chris Eppstein + +/*~ Note that ES6 modules cannot directly export callable functions. + *~ This file should be imported using the CommonJS-style: + *~ import x = require('someLibrary'); + *~ + *~ Refer to the documentation to understand common + *~ workarounds for this limitation of ES6 modules. + */ + +/*~ This declaration specifies that the function + *~ is the exported object from the file + */ +export = parser; + +// A type that's T but not U. +type Diff = T extends U ? never : T; + +// TODO: Conditional types in TS 1.8 will really clean this up. +declare function parser(): parser.Processor; +declare function parser(processor: parser.AsyncProcessor): parser.Processor; +declare function parser(processor: parser.AsyncProcessor): parser.Processor; +declare function parser(processor: parser.SyncProcessor): parser.Processor; +declare function parser(processor: parser.SyncProcessor): parser.Processor; +declare function parser(processor?: parser.SyncProcessor | parser.AsyncProcessor): parser.Processor; + +/*~ If you want to expose types from your module as well, you can + *~ place them in this block. Often you will want to describe the + *~ shape of the return type of the function; that type should + *~ be declared in here, as this example shows. + */ +declare namespace parser { + /* copied from postcss -- so we don't need to add a dependency */ + type ErrorOptions = { + plugin?: string; + word?: string; + index?: number + }; + /* the bits we use of postcss.Rule, copied from postcss -- so we don't need to add a dependency */ + type PostCSSRuleNode = { + selector: string + /** + * @returns postcss.CssSyntaxError but it's a complex object, caller + * should cast to it if they have a dependency on postcss. + */ + error(message: string, options?: ErrorOptions): Error; + }; + /** Accepts a string */ + type Selectors = string | PostCSSRuleNode + type ProcessorFn = (root: parser.Root) => ReturnType; + type SyncProcessor = ProcessorFn; + type AsyncProcessor = ProcessorFn>; + + const TAG: "tag"; + const STRING: "string"; + const SELECTOR: "selector"; + const ROOT: "root"; + const PSEUDO: "pseudo"; + const NESTING: "nesting"; + const ID: "id"; + const COMMENT: "comment"; + const COMBINATOR: "combinator"; + const CLASS: "class"; + const ATTRIBUTE: "attribute"; + const UNIVERSAL: "universal"; + + interface NodeTypes { + tag: Tag, + string: String, + selector: Selector, + root: Root, + pseudo: Pseudo, + nesting: Nesting, + id: Identifier, + comment: Comment, + combinator: Combinator, + class: ClassName, + attribute: Attribute, + universal: Universal + } + + type Node = NodeTypes[keyof NodeTypes]; + + function isNode(node: any): node is Node; + + interface Options { + /** + * Preserve whitespace when true. Default: false; + */ + lossless: boolean; + /** + * When true and a postcss.Rule is passed, set the result of + * processing back onto the rule when done. Default: false. + */ + updateSelector: boolean; + } + class Processor< + TransformType = never, + SyncSelectorsType extends Selectors | never = Selectors + > { + res: Root; + readonly result: String; + ast(selectors: Selectors, options?: Partial): Promise; + astSync(selectors: SyncSelectorsType, options?: Partial): Root; + transform(selectors: Selectors, options?: Partial): Promise; + transformSync(selectors: SyncSelectorsType, options?: Partial): TransformType; + process(selectors: Selectors, options?: Partial): Promise; + processSync(selectors: SyncSelectorsType, options?: Partial): string; + } + interface ParserOptions { + css: string; + error: (message: string, options: ErrorOptions) => Error; + options: Options; + } + class Parser { + input: ParserOptions; + lossy: boolean; + position: number; + root: Root; + selectors: string; + current: Selector; + constructor(input: ParserOptions); + /** + * Raises an error, if the processor is invoked on + * a postcss Rule node, a better error message is raised. + */ + error(message: string, options?: ErrorOptions): void; + } + interface NodeSource { + start?: { + line: number, + column: number + }, + end?: { + line: number, + column: number + } + } + interface SpaceAround { + before: string; + after: string; + } + interface Spaces extends SpaceAround { + [spaceType: string]: string | Partial | undefined; + } + interface NodeOptions { + value: Value; + spaces?: Partial; + source?: NodeSource; + sourceIndex?: number; + } + interface Base< + Value extends string | undefined = string, + ParentType extends Container | undefined = Container | undefined + > { + type: keyof NodeTypes; + parent: ParentType; + value: Value; + spaces: Spaces; + source?: NodeSource; + sourceIndex: number; + rawSpaceBefore: string; + rawSpaceAfter: string; + remove(): Node; + replaceWith(...nodes: Node[]): Node; + next(): Node; + prev(): Node; + clone(opts: {[override: string]:any}): Node; + /** + * Return whether this node includes the character at the position of the given line and column. + * Returns undefined if the nodes lack sufficient source metadata to determine the position. + * @param line 1-index based line number relative to the start of the selector. + * @param column 1-index based column number relative to the start of the selector. + */ + isAtPosition(line: number, column: number): boolean | undefined; + /** + * Some non-standard syntax doesn't follow normal escaping rules for css, + * this allows the escaped value to be specified directly, allowing illegal characters to be + * directly inserted into css output. + * @param name the property to set + * @param value the unescaped value of the property + * @param valueEscaped optional. the escaped value of the property. + */ + setPropertyAndEscape(name: string, value: any, valueEscaped: string): void; + /** + * When you want a value to passed through to CSS directly. This method + * deletes the corresponding raw value causing the stringifier to fallback + * to the unescaped value. + * @param name the property to set. + * @param value The value that is both escaped and unescaped. + */ + setPropertyWithoutEscape(name: string, value: any): void; + /** + * Some non-standard syntax doesn't follow normal escaping rules for css. + * This allows non standard syntax to be appended to an existing property + * by specifying the escaped value. By specifying the escaped value, + * illegal characters are allowed to be directly inserted into css output. + * @param {string} name the property to set + * @param {any} value the unescaped value of the property + * @param {string} valueEscaped optional. the escaped value of the property. + */ + appendToPropertyAndEscape(name: string, value: any, valueEscaped: string): void; + toString(): string; + } + interface ContainerOptions extends NodeOptions { + nodes?: Array; + } + interface Container< + Value extends string | undefined = string, + Child extends Node = Node + > extends Base { + nodes: Array; + append(selector: Selector): this; + prepend(selector: Selector): this; + at(index: number): Child; + /** + * Return the most specific node at the line and column number given. + * The source location is based on the original parsed location, locations aren't + * updated as selector nodes are mutated. + * + * Note that this location is relative to the location of the first character + * of the selector, and not the location of the selector in the overall document + * when used in conjunction with postcss. + * + * If not found, returns undefined. + * @param line The line number of the node to find. (1-based index) + * @param col The column number of the node to find. (1-based index) + */ + atPosition(line: number, column: number): Child; + index(child: Child): number; + readonly first: Child; + readonly last: Child; + readonly length: number; + removeChild(child: Child): this; + removeAll(): Container; + empty(): Container; + insertAfter(oldNode: Child, newNode: Child): this; + insertBefore(oldNode: Child, newNode: Child): this; + each(callback: (node: Child) => boolean | void): boolean | undefined; + walk( + callback: (node: Node) => boolean | void + ): boolean | undefined; + walkAttributes( + callback: (node: Attribute) => boolean | void + ): boolean | undefined; + walkClasses( + callback: (node: ClassName) => boolean | void + ): boolean | undefined; + walkCombinators( + callback: (node: Combinator) => boolean | void + ): boolean | undefined; + walkComments( + callback: (node: Comment) => boolean | void + ): boolean | undefined; + walkIds( + callback: (node: Identifier) => boolean | void + ): boolean | undefined; + walkNesting( + callback: (node: Nesting) => boolean | void + ): boolean | undefined; + walkPseudos( + callback: (node: Pseudo) => boolean | void + ): boolean | undefined; + walkTags(callback: (node: Tag) => boolean | void): boolean | undefined; + split(callback: (node: Child) => boolean): [Child[], Child[]]; + map(callback: (node: Child) => T): T[]; + reduce( + callback: ( + previousValue: Child, + currentValue: Child, + currentIndex: number, + array: readonly Child[] + ) => Child + ): Child; + reduce( + callback: ( + previousValue: Child, + currentValue: Child, + currentIndex: number, + array: readonly Child[] + ) => Child, + initialValue: Child + ): Child; + reduce( + callback: ( + previousValue: T, + currentValue: Child, + currentIndex: number, + array: readonly Child[] + ) => T, + initialValue: T + ): T; + every(callback: (node: Child) => boolean): boolean; + some(callback: (node: Child) => boolean): boolean; + filter(callback: (node: Child) => boolean): Child[]; + sort(callback: (nodeA: Child, nodeB: Child) => number): Child[]; + toString(): string; + } + function isContainer(node: any): node is Root | Selector | Pseudo; + + interface NamespaceOptions extends NodeOptions { + namespace?: string | true; + } + interface Namespace extends Base { + /** alias for namespace */ + ns: string | true; + /** + * namespace prefix. + */ + namespace: string | true; + /** + * If a namespace exists, prefix the value provided with it, separated by |. + */ + qualifiedName(value: string): string; + /** + * A string representing the namespace suitable for output. + */ + readonly namespaceString: string; + } + function isNamespace(node: any): node is Attribute | Tag; + + interface Root extends Container { + type: "root"; + /** + * Raises an error, if the processor is invoked on + * a postcss Rule node, a better error message is raised. + */ + error(message: string, options?: ErrorOptions): Error; + nodeAt(line: number, column: number): Node + } + function root(opts: ContainerOptions): Root; + function isRoot(node: any): node is Root; + + interface _Selector extends Container> { + type: "selector"; + } + type Selector = _Selector; + function selector(opts: ContainerOptions): Selector; + function isSelector(node: any): node is Selector; + + interface CombinatorRaws { + value?: string; + spaces?: { + before?: string; + after?: string; + }; + } + interface Combinator extends Base { + type: "combinator"; + raws?: CombinatorRaws; + } + function combinator(opts: NodeOptions): Combinator; + function isCombinator(node: any): node is Combinator; + + interface ClassName extends Base { + type: "class"; + } + function className(opts: NamespaceOptions): ClassName; + function isClassName(node: any): node is ClassName; + + type AttributeOperator = "=" | "~=" | "|=" | "^=" | "$=" | "*="; + type QuoteMark = '"' | "'" | null; + interface PreferredQuoteMarkOptions { + quoteMark?: QuoteMark; + preferCurrentQuoteMark?: boolean; + } + interface SmartQuoteMarkOptions extends PreferredQuoteMarkOptions { + smart?: boolean; + } + interface AttributeOptions extends NamespaceOptions { + attribute: string; + operator?: AttributeOperator; + insensitive?: boolean; + quoteMark?: QuoteMark; + /** @deprecated Use quoteMark instead. */ + quoted?: boolean; + spaces?: { + before?: string; + after?: string; + attribute?: Partial; + operator?: Partial; + value?: Partial; + insensitive?: Partial; + } + raws: { + unquoted?: string; + attribute?: string; + operator?: string; + value?: string; + insensitive?: string; + spaces?: { + attribute?: Partial; + operator?: Partial; + value?: Partial; + insensitive?: Partial; + } + }; + } + interface Attribute extends Namespace { + type: "attribute"; + attribute: string; + operator?: AttributeOperator; + insensitive?: boolean; + quoteMark: QuoteMark; + quoted?: boolean; + spaces: { + before: string; + after: string; + attribute?: Partial; + operator?: Partial; + value?: Partial; + insensitive?: Partial; + } + raws: { + /** @deprecated The attribute value is unquoted, use that instead.. */ + unquoted?: string; + attribute?: string; + operator?: string; + /** The value of the attribute with quotes and escapes. */ + value?: string; + insensitive?: string; + spaces?: { + attribute?: Partial; + operator?: Partial; + value?: Partial; + insensitive?: Partial; + } + }; + /** + * The attribute name after having been qualified with a namespace. + */ + readonly qualifiedAttribute: string; + + /** + * The case insensitivity flag or an empty string depending on whether this + * attribute is case insensitive. + */ + readonly insensitiveFlag : 'i' | ''; + + /** + * Returns the attribute's value quoted such that it would be legal to use + * in the value of a css file. The original value's quotation setting + * used for stringification is left unchanged. See `setValue(value, options)` + * if you want to control the quote settings of a new value for the attribute or + * `set quoteMark(mark)` if you want to change the quote settings of the current + * value. + * + * You can also change the quotation used for the current value by setting quoteMark. + **/ + getQuotedValue(options?: SmartQuoteMarkOptions): string; + + /** + * Set the unescaped value with the specified quotation options. The value + * provided must not include any wrapping quote marks -- those quotes will + * be interpreted as part of the value and escaped accordingly. + * @param value + */ + setValue(value: string, options?: SmartQuoteMarkOptions): void; + + /** + * Intelligently select a quoteMark value based on the value's contents. If + * the value is a legal CSS ident, it will not be quoted. Otherwise a quote + * mark will be picked that minimizes the number of escapes. + * + * If there's no clear winner, the quote mark from these options is used, + * then the source quote mark (this is inverted if `preferCurrentQuoteMark` is + * true). If the quoteMark is unspecified, a double quote is used. + **/ + smartQuoteMark(options: PreferredQuoteMarkOptions): QuoteMark; + + /** + * Selects the preferred quote mark based on the options and the current quote mark value. + * If you want the quote mark to depend on the attribute value, call `smartQuoteMark(opts)` + * instead. + */ + preferredQuoteMark(options: PreferredQuoteMarkOptions): QuoteMark + + /** + * returns the offset of the attribute part specified relative to the + * start of the node of the output string. + * + * * "ns" - alias for "namespace" + * * "namespace" - the namespace if it exists. + * * "attribute" - the attribute name + * * "attributeNS" - the start of the attribute or its namespace + * * "operator" - the match operator of the attribute + * * "value" - The value (string or identifier) + * * "insensitive" - the case insensitivity flag; + * @param part One of the possible values inside an attribute. + * @returns -1 if the name is invalid or the value doesn't exist in this attribute. + */ + offsetOf(part: "ns" | "namespace" | "attribute" | "attributeNS" | "operator" | "value" | "insensitive"): number; + } + function attribute(opts: AttributeOptions): Attribute; + function isAttribute(node: any): node is Attribute; + + interface Pseudo extends Container { + type: "pseudo"; + } + function pseudo(opts: ContainerOptions): Pseudo; + /** + * Checks wether the node is the Psuedo subtype of node. + */ + function isPseudo(node: any): node is Pseudo; + + /** + * Checks wether the node is, specifically, a pseudo element instead of + * pseudo class. + */ + function isPseudoElement(node: any): node is Pseudo; + + /** + * Checks wether the node is, specifically, a pseudo class instead of + * pseudo element. + */ + function isPseudoClass(node: any): node is Pseudo; + + + interface Tag extends Namespace { + type: "tag"; + } + function tag(opts: NamespaceOptions): Tag; + function isTag(node: any): node is Tag; + + interface Comment extends Base { + type: "comment"; + } + function comment(opts: NodeOptions): Comment; + function isComment(node: any): node is Comment; + + interface Identifier extends Base { + type: "id"; + } + function id(opts: any): any; + function isIdentifier(node: any): node is Identifier; + + interface Nesting extends Base { + type: "nesting"; + } + function nesting(opts: any): any; + function isNesting(node: any): node is Nesting; + + interface String extends Base { + type: "string"; + } + function string(opts: NodeOptions): String; + function isString(node: any): node is String; + + interface Universal extends Base { + type: "universal"; + } + function universal(opts?: NamespaceOptions): any; + function isUniversal(node: any): node is Universal; +} diff --git a/node_modules/postcss-value-parser/LICENSE b/node_modules/postcss-value-parser/LICENSE new file mode 100644 index 0000000..6dcaefc --- /dev/null +++ b/node_modules/postcss-value-parser/LICENSE @@ -0,0 +1,22 @@ +Copyright (c) Bogdan Chadkin + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss-value-parser/README.md b/node_modules/postcss-value-parser/README.md new file mode 100644 index 0000000..3bd6a0d --- /dev/null +++ b/node_modules/postcss-value-parser/README.md @@ -0,0 +1,263 @@ +# postcss-value-parser + +[![Travis CI](https://travis-ci.org/TrySound/postcss-value-parser.svg)](https://travis-ci.org/TrySound/postcss-value-parser) + +Transforms CSS declaration values and at-rule parameters into a tree of nodes, and provides a simple traversal API. + +## Usage + +```js +var valueParser = require('postcss-value-parser'); +var cssBackgroundValue = 'url(foo.png) no-repeat 40px 73%'; +var parsedValue = valueParser(cssBackgroundValue); +// parsedValue exposes an API described below, +// e.g. parsedValue.walk(..), parsedValue.toString(), etc. +``` + +For example, parsing the value `rgba(233, 45, 66, .5)` will return the following: + +```js +{ + nodes: [ + { + type: 'function', + value: 'rgba', + before: '', + after: '', + nodes: [ + { type: 'word', value: '233' }, + { type: 'div', value: ',', before: '', after: ' ' }, + { type: 'word', value: '45' }, + { type: 'div', value: ',', before: '', after: ' ' }, + { type: 'word', value: '66' }, + { type: 'div', value: ',', before: ' ', after: '' }, + { type: 'word', value: '.5' } + ] + } + ] +} +``` + +If you wanted to convert each `rgba()` value in `sourceCSS` to a hex value, you could do so like this: + +```js +var valueParser = require('postcss-value-parser'); + +var parsed = valueParser(sourceCSS); + +// walk() will visit all the of the nodes in the tree, +// invoking the callback for each. +parsed.walk(function (node) { + + // Since we only want to transform rgba() values, + // we can ignore anything else. + if (node.type !== 'function' && node.value !== 'rgba') return; + + // We can make an array of the rgba() arguments to feed to a + // convertToHex() function + var color = node.nodes.filter(function (node) { + return node.type === 'word'; + }).map(function (node) { + return Number(node.value); + }); // [233, 45, 66, .5] + + // Now we will transform the existing rgba() function node + // into a word node with the hex value + node.type = 'word'; + node.value = convertToHex(color); +}) + +parsed.toString(); // #E92D42 +``` + +## Nodes + +Each node is an object with these common properties: + +- **type**: The type of node (`word`, `string`, `div`, `space`, `comment`, or `function`). + Each type is documented below. +- **value**: Each node has a `value` property; but what exactly `value` means + is specific to the node type. Details are documented for each type below. +- **sourceIndex**: The starting index of the node within the original source + string. For example, given the source string `10px 20px`, the `word` node + whose value is `20px` will have a `sourceIndex` of `5`. + +### word + +The catch-all node type that includes keywords (e.g. `no-repeat`), +quantities (e.g. `20px`, `75%`, `1.5`), and hex colors (e.g. `#e6e6e6`). + +Node-specific properties: + +- **value**: The "word" itself. + +### string + +A quoted string value, e.g. `"something"` in `content: "something";`. + +Node-specific properties: + +- **value**: The text content of the string. +- **quote**: The quotation mark surrounding the string, either `"` or `'`. +- **unclosed**: `true` if the string was not closed properly. e.g. `"unclosed string `. + +### div + +A divider, for example + +- `,` in `animation-duration: 1s, 2s, 3s` +- `/` in `border-radius: 10px / 23px` +- `:` in `(min-width: 700px)` + +Node-specific properties: + +- **value**: The divider character. Either `,`, `/`, or `:` (see examples above). +- **before**: Whitespace before the divider. +- **after**: Whitespace after the divider. + +### space + +Whitespace used as a separator, e.g. ` ` occurring twice in `border: 1px solid black;`. + +Node-specific properties: + +- **value**: The whitespace itself. + +### comment + +A CSS comment starts with `/*` and ends with `*/` + +Node-specific properties: + +- **value**: The comment value without `/*` and `*/` +- **unclosed**: `true` if the comment was not closed properly. e.g. `/* comment without an end `. + +### function + +A CSS function, e.g. `rgb(0,0,0)` or `url(foo.bar)`. + +Function nodes have nodes nested within them: the function arguments. + +Additional properties: + +- **value**: The name of the function, e.g. `rgb` in `rgb(0,0,0)`. +- **before**: Whitespace after the opening parenthesis and before the first argument, + e.g. ` ` in `rgb( 0,0,0)`. +- **after**: Whitespace before the closing parenthesis and after the last argument, + e.g. ` ` in `rgb(0,0,0 )`. +- **nodes**: More nodes representing the arguments to the function. +- **unclosed**: `true` if the parentheses was not closed properly. e.g. `( unclosed-function `. + +Media features surrounded by parentheses are considered functions with an +empty value. For example, `(min-width: 700px)` parses to these nodes: + +```js +[ + { + type: 'function', value: '', before: '', after: '', + nodes: [ + { type: 'word', value: 'min-width' }, + { type: 'div', value: ':', before: '', after: ' ' }, + { type: 'word', value: '700px' } + ] + } +] +``` + +`url()` functions can be parsed a little bit differently depending on +whether the first character in the argument is a quotation mark. + +`url( /gfx/img/bg.jpg )` parses to: + +```js +{ type: 'function', sourceIndex: 0, value: 'url', before: ' ', after: ' ', nodes: [ + { type: 'word', sourceIndex: 5, value: '/gfx/img/bg.jpg' } +] } +``` + +`url( "/gfx/img/bg.jpg" )`, on the other hand, parses to: + +```js +{ type: 'function', sourceIndex: 0, value: 'url', before: ' ', after: ' ', nodes: [ + type: 'string', sourceIndex: 5, quote: '"', value: '/gfx/img/bg.jpg' }, +] } +``` + +### unicode-range + +The unicode-range CSS descriptor sets the specific range of characters to be +used from a font defined by @font-face and made available +for use on the current page (`unicode-range: U+0025-00FF`). + +Node-specific properties: + +- **value**: The "unicode-range" itself. + +## API + +``` +var valueParser = require('postcss-value-parser'); +``` + +### valueParser.unit(quantity) + +Parses `quantity`, distinguishing the number from the unit. Returns an object like the following: + +```js +// Given 2rem +{ + number: '2', + unit: 'rem' +} +``` + +If the `quantity` argument cannot be parsed as a number, returns `false`. + +*This function does not parse complete values*: you cannot pass it `1px solid black` and expect `px` as +the unit. Instead, you should pass it single quantities only. Parse `1px solid black`, then pass it +the stringified `1px` node (a `word` node) to parse the number and unit. + +### valueParser.stringify(nodes[, custom]) + +Stringifies a node or array of nodes. + +The `custom` function is called for each `node`; return a string to override the default behaviour. + +### valueParser.walk(nodes, callback[, bubble]) + +Walks each provided node, recursively walking all descendent nodes within functions. + +Returning `false` in the `callback` will prevent traversal of descendent nodes (within functions). +You can use this feature to for shallow iteration, walking over only the *immediate* children. +*Note: This only applies if `bubble` is `false` (which is the default).* + +By default, the tree is walked from the outermost node inwards. +To reverse the direction, pass `true` for the `bubble` argument. + +The `callback` is invoked with three arguments: `callback(node, index, nodes)`. + +- `node`: The current node. +- `index`: The index of the current node. +- `nodes`: The complete nodes array passed to `walk()`. + +Returns the `valueParser` instance. + +### var parsed = valueParser(value) + +Returns the parsed node tree. + +### parsed.nodes + +The array of nodes. + +### parsed.toString() + +Stringifies the node tree. + +### parsed.walk(callback[, bubble]) + +Walks each node inside `parsed.nodes`. See the documentation for `valueParser.walk()` above. + +# License + +MIT © [Bogdan Chadkin](mailto:trysound@yandex.ru) diff --git a/node_modules/postcss-value-parser/lib/index.d.ts b/node_modules/postcss-value-parser/lib/index.d.ts new file mode 100644 index 0000000..8759f3f --- /dev/null +++ b/node_modules/postcss-value-parser/lib/index.d.ts @@ -0,0 +1,177 @@ +declare namespace postcssValueParser { + interface BaseNode { + /** + * The offset, inclusive, inside the CSS value at which the node starts. + */ + sourceIndex: number; + + /** + * The offset, exclusive, inside the CSS value at which the node ends. + */ + sourceEndIndex: number; + + /** + * The node's characteristic value + */ + value: string; + } + + interface ClosableNode { + /** + * Whether the parsed CSS value ended before the node was properly closed + */ + unclosed?: true; + } + + interface AdjacentAwareNode { + /** + * The token at the start of the node + */ + before: string; + + /** + * The token at the end of the node + */ + after: string; + } + + interface CommentNode extends BaseNode, ClosableNode { + type: "comment"; + } + + interface DivNode extends BaseNode, AdjacentAwareNode { + type: "div"; + } + + interface FunctionNode extends BaseNode, ClosableNode, AdjacentAwareNode { + type: "function"; + + /** + * Nodes inside the function + */ + nodes: Node[]; + } + + interface SpaceNode extends BaseNode { + type: "space"; + } + + interface StringNode extends BaseNode, ClosableNode { + type: "string"; + + /** + * The quote type delimiting the string + */ + quote: '"' | "'"; + } + + interface UnicodeRangeNode extends BaseNode { + type: "unicode-range"; + } + + interface WordNode extends BaseNode { + type: "word"; + } + + /** + * Any node parsed from a CSS value + */ + type Node = + | CommentNode + | DivNode + | FunctionNode + | SpaceNode + | StringNode + | UnicodeRangeNode + | WordNode; + + interface CustomStringifierCallback { + /** + * @param node The node to stringify + * @returns The serialized CSS representation of the node + */ + (nodes: Node): string | undefined; + } + + interface WalkCallback { + /** + * @param node The currently visited node + * @param index The index of the node in the series of parsed nodes + * @param nodes The series of parsed nodes + * @returns Returning `false` will prevent traversal of descendant nodes (only applies if `bubble` was set to `true` in the `walk()` call) + */ + (node: Node, index: number, nodes: Node[]): void | boolean; + } + + /** + * A CSS dimension, decomposed into its numeric and unit parts + */ + interface Dimension { + number: string; + unit: string; + } + + /** + * A wrapper around a parsed CSS value that allows for inspecting and walking nodes + */ + interface ParsedValue { + /** + * The series of parsed nodes + */ + nodes: Node[]; + + /** + * Walk all parsed nodes, applying a callback + * + * @param callback A visitor callback that will be executed for each node + * @param bubble When set to `true`, walking will be done inside-out instead of outside-in + */ + walk(callback: WalkCallback, bubble?: boolean): this; + } + + interface ValueParser { + /** + * Decompose a CSS dimension into its numeric and unit part + * + * @param value The dimension to decompose + * @returns An object representing `number` and `unit` part of the dimension or `false` if the decomposing fails + */ + unit(value: string): Dimension | false; + + /** + * Serialize a series of nodes into a CSS value + * + * @param nodes The nodes to stringify + * @param custom A custom stringifier callback + * @returns The generated CSS value + */ + stringify(nodes: Node | Node[], custom?: CustomStringifierCallback): string; + + /** + * Walk a series of nodes, applying a callback + * + * @param nodes The nodes to walk + * @param callback A visitor callback that will be executed for each node + * @param bubble When set to `true`, walking will be done inside-out instead of outside-in + */ + walk(nodes: Node[], callback: WalkCallback, bubble?: boolean): void; + + /** + * Parse a CSS value into a series of nodes to operate on + * + * @param value The value to parse + */ + new (value: string): ParsedValue; + + /** + * Parse a CSS value into a series of nodes to operate on + * + * @param value The value to parse + */ + (value: string): ParsedValue; + } +} + +declare const postcssValueParser: postcssValueParser.ValueParser; + +export = postcssValueParser; diff --git a/node_modules/postcss-value-parser/lib/index.js b/node_modules/postcss-value-parser/lib/index.js new file mode 100644 index 0000000..f9ac0e6 --- /dev/null +++ b/node_modules/postcss-value-parser/lib/index.js @@ -0,0 +1,28 @@ +var parse = require("./parse"); +var walk = require("./walk"); +var stringify = require("./stringify"); + +function ValueParser(value) { + if (this instanceof ValueParser) { + this.nodes = parse(value); + return this; + } + return new ValueParser(value); +} + +ValueParser.prototype.toString = function() { + return Array.isArray(this.nodes) ? stringify(this.nodes) : ""; +}; + +ValueParser.prototype.walk = function(cb, bubble) { + walk(this.nodes, cb, bubble); + return this; +}; + +ValueParser.unit = require("./unit"); + +ValueParser.walk = walk; + +ValueParser.stringify = stringify; + +module.exports = ValueParser; diff --git a/node_modules/postcss-value-parser/lib/parse.js b/node_modules/postcss-value-parser/lib/parse.js new file mode 100644 index 0000000..950631c --- /dev/null +++ b/node_modules/postcss-value-parser/lib/parse.js @@ -0,0 +1,321 @@ +var openParentheses = "(".charCodeAt(0); +var closeParentheses = ")".charCodeAt(0); +var singleQuote = "'".charCodeAt(0); +var doubleQuote = '"'.charCodeAt(0); +var backslash = "\\".charCodeAt(0); +var slash = "/".charCodeAt(0); +var comma = ",".charCodeAt(0); +var colon = ":".charCodeAt(0); +var star = "*".charCodeAt(0); +var uLower = "u".charCodeAt(0); +var uUpper = "U".charCodeAt(0); +var plus = "+".charCodeAt(0); +var isUnicodeRange = /^[a-f0-9?-]+$/i; + +module.exports = function(input) { + var tokens = []; + var value = input; + + var next, + quote, + prev, + token, + escape, + escapePos, + whitespacePos, + parenthesesOpenPos; + var pos = 0; + var code = value.charCodeAt(pos); + var max = value.length; + var stack = [{ nodes: tokens }]; + var balanced = 0; + var parent; + + var name = ""; + var before = ""; + var after = ""; + + while (pos < max) { + // Whitespaces + if (code <= 32) { + next = pos; + do { + next += 1; + code = value.charCodeAt(next); + } while (code <= 32); + token = value.slice(pos, next); + + prev = tokens[tokens.length - 1]; + if (code === closeParentheses && balanced) { + after = token; + } else if (prev && prev.type === "div") { + prev.after = token; + prev.sourceEndIndex += token.length; + } else if ( + code === comma || + code === colon || + (code === slash && + value.charCodeAt(next + 1) !== star && + (!parent || + (parent && parent.type === "function" && parent.value !== "calc"))) + ) { + before = token; + } else { + tokens.push({ + type: "space", + sourceIndex: pos, + sourceEndIndex: next, + value: token + }); + } + + pos = next; + + // Quotes + } else if (code === singleQuote || code === doubleQuote) { + next = pos; + quote = code === singleQuote ? "'" : '"'; + token = { + type: "string", + sourceIndex: pos, + quote: quote + }; + do { + escape = false; + next = value.indexOf(quote, next + 1); + if (~next) { + escapePos = next; + while (value.charCodeAt(escapePos - 1) === backslash) { + escapePos -= 1; + escape = !escape; + } + } else { + value += quote; + next = value.length - 1; + token.unclosed = true; + } + } while (escape); + token.value = value.slice(pos + 1, next); + token.sourceEndIndex = token.unclosed ? next : next + 1; + tokens.push(token); + pos = next + 1; + code = value.charCodeAt(pos); + + // Comments + } else if (code === slash && value.charCodeAt(pos + 1) === star) { + next = value.indexOf("*/", pos); + + token = { + type: "comment", + sourceIndex: pos, + sourceEndIndex: next + 2 + }; + + if (next === -1) { + token.unclosed = true; + next = value.length; + token.sourceEndIndex = next; + } + + token.value = value.slice(pos + 2, next); + tokens.push(token); + + pos = next + 2; + code = value.charCodeAt(pos); + + // Operation within calc + } else if ( + (code === slash || code === star) && + parent && + parent.type === "function" && + parent.value === "calc" + ) { + token = value[pos]; + tokens.push({ + type: "word", + sourceIndex: pos - before.length, + sourceEndIndex: pos + token.length, + value: token + }); + pos += 1; + code = value.charCodeAt(pos); + + // Dividers + } else if (code === slash || code === comma || code === colon) { + token = value[pos]; + + tokens.push({ + type: "div", + sourceIndex: pos - before.length, + sourceEndIndex: pos + token.length, + value: token, + before: before, + after: "" + }); + before = ""; + + pos += 1; + code = value.charCodeAt(pos); + + // Open parentheses + } else if (openParentheses === code) { + // Whitespaces after open parentheses + next = pos; + do { + next += 1; + code = value.charCodeAt(next); + } while (code <= 32); + parenthesesOpenPos = pos; + token = { + type: "function", + sourceIndex: pos - name.length, + value: name, + before: value.slice(parenthesesOpenPos + 1, next) + }; + pos = next; + + if (name === "url" && code !== singleQuote && code !== doubleQuote) { + next -= 1; + do { + escape = false; + next = value.indexOf(")", next + 1); + if (~next) { + escapePos = next; + while (value.charCodeAt(escapePos - 1) === backslash) { + escapePos -= 1; + escape = !escape; + } + } else { + value += ")"; + next = value.length - 1; + token.unclosed = true; + } + } while (escape); + // Whitespaces before closed + whitespacePos = next; + do { + whitespacePos -= 1; + code = value.charCodeAt(whitespacePos); + } while (code <= 32); + if (parenthesesOpenPos < whitespacePos) { + if (pos !== whitespacePos + 1) { + token.nodes = [ + { + type: "word", + sourceIndex: pos, + sourceEndIndex: whitespacePos + 1, + value: value.slice(pos, whitespacePos + 1) + } + ]; + } else { + token.nodes = []; + } + if (token.unclosed && whitespacePos + 1 !== next) { + token.after = ""; + token.nodes.push({ + type: "space", + sourceIndex: whitespacePos + 1, + sourceEndIndex: next, + value: value.slice(whitespacePos + 1, next) + }); + } else { + token.after = value.slice(whitespacePos + 1, next); + token.sourceEndIndex = next; + } + } else { + token.after = ""; + token.nodes = []; + } + pos = next + 1; + token.sourceEndIndex = token.unclosed ? next : pos; + code = value.charCodeAt(pos); + tokens.push(token); + } else { + balanced += 1; + token.after = ""; + token.sourceEndIndex = pos + 1; + tokens.push(token); + stack.push(token); + tokens = token.nodes = []; + parent = token; + } + name = ""; + + // Close parentheses + } else if (closeParentheses === code && balanced) { + pos += 1; + code = value.charCodeAt(pos); + + parent.after = after; + parent.sourceEndIndex += after.length; + after = ""; + balanced -= 1; + stack[stack.length - 1].sourceEndIndex = pos; + stack.pop(); + parent = stack[balanced]; + tokens = parent.nodes; + + // Words + } else { + next = pos; + do { + if (code === backslash) { + next += 1; + } + next += 1; + code = value.charCodeAt(next); + } while ( + next < max && + !( + code <= 32 || + code === singleQuote || + code === doubleQuote || + code === comma || + code === colon || + code === slash || + code === openParentheses || + (code === star && + parent && + parent.type === "function" && + parent.value === "calc") || + (code === slash && + parent.type === "function" && + parent.value === "calc") || + (code === closeParentheses && balanced) + ) + ); + token = value.slice(pos, next); + + if (openParentheses === code) { + name = token; + } else if ( + (uLower === token.charCodeAt(0) || uUpper === token.charCodeAt(0)) && + plus === token.charCodeAt(1) && + isUnicodeRange.test(token.slice(2)) + ) { + tokens.push({ + type: "unicode-range", + sourceIndex: pos, + sourceEndIndex: next, + value: token + }); + } else { + tokens.push({ + type: "word", + sourceIndex: pos, + sourceEndIndex: next, + value: token + }); + } + + pos = next; + } + } + + for (pos = stack.length - 1; pos; pos -= 1) { + stack[pos].unclosed = true; + stack[pos].sourceEndIndex = value.length; + } + + return stack[0].nodes; +}; diff --git a/node_modules/postcss-value-parser/lib/stringify.js b/node_modules/postcss-value-parser/lib/stringify.js new file mode 100644 index 0000000..6079671 --- /dev/null +++ b/node_modules/postcss-value-parser/lib/stringify.js @@ -0,0 +1,48 @@ +function stringifyNode(node, custom) { + var type = node.type; + var value = node.value; + var buf; + var customResult; + + if (custom && (customResult = custom(node)) !== undefined) { + return customResult; + } else if (type === "word" || type === "space") { + return value; + } else if (type === "string") { + buf = node.quote || ""; + return buf + value + (node.unclosed ? "" : buf); + } else if (type === "comment") { + return "/*" + value + (node.unclosed ? "" : "*/"); + } else if (type === "div") { + return (node.before || "") + value + (node.after || ""); + } else if (Array.isArray(node.nodes)) { + buf = stringify(node.nodes, custom); + if (type !== "function") { + return buf; + } + return ( + value + + "(" + + (node.before || "") + + buf + + (node.after || "") + + (node.unclosed ? "" : ")") + ); + } + return value; +} + +function stringify(nodes, custom) { + var result, i; + + if (Array.isArray(nodes)) { + result = ""; + for (i = nodes.length - 1; ~i; i -= 1) { + result = stringifyNode(nodes[i], custom) + result; + } + return result; + } + return stringifyNode(nodes, custom); +} + +module.exports = stringify; diff --git a/node_modules/postcss-value-parser/lib/unit.js b/node_modules/postcss-value-parser/lib/unit.js new file mode 100644 index 0000000..c349661 --- /dev/null +++ b/node_modules/postcss-value-parser/lib/unit.js @@ -0,0 +1,120 @@ +var minus = "-".charCodeAt(0); +var plus = "+".charCodeAt(0); +var dot = ".".charCodeAt(0); +var exp = "e".charCodeAt(0); +var EXP = "E".charCodeAt(0); + +// Check if three code points would start a number +// https://www.w3.org/TR/css-syntax-3/#starts-with-a-number +function likeNumber(value) { + var code = value.charCodeAt(0); + var nextCode; + + if (code === plus || code === minus) { + nextCode = value.charCodeAt(1); + + if (nextCode >= 48 && nextCode <= 57) { + return true; + } + + var nextNextCode = value.charCodeAt(2); + + if (nextCode === dot && nextNextCode >= 48 && nextNextCode <= 57) { + return true; + } + + return false; + } + + if (code === dot) { + nextCode = value.charCodeAt(1); + + if (nextCode >= 48 && nextCode <= 57) { + return true; + } + + return false; + } + + if (code >= 48 && code <= 57) { + return true; + } + + return false; +} + +// Consume a number +// https://www.w3.org/TR/css-syntax-3/#consume-number +module.exports = function(value) { + var pos = 0; + var length = value.length; + var code; + var nextCode; + var nextNextCode; + + if (length === 0 || !likeNumber(value)) { + return false; + } + + code = value.charCodeAt(pos); + + if (code === plus || code === minus) { + pos++; + } + + while (pos < length) { + code = value.charCodeAt(pos); + + if (code < 48 || code > 57) { + break; + } + + pos += 1; + } + + code = value.charCodeAt(pos); + nextCode = value.charCodeAt(pos + 1); + + if (code === dot && nextCode >= 48 && nextCode <= 57) { + pos += 2; + + while (pos < length) { + code = value.charCodeAt(pos); + + if (code < 48 || code > 57) { + break; + } + + pos += 1; + } + } + + code = value.charCodeAt(pos); + nextCode = value.charCodeAt(pos + 1); + nextNextCode = value.charCodeAt(pos + 2); + + if ( + (code === exp || code === EXP) && + ((nextCode >= 48 && nextCode <= 57) || + ((nextCode === plus || nextCode === minus) && + nextNextCode >= 48 && + nextNextCode <= 57)) + ) { + pos += nextCode === plus || nextCode === minus ? 3 : 2; + + while (pos < length) { + code = value.charCodeAt(pos); + + if (code < 48 || code > 57) { + break; + } + + pos += 1; + } + } + + return { + number: value.slice(0, pos), + unit: value.slice(pos) + }; +}; diff --git a/node_modules/postcss-value-parser/lib/walk.js b/node_modules/postcss-value-parser/lib/walk.js new file mode 100644 index 0000000..7666c5b --- /dev/null +++ b/node_modules/postcss-value-parser/lib/walk.js @@ -0,0 +1,22 @@ +module.exports = function walk(nodes, cb, bubble) { + var i, max, node, result; + + for (i = 0, max = nodes.length; i < max; i += 1) { + node = nodes[i]; + if (!bubble) { + result = cb(node, i, nodes); + } + + if ( + result !== false && + node.type === "function" && + Array.isArray(node.nodes) + ) { + walk(node.nodes, cb, bubble); + } + + if (bubble) { + cb(node, i, nodes); + } + } +}; diff --git a/node_modules/postcss-value-parser/package.json b/node_modules/postcss-value-parser/package.json new file mode 100644 index 0000000..02d744a --- /dev/null +++ b/node_modules/postcss-value-parser/package.json @@ -0,0 +1,58 @@ +{ + "name": "postcss-value-parser", + "version": "4.2.0", + "description": "Transforms css values and at-rule params into the tree", + "main": "lib/index.js", + "files": [ + "lib" + ], + "devDependencies": { + "eslint": "^5.16.0", + "husky": "^2.3.0", + "lint-staged": "^8.1.7", + "prettier": "^1.17.1", + "tap-spec": "^5.0.0", + "tape": "^4.10.2" + }, + "scripts": { + "lint:prettier": "prettier \"**/*.js\" \"**/*.ts\" --list-different", + "lint:js": "eslint . --cache", + "lint": "yarn lint:js && yarn lint:prettier", + "pretest": "yarn lint", + "test": "tape test/*.js | tap-spec" + }, + "eslintConfig": { + "env": { + "es6": true, + "node": true + }, + "extends": "eslint:recommended" + }, + "lint-staged": { + "*.js": [ + "eslint", + "prettier --write", + "git add" + ] + }, + "husky": { + "hooks": { + "pre-commit": "lint-staged" + } + }, + "author": "Bogdan Chadkin ", + "license": "MIT", + "homepage": "https://github.com/TrySound/postcss-value-parser", + "repository": { + "type": "git", + "url": "https://github.com/TrySound/postcss-value-parser.git" + }, + "keywords": [ + "postcss", + "value", + "parser" + ], + "bugs": { + "url": "https://github.com/TrySound/postcss-value-parser/issues" + } +} diff --git a/node_modules/postcss/LICENSE b/node_modules/postcss/LICENSE new file mode 100644 index 0000000..da057b4 --- /dev/null +++ b/node_modules/postcss/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright 2013 Andrey Sitnik + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/postcss/README.md b/node_modules/postcss/README.md new file mode 100644 index 0000000..9b646dd --- /dev/null +++ b/node_modules/postcss/README.md @@ -0,0 +1,28 @@ +# PostCSS + +Philosopher’s stone, logo of PostCSS + +PostCSS is a tool for transforming styles with JS plugins. +These plugins can lint your CSS, support variables and mixins, +transpile future CSS syntax, inline images, and more. + +PostCSS is used by industry leaders including Wikipedia, Twitter, Alibaba, +and JetBrains. The [Autoprefixer] and [Stylelint] PostCSS plugins is one of the most popular CSS tools. + +--- + +  Made in Evil Martians, product consulting for developer tools. + +--- + +[Abstract Syntax Tree]: https://en.wikipedia.org/wiki/Abstract_syntax_tree +[Evil Martians]: https://evilmartians.com/?utm_source=postcss +[Autoprefixer]: https://github.com/postcss/autoprefixer +[Stylelint]: https://stylelint.io/ +[plugins]: https://github.com/postcss/postcss#plugins + + +## Docs +Read full docs **[here](https://postcss.org/)**. diff --git a/node_modules/postcss/lib/at-rule.d.ts b/node_modules/postcss/lib/at-rule.d.ts new file mode 100644 index 0000000..5bdee38 --- /dev/null +++ b/node_modules/postcss/lib/at-rule.d.ts @@ -0,0 +1,137 @@ +import Container, { + ContainerProps, + ContainerWithChildren +} from './container.js' + +declare namespace AtRule { + export interface AtRuleRaws extends Record { + /** + * The space symbols after the last child of the node to the end of the node. + */ + after?: string + + /** + * The space between the at-rule name and its parameters. + */ + afterName?: string + + /** + * The space symbols before the node. It also stores `*` + * and `_` symbols before the declaration (IE hack). + */ + before?: string + + /** + * The symbols between the last parameter and `{` for rules. + */ + between?: string + + /** + * The rule’s selector with comments. + */ + params?: { + raw: string + value: string + } + + /** + * Contains `true` if the last child has an (optional) semicolon. + */ + semicolon?: boolean + } + + export interface AtRuleProps extends ContainerProps { + /** Name of the at-rule. */ + name: string + /** Parameters following the name of the at-rule. */ + params?: number | string + /** Information used to generate byte-to-byte equal node string as it was in the origin input. */ + raws?: AtRuleRaws + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { AtRule_ as default } +} + +/** + * Represents an at-rule. + * + * ```js + * Once (root, { AtRule }) { + * let media = new AtRule({ name: 'media', params: 'print' }) + * media.append(…) + * root.append(media) + * } + * ``` + * + * If it’s followed in the CSS by a `{}` block, this node will have + * a nodes property representing its children. + * + * ```js + * const root = postcss.parse('@charset "UTF-8"; @media print {}') + * + * const charset = root.first + * charset.type //=> 'atrule' + * charset.nodes //=> undefined + * + * const media = root.last + * media.nodes //=> [] + * ``` + */ +declare class AtRule_ extends Container { + /** + * The at-rule’s name immediately follows the `@`. + * + * ```js + * const root = postcss.parse('@media print {}') + * const media = root.first + * media.name //=> 'media' + * ``` + */ + name: string + /** + * An array containing the layer’s children. + * + * ```js + * const root = postcss.parse('@layer example { a { color: black } }') + * const layer = root.first + * layer.nodes.length //=> 1 + * layer.nodes[0].selector //=> 'a' + * ``` + * + * Can be `undefinded` if the at-rule has no body. + * + * ```js + * const root = postcss.parse('@layer a, b, c;') + * const layer = root.first + * layer.nodes //=> undefined + * ``` + */ + nodes: Container['nodes'] + /** + * The at-rule’s parameters, the values that follow the at-rule’s name + * but precede any `{}` block. + * + * ```js + * const root = postcss.parse('@media print, screen {}') + * const media = root.first + * media.params //=> 'print, screen' + * ``` + */ + params: string + parent: ContainerWithChildren | undefined + + raws: AtRule.AtRuleRaws + + type: 'atrule' + + constructor(defaults?: AtRule.AtRuleProps) + assign(overrides: AtRule.AtRuleProps | object): this + clone(overrides?: Partial): AtRule + cloneAfter(overrides?: Partial): AtRule + cloneBefore(overrides?: Partial): AtRule +} + +declare class AtRule extends AtRule_ {} + +export = AtRule diff --git a/node_modules/postcss/lib/at-rule.js b/node_modules/postcss/lib/at-rule.js new file mode 100644 index 0000000..9486447 --- /dev/null +++ b/node_modules/postcss/lib/at-rule.js @@ -0,0 +1,25 @@ +'use strict' + +let Container = require('./container') + +class AtRule extends Container { + constructor(defaults) { + super(defaults) + this.type = 'atrule' + } + + append(...children) { + if (!this.proxyOf.nodes) this.nodes = [] + return super.append(...children) + } + + prepend(...children) { + if (!this.proxyOf.nodes) this.nodes = [] + return super.prepend(...children) + } +} + +module.exports = AtRule +AtRule.default = AtRule + +Container.registerAtRule(AtRule) diff --git a/node_modules/postcss/lib/comment.d.ts b/node_modules/postcss/lib/comment.d.ts new file mode 100644 index 0000000..d244508 --- /dev/null +++ b/node_modules/postcss/lib/comment.d.ts @@ -0,0 +1,67 @@ +import Container from './container.js' +import Node, { NodeProps } from './node.js' + +declare namespace Comment { + export interface CommentRaws extends Record { + /** + * The space symbols before the node. + */ + before?: string + + /** + * The space symbols between `/*` and the comment’s text. + */ + left?: string + + /** + * The space symbols between the comment’s text. + */ + right?: string + } + + export interface CommentProps extends NodeProps { + /** Information used to generate byte-to-byte equal node string as it was in the origin input. */ + raws?: CommentRaws + /** Content of the comment. */ + text: string + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Comment_ as default } +} + +/** + * It represents a class that handles + * [CSS comments](https://developer.mozilla.org/en-US/docs/Web/CSS/Comments) + * + * ```js + * Once (root, { Comment }) { + * const note = new Comment({ text: 'Note: …' }) + * root.append(note) + * } + * ``` + * + * Remember that CSS comments inside selectors, at-rule parameters, + * or declaration values will be stored in the `raws` properties + * explained above. + */ +declare class Comment_ extends Node { + parent: Container | undefined + raws: Comment.CommentRaws + /** + * The comment's text. + */ + text: string + + type: 'comment' + + constructor(defaults?: Comment.CommentProps) + assign(overrides: Comment.CommentProps | object): this + clone(overrides?: Partial): Comment + cloneAfter(overrides?: Partial): Comment + cloneBefore(overrides?: Partial): Comment +} + +declare class Comment extends Comment_ {} + +export = Comment diff --git a/node_modules/postcss/lib/comment.js b/node_modules/postcss/lib/comment.js new file mode 100644 index 0000000..c566506 --- /dev/null +++ b/node_modules/postcss/lib/comment.js @@ -0,0 +1,13 @@ +'use strict' + +let Node = require('./node') + +class Comment extends Node { + constructor(defaults) { + super(defaults) + this.type = 'comment' + } +} + +module.exports = Comment +Comment.default = Comment diff --git a/node_modules/postcss/lib/container.d.ts b/node_modules/postcss/lib/container.d.ts new file mode 100644 index 0000000..d16b85d --- /dev/null +++ b/node_modules/postcss/lib/container.d.ts @@ -0,0 +1,490 @@ +import AtRule from './at-rule.js' +import Comment from './comment.js' +import Declaration from './declaration.js' +import Node, { ChildNode, ChildProps, NodeProps } from './node.js' +import Rule from './rule.js' + +declare namespace Container { + export class ContainerWithChildren< + Child extends Node = ChildNode + > extends Container_ { + nodes: Child[] + } + + export interface ValueOptions { + /** + * String that’s used to narrow down values and speed up the regexp search. + */ + fast?: string + + /** + * An array of property names. + */ + props?: string[] + } + + export interface ContainerProps extends NodeProps { + nodes?: (ChildNode | ChildProps)[] + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Container_ as default } +} + +/** + * The `Root`, `AtRule`, and `Rule` container nodes + * inherit some common methods to help work with their children. + * + * Note that all containers can store any content. If you write a rule inside + * a rule, PostCSS will parse it. + */ +declare abstract class Container_ extends Node { + /** + * An array containing the container’s children. + * + * ```js + * const root = postcss.parse('a { color: black }') + * root.nodes.length //=> 1 + * root.nodes[0].selector //=> 'a' + * root.nodes[0].nodes[0].prop //=> 'color' + * ``` + */ + nodes: Child[] | undefined + + /** + * Inserts new nodes to the end of the container. + * + * ```js + * const decl1 = new Declaration({ prop: 'color', value: 'black' }) + * const decl2 = new Declaration({ prop: 'background-color', value: 'white' }) + * rule.append(decl1, decl2) + * + * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule + * root.append({ selector: 'a' }) // rule + * rule.append({ prop: 'color', value: 'black' }) // declaration + * rule.append({ text: 'Comment' }) // comment + * + * root.append('a {}') + * root.first.append('color: black; z-index: 1') + * ``` + * + * @param nodes New nodes. + * @return This node for methods chain. + */ + append( + ...nodes: ( + | ChildProps + | ChildProps[] + | Node + | Node[] + | string + | string[] + | undefined + )[] + ): this + + assign(overrides: Container.ContainerProps | object): this + clone(overrides?: Partial): Container + cloneAfter(overrides?: Partial): Container + cloneBefore(overrides?: Partial): Container + + /** + * Iterates through the container’s immediate children, + * calling `callback` for each child. + * + * Returning `false` in the callback will break iteration. + * + * This method only iterates through the container’s immediate children. + * If you need to recursively iterate through all the container’s descendant + * nodes, use `Container#walk`. + * + * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe + * if you are mutating the array of child nodes during iteration. + * PostCSS will adjust the current index to match the mutations. + * + * ```js + * const root = postcss.parse('a { color: black; z-index: 1 }') + * const rule = root.first + * + * for (const decl of rule.nodes) { + * decl.cloneBefore({ prop: '-webkit-' + decl.prop }) + * // Cycle will be infinite, because cloneBefore moves the current node + * // to the next index + * } + * + * rule.each(decl => { + * decl.cloneBefore({ prop: '-webkit-' + decl.prop }) + * // Will be executed only for color and z-index + * }) + * ``` + * + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + each( + callback: (node: Child, index: number) => false | void + ): false | undefined + + /** + * Returns `true` if callback returns `true` + * for all of the container’s children. + * + * ```js + * const noPrefixes = rule.every(i => i.prop[0] !== '-') + * ``` + * + * @param condition Iterator returns true or false. + * @return Is every child pass condition. + */ + every( + condition: (node: Child, index: number, nodes: Child[]) => boolean + ): boolean + /** + * Returns a `child`’s index within the `Container#nodes` array. + * + * ```js + * rule.index( rule.nodes[2] ) //=> 2 + * ``` + * + * @param child Child of the current container. + * @return Child index. + */ + index(child: Child | number): number + + /** + * Insert new node after old node within the container. + * + * @param oldNode Child or child’s index. + * @param newNode New node. + * @return This node for methods chain. + */ + insertAfter( + oldNode: Child | number, + newNode: + | Child + | Child[] + | ChildProps + | ChildProps[] + | string + | string[] + | undefined + ): this + /** + * Insert new node before old node within the container. + * + * ```js + * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop })) + * ``` + * + * @param oldNode Child or child’s index. + * @param newNode New node. + * @return This node for methods chain. + */ + insertBefore( + oldNode: Child | number, + newNode: + | Child + | Child[] + | ChildProps + | ChildProps[] + | string + | string[] + | undefined + ): this + + /** + * Traverses the container’s descendant nodes, calling callback + * for each comment node. + * + * Like `Container#each`, this method is safe + * to use if you are mutating arrays during iteration. + * + * ```js + * root.walkComments(comment => { + * comment.remove() + * }) + * ``` + * + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + + /** + * Inserts new nodes to the start of the container. + * + * ```js + * const decl1 = new Declaration({ prop: 'color', value: 'black' }) + * const decl2 = new Declaration({ prop: 'background-color', value: 'white' }) + * rule.prepend(decl1, decl2) + * + * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule + * root.append({ selector: 'a' }) // rule + * rule.append({ prop: 'color', value: 'black' }) // declaration + * rule.append({ text: 'Comment' }) // comment + * + * root.append('a {}') + * root.first.append('color: black; z-index: 1') + * ``` + * + * @param nodes New nodes. + * @return This node for methods chain. + */ + prepend( + ...nodes: ( + | ChildProps + | ChildProps[] + | Node + | Node[] + | string + | string[] + | undefined + )[] + ): this + /** + * Add child to the end of the node. + * + * ```js + * rule.push(new Declaration({ prop: 'color', value: 'black' })) + * ``` + * + * @param child New node. + * @return This node for methods chain. + */ + push(child: Child): this + + /** + * Removes all children from the container + * and cleans their parent properties. + * + * ```js + * rule.removeAll() + * rule.nodes.length //=> 0 + * ``` + * + * @return This node for methods chain. + */ + removeAll(): this + + /** + * Removes node from the container and cleans the parent properties + * from the node and its children. + * + * ```js + * rule.nodes.length //=> 5 + * rule.removeChild(decl) + * rule.nodes.length //=> 4 + * decl.parent //=> undefined + * ``` + * + * @param child Child or child’s index. + * @return This node for methods chain. + */ + removeChild(child: Child | number): this + + replaceValues( + pattern: RegExp | string, + replaced: { (substring: string, ...args: any[]): string } | string + ): this + + /** + * Passes all declaration values within the container that match pattern + * through callback, replacing those values with the returned result + * of callback. + * + * This method is useful if you are using a custom unit or function + * and need to iterate through all values. + * + * ```js + * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => { + * return 15 * parseInt(string) + 'px' + * }) + * ``` + * + * @param pattern Replace pattern. + * @param {object} opts Options to speed up the search. + * @param callback String to replace pattern or callback + * that returns a new value. The callback + * will receive the same arguments + * as those passed to a function parameter + * of `String#replace`. + * @return This node for methods chain. + */ + replaceValues( + pattern: RegExp | string, + options: Container.ValueOptions, + replaced: { (substring: string, ...args: any[]): string } | string + ): this + + /** + * Returns `true` if callback returns `true` for (at least) one + * of the container’s children. + * + * ```js + * const hasPrefix = rule.some(i => i.prop[0] === '-') + * ``` + * + * @param condition Iterator returns true or false. + * @return Is some child pass condition. + */ + some( + condition: (node: Child, index: number, nodes: Child[]) => boolean + ): boolean + + /** + * Traverses the container’s descendant nodes, calling callback + * for each node. + * + * Like container.each(), this method is safe to use + * if you are mutating arrays during iteration. + * + * If you only need to iterate through the container’s immediate children, + * use `Container#each`. + * + * ```js + * root.walk(node => { + * // Traverses all descendant nodes. + * }) + * ``` + * + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + walk( + callback: (node: ChildNode, index: number) => false | void + ): false | undefined + + /** + * Traverses the container’s descendant nodes, calling callback + * for each at-rule node. + * + * If you pass a filter, iteration will only happen over at-rules + * that have matching names. + * + * Like `Container#each`, this method is safe + * to use if you are mutating arrays during iteration. + * + * ```js + * root.walkAtRules(rule => { + * if (isOld(rule.name)) rule.remove() + * }) + * + * let first = false + * root.walkAtRules('charset', rule => { + * if (!first) { + * first = true + * } else { + * rule.remove() + * } + * }) + * ``` + * + * @param name String or regular expression to filter at-rules by name. + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + walkAtRules( + nameFilter: RegExp | string, + callback: (atRule: AtRule, index: number) => false | void + ): false | undefined + + walkAtRules( + callback: (atRule: AtRule, index: number) => false | void + ): false | undefined + walkComments( + callback: (comment: Comment, indexed: number) => false | void + ): false | undefined + + walkComments( + callback: (comment: Comment, indexed: number) => false | void + ): false | undefined + + /** + * Traverses the container’s descendant nodes, calling callback + * for each declaration node. + * + * If you pass a filter, iteration will only happen over declarations + * with matching properties. + * + * ```js + * root.walkDecls(decl => { + * checkPropertySupport(decl.prop) + * }) + * + * root.walkDecls('border-radius', decl => { + * decl.remove() + * }) + * + * root.walkDecls(/^background/, decl => { + * decl.value = takeFirstColorFromGradient(decl.value) + * }) + * ``` + * + * Like `Container#each`, this method is safe + * to use if you are mutating arrays during iteration. + * + * @param prop String or regular expression to filter declarations + * by property name. + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + walkDecls( + propFilter: RegExp | string, + callback: (decl: Declaration, index: number) => false | void + ): false | undefined + + walkDecls( + callback: (decl: Declaration, index: number) => false | void + ): false | undefined + + /** + * Traverses the container’s descendant nodes, calling callback + * for each rule node. + * + * If you pass a filter, iteration will only happen over rules + * with matching selectors. + * + * Like `Container#each`, this method is safe + * to use if you are mutating arrays during iteration. + * + * ```js + * const selectors = [] + * root.walkRules(rule => { + * selectors.push(rule.selector) + * }) + * console.log(`Your CSS uses ${ selectors.length } selectors`) + * ``` + * + * @param selector String or regular expression to filter rules by selector. + * @param callback Iterator receives each node and index. + * @return Returns `false` if iteration was broke. + */ + walkRules( + selectorFilter: RegExp | string, + callback: (rule: Rule, index: number) => false | void + ): false | undefined + walkRules( + callback: (rule: Rule, index: number) => false | void + ): false | undefined + /** + * The container’s first child. + * + * ```js + * rule.first === rules.nodes[0] + * ``` + */ + get first(): Child | undefined + /** + * The container’s last child. + * + * ```js + * rule.last === rule.nodes[rule.nodes.length - 1] + * ``` + */ + get last(): Child | undefined +} + +declare class Container< + Child extends Node = ChildNode +> extends Container_ {} + +export = Container diff --git a/node_modules/postcss/lib/container.js b/node_modules/postcss/lib/container.js new file mode 100644 index 0000000..462e3f0 --- /dev/null +++ b/node_modules/postcss/lib/container.js @@ -0,0 +1,441 @@ +'use strict' + +let { isClean, my } = require('./symbols') +let Declaration = require('./declaration') +let Comment = require('./comment') +let Node = require('./node') + +let parse, Rule, AtRule, Root + +function cleanSource(nodes) { + return nodes.map(i => { + if (i.nodes) i.nodes = cleanSource(i.nodes) + delete i.source + return i + }) +} + +function markDirtyUp(node) { + node[isClean] = false + if (node.proxyOf.nodes) { + for (let i of node.proxyOf.nodes) { + markDirtyUp(i) + } + } +} + +class Container extends Node { + append(...children) { + for (let child of children) { + let nodes = this.normalize(child, this.last) + for (let node of nodes) this.proxyOf.nodes.push(node) + } + + this.markDirty() + + return this + } + + cleanRaws(keepBetween) { + super.cleanRaws(keepBetween) + if (this.nodes) { + for (let node of this.nodes) node.cleanRaws(keepBetween) + } + } + + each(callback) { + if (!this.proxyOf.nodes) return undefined + let iterator = this.getIterator() + + let index, result + while (this.indexes[iterator] < this.proxyOf.nodes.length) { + index = this.indexes[iterator] + result = callback(this.proxyOf.nodes[index], index) + if (result === false) break + + this.indexes[iterator] += 1 + } + + delete this.indexes[iterator] + return result + } + + every(condition) { + return this.nodes.every(condition) + } + + getIterator() { + if (!this.lastEach) this.lastEach = 0 + if (!this.indexes) this.indexes = {} + + this.lastEach += 1 + let iterator = this.lastEach + this.indexes[iterator] = 0 + + return iterator + } + + getProxyProcessor() { + return { + get(node, prop) { + if (prop === 'proxyOf') { + return node + } else if (!node[prop]) { + return node[prop] + } else if ( + prop === 'each' || + (typeof prop === 'string' && prop.startsWith('walk')) + ) { + return (...args) => { + return node[prop]( + ...args.map(i => { + if (typeof i === 'function') { + return (child, index) => i(child.toProxy(), index) + } else { + return i + } + }) + ) + } + } else if (prop === 'every' || prop === 'some') { + return cb => { + return node[prop]((child, ...other) => + cb(child.toProxy(), ...other) + ) + } + } else if (prop === 'root') { + return () => node.root().toProxy() + } else if (prop === 'nodes') { + return node.nodes.map(i => i.toProxy()) + } else if (prop === 'first' || prop === 'last') { + return node[prop].toProxy() + } else { + return node[prop] + } + }, + + set(node, prop, value) { + if (node[prop] === value) return true + node[prop] = value + if (prop === 'name' || prop === 'params' || prop === 'selector') { + node.markDirty() + } + return true + } + } + } + + index(child) { + if (typeof child === 'number') return child + if (child.proxyOf) child = child.proxyOf + return this.proxyOf.nodes.indexOf(child) + } + + insertAfter(exist, add) { + let existIndex = this.index(exist) + let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse() + existIndex = this.index(exist) + for (let node of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node) + + let index + for (let id in this.indexes) { + index = this.indexes[id] + if (existIndex < index) { + this.indexes[id] = index + nodes.length + } + } + + this.markDirty() + + return this + } + + insertBefore(exist, add) { + let existIndex = this.index(exist) + let type = existIndex === 0 ? 'prepend' : false + let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse() + existIndex = this.index(exist) + for (let node of nodes) this.proxyOf.nodes.splice(existIndex, 0, node) + + let index + for (let id in this.indexes) { + index = this.indexes[id] + if (existIndex <= index) { + this.indexes[id] = index + nodes.length + } + } + + this.markDirty() + + return this + } + + normalize(nodes, sample) { + if (typeof nodes === 'string') { + nodes = cleanSource(parse(nodes).nodes) + } else if (typeof nodes === 'undefined') { + nodes = [] + } else if (Array.isArray(nodes)) { + nodes = nodes.slice(0) + for (let i of nodes) { + if (i.parent) i.parent.removeChild(i, 'ignore') + } + } else if (nodes.type === 'root' && this.type !== 'document') { + nodes = nodes.nodes.slice(0) + for (let i of nodes) { + if (i.parent) i.parent.removeChild(i, 'ignore') + } + } else if (nodes.type) { + nodes = [nodes] + } else if (nodes.prop) { + if (typeof nodes.value === 'undefined') { + throw new Error('Value field is missed in node creation') + } else if (typeof nodes.value !== 'string') { + nodes.value = String(nodes.value) + } + nodes = [new Declaration(nodes)] + } else if (nodes.selector) { + nodes = [new Rule(nodes)] + } else if (nodes.name) { + nodes = [new AtRule(nodes)] + } else if (nodes.text) { + nodes = [new Comment(nodes)] + } else { + throw new Error('Unknown node type in node creation') + } + + let processed = nodes.map(i => { + /* c8 ignore next */ + if (!i[my]) Container.rebuild(i) + i = i.proxyOf + if (i.parent) i.parent.removeChild(i) + if (i[isClean]) markDirtyUp(i) + if (typeof i.raws.before === 'undefined') { + if (sample && typeof sample.raws.before !== 'undefined') { + i.raws.before = sample.raws.before.replace(/\S/g, '') + } + } + i.parent = this.proxyOf + return i + }) + + return processed + } + + prepend(...children) { + children = children.reverse() + for (let child of children) { + let nodes = this.normalize(child, this.first, 'prepend').reverse() + for (let node of nodes) this.proxyOf.nodes.unshift(node) + for (let id in this.indexes) { + this.indexes[id] = this.indexes[id] + nodes.length + } + } + + this.markDirty() + + return this + } + + push(child) { + child.parent = this + this.proxyOf.nodes.push(child) + return this + } + + removeAll() { + for (let node of this.proxyOf.nodes) node.parent = undefined + this.proxyOf.nodes = [] + + this.markDirty() + + return this + } + + removeChild(child) { + child = this.index(child) + this.proxyOf.nodes[child].parent = undefined + this.proxyOf.nodes.splice(child, 1) + + let index + for (let id in this.indexes) { + index = this.indexes[id] + if (index >= child) { + this.indexes[id] = index - 1 + } + } + + this.markDirty() + + return this + } + + replaceValues(pattern, opts, callback) { + if (!callback) { + callback = opts + opts = {} + } + + this.walkDecls(decl => { + if (opts.props && !opts.props.includes(decl.prop)) return + if (opts.fast && !decl.value.includes(opts.fast)) return + + decl.value = decl.value.replace(pattern, callback) + }) + + this.markDirty() + + return this + } + + some(condition) { + return this.nodes.some(condition) + } + + walk(callback) { + return this.each((child, i) => { + let result + try { + result = callback(child, i) + } catch (e) { + throw child.addToError(e) + } + if (result !== false && child.walk) { + result = child.walk(callback) + } + + return result + }) + } + + walkAtRules(name, callback) { + if (!callback) { + callback = name + return this.walk((child, i) => { + if (child.type === 'atrule') { + return callback(child, i) + } + }) + } + if (name instanceof RegExp) { + return this.walk((child, i) => { + if (child.type === 'atrule' && name.test(child.name)) { + return callback(child, i) + } + }) + } + return this.walk((child, i) => { + if (child.type === 'atrule' && child.name === name) { + return callback(child, i) + } + }) + } + + walkComments(callback) { + return this.walk((child, i) => { + if (child.type === 'comment') { + return callback(child, i) + } + }) + } + + walkDecls(prop, callback) { + if (!callback) { + callback = prop + return this.walk((child, i) => { + if (child.type === 'decl') { + return callback(child, i) + } + }) + } + if (prop instanceof RegExp) { + return this.walk((child, i) => { + if (child.type === 'decl' && prop.test(child.prop)) { + return callback(child, i) + } + }) + } + return this.walk((child, i) => { + if (child.type === 'decl' && child.prop === prop) { + return callback(child, i) + } + }) + } + + walkRules(selector, callback) { + if (!callback) { + callback = selector + + return this.walk((child, i) => { + if (child.type === 'rule') { + return callback(child, i) + } + }) + } + if (selector instanceof RegExp) { + return this.walk((child, i) => { + if (child.type === 'rule' && selector.test(child.selector)) { + return callback(child, i) + } + }) + } + return this.walk((child, i) => { + if (child.type === 'rule' && child.selector === selector) { + return callback(child, i) + } + }) + } + + get first() { + if (!this.proxyOf.nodes) return undefined + return this.proxyOf.nodes[0] + } + + get last() { + if (!this.proxyOf.nodes) return undefined + return this.proxyOf.nodes[this.proxyOf.nodes.length - 1] + } +} + +Container.registerParse = dependant => { + parse = dependant +} + +Container.registerRule = dependant => { + Rule = dependant +} + +Container.registerAtRule = dependant => { + AtRule = dependant +} + +Container.registerRoot = dependant => { + Root = dependant +} + +module.exports = Container +Container.default = Container + +/* c8 ignore start */ +Container.rebuild = node => { + if (node.type === 'atrule') { + Object.setPrototypeOf(node, AtRule.prototype) + } else if (node.type === 'rule') { + Object.setPrototypeOf(node, Rule.prototype) + } else if (node.type === 'decl') { + Object.setPrototypeOf(node, Declaration.prototype) + } else if (node.type === 'comment') { + Object.setPrototypeOf(node, Comment.prototype) + } else if (node.type === 'root') { + Object.setPrototypeOf(node, Root.prototype) + } + + node[my] = true + + if (node.nodes) { + node.nodes.forEach(child => { + Container.rebuild(child) + }) + } +} +/* c8 ignore stop */ diff --git a/node_modules/postcss/lib/css-syntax-error.d.ts b/node_modules/postcss/lib/css-syntax-error.d.ts new file mode 100644 index 0000000..d2d11bf --- /dev/null +++ b/node_modules/postcss/lib/css-syntax-error.d.ts @@ -0,0 +1,248 @@ +import { FilePosition } from './input.js' + +declare namespace CssSyntaxError { + /** + * A position that is part of a range. + */ + export interface RangePosition { + /** + * The column number in the input. + */ + column: number + + /** + * The line number in the input. + */ + line: number + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { CssSyntaxError_ as default } +} + +/** + * The CSS parser throws this error for broken CSS. + * + * Custom parsers can throw this error for broken custom syntax using + * the `Node#error` method. + * + * PostCSS will use the input source map to detect the original error location. + * If you wrote a Sass file, compiled it to CSS and then parsed it with PostCSS, + * PostCSS will show the original position in the Sass file. + * + * If you need the position in the PostCSS input + * (e.g., to debug the previous compiler), use `error.input.file`. + * + * ```js + * // Raising error from plugin + * throw node.error('Unknown variable', { plugin: 'postcss-vars' }) + * ``` + * + * ```js + * // Catching and checking syntax error + * try { + * postcss.parse('a{') + * } catch (error) { + * if (error.name === 'CssSyntaxError') { + * error //=> CssSyntaxError + * } + * } + * ``` + */ +declare class CssSyntaxError_ { + /** + * Source column of the error. + * + * ```js + * error.column //=> 1 + * error.input.column //=> 4 + * ``` + * + * PostCSS will use the input source map to detect the original location. + * If you need the position in the PostCSS input, use `error.input.column`. + */ + column?: number + + /** + * Source column of the error's end, exclusive. Provided if the error pertains + * to a range. + * + * ```js + * error.endColumn //=> 1 + * error.input.endColumn //=> 4 + * ``` + * + * PostCSS will use the input source map to detect the original location. + * If you need the position in the PostCSS input, use `error.input.endColumn`. + */ + endColumn?: number + + /** + * Source line of the error's end, exclusive. Provided if the error pertains + * to a range. + * + * ```js + * error.endLine //=> 3 + * error.input.endLine //=> 4 + * ``` + * + * PostCSS will use the input source map to detect the original location. + * If you need the position in the PostCSS input, use `error.input.endLine`. + */ + endLine?: number + + /** + * Absolute path to the broken file. + * + * ```js + * error.file //=> 'a.sass' + * error.input.file //=> 'a.css' + * ``` + * + * PostCSS will use the input source map to detect the original location. + * If you need the position in the PostCSS input, use `error.input.file`. + */ + file?: string + + /** + * Input object with PostCSS internal information + * about input file. If input has source map + * from previous tool, PostCSS will use origin + * (for example, Sass) source. You can use this + * object to get PostCSS input source. + * + * ```js + * error.input.file //=> 'a.css' + * error.file //=> 'a.sass' + * ``` + */ + input?: FilePosition + + /** + * Source line of the error. + * + * ```js + * error.line //=> 2 + * error.input.line //=> 4 + * ``` + * + * PostCSS will use the input source map to detect the original location. + * If you need the position in the PostCSS input, use `error.input.line`. + */ + line?: number + + /** + * Full error text in the GNU error format + * with plugin, file, line and column. + * + * ```js + * error.message //=> 'a.css:1:1: Unclosed block' + * ``` + */ + message: string + + /** + * Always equal to `'CssSyntaxError'`. You should always check error type + * by `error.name === 'CssSyntaxError'` + * instead of `error instanceof CssSyntaxError`, + * because npm could have several PostCSS versions. + * + * ```js + * if (error.name === 'CssSyntaxError') { + * error //=> CssSyntaxError + * } + * ``` + */ + name: 'CssSyntaxError' + + /** + * Plugin name, if error came from plugin. + * + * ```js + * error.plugin //=> 'postcss-vars' + * ``` + */ + plugin?: string + + /** + * Error message. + * + * ```js + * error.message //=> 'Unclosed block' + * ``` + */ + reason: string + + /** + * Source code of the broken file. + * + * ```js + * error.source //=> 'a { b {} }' + * error.input.source //=> 'a b { }' + * ``` + */ + source?: string + + stack: string + + /** + * Instantiates a CSS syntax error. Can be instantiated for a single position + * or for a range. + * @param message Error message. + * @param lineOrStartPos If for a single position, the line number, or if for + * a range, the inclusive start position of the error. + * @param columnOrEndPos If for a single position, the column number, or if for + * a range, the exclusive end position of the error. + * @param source Source code of the broken file. + * @param file Absolute path to the broken file. + * @param plugin PostCSS plugin name, if error came from plugin. + */ + constructor( + message: string, + lineOrStartPos?: CssSyntaxError.RangePosition | number, + columnOrEndPos?: CssSyntaxError.RangePosition | number, + source?: string, + file?: string, + plugin?: string + ) + + /** + * Returns a few lines of CSS source that caused the error. + * + * If the CSS has an input source map without `sourceContent`, + * this method will return an empty string. + * + * ```js + * error.showSourceCode() //=> " 4 | } + * // 5 | a { + * // > 6 | bad + * // | ^ + * // 7 | } + * // 8 | b {" + * ``` + * + * @param color Whether arrow will be colored red by terminal + * color codes. By default, PostCSS will detect + * color support by `process.stdout.isTTY` + * and `process.env.NODE_DISABLE_COLORS`. + * @return Few lines of CSS source that caused the error. + */ + showSourceCode(color?: boolean): string + + /** + * Returns error position, message and source code of the broken part. + * + * ```js + * error.toString() //=> "CssSyntaxError: app.css:1:1: Unclosed block + * // > 1 | a { + * // | ^" + * ``` + * + * @return Error position, message and source code. + */ + toString(): string +} + +declare class CssSyntaxError extends CssSyntaxError_ {} + +export = CssSyntaxError diff --git a/node_modules/postcss/lib/css-syntax-error.js b/node_modules/postcss/lib/css-syntax-error.js new file mode 100644 index 0000000..1693033 --- /dev/null +++ b/node_modules/postcss/lib/css-syntax-error.js @@ -0,0 +1,100 @@ +'use strict' + +let pico = require('picocolors') + +let terminalHighlight = require('./terminal-highlight') + +class CssSyntaxError extends Error { + constructor(message, line, column, source, file, plugin) { + super(message) + this.name = 'CssSyntaxError' + this.reason = message + + if (file) { + this.file = file + } + if (source) { + this.source = source + } + if (plugin) { + this.plugin = plugin + } + if (typeof line !== 'undefined' && typeof column !== 'undefined') { + if (typeof line === 'number') { + this.line = line + this.column = column + } else { + this.line = line.line + this.column = line.column + this.endLine = column.line + this.endColumn = column.column + } + } + + this.setMessage() + + if (Error.captureStackTrace) { + Error.captureStackTrace(this, CssSyntaxError) + } + } + + setMessage() { + this.message = this.plugin ? this.plugin + ': ' : '' + this.message += this.file ? this.file : '' + if (typeof this.line !== 'undefined') { + this.message += ':' + this.line + ':' + this.column + } + this.message += ': ' + this.reason + } + + showSourceCode(color) { + if (!this.source) return '' + + let css = this.source + if (color == null) color = pico.isColorSupported + if (terminalHighlight) { + if (color) css = terminalHighlight(css) + } + + let lines = css.split(/\r?\n/) + let start = Math.max(this.line - 3, 0) + let end = Math.min(this.line + 2, lines.length) + + let maxWidth = String(end).length + + let mark, aside + if (color) { + let { bold, gray, red } = pico.createColors(true) + mark = text => bold(red(text)) + aside = text => gray(text) + } else { + mark = aside = str => str + } + + return lines + .slice(start, end) + .map((line, index) => { + let number = start + 1 + index + let gutter = ' ' + (' ' + number).slice(-maxWidth) + ' | ' + if (number === this.line) { + let spacing = + aside(gutter.replace(/\d/g, ' ')) + + line.slice(0, this.column - 1).replace(/[^\t]/g, ' ') + return mark('>') + aside(gutter) + line + '\n ' + spacing + mark('^') + } + return ' ' + aside(gutter) + line + }) + .join('\n') + } + + toString() { + let code = this.showSourceCode() + if (code) { + code = '\n\n' + code + '\n' + } + return this.name + ': ' + this.message + code + } +} + +module.exports = CssSyntaxError +CssSyntaxError.default = CssSyntaxError diff --git a/node_modules/postcss/lib/declaration.d.ts b/node_modules/postcss/lib/declaration.d.ts new file mode 100644 index 0000000..a5db984 --- /dev/null +++ b/node_modules/postcss/lib/declaration.d.ts @@ -0,0 +1,148 @@ +import { ContainerWithChildren } from './container.js' +import Node from './node.js' + +declare namespace Declaration { + export interface DeclarationRaws extends Record { + /** + * The space symbols before the node. It also stores `*` + * and `_` symbols before the declaration (IE hack). + */ + before?: string + + /** + * The symbols between the property and value for declarations. + */ + between?: string + + /** + * The content of the important statement, if it is not just `!important`. + */ + important?: string + + /** + * Declaration value with comments. + */ + value?: { + raw: string + value: string + } + } + + export interface DeclarationProps { + /** Whether the declaration has an `!important` annotation. */ + important?: boolean + /** Name of the declaration. */ + prop: string + /** Information used to generate byte-to-byte equal node string as it was in the origin input. */ + raws?: DeclarationRaws + /** Value of the declaration. */ + value: string + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Declaration_ as default } +} + +/** + * It represents a class that handles + * [CSS declarations](https://developer.mozilla.org/en-US/docs/Web/CSS/Syntax#css_declarations) + * + * ```js + * Once (root, { Declaration }) { + * const color = new Declaration({ prop: 'color', value: 'black' }) + * root.append(color) + * } + * ``` + * + * ```js + * const root = postcss.parse('a { color: black }') + * const decl = root.first?.first + * + * decl.type //=> 'decl' + * decl.toString() //=> ' color: black' + * ``` + */ +declare class Declaration_ extends Node { + /** + * It represents a specificity of the declaration. + * + * If true, the CSS declaration will have an + * [important](https://developer.mozilla.org/en-US/docs/Web/CSS/important) + * specifier. + * + * ```js + * const root = postcss.parse('a { color: black !important; color: red }') + * + * root.first.first.important //=> true + * root.first.last.important //=> undefined + * ``` + */ + important: boolean + + parent: ContainerWithChildren | undefined + + /** + * The property name for a CSS declaration. + * + * ```js + * const root = postcss.parse('a { color: black }') + * const decl = root.first.first + * + * decl.prop //=> 'color' + * ``` + */ + prop: string + + raws: Declaration.DeclarationRaws + + type: 'decl' + + /** + * The property value for a CSS declaration. + * + * Any CSS comments inside the value string will be filtered out. + * CSS comments present in the source value will be available in + * the `raws` property. + * + * Assigning new `value` would ignore the comments in `raws` + * property while compiling node to string. + * + * ```js + * const root = postcss.parse('a { color: black }') + * const decl = root.first.first + * + * decl.value //=> 'black' + * ``` + */ + value: string + + /** + * It represents a getter that returns `true` if a declaration starts with + * `--` or `$`, which are used to declare variables in CSS and SASS/SCSS. + * + * ```js + * const root = postcss.parse(':root { --one: 1 }') + * const one = root.first.first + * + * one.variable //=> true + * ``` + * + * ```js + * const root = postcss.parse('$one: 1') + * const one = root.first + * + * one.variable //=> true + * ``` + */ + variable: boolean + + constructor(defaults?: Declaration.DeclarationProps) + assign(overrides: Declaration.DeclarationProps | object): this + clone(overrides?: Partial): Declaration + cloneAfter(overrides?: Partial): Declaration + cloneBefore(overrides?: Partial): Declaration +} + +declare class Declaration extends Declaration_ {} + +export = Declaration diff --git a/node_modules/postcss/lib/declaration.js b/node_modules/postcss/lib/declaration.js new file mode 100644 index 0000000..a04bdec --- /dev/null +++ b/node_modules/postcss/lib/declaration.js @@ -0,0 +1,24 @@ +'use strict' + +let Node = require('./node') + +class Declaration extends Node { + constructor(defaults) { + if ( + defaults && + typeof defaults.value !== 'undefined' && + typeof defaults.value !== 'string' + ) { + defaults = { ...defaults, value: String(defaults.value) } + } + super(defaults) + this.type = 'decl' + } + + get variable() { + return this.prop.startsWith('--') || this.prop[0] === '$' + } +} + +module.exports = Declaration +Declaration.default = Declaration diff --git a/node_modules/postcss/lib/document.d.ts b/node_modules/postcss/lib/document.d.ts new file mode 100644 index 0000000..a368f16 --- /dev/null +++ b/node_modules/postcss/lib/document.d.ts @@ -0,0 +1,69 @@ +import Container, { ContainerProps } from './container.js' +import { ProcessOptions } from './postcss.js' +import Result from './result.js' +import Root from './root.js' + +declare namespace Document { + export interface DocumentProps extends ContainerProps { + nodes?: Root[] + + /** + * Information to generate byte-to-byte equal node string as it was + * in the origin input. + * + * Every parser saves its own properties. + */ + raws?: Record + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Document_ as default } +} + +/** + * Represents a file and contains all its parsed nodes. + * + * **Experimental:** some aspects of this node could change within minor + * or patch version releases. + * + * ```js + * const document = htmlParser( + * '' + * ) + * document.type //=> 'document' + * document.nodes.length //=> 2 + * ``` + */ +declare class Document_ extends Container { + nodes: Root[] + parent: undefined + type: 'document' + + constructor(defaults?: Document.DocumentProps) + + assign(overrides: Document.DocumentProps | object): this + clone(overrides?: Partial): Document + cloneAfter(overrides?: Partial): Document + cloneBefore(overrides?: Partial): Document + + /** + * Returns a `Result` instance representing the document’s CSS roots. + * + * ```js + * const root1 = postcss.parse(css1, { from: 'a.css' }) + * const root2 = postcss.parse(css2, { from: 'b.css' }) + * const document = postcss.document() + * document.append(root1) + * document.append(root2) + * const result = document.toResult({ to: 'all.css', map: true }) + * ``` + * + * @param opts Options. + * @return Result with current document’s CSS. + */ + toResult(options?: ProcessOptions): Result +} + +declare class Document extends Document_ {} + +export = Document diff --git a/node_modules/postcss/lib/document.js b/node_modules/postcss/lib/document.js new file mode 100644 index 0000000..4468991 --- /dev/null +++ b/node_modules/postcss/lib/document.js @@ -0,0 +1,33 @@ +'use strict' + +let Container = require('./container') + +let LazyResult, Processor + +class Document extends Container { + constructor(defaults) { + // type needs to be passed to super, otherwise child roots won't be normalized correctly + super({ type: 'document', ...defaults }) + + if (!this.nodes) { + this.nodes = [] + } + } + + toResult(opts = {}) { + let lazy = new LazyResult(new Processor(), this, opts) + + return lazy.stringify() + } +} + +Document.registerLazyResult = dependant => { + LazyResult = dependant +} + +Document.registerProcessor = dependant => { + Processor = dependant +} + +module.exports = Document +Document.default = Document diff --git a/node_modules/postcss/lib/fromJSON.d.ts b/node_modules/postcss/lib/fromJSON.d.ts new file mode 100644 index 0000000..e1deedb --- /dev/null +++ b/node_modules/postcss/lib/fromJSON.d.ts @@ -0,0 +1,9 @@ +import { JSONHydrator } from './postcss.js' + +interface FromJSON extends JSONHydrator { + default: FromJSON +} + +declare const fromJSON: FromJSON + +export = fromJSON diff --git a/node_modules/postcss/lib/fromJSON.js b/node_modules/postcss/lib/fromJSON.js new file mode 100644 index 0000000..09f2b89 --- /dev/null +++ b/node_modules/postcss/lib/fromJSON.js @@ -0,0 +1,54 @@ +'use strict' + +let Declaration = require('./declaration') +let PreviousMap = require('./previous-map') +let Comment = require('./comment') +let AtRule = require('./at-rule') +let Input = require('./input') +let Root = require('./root') +let Rule = require('./rule') + +function fromJSON(json, inputs) { + if (Array.isArray(json)) return json.map(n => fromJSON(n)) + + let { inputs: ownInputs, ...defaults } = json + if (ownInputs) { + inputs = [] + for (let input of ownInputs) { + let inputHydrated = { ...input, __proto__: Input.prototype } + if (inputHydrated.map) { + inputHydrated.map = { + ...inputHydrated.map, + __proto__: PreviousMap.prototype + } + } + inputs.push(inputHydrated) + } + } + if (defaults.nodes) { + defaults.nodes = json.nodes.map(n => fromJSON(n, inputs)) + } + if (defaults.source) { + let { inputId, ...source } = defaults.source + defaults.source = source + if (inputId != null) { + defaults.source.input = inputs[inputId] + } + } + if (defaults.type === 'root') { + return new Root(defaults) + } else if (defaults.type === 'decl') { + return new Declaration(defaults) + } else if (defaults.type === 'rule') { + return new Rule(defaults) + } else if (defaults.type === 'comment') { + return new Comment(defaults) + } else if (defaults.type === 'atrule') { + return new AtRule(defaults) + } else { + throw new Error('Unknown node type: ' + json.type) + } +} + +module.exports = fromJSON +fromJSON.default = fromJSON diff --git a/node_modules/postcss/lib/input.d.ts b/node_modules/postcss/lib/input.d.ts new file mode 100644 index 0000000..c718bd1 --- /dev/null +++ b/node_modules/postcss/lib/input.d.ts @@ -0,0 +1,194 @@ +import { CssSyntaxError, ProcessOptions } from './postcss.js' +import PreviousMap from './previous-map.js' + +declare namespace Input { + export interface FilePosition { + /** + * Column of inclusive start position in source file. + */ + column: number + + /** + * Column of exclusive end position in source file. + */ + endColumn?: number + + /** + * Line of exclusive end position in source file. + */ + endLine?: number + + /** + * Absolute path to the source file. + */ + file?: string + + /** + * Line of inclusive start position in source file. + */ + line: number + + /** + * Source code. + */ + source?: string + + /** + * URL for the source file. + */ + url: string + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Input_ as default } +} + +/** + * Represents the source CSS. + * + * ```js + * const root = postcss.parse(css, { from: file }) + * const input = root.source.input + * ``` + */ +declare class Input_ { + /** + * Input CSS source. + * + * ```js + * const input = postcss.parse('a{}', { from: file }).input + * input.css //=> "a{}" + * ``` + */ + css: string + + /** + * The absolute path to the CSS source file defined + * with the `from` option. + * + * ```js + * const root = postcss.parse(css, { from: 'a.css' }) + * root.source.input.file //=> '/home/ai/a.css' + * ``` + */ + file?: string + + /** + * The flag to indicate whether or not the source code has Unicode BOM. + */ + hasBOM: boolean + + /** + * The unique ID of the CSS source. It will be created if `from` option + * is not provided (because PostCSS does not know the file path). + * + * ```js + * const root = postcss.parse(css) + * root.source.input.file //=> undefined + * root.source.input.id //=> "" + * ``` + */ + id?: string + + /** + * The input source map passed from a compilation step before PostCSS + * (for example, from Sass compiler). + * + * ```js + * root.source.input.map.consumer().sources //=> ['a.sass'] + * ``` + */ + map: PreviousMap + + /** + * @param css Input CSS source. + * @param opts Process options. + */ + constructor(css: string, opts?: ProcessOptions) + + error( + message: string, + start: + | { + column: number + line: number + } + | { + offset: number + }, + end: + | { + column: number + line: number + } + | { + offset: number + }, + opts?: { plugin?: CssSyntaxError['plugin'] } + ): CssSyntaxError + + /** + * Returns `CssSyntaxError` with information about the error and its position. + */ + error( + message: string, + line: number, + column: number, + opts?: { plugin?: CssSyntaxError['plugin'] } + ): CssSyntaxError + + error( + message: string, + offset: number, + opts?: { plugin?: CssSyntaxError['plugin'] } + ): CssSyntaxError + + /** + * Converts source offset to line and column. + * + * @param offset Source offset. + */ + fromOffset(offset: number): { col: number; line: number } | null + /** + * Reads the input source map and returns a symbol position + * in the input source (e.g., in a Sass file that was compiled + * to CSS before being passed to PostCSS). Optionally takes an + * end position, exclusive. + * + * ```js + * root.source.input.origin(1, 1) //=> { file: 'a.css', line: 3, column: 1 } + * root.source.input.origin(1, 1, 1, 4) + * //=> { file: 'a.css', line: 3, column: 1, endLine: 3, endColumn: 4 } + * ``` + * + * @param line Line for inclusive start position in input CSS. + * @param column Column for inclusive start position in input CSS. + * @param endLine Line for exclusive end position in input CSS. + * @param endColumn Column for exclusive end position in input CSS. + * + * @return Position in input source. + */ + origin( + line: number, + column: number, + endLine?: number, + endColumn?: number + ): false | Input.FilePosition + /** + * The CSS source identifier. Contains `Input#file` if the user + * set the `from` option, or `Input#id` if they did not. + * + * ```js + * const root = postcss.parse(css, { from: 'a.css' }) + * root.source.input.from //=> "/home/ai/a.css" + * + * const root = postcss.parse(css) + * root.source.input.from //=> "" + * ``` + */ + get from(): string +} + +declare class Input extends Input_ {} + +export = Input diff --git a/node_modules/postcss/lib/input.js b/node_modules/postcss/lib/input.js new file mode 100644 index 0000000..4b5ee5e --- /dev/null +++ b/node_modules/postcss/lib/input.js @@ -0,0 +1,248 @@ +'use strict' + +let { SourceMapConsumer, SourceMapGenerator } = require('source-map-js') +let { fileURLToPath, pathToFileURL } = require('url') +let { isAbsolute, resolve } = require('path') +let { nanoid } = require('nanoid/non-secure') + +let terminalHighlight = require('./terminal-highlight') +let CssSyntaxError = require('./css-syntax-error') +let PreviousMap = require('./previous-map') + +let fromOffsetCache = Symbol('fromOffsetCache') + +let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator) +let pathAvailable = Boolean(resolve && isAbsolute) + +class Input { + constructor(css, opts = {}) { + if ( + css === null || + typeof css === 'undefined' || + (typeof css === 'object' && !css.toString) + ) { + throw new Error(`PostCSS received ${css} instead of CSS string`) + } + + this.css = css.toString() + + if (this.css[0] === '\uFEFF' || this.css[0] === '\uFFFE') { + this.hasBOM = true + this.css = this.css.slice(1) + } else { + this.hasBOM = false + } + + if (opts.from) { + if ( + !pathAvailable || + /^\w+:\/\//.test(opts.from) || + isAbsolute(opts.from) + ) { + this.file = opts.from + } else { + this.file = resolve(opts.from) + } + } + + if (pathAvailable && sourceMapAvailable) { + let map = new PreviousMap(this.css, opts) + if (map.text) { + this.map = map + let file = map.consumer().file + if (!this.file && file) this.file = this.mapResolve(file) + } + } + + if (!this.file) { + this.id = '' + } + if (this.map) this.map.file = this.from + } + + error(message, line, column, opts = {}) { + let result, endLine, endColumn + + if (line && typeof line === 'object') { + let start = line + let end = column + if (typeof start.offset === 'number') { + let pos = this.fromOffset(start.offset) + line = pos.line + column = pos.col + } else { + line = start.line + column = start.column + } + if (typeof end.offset === 'number') { + let pos = this.fromOffset(end.offset) + endLine = pos.line + endColumn = pos.col + } else { + endLine = end.line + endColumn = end.column + } + } else if (!column) { + let pos = this.fromOffset(line) + line = pos.line + column = pos.col + } + + let origin = this.origin(line, column, endLine, endColumn) + if (origin) { + result = new CssSyntaxError( + message, + origin.endLine === undefined + ? origin.line + : { column: origin.column, line: origin.line }, + origin.endLine === undefined + ? origin.column + : { column: origin.endColumn, line: origin.endLine }, + origin.source, + origin.file, + opts.plugin + ) + } else { + result = new CssSyntaxError( + message, + endLine === undefined ? line : { column, line }, + endLine === undefined ? column : { column: endColumn, line: endLine }, + this.css, + this.file, + opts.plugin + ) + } + + result.input = { column, endColumn, endLine, line, source: this.css } + if (this.file) { + if (pathToFileURL) { + result.input.url = pathToFileURL(this.file).toString() + } + result.input.file = this.file + } + + return result + } + + fromOffset(offset) { + let lastLine, lineToIndex + if (!this[fromOffsetCache]) { + let lines = this.css.split('\n') + lineToIndex = new Array(lines.length) + let prevIndex = 0 + + for (let i = 0, l = lines.length; i < l; i++) { + lineToIndex[i] = prevIndex + prevIndex += lines[i].length + 1 + } + + this[fromOffsetCache] = lineToIndex + } else { + lineToIndex = this[fromOffsetCache] + } + lastLine = lineToIndex[lineToIndex.length - 1] + + let min = 0 + if (offset >= lastLine) { + min = lineToIndex.length - 1 + } else { + let max = lineToIndex.length - 2 + let mid + while (min < max) { + mid = min + ((max - min) >> 1) + if (offset < lineToIndex[mid]) { + max = mid - 1 + } else if (offset >= lineToIndex[mid + 1]) { + min = mid + 1 + } else { + min = mid + break + } + } + } + return { + col: offset - lineToIndex[min] + 1, + line: min + 1 + } + } + + mapResolve(file) { + if (/^\w+:\/\//.test(file)) { + return file + } + return resolve(this.map.consumer().sourceRoot || this.map.root || '.', file) + } + + origin(line, column, endLine, endColumn) { + if (!this.map) return false + let consumer = this.map.consumer() + + let from = consumer.originalPositionFor({ column, line }) + if (!from.source) return false + + let to + if (typeof endLine === 'number') { + to = consumer.originalPositionFor({ column: endColumn, line: endLine }) + } + + let fromUrl + + if (isAbsolute(from.source)) { + fromUrl = pathToFileURL(from.source) + } else { + fromUrl = new URL( + from.source, + this.map.consumer().sourceRoot || pathToFileURL(this.map.mapFile) + ) + } + + let result = { + column: from.column, + endColumn: to && to.column, + endLine: to && to.line, + line: from.line, + url: fromUrl.toString() + } + + if (fromUrl.protocol === 'file:') { + if (fileURLToPath) { + result.file = fileURLToPath(fromUrl) + } else { + /* c8 ignore next 2 */ + throw new Error(`file: protocol is not available in this PostCSS build`) + } + } + + let source = consumer.sourceContentFor(from.source) + if (source) result.source = source + + return result + } + + toJSON() { + let json = {} + for (let name of ['hasBOM', 'css', 'file', 'id']) { + if (this[name] != null) { + json[name] = this[name] + } + } + if (this.map) { + json.map = { ...this.map } + if (json.map.consumerCache) { + json.map.consumerCache = undefined + } + } + return json + } + + get from() { + return this.file || this.id + } +} + +module.exports = Input +Input.default = Input + +if (terminalHighlight && terminalHighlight.registerInput) { + terminalHighlight.registerInput(Input) +} diff --git a/node_modules/postcss/lib/lazy-result.d.ts b/node_modules/postcss/lib/lazy-result.d.ts new file mode 100644 index 0000000..dd291aa --- /dev/null +++ b/node_modules/postcss/lib/lazy-result.d.ts @@ -0,0 +1,190 @@ +import Document from './document.js' +import { SourceMap } from './postcss.js' +import Processor from './processor.js' +import Result, { Message, ResultOptions } from './result.js' +import Root from './root.js' +import Warning from './warning.js' + +declare namespace LazyResult { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { LazyResult_ as default } +} + +/** + * A Promise proxy for the result of PostCSS transformations. + * + * A `LazyResult` instance is returned by `Processor#process`. + * + * ```js + * const lazy = postcss([autoprefixer]).process(css) + * ``` + */ +declare class LazyResult_ + implements PromiseLike> +{ + /** + * Processes input CSS through synchronous and asynchronous plugins + * and calls onRejected for each error thrown in any plugin. + * + * It implements standard Promise API. + * + * ```js + * postcss([autoprefixer]).process(css).then(result => { + * console.log(result.css) + * }).catch(error => { + * console.error(error) + * }) + * ``` + */ + catch: Promise>['catch'] + + /** + * Processes input CSS through synchronous and asynchronous plugins + * and calls onFinally on any error or when all plugins will finish work. + * + * It implements standard Promise API. + * + * ```js + * postcss([autoprefixer]).process(css).finally(() => { + * console.log('processing ended') + * }) + * ``` + */ + finally: Promise>['finally'] + + /** + * Processes input CSS through synchronous and asynchronous plugins + * and calls `onFulfilled` with a Result instance. If a plugin throws + * an error, the `onRejected` callback will be executed. + * + * It implements standard Promise API. + * + * ```js + * postcss([autoprefixer]).process(css, { from: cssPath }).then(result => { + * console.log(result.css) + * }) + * ``` + */ + then: Promise>['then'] + + /** + * @param processor Processor used for this transformation. + * @param css CSS to parse and transform. + * @param opts Options from the `Processor#process` or `Root#toResult`. + */ + constructor(processor: Processor, css: string, opts: ResultOptions) + + /** + * Run plugin in async way and return `Result`. + * + * @return Result with output content. + */ + async(): Promise> + + /** + * Run plugin in sync way and return `Result`. + * + * @return Result with output content. + */ + sync(): Result + + /** + * Alias for the `LazyResult#css` property. + * + * ```js + * lazy + '' === lazy.css + * ``` + * + * @return Output CSS. + */ + toString(): string + + /** + * Processes input CSS through synchronous plugins + * and calls `Result#warnings`. + * + * @return Warnings from plugins. + */ + warnings(): Warning[] + + /** + * An alias for the `css` property. Use it with syntaxes + * that generate non-CSS output. + * + * This property will only work with synchronous plugins. + * If the processor contains any asynchronous plugins + * it will throw an error. + * + * PostCSS runners should always use `LazyResult#then`. + */ + get content(): string + + /** + * Processes input CSS through synchronous plugins, converts `Root` + * to a CSS string and returns `Result#css`. + * + * This property will only work with synchronous plugins. + * If the processor contains any asynchronous plugins + * it will throw an error. + * + * PostCSS runners should always use `LazyResult#then`. + */ + get css(): string + + /** + * Processes input CSS through synchronous plugins + * and returns `Result#map`. + * + * This property will only work with synchronous plugins. + * If the processor contains any asynchronous plugins + * it will throw an error. + * + * PostCSS runners should always use `LazyResult#then`. + */ + get map(): SourceMap + + /** + * Processes input CSS through synchronous plugins + * and returns `Result#messages`. + * + * This property will only work with synchronous plugins. If the processor + * contains any asynchronous plugins it will throw an error. + * + * PostCSS runners should always use `LazyResult#then`. + */ + get messages(): Message[] + + /** + * Options from the `Processor#process` call. + */ + get opts(): ResultOptions + + /** + * Returns a `Processor` instance, which will be used + * for CSS transformations. + */ + get processor(): Processor + + /** + * Processes input CSS through synchronous plugins + * and returns `Result#root`. + * + * This property will only work with synchronous plugins. If the processor + * contains any asynchronous plugins it will throw an error. + * + * PostCSS runners should always use `LazyResult#then`. + */ + get root(): RootNode + + /** + * Returns the default string description of an object. + * Required to implement the Promise interface. + */ + get [Symbol.toStringTag](): string +} + +declare class LazyResult< + RootNode = Document | Root +> extends LazyResult_ {} + +export = LazyResult diff --git a/node_modules/postcss/lib/lazy-result.js b/node_modules/postcss/lib/lazy-result.js new file mode 100644 index 0000000..126f40c --- /dev/null +++ b/node_modules/postcss/lib/lazy-result.js @@ -0,0 +1,550 @@ +'use strict' + +let { isClean, my } = require('./symbols') +let MapGenerator = require('./map-generator') +let stringify = require('./stringify') +let Container = require('./container') +let Document = require('./document') +let warnOnce = require('./warn-once') +let Result = require('./result') +let parse = require('./parse') +let Root = require('./root') + +const TYPE_TO_CLASS_NAME = { + atrule: 'AtRule', + comment: 'Comment', + decl: 'Declaration', + document: 'Document', + root: 'Root', + rule: 'Rule' +} + +const PLUGIN_PROPS = { + AtRule: true, + AtRuleExit: true, + Comment: true, + CommentExit: true, + Declaration: true, + DeclarationExit: true, + Document: true, + DocumentExit: true, + Once: true, + OnceExit: true, + postcssPlugin: true, + prepare: true, + Root: true, + RootExit: true, + Rule: true, + RuleExit: true +} + +const NOT_VISITORS = { + Once: true, + postcssPlugin: true, + prepare: true +} + +const CHILDREN = 0 + +function isPromise(obj) { + return typeof obj === 'object' && typeof obj.then === 'function' +} + +function getEvents(node) { + let key = false + let type = TYPE_TO_CLASS_NAME[node.type] + if (node.type === 'decl') { + key = node.prop.toLowerCase() + } else if (node.type === 'atrule') { + key = node.name.toLowerCase() + } + + if (key && node.append) { + return [ + type, + type + '-' + key, + CHILDREN, + type + 'Exit', + type + 'Exit-' + key + ] + } else if (key) { + return [type, type + '-' + key, type + 'Exit', type + 'Exit-' + key] + } else if (node.append) { + return [type, CHILDREN, type + 'Exit'] + } else { + return [type, type + 'Exit'] + } +} + +function toStack(node) { + let events + if (node.type === 'document') { + events = ['Document', CHILDREN, 'DocumentExit'] + } else if (node.type === 'root') { + events = ['Root', CHILDREN, 'RootExit'] + } else { + events = getEvents(node) + } + + return { + eventIndex: 0, + events, + iterator: 0, + node, + visitorIndex: 0, + visitors: [] + } +} + +function cleanMarks(node) { + node[isClean] = false + if (node.nodes) node.nodes.forEach(i => cleanMarks(i)) + return node +} + +let postcss = {} + +class LazyResult { + constructor(processor, css, opts) { + this.stringified = false + this.processed = false + + let root + if ( + typeof css === 'object' && + css !== null && + (css.type === 'root' || css.type === 'document') + ) { + root = cleanMarks(css) + } else if (css instanceof LazyResult || css instanceof Result) { + root = cleanMarks(css.root) + if (css.map) { + if (typeof opts.map === 'undefined') opts.map = {} + if (!opts.map.inline) opts.map.inline = false + opts.map.prev = css.map + } + } else { + let parser = parse + if (opts.syntax) parser = opts.syntax.parse + if (opts.parser) parser = opts.parser + if (parser.parse) parser = parser.parse + + try { + root = parser(css, opts) + } catch (error) { + this.processed = true + this.error = error + } + + if (root && !root[my]) { + /* c8 ignore next 2 */ + Container.rebuild(root) + } + } + + this.result = new Result(processor, root, opts) + this.helpers = { ...postcss, postcss, result: this.result } + this.plugins = this.processor.plugins.map(plugin => { + if (typeof plugin === 'object' && plugin.prepare) { + return { ...plugin, ...plugin.prepare(this.result) } + } else { + return plugin + } + }) + } + + async() { + if (this.error) return Promise.reject(this.error) + if (this.processed) return Promise.resolve(this.result) + if (!this.processing) { + this.processing = this.runAsync() + } + return this.processing + } + + catch(onRejected) { + return this.async().catch(onRejected) + } + + finally(onFinally) { + return this.async().then(onFinally, onFinally) + } + + getAsyncError() { + throw new Error('Use process(css).then(cb) to work with async plugins') + } + + handleError(error, node) { + let plugin = this.result.lastPlugin + try { + if (node) node.addToError(error) + this.error = error + if (error.name === 'CssSyntaxError' && !error.plugin) { + error.plugin = plugin.postcssPlugin + error.setMessage() + } else if (plugin.postcssVersion) { + if (process.env.NODE_ENV !== 'production') { + let pluginName = plugin.postcssPlugin + let pluginVer = plugin.postcssVersion + let runtimeVer = this.result.processor.version + let a = pluginVer.split('.') + let b = runtimeVer.split('.') + + if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) { + // eslint-disable-next-line no-console + console.error( + 'Unknown error from PostCSS plugin. Your current PostCSS ' + + 'version is ' + + runtimeVer + + ', but ' + + pluginName + + ' uses ' + + pluginVer + + '. Perhaps this is the source of the error below.' + ) + } + } + } + } catch (err) { + /* c8 ignore next 3 */ + // eslint-disable-next-line no-console + if (console && console.error) console.error(err) + } + return error + } + + prepareVisitors() { + this.listeners = {} + let add = (plugin, type, cb) => { + if (!this.listeners[type]) this.listeners[type] = [] + this.listeners[type].push([plugin, cb]) + } + for (let plugin of this.plugins) { + if (typeof plugin === 'object') { + for (let event in plugin) { + if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { + throw new Error( + `Unknown event ${event} in ${plugin.postcssPlugin}. ` + + `Try to update PostCSS (${this.processor.version} now).` + ) + } + if (!NOT_VISITORS[event]) { + if (typeof plugin[event] === 'object') { + for (let filter in plugin[event]) { + if (filter === '*') { + add(plugin, event, plugin[event][filter]) + } else { + add( + plugin, + event + '-' + filter.toLowerCase(), + plugin[event][filter] + ) + } + } + } else if (typeof plugin[event] === 'function') { + add(plugin, event, plugin[event]) + } + } + } + } + } + this.hasListener = Object.keys(this.listeners).length > 0 + } + + async runAsync() { + this.plugin = 0 + for (let i = 0; i < this.plugins.length; i++) { + let plugin = this.plugins[i] + let promise = this.runOnRoot(plugin) + if (isPromise(promise)) { + try { + await promise + } catch (error) { + throw this.handleError(error) + } + } + } + + this.prepareVisitors() + if (this.hasListener) { + let root = this.result.root + while (!root[isClean]) { + root[isClean] = true + let stack = [toStack(root)] + while (stack.length > 0) { + let promise = this.visitTick(stack) + if (isPromise(promise)) { + try { + await promise + } catch (e) { + let node = stack[stack.length - 1].node + throw this.handleError(e, node) + } + } + } + } + + if (this.listeners.OnceExit) { + for (let [plugin, visitor] of this.listeners.OnceExit) { + this.result.lastPlugin = plugin + try { + if (root.type === 'document') { + let roots = root.nodes.map(subRoot => + visitor(subRoot, this.helpers) + ) + + await Promise.all(roots) + } else { + await visitor(root, this.helpers) + } + } catch (e) { + throw this.handleError(e) + } + } + } + } + + this.processed = true + return this.stringify() + } + + runOnRoot(plugin) { + this.result.lastPlugin = plugin + try { + if (typeof plugin === 'object' && plugin.Once) { + if (this.result.root.type === 'document') { + let roots = this.result.root.nodes.map(root => + plugin.Once(root, this.helpers) + ) + + if (isPromise(roots[0])) { + return Promise.all(roots) + } + + return roots + } + + return plugin.Once(this.result.root, this.helpers) + } else if (typeof plugin === 'function') { + return plugin(this.result.root, this.result) + } + } catch (error) { + throw this.handleError(error) + } + } + + stringify() { + if (this.error) throw this.error + if (this.stringified) return this.result + this.stringified = true + + this.sync() + + let opts = this.result.opts + let str = stringify + if (opts.syntax) str = opts.syntax.stringify + if (opts.stringifier) str = opts.stringifier + if (str.stringify) str = str.stringify + + let map = new MapGenerator(str, this.result.root, this.result.opts) + let data = map.generate() + this.result.css = data[0] + this.result.map = data[1] + + return this.result + } + + sync() { + if (this.error) throw this.error + if (this.processed) return this.result + this.processed = true + + if (this.processing) { + throw this.getAsyncError() + } + + for (let plugin of this.plugins) { + let promise = this.runOnRoot(plugin) + if (isPromise(promise)) { + throw this.getAsyncError() + } + } + + this.prepareVisitors() + if (this.hasListener) { + let root = this.result.root + while (!root[isClean]) { + root[isClean] = true + this.walkSync(root) + } + if (this.listeners.OnceExit) { + if (root.type === 'document') { + for (let subRoot of root.nodes) { + this.visitSync(this.listeners.OnceExit, subRoot) + } + } else { + this.visitSync(this.listeners.OnceExit, root) + } + } + } + + return this.result + } + + then(onFulfilled, onRejected) { + if (process.env.NODE_ENV !== 'production') { + if (!('from' in this.opts)) { + warnOnce( + 'Without `from` option PostCSS could generate wrong source map ' + + 'and will not find Browserslist config. Set it to CSS file path ' + + 'or to `undefined` to prevent this warning.' + ) + } + } + return this.async().then(onFulfilled, onRejected) + } + + toString() { + return this.css + } + + visitSync(visitors, node) { + for (let [plugin, visitor] of visitors) { + this.result.lastPlugin = plugin + let promise + try { + promise = visitor(node, this.helpers) + } catch (e) { + throw this.handleError(e, node.proxyOf) + } + if (node.type !== 'root' && node.type !== 'document' && !node.parent) { + return true + } + if (isPromise(promise)) { + throw this.getAsyncError() + } + } + } + + visitTick(stack) { + let visit = stack[stack.length - 1] + let { node, visitors } = visit + + if (node.type !== 'root' && node.type !== 'document' && !node.parent) { + stack.pop() + return + } + + if (visitors.length > 0 && visit.visitorIndex < visitors.length) { + let [plugin, visitor] = visitors[visit.visitorIndex] + visit.visitorIndex += 1 + if (visit.visitorIndex === visitors.length) { + visit.visitors = [] + visit.visitorIndex = 0 + } + this.result.lastPlugin = plugin + try { + return visitor(node.toProxy(), this.helpers) + } catch (e) { + throw this.handleError(e, node) + } + } + + if (visit.iterator !== 0) { + let iterator = visit.iterator + let child + while ((child = node.nodes[node.indexes[iterator]])) { + node.indexes[iterator] += 1 + if (!child[isClean]) { + child[isClean] = true + stack.push(toStack(child)) + return + } + } + visit.iterator = 0 + delete node.indexes[iterator] + } + + let events = visit.events + while (visit.eventIndex < events.length) { + let event = events[visit.eventIndex] + visit.eventIndex += 1 + if (event === CHILDREN) { + if (node.nodes && node.nodes.length) { + node[isClean] = true + visit.iterator = node.getIterator() + } + return + } else if (this.listeners[event]) { + visit.visitors = this.listeners[event] + return + } + } + stack.pop() + } + + walkSync(node) { + node[isClean] = true + let events = getEvents(node) + for (let event of events) { + if (event === CHILDREN) { + if (node.nodes) { + node.each(child => { + if (!child[isClean]) this.walkSync(child) + }) + } + } else { + let visitors = this.listeners[event] + if (visitors) { + if (this.visitSync(visitors, node.toProxy())) return + } + } + } + } + + warnings() { + return this.sync().warnings() + } + + get content() { + return this.stringify().content + } + + get css() { + return this.stringify().css + } + + get map() { + return this.stringify().map + } + + get messages() { + return this.sync().messages + } + + get opts() { + return this.result.opts + } + + get processor() { + return this.result.processor + } + + get root() { + return this.sync().root + } + + get [Symbol.toStringTag]() { + return 'LazyResult' + } +} + +LazyResult.registerPostcss = dependant => { + postcss = dependant +} + +module.exports = LazyResult +LazyResult.default = LazyResult + +Root.registerLazyResult(LazyResult) +Document.registerLazyResult(LazyResult) diff --git a/node_modules/postcss/lib/list.d.ts b/node_modules/postcss/lib/list.d.ts new file mode 100644 index 0000000..1a74d74 --- /dev/null +++ b/node_modules/postcss/lib/list.d.ts @@ -0,0 +1,57 @@ +declare namespace list { + type List = { + /** + * Safely splits comma-separated values (such as those for `transition-*` + * and `background` properties). + * + * ```js + * Once (root, { list }) { + * list.comma('black, linear-gradient(white, black)') + * //=> ['black', 'linear-gradient(white, black)'] + * } + * ``` + * + * @param str Comma-separated values. + * @return Split values. + */ + comma(str: string): string[] + + default: List + + /** + * Safely splits space-separated values (such as those for `background`, + * `border-radius`, and other shorthand properties). + * + * ```js + * Once (root, { list }) { + * list.space('1px calc(10% + 1px)') //=> ['1px', 'calc(10% + 1px)'] + * } + * ``` + * + * @param str Space-separated values. + * @return Split values. + */ + space(str: string): string[] + + /** + * Safely splits values. + * + * ```js + * Once (root, { list }) { + * list.split('1px calc(10% + 1px)', [' ', '\n', '\t']) //=> ['1px', 'calc(10% + 1px)'] + * } + * ``` + * + * @param string separated values. + * @param separators array of separators. + * @param last boolean indicator. + * @return Split values. + */ + split(string: string, separators: string[], last: boolean): string[] + } +} + +// eslint-disable-next-line @typescript-eslint/no-redeclare +declare const list: list.List + +export = list diff --git a/node_modules/postcss/lib/list.js b/node_modules/postcss/lib/list.js new file mode 100644 index 0000000..1b31f98 --- /dev/null +++ b/node_modules/postcss/lib/list.js @@ -0,0 +1,58 @@ +'use strict' + +let list = { + comma(string) { + return list.split(string, [','], true) + }, + + space(string) { + let spaces = [' ', '\n', '\t'] + return list.split(string, spaces) + }, + + split(string, separators, last) { + let array = [] + let current = '' + let split = false + + let func = 0 + let inQuote = false + let prevQuote = '' + let escape = false + + for (let letter of string) { + if (escape) { + escape = false + } else if (letter === '\\') { + escape = true + } else if (inQuote) { + if (letter === prevQuote) { + inQuote = false + } + } else if (letter === '"' || letter === "'") { + inQuote = true + prevQuote = letter + } else if (letter === '(') { + func += 1 + } else if (letter === ')') { + if (func > 0) func -= 1 + } else if (func === 0) { + if (separators.includes(letter)) split = true + } + + if (split) { + if (current !== '') array.push(current.trim()) + current = '' + split = false + } else { + current += letter + } + } + + if (last || current !== '') array.push(current.trim()) + return array + } +} + +module.exports = list +list.default = list diff --git a/node_modules/postcss/lib/map-generator.js b/node_modules/postcss/lib/map-generator.js new file mode 100644 index 0000000..71b21ca --- /dev/null +++ b/node_modules/postcss/lib/map-generator.js @@ -0,0 +1,368 @@ +'use strict' + +let { SourceMapConsumer, SourceMapGenerator } = require('source-map-js') +let { dirname, relative, resolve, sep } = require('path') +let { pathToFileURL } = require('url') + +let Input = require('./input') + +let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator) +let pathAvailable = Boolean(dirname && resolve && relative && sep) + +class MapGenerator { + constructor(stringify, root, opts, cssString) { + this.stringify = stringify + this.mapOpts = opts.map || {} + this.root = root + this.opts = opts + this.css = cssString + this.originalCSS = cssString + this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute + + this.memoizedFileURLs = new Map() + this.memoizedPaths = new Map() + this.memoizedURLs = new Map() + } + + addAnnotation() { + let content + + if (this.isInline()) { + content = + 'data:application/json;base64,' + this.toBase64(this.map.toString()) + } else if (typeof this.mapOpts.annotation === 'string') { + content = this.mapOpts.annotation + } else if (typeof this.mapOpts.annotation === 'function') { + content = this.mapOpts.annotation(this.opts.to, this.root) + } else { + content = this.outputFile() + '.map' + } + let eol = '\n' + if (this.css.includes('\r\n')) eol = '\r\n' + + this.css += eol + '/*# sourceMappingURL=' + content + ' */' + } + + applyPrevMaps() { + for (let prev of this.previous()) { + let from = this.toUrl(this.path(prev.file)) + let root = prev.root || dirname(prev.file) + let map + + if (this.mapOpts.sourcesContent === false) { + map = new SourceMapConsumer(prev.text) + if (map.sourcesContent) { + map.sourcesContent = null + } + } else { + map = prev.consumer() + } + + this.map.applySourceMap(map, from, this.toUrl(this.path(root))) + } + } + + clearAnnotation() { + if (this.mapOpts.annotation === false) return + + if (this.root) { + let node + for (let i = this.root.nodes.length - 1; i >= 0; i--) { + node = this.root.nodes[i] + if (node.type !== 'comment') continue + if (node.text.indexOf('# sourceMappingURL=') === 0) { + this.root.removeChild(i) + } + } + } else if (this.css) { + this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, '') + } + } + + generate() { + this.clearAnnotation() + if (pathAvailable && sourceMapAvailable && this.isMap()) { + return this.generateMap() + } else { + let result = '' + this.stringify(this.root, i => { + result += i + }) + return [result] + } + } + + generateMap() { + if (this.root) { + this.generateString() + } else if (this.previous().length === 1) { + let prev = this.previous()[0].consumer() + prev.file = this.outputFile() + this.map = SourceMapGenerator.fromSourceMap(prev, { + ignoreInvalidMapping: true + }) + } else { + this.map = new SourceMapGenerator({ + file: this.outputFile(), + ignoreInvalidMapping: true + }) + this.map.addMapping({ + generated: { column: 0, line: 1 }, + original: { column: 0, line: 1 }, + source: this.opts.from + ? this.toUrl(this.path(this.opts.from)) + : '' + }) + } + + if (this.isSourcesContent()) this.setSourcesContent() + if (this.root && this.previous().length > 0) this.applyPrevMaps() + if (this.isAnnotation()) this.addAnnotation() + + if (this.isInline()) { + return [this.css] + } else { + return [this.css, this.map] + } + } + + generateString() { + this.css = '' + this.map = new SourceMapGenerator({ + file: this.outputFile(), + ignoreInvalidMapping: true + }) + + let line = 1 + let column = 1 + + let noSource = '' + let mapping = { + generated: { column: 0, line: 0 }, + original: { column: 0, line: 0 }, + source: '' + } + + let lines, last + this.stringify(this.root, (str, node, type) => { + this.css += str + + if (node && type !== 'end') { + mapping.generated.line = line + mapping.generated.column = column - 1 + if (node.source && node.source.start) { + mapping.source = this.sourcePath(node) + mapping.original.line = node.source.start.line + mapping.original.column = node.source.start.column - 1 + this.map.addMapping(mapping) + } else { + mapping.source = noSource + mapping.original.line = 1 + mapping.original.column = 0 + this.map.addMapping(mapping) + } + } + + lines = str.match(/\n/g) + if (lines) { + line += lines.length + last = str.lastIndexOf('\n') + column = str.length - last + } else { + column += str.length + } + + if (node && type !== 'start') { + let p = node.parent || { raws: {} } + let childless = + node.type === 'decl' || (node.type === 'atrule' && !node.nodes) + if (!childless || node !== p.last || p.raws.semicolon) { + if (node.source && node.source.end) { + mapping.source = this.sourcePath(node) + mapping.original.line = node.source.end.line + mapping.original.column = node.source.end.column - 1 + mapping.generated.line = line + mapping.generated.column = column - 2 + this.map.addMapping(mapping) + } else { + mapping.source = noSource + mapping.original.line = 1 + mapping.original.column = 0 + mapping.generated.line = line + mapping.generated.column = column - 1 + this.map.addMapping(mapping) + } + } + } + }) + } + + isAnnotation() { + if (this.isInline()) { + return true + } + if (typeof this.mapOpts.annotation !== 'undefined') { + return this.mapOpts.annotation + } + if (this.previous().length) { + return this.previous().some(i => i.annotation) + } + return true + } + + isInline() { + if (typeof this.mapOpts.inline !== 'undefined') { + return this.mapOpts.inline + } + + let annotation = this.mapOpts.annotation + if (typeof annotation !== 'undefined' && annotation !== true) { + return false + } + + if (this.previous().length) { + return this.previous().some(i => i.inline) + } + return true + } + + isMap() { + if (typeof this.opts.map !== 'undefined') { + return !!this.opts.map + } + return this.previous().length > 0 + } + + isSourcesContent() { + if (typeof this.mapOpts.sourcesContent !== 'undefined') { + return this.mapOpts.sourcesContent + } + if (this.previous().length) { + return this.previous().some(i => i.withContent()) + } + return true + } + + outputFile() { + if (this.opts.to) { + return this.path(this.opts.to) + } else if (this.opts.from) { + return this.path(this.opts.from) + } else { + return 'to.css' + } + } + + path(file) { + if (this.mapOpts.absolute) return file + if (file.charCodeAt(0) === 60 /* `<` */) return file + if (/^\w+:\/\//.test(file)) return file + let cached = this.memoizedPaths.get(file) + if (cached) return cached + + let from = this.opts.to ? dirname(this.opts.to) : '.' + + if (typeof this.mapOpts.annotation === 'string') { + from = dirname(resolve(from, this.mapOpts.annotation)) + } + + let path = relative(from, file) + this.memoizedPaths.set(file, path) + + return path + } + + previous() { + if (!this.previousMaps) { + this.previousMaps = [] + if (this.root) { + this.root.walk(node => { + if (node.source && node.source.input.map) { + let map = node.source.input.map + if (!this.previousMaps.includes(map)) { + this.previousMaps.push(map) + } + } + }) + } else { + let input = new Input(this.originalCSS, this.opts) + if (input.map) this.previousMaps.push(input.map) + } + } + + return this.previousMaps + } + + setSourcesContent() { + let already = {} + if (this.root) { + this.root.walk(node => { + if (node.source) { + let from = node.source.input.from + if (from && !already[from]) { + already[from] = true + let fromUrl = this.usesFileUrls + ? this.toFileUrl(from) + : this.toUrl(this.path(from)) + this.map.setSourceContent(fromUrl, node.source.input.css) + } + } + }) + } else if (this.css) { + let from = this.opts.from + ? this.toUrl(this.path(this.opts.from)) + : '' + this.map.setSourceContent(from, this.css) + } + } + + sourcePath(node) { + if (this.mapOpts.from) { + return this.toUrl(this.mapOpts.from) + } else if (this.usesFileUrls) { + return this.toFileUrl(node.source.input.from) + } else { + return this.toUrl(this.path(node.source.input.from)) + } + } + + toBase64(str) { + if (Buffer) { + return Buffer.from(str).toString('base64') + } else { + return window.btoa(unescape(encodeURIComponent(str))) + } + } + + toFileUrl(path) { + let cached = this.memoizedFileURLs.get(path) + if (cached) return cached + + if (pathToFileURL) { + let fileURL = pathToFileURL(path).toString() + this.memoizedFileURLs.set(path, fileURL) + + return fileURL + } else { + throw new Error( + '`map.absolute` option is not available in this PostCSS build' + ) + } + } + + toUrl(path) { + let cached = this.memoizedURLs.get(path) + if (cached) return cached + + if (sep === '\\') { + path = path.replace(/\\/g, '/') + } + + let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent) + this.memoizedURLs.set(path, url) + + return url + } +} + +module.exports = MapGenerator diff --git a/node_modules/postcss/lib/no-work-result.d.ts b/node_modules/postcss/lib/no-work-result.d.ts new file mode 100644 index 0000000..8039076 --- /dev/null +++ b/node_modules/postcss/lib/no-work-result.d.ts @@ -0,0 +1,46 @@ +import LazyResult from './lazy-result.js' +import { SourceMap } from './postcss.js' +import Processor from './processor.js' +import Result, { Message, ResultOptions } from './result.js' +import Root from './root.js' +import Warning from './warning.js' + +declare namespace NoWorkResult { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { NoWorkResult_ as default } +} + +/** + * A Promise proxy for the result of PostCSS transformations. + * This lazy result instance doesn't parse css unless `NoWorkResult#root` or `Result#root` + * are accessed. See the example below for details. + * A `NoWork` instance is returned by `Processor#process` ONLY when no plugins defined. + * + * ```js + * const noWorkResult = postcss().process(css) // No plugins are defined. + * // CSS is not parsed + * let root = noWorkResult.root // now css is parsed because we accessed the root + * ``` + */ +declare class NoWorkResult_ implements LazyResult { + catch: Promise>['catch'] + finally: Promise>['finally'] + then: Promise>['then'] + constructor(processor: Processor, css: string, opts: ResultOptions) + async(): Promise> + sync(): Result + toString(): string + warnings(): Warning[] + get content(): string + get css(): string + get map(): SourceMap + get messages(): Message[] + get opts(): ResultOptions + get processor(): Processor + get root(): Root + get [Symbol.toStringTag](): string +} + +declare class NoWorkResult extends NoWorkResult_ {} + +export = NoWorkResult diff --git a/node_modules/postcss/lib/no-work-result.js b/node_modules/postcss/lib/no-work-result.js new file mode 100644 index 0000000..05821b7 --- /dev/null +++ b/node_modules/postcss/lib/no-work-result.js @@ -0,0 +1,138 @@ +'use strict' + +let MapGenerator = require('./map-generator') +let stringify = require('./stringify') +let warnOnce = require('./warn-once') +let parse = require('./parse') +const Result = require('./result') + +class NoWorkResult { + constructor(processor, css, opts) { + css = css.toString() + this.stringified = false + + this._processor = processor + this._css = css + this._opts = opts + this._map = undefined + let root + + let str = stringify + this.result = new Result(this._processor, root, this._opts) + this.result.css = css + + let self = this + Object.defineProperty(this.result, 'root', { + get() { + return self.root + } + }) + + let map = new MapGenerator(str, root, this._opts, css) + if (map.isMap()) { + let [generatedCSS, generatedMap] = map.generate() + if (generatedCSS) { + this.result.css = generatedCSS + } + if (generatedMap) { + this.result.map = generatedMap + } + } else { + map.clearAnnotation() + this.result.css = map.css + } + } + + async() { + if (this.error) return Promise.reject(this.error) + return Promise.resolve(this.result) + } + + catch(onRejected) { + return this.async().catch(onRejected) + } + + finally(onFinally) { + return this.async().then(onFinally, onFinally) + } + + sync() { + if (this.error) throw this.error + return this.result + } + + then(onFulfilled, onRejected) { + if (process.env.NODE_ENV !== 'production') { + if (!('from' in this._opts)) { + warnOnce( + 'Without `from` option PostCSS could generate wrong source map ' + + 'and will not find Browserslist config. Set it to CSS file path ' + + 'or to `undefined` to prevent this warning.' + ) + } + } + + return this.async().then(onFulfilled, onRejected) + } + + toString() { + return this._css + } + + warnings() { + return [] + } + + get content() { + return this.result.css + } + + get css() { + return this.result.css + } + + get map() { + return this.result.map + } + + get messages() { + return [] + } + + get opts() { + return this.result.opts + } + + get processor() { + return this.result.processor + } + + get root() { + if (this._root) { + return this._root + } + + let root + let parser = parse + + try { + root = parser(this._css, this._opts) + } catch (error) { + this.error = error + } + + if (this.error) { + throw this.error + } else { + this._root = root + return root + } + } + + get [Symbol.toStringTag]() { + return 'NoWorkResult' + } +} + +module.exports = NoWorkResult +NoWorkResult.default = NoWorkResult diff --git a/node_modules/postcss/lib/node.d.ts b/node_modules/postcss/lib/node.d.ts new file mode 100644 index 0000000..5971656 --- /dev/null +++ b/node_modules/postcss/lib/node.d.ts @@ -0,0 +1,536 @@ +import AtRule = require('./at-rule.js') + +import { AtRuleProps } from './at-rule.js' +import Comment, { CommentProps } from './comment.js' +import Container from './container.js' +import CssSyntaxError from './css-syntax-error.js' +import Declaration, { DeclarationProps } from './declaration.js' +import Document from './document.js' +import Input from './input.js' +import { Stringifier, Syntax } from './postcss.js' +import Result from './result.js' +import Root from './root.js' +import Rule, { RuleProps } from './rule.js' +import Warning, { WarningOptions } from './warning.js' + +declare namespace Node { + export type ChildNode = AtRule.default | Comment | Declaration | Rule + + export type AnyNode = + | AtRule.default + | Comment + | Declaration + | Document + | Root + | Rule + + export type ChildProps = + | AtRuleProps + | CommentProps + | DeclarationProps + | RuleProps + + export interface Position { + /** + * Source line in file. In contrast to `offset` it starts from 1. + */ + column: number + + /** + * Source column in file. + */ + line: number + + /** + * Source offset in file. It starts from 0. + */ + offset: number + } + + export interface Range { + /** + * End position, exclusive. + */ + end: Position + + /** + * Start position, inclusive. + */ + start: Position + } + + /** + * Source represents an interface for the {@link Node.source} property. + */ + export interface Source { + /** + * The inclusive ending position for the source + * code of a node. + */ + end?: Position + + /** + * The source file from where a node has originated. + */ + input: Input + + /** + * The inclusive starting position for the source + * code of a node. + */ + start?: Position + } + + /** + * Interface represents an interface for an object received + * as parameter by Node class constructor. + */ + export interface NodeProps { + source?: Source + } + + export interface NodeErrorOptions { + /** + * An ending index inside a node's string that should be highlighted as + * source of error. + */ + endIndex?: number + /** + * An index inside a node's string that should be highlighted as source + * of error. + */ + index?: number + /** + * Plugin name that created this error. PostCSS will set it automatically. + */ + plugin?: string + /** + * A word inside a node's string, that should be highlighted as source + * of error. + */ + word?: string + } + + // eslint-disable-next-line @typescript-eslint/no-shadow + class Node extends Node_ {} + export { Node as default } +} + +/** + * It represents an abstract class that handles common + * methods for other CSS abstract syntax tree nodes. + * + * Any node that represents CSS selector or value should + * not extend the `Node` class. + */ +declare abstract class Node_ { + /** + * It represents parent of the current node. + * + * ```js + * root.nodes[0].parent === root //=> true + * ``` + */ + parent: Container | Document | undefined + + /** + * It represents unnecessary whitespace and characters present + * in the css source code. + * + * Information to generate byte-to-byte equal node string as it was + * in the origin input. + * + * The properties of the raws object are decided by parser, + * the default parser uses the following properties: + * + * * `before`: the space symbols before the node. It also stores `*` + * and `_` symbols before the declaration (IE hack). + * * `after`: the space symbols after the last child of the node + * to the end of the node. + * * `between`: the symbols between the property and value + * for declarations, selector and `{` for rules, or last parameter + * and `{` for at-rules. + * * `semicolon`: contains true if the last child has + * an (optional) semicolon. + * * `afterName`: the space between the at-rule name and its parameters. + * * `left`: the space symbols between `/*` and the comment’s text. + * * `right`: the space symbols between the comment’s text + * and */. + * - `important`: the content of the important statement, + * if it is not just `!important`. + * + * PostCSS filters out the comments inside selectors, declaration values + * and at-rule parameters but it stores the origin content in raws. + * + * ```js + * const root = postcss.parse('a {\n color:black\n}') + * root.first.first.raws //=> { before: '\n ', between: ':' } + * ``` + */ + raws: any + + /** + * It represents information related to origin of a node and is required + * for generating source maps. + * + * The nodes that are created manually using the public APIs + * provided by PostCSS will have `source` undefined and + * will be absent in the source map. + * + * For this reason, the plugin developer should consider + * duplicating nodes as the duplicate node will have the + * same source as the original node by default or assign + * source to a node created manually. + * + * ```js + * decl.source.input.from //=> '/home/ai/source.css' + * decl.source.start //=> { line: 10, column: 2 } + * decl.source.end //=> { line: 10, column: 12 } + * ``` + * + * ```js + * // Incorrect method, source not specified! + * const prefixed = postcss.decl({ + * prop: '-moz-' + decl.prop, + * value: decl.value + * }) + * + * // Correct method, source is inherited when duplicating. + * const prefixed = decl.clone({ + * prop: '-moz-' + decl.prop + * }) + * ``` + * + * ```js + * if (atrule.name === 'add-link') { + * const rule = postcss.rule({ + * selector: 'a', + * source: atrule.source + * }) + * + * atrule.parent.insertBefore(atrule, rule) + * } + * ``` + */ + source?: Node.Source + + /** + * It represents type of a node in + * an abstract syntax tree. + * + * A type of node helps in identification of a node + * and perform operation based on it's type. + * + * ```js + * const declaration = new Declaration({ + * prop: 'color', + * value: 'black' + * }) + * + * declaration.type //=> 'decl' + * ``` + */ + type: string + + constructor(defaults?: object) + + /** + * Insert new node after current node to current node’s parent. + * + * Just alias for `node.parent.insertAfter(node, add)`. + * + * ```js + * decl.after('color: black') + * ``` + * + * @param newNode New node. + * @return This node for methods chain. + */ + after(newNode: Node | Node.ChildProps | Node[] | string | undefined): this + + /** + * It assigns properties to an existing node instance. + * + * ```js + * decl.assign({ prop: 'word-wrap', value: 'break-word' }) + * ``` + * + * @param overrides New properties to override the node. + * + * @return `this` for method chaining. + */ + assign(overrides: object): this + + /** + * Insert new node before current node to current node’s parent. + * + * Just alias for `node.parent.insertBefore(node, add)`. + * + * ```js + * decl.before('content: ""') + * ``` + * + * @param newNode New node. + * @return This node for methods chain. + */ + before(newNode: Node | Node.ChildProps | Node[] | string | undefined): this + + /** + * Clear the code style properties for the node and its children. + * + * ```js + * node.raws.before //=> ' ' + * node.cleanRaws() + * node.raws.before //=> undefined + * ``` + * + * @param keepBetween Keep the `raws.between` symbols. + */ + cleanRaws(keepBetween?: boolean): void + + /** + * It creates clone of an existing node, which includes all the properties + * and their values, that includes `raws` but not `type`. + * + * ```js + * decl.raws.before //=> "\n " + * const cloned = decl.clone({ prop: '-moz-' + decl.prop }) + * cloned.raws.before //=> "\n " + * cloned.toString() //=> -moz-transform: scale(0) + * ``` + * + * @param overrides New properties to override in the clone. + * + * @return Duplicate of the node instance. + */ + clone(overrides?: object): Node + + /** + * Shortcut to clone the node and insert the resulting cloned node + * after the current node. + * + * @param overrides New properties to override in the clone. + * @return New node. + */ + cloneAfter(overrides?: object): Node + + /** + * Shortcut to clone the node and insert the resulting cloned node + * before the current node. + * + * ```js + * decl.cloneBefore({ prop: '-moz-' + decl.prop }) + * ``` + * + * @param overrides Mew properties to override in the clone. + * + * @return New node + */ + cloneBefore(overrides?: object): Node + + /** + * It creates an instance of the class `CssSyntaxError` and parameters passed + * to this method are assigned to the error instance. + * + * The error instance will have description for the + * error, original position of the node in the + * source, showing line and column number. + * + * If any previous map is present, it would be used + * to get original position of the source. + * + * The Previous Map here is referred to the source map + * generated by previous compilation, example: Less, + * Stylus and Sass. + * + * This method returns the error instance instead of + * throwing it. + * + * ```js + * if (!variables[name]) { + * throw decl.error(`Unknown variable ${name}`, { word: name }) + * // CssSyntaxError: postcss-vars:a.sass:4:3: Unknown variable $black + * // color: $black + * // a + * // ^ + * // background: white + * } + * ``` + * + * @param message Description for the error instance. + * @param options Options for the error instance. + * + * @return Error instance is returned. + */ + error(message: string, options?: Node.NodeErrorOptions): CssSyntaxError + + /** + * Returns the next child of the node’s parent. + * Returns `undefined` if the current node is the last child. + * + * ```js + * if (comment.text === 'delete next') { + * const next = comment.next() + * if (next) { + * next.remove() + * } + * } + * ``` + * + * @return Next node. + */ + next(): Node.ChildNode | undefined + + /** + * Get the position for a word or an index inside the node. + * + * @param opts Options. + * @return Position. + */ + positionBy(opts?: Pick): Node.Position + + /** + * Convert string index to line/column. + * + * @param index The symbol number in the node’s string. + * @return Symbol position in file. + */ + positionInside(index: number): Node.Position + + /** + * Returns the previous child of the node’s parent. + * Returns `undefined` if the current node is the first child. + * + * ```js + * const annotation = decl.prev() + * if (annotation.type === 'comment') { + * readAnnotation(annotation.text) + * } + * ``` + * + * @return Previous node. + */ + prev(): Node.ChildNode | undefined + + /** + * Get the range for a word or start and end index inside the node. + * The start index is inclusive; the end index is exclusive. + * + * @param opts Options. + * @return Range. + */ + rangeBy( + opts?: Pick + ): Node.Range + + /** + * Returns a `raws` value. If the node is missing + * the code style property (because the node was manually built or cloned), + * PostCSS will try to autodetect the code style property by looking + * at other nodes in the tree. + * + * ```js + * const root = postcss.parse('a { background: white }') + * root.nodes[0].append({ prop: 'color', value: 'black' }) + * root.nodes[0].nodes[1].raws.before //=> undefined + * root.nodes[0].nodes[1].raw('before') //=> ' ' + * ``` + * + * @param prop Name of code style property. + * @param defaultType Name of default value, it can be missed + * if the value is the same as prop. + * @return {string} Code style value. + */ + raw(prop: string, defaultType?: string): string + + /** + * It removes the node from its parent and deletes its parent property. + * + * ```js + * if (decl.prop.match(/^-webkit-/)) { + * decl.remove() + * } + * ``` + * + * @return `this` for method chaining. + */ + remove(): this + + /** + * Inserts node(s) before the current node and removes the current node. + * + * ```js + * AtRule: { + * mixin: atrule => { + * atrule.replaceWith(mixinRules[atrule.params]) + * } + * } + * ``` + * + * @param nodes Mode(s) to replace current one. + * @return Current node to methods chain. + */ + replaceWith( + ...nodes: ( + | Node.ChildNode + | Node.ChildNode[] + | Node.ChildProps + | Node.ChildProps[] + )[] + ): this + + /** + * Finds the Root instance of the node’s tree. + * + * ```js + * root.nodes[0].nodes[0].root() === root + * ``` + * + * @return Root parent. + */ + root(): Root + + /** + * Fix circular links on `JSON.stringify()`. + * + * @return Cleaned object. + */ + toJSON(): object + + /** + * It compiles the node to browser readable cascading style sheets string + * depending on it's type. + * + * ```js + * new Rule({ selector: 'a' }).toString() //=> "a {}" + * ``` + * + * @param stringifier A syntax to use in string generation. + * @return CSS string of this node. + */ + toString(stringifier?: Stringifier | Syntax): string + + /** + * It is a wrapper for {@link Result#warn}, providing convenient + * way of generating warnings. + * + * ```js + * Declaration: { + * bad: (decl, { result }) => { + * decl.warn(result, 'Deprecated property: bad') + * } + * } + * ``` + * + * @param result The `Result` instance that will receive the warning. + * @param message Description for the warning. + * @param options Options for the warning. + * + * @return `Warning` instance is returned + */ + warn(result: Result, message: string, options?: WarningOptions): Warning +} + +declare class Node extends Node_ {} + +export = Node diff --git a/node_modules/postcss/lib/node.js b/node_modules/postcss/lib/node.js new file mode 100644 index 0000000..9e747ca --- /dev/null +++ b/node_modules/postcss/lib/node.js @@ -0,0 +1,381 @@ +'use strict' + +let { isClean, my } = require('./symbols') +let CssSyntaxError = require('./css-syntax-error') +let Stringifier = require('./stringifier') +let stringify = require('./stringify') + +function cloneNode(obj, parent) { + let cloned = new obj.constructor() + + for (let i in obj) { + if (!Object.prototype.hasOwnProperty.call(obj, i)) { + /* c8 ignore next 2 */ + continue + } + if (i === 'proxyCache') continue + let value = obj[i] + let type = typeof value + + if (i === 'parent' && type === 'object') { + if (parent) cloned[i] = parent + } else if (i === 'source') { + cloned[i] = value + } else if (Array.isArray(value)) { + cloned[i] = value.map(j => cloneNode(j, cloned)) + } else { + if (type === 'object' && value !== null) value = cloneNode(value) + cloned[i] = value + } + } + + return cloned +} + +class Node { + constructor(defaults = {}) { + this.raws = {} + this[isClean] = false + this[my] = true + + for (let name in defaults) { + if (name === 'nodes') { + this.nodes = [] + for (let node of defaults[name]) { + if (typeof node.clone === 'function') { + this.append(node.clone()) + } else { + this.append(node) + } + } + } else { + this[name] = defaults[name] + } + } + } + + addToError(error) { + error.postcssNode = this + if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { + let s = this.source + error.stack = error.stack.replace( + /\n\s{4}at /, + `$&${s.input.from}:${s.start.line}:${s.start.column}$&` + ) + } + return error + } + + after(add) { + this.parent.insertAfter(this, add) + return this + } + + assign(overrides = {}) { + for (let name in overrides) { + this[name] = overrides[name] + } + return this + } + + before(add) { + this.parent.insertBefore(this, add) + return this + } + + cleanRaws(keepBetween) { + delete this.raws.before + delete this.raws.after + if (!keepBetween) delete this.raws.between + } + + clone(overrides = {}) { + let cloned = cloneNode(this) + for (let name in overrides) { + cloned[name] = overrides[name] + } + return cloned + } + + cloneAfter(overrides = {}) { + let cloned = this.clone(overrides) + this.parent.insertAfter(this, cloned) + return cloned + } + + cloneBefore(overrides = {}) { + let cloned = this.clone(overrides) + this.parent.insertBefore(this, cloned) + return cloned + } + + error(message, opts = {}) { + if (this.source) { + let { end, start } = this.rangeBy(opts) + return this.source.input.error( + message, + { column: start.column, line: start.line }, + { column: end.column, line: end.line }, + opts + ) + } + return new CssSyntaxError(message) + } + + getProxyProcessor() { + return { + get(node, prop) { + if (prop === 'proxyOf') { + return node + } else if (prop === 'root') { + return () => node.root().toProxy() + } else { + return node[prop] + } + }, + + set(node, prop, value) { + if (node[prop] === value) return true + node[prop] = value + if ( + prop === 'prop' || + prop === 'value' || + prop === 'name' || + prop === 'params' || + prop === 'important' || + /* c8 ignore next */ + prop === 'text' + ) { + node.markDirty() + } + return true + } + } + } + + markDirty() { + if (this[isClean]) { + this[isClean] = false + let next = this + while ((next = next.parent)) { + next[isClean] = false + } + } + } + + next() { + if (!this.parent) return undefined + let index = this.parent.index(this) + return this.parent.nodes[index + 1] + } + + positionBy(opts, stringRepresentation) { + let pos = this.source.start + if (opts.index) { + pos = this.positionInside(opts.index, stringRepresentation) + } else if (opts.word) { + stringRepresentation = this.toString() + let index = stringRepresentation.indexOf(opts.word) + if (index !== -1) pos = this.positionInside(index, stringRepresentation) + } + return pos + } + + positionInside(index, stringRepresentation) { + let string = stringRepresentation || this.toString() + let column = this.source.start.column + let line = this.source.start.line + + for (let i = 0; i < index; i++) { + if (string[i] === '\n') { + column = 1 + line += 1 + } else { + column += 1 + } + } + + return { column, line } + } + + prev() { + if (!this.parent) return undefined + let index = this.parent.index(this) + return this.parent.nodes[index - 1] + } + + rangeBy(opts) { + let start = { + column: this.source.start.column, + line: this.source.start.line + } + let end = this.source.end + ? { + column: this.source.end.column + 1, + line: this.source.end.line + } + : { + column: start.column + 1, + line: start.line + } + + if (opts.word) { + let stringRepresentation = this.toString() + let index = stringRepresentation.indexOf(opts.word) + if (index !== -1) { + start = this.positionInside(index, stringRepresentation) + end = this.positionInside(index + opts.word.length, stringRepresentation) + } + } else { + if (opts.start) { + start = { + column: opts.start.column, + line: opts.start.line + } + } else if (opts.index) { + start = this.positionInside(opts.index) + } + + if (opts.end) { + end = { + column: opts.end.column, + line: opts.end.line + } + } else if (typeof opts.endIndex === 'number') { + end = this.positionInside(opts.endIndex) + } else if (opts.index) { + end = this.positionInside(opts.index + 1) + } + } + + if ( + end.line < start.line || + (end.line === start.line && end.column <= start.column) + ) { + end = { column: start.column + 1, line: start.line } + } + + return { end, start } + } + + raw(prop, defaultType) { + let str = new Stringifier() + return str.raw(this, prop, defaultType) + } + + remove() { + if (this.parent) { + this.parent.removeChild(this) + } + this.parent = undefined + return this + } + + replaceWith(...nodes) { + if (this.parent) { + let bookmark = this + let foundSelf = false + for (let node of nodes) { + if (node === this) { + foundSelf = true + } else if (foundSelf) { + this.parent.insertAfter(bookmark, node) + bookmark = node + } else { + this.parent.insertBefore(bookmark, node) + } + } + + if (!foundSelf) { + this.remove() + } + } + + return this + } + + root() { + let result = this + while (result.parent && result.parent.type !== 'document') { + result = result.parent + } + return result + } + + toJSON(_, inputs) { + let fixed = {} + let emitInputs = inputs == null + inputs = inputs || new Map() + let inputsNextIndex = 0 + + for (let name in this) { + if (!Object.prototype.hasOwnProperty.call(this, name)) { + /* c8 ignore next 2 */ + continue + } + if (name === 'parent' || name === 'proxyCache') continue + let value = this[name] + + if (Array.isArray(value)) { + fixed[name] = value.map(i => { + if (typeof i === 'object' && i.toJSON) { + return i.toJSON(null, inputs) + } else { + return i + } + }) + } else if (typeof value === 'object' && value.toJSON) { + fixed[name] = value.toJSON(null, inputs) + } else if (name === 'source') { + let inputId = inputs.get(value.input) + if (inputId == null) { + inputId = inputsNextIndex + inputs.set(value.input, inputsNextIndex) + inputsNextIndex++ + } + fixed[name] = { + end: value.end, + inputId, + start: value.start + } + } else { + fixed[name] = value + } + } + + if (emitInputs) { + fixed.inputs = [...inputs.keys()].map(input => input.toJSON()) + } + + return fixed + } + + toProxy() { + if (!this.proxyCache) { + this.proxyCache = new Proxy(this, this.getProxyProcessor()) + } + return this.proxyCache + } + + toString(stringifier = stringify) { + if (stringifier.stringify) stringifier = stringifier.stringify + let result = '' + stringifier(this, i => { + result += i + }) + return result + } + + warn(result, text, opts) { + let data = { node: this } + for (let i in opts) data[i] = opts[i] + return result.warn(text, data) + } + + get proxyOf() { + return this + } +} + +module.exports = Node +Node.default = Node diff --git a/node_modules/postcss/lib/parse.d.ts b/node_modules/postcss/lib/parse.d.ts new file mode 100644 index 0000000..4c943a4 --- /dev/null +++ b/node_modules/postcss/lib/parse.d.ts @@ -0,0 +1,9 @@ +import { Parser } from './postcss.js' + +interface Parse extends Parser { + default: Parse +} + +declare const parse: Parse + +export = parse diff --git a/node_modules/postcss/lib/parse.js b/node_modules/postcss/lib/parse.js new file mode 100644 index 0000000..971431f --- /dev/null +++ b/node_modules/postcss/lib/parse.js @@ -0,0 +1,42 @@ +'use strict' + +let Container = require('./container') +let Parser = require('./parser') +let Input = require('./input') + +function parse(css, opts) { + let input = new Input(css, opts) + let parser = new Parser(input) + try { + parser.parse() + } catch (e) { + if (process.env.NODE_ENV !== 'production') { + if (e.name === 'CssSyntaxError' && opts && opts.from) { + if (/\.scss$/i.test(opts.from)) { + e.message += + '\nYou tried to parse SCSS with ' + + 'the standard CSS parser; ' + + 'try again with the postcss-scss parser' + } else if (/\.sass/i.test(opts.from)) { + e.message += + '\nYou tried to parse Sass with ' + + 'the standard CSS parser; ' + + 'try again with the postcss-sass parser' + } else if (/\.less$/i.test(opts.from)) { + e.message += + '\nYou tried to parse Less with ' + + 'the standard CSS parser; ' + + 'try again with the postcss-less parser' + } + } + } + throw e + } + + return parser.root +} + +module.exports = parse +parse.default = parse + +Container.registerParse(parse) diff --git a/node_modules/postcss/lib/parser.js b/node_modules/postcss/lib/parser.js new file mode 100644 index 0000000..bc761de --- /dev/null +++ b/node_modules/postcss/lib/parser.js @@ -0,0 +1,609 @@ +'use strict' + +let Declaration = require('./declaration') +let tokenizer = require('./tokenize') +let Comment = require('./comment') +let AtRule = require('./at-rule') +let Root = require('./root') +let Rule = require('./rule') + +const SAFE_COMMENT_NEIGHBOR = { + empty: true, + space: true +} + +function findLastWithPosition(tokens) { + for (let i = tokens.length - 1; i >= 0; i--) { + let token = tokens[i] + let pos = token[3] || token[2] + if (pos) return pos + } +} + +class Parser { + constructor(input) { + this.input = input + + this.root = new Root() + this.current = this.root + this.spaces = '' + this.semicolon = false + + this.createTokenizer() + this.root.source = { input, start: { column: 1, line: 1, offset: 0 } } + } + + atrule(token) { + let node = new AtRule() + node.name = token[1].slice(1) + if (node.name === '') { + this.unnamedAtrule(node, token) + } + this.init(node, token[2]) + + let type + let prev + let shift + let last = false + let open = false + let params = [] + let brackets = [] + + while (!this.tokenizer.endOfFile()) { + token = this.tokenizer.nextToken() + type = token[0] + + if (type === '(' || type === '[') { + brackets.push(type === '(' ? ')' : ']') + } else if (type === '{' && brackets.length > 0) { + brackets.push('}') + } else if (type === brackets[brackets.length - 1]) { + brackets.pop() + } + + if (brackets.length === 0) { + if (type === ';') { + node.source.end = this.getPosition(token[2]) + node.source.end.offset++ + this.semicolon = true + break + } else if (type === '{') { + open = true + break + } else if (type === '}') { + if (params.length > 0) { + shift = params.length - 1 + prev = params[shift] + while (prev && prev[0] === 'space') { + prev = params[--shift] + } + if (prev) { + node.source.end = this.getPosition(prev[3] || prev[2]) + node.source.end.offset++ + } + } + this.end(token) + break + } else { + params.push(token) + } + } else { + params.push(token) + } + + if (this.tokenizer.endOfFile()) { + last = true + break + } + } + + node.raws.between = this.spacesAndCommentsFromEnd(params) + if (params.length) { + node.raws.afterName = this.spacesAndCommentsFromStart(params) + this.raw(node, 'params', params) + if (last) { + token = params[params.length - 1] + node.source.end = this.getPosition(token[3] || token[2]) + node.source.end.offset++ + this.spaces = node.raws.between + node.raws.between = '' + } + } else { + node.raws.afterName = '' + node.params = '' + } + + if (open) { + node.nodes = [] + this.current = node + } + } + + checkMissedSemicolon(tokens) { + let colon = this.colon(tokens) + if (colon === false) return + + let founded = 0 + let token + for (let j = colon - 1; j >= 0; j--) { + token = tokens[j] + if (token[0] !== 'space') { + founded += 1 + if (founded === 2) break + } + } + // If the token is a word, e.g. `!important`, `red` or any other valid property's value. + // Then we need to return the colon after that word token. [3] is the "end" colon of that word. + // And because we need it after that one we do +1 to get the next one. + throw this.input.error( + 'Missed semicolon', + token[0] === 'word' ? token[3] + 1 : token[2] + ) + } + + colon(tokens) { + let brackets = 0 + let token, type, prev + for (let [i, element] of tokens.entries()) { + token = element + type = token[0] + + if (type === '(') { + brackets += 1 + } + if (type === ')') { + brackets -= 1 + } + if (brackets === 0 && type === ':') { + if (!prev) { + this.doubleColon(token) + } else if (prev[0] === 'word' && prev[1] === 'progid') { + continue + } else { + return i + } + } + + prev = token + } + return false + } + + comment(token) { + let node = new Comment() + this.init(node, token[2]) + node.source.end = this.getPosition(token[3] || token[2]) + node.source.end.offset++ + + let text = token[1].slice(2, -2) + if (/^\s*$/.test(text)) { + node.text = '' + node.raws.left = text + node.raws.right = '' + } else { + let match = text.match(/^(\s*)([^]*\S)(\s*)$/) + node.text = match[2] + node.raws.left = match[1] + node.raws.right = match[3] + } + } + + createTokenizer() { + this.tokenizer = tokenizer(this.input) + } + + decl(tokens, customProperty) { + let node = new Declaration() + this.init(node, tokens[0][2]) + + let last = tokens[tokens.length - 1] + if (last[0] === ';') { + this.semicolon = true + tokens.pop() + } + + node.source.end = this.getPosition( + last[3] || last[2] || findLastWithPosition(tokens) + ) + node.source.end.offset++ + + while (tokens[0][0] !== 'word') { + if (tokens.length === 1) this.unknownWord(tokens) + node.raws.before += tokens.shift()[1] + } + node.source.start = this.getPosition(tokens[0][2]) + + node.prop = '' + while (tokens.length) { + let type = tokens[0][0] + if (type === ':' || type === 'space' || type === 'comment') { + break + } + node.prop += tokens.shift()[1] + } + + node.raws.between = '' + + let token + while (tokens.length) { + token = tokens.shift() + + if (token[0] === ':') { + node.raws.between += token[1] + break + } else { + if (token[0] === 'word' && /\w/.test(token[1])) { + this.unknownWord([token]) + } + node.raws.between += token[1] + } + } + + if (node.prop[0] === '_' || node.prop[0] === '*') { + node.raws.before += node.prop[0] + node.prop = node.prop.slice(1) + } + + let firstSpaces = [] + let next + while (tokens.length) { + next = tokens[0][0] + if (next !== 'space' && next !== 'comment') break + firstSpaces.push(tokens.shift()) + } + + this.precheckMissedSemicolon(tokens) + + for (let i = tokens.length - 1; i >= 0; i--) { + token = tokens[i] + if (token[1].toLowerCase() === '!important') { + node.important = true + let string = this.stringFrom(tokens, i) + string = this.spacesFromEnd(tokens) + string + if (string !== ' !important') node.raws.important = string + break + } else if (token[1].toLowerCase() === 'important') { + let cache = tokens.slice(0) + let str = '' + for (let j = i; j > 0; j--) { + let type = cache[j][0] + if (str.trim().indexOf('!') === 0 && type !== 'space') { + break + } + str = cache.pop()[1] + str + } + if (str.trim().indexOf('!') === 0) { + node.important = true + node.raws.important = str + tokens = cache + } + } + + if (token[0] !== 'space' && token[0] !== 'comment') { + break + } + } + + let hasWord = tokens.some(i => i[0] !== 'space' && i[0] !== 'comment') + + if (hasWord) { + node.raws.between += firstSpaces.map(i => i[1]).join('') + firstSpaces = [] + } + this.raw(node, 'value', firstSpaces.concat(tokens), customProperty) + + if (node.value.includes(':') && !customProperty) { + this.checkMissedSemicolon(tokens) + } + } + + doubleColon(token) { + throw this.input.error( + 'Double colon', + { offset: token[2] }, + { offset: token[2] + token[1].length } + ) + } + + emptyRule(token) { + let node = new Rule() + this.init(node, token[2]) + node.selector = '' + node.raws.between = '' + this.current = node + } + + end(token) { + if (this.current.nodes && this.current.nodes.length) { + this.current.raws.semicolon = this.semicolon + } + this.semicolon = false + + this.current.raws.after = (this.current.raws.after || '') + this.spaces + this.spaces = '' + + if (this.current.parent) { + this.current.source.end = this.getPosition(token[2]) + this.current.source.end.offset++ + this.current = this.current.parent + } else { + this.unexpectedClose(token) + } + } + + endFile() { + if (this.current.parent) this.unclosedBlock() + if (this.current.nodes && this.current.nodes.length) { + this.current.raws.semicolon = this.semicolon + } + this.current.raws.after = (this.current.raws.after || '') + this.spaces + this.root.source.end = this.getPosition(this.tokenizer.position()) + } + + freeSemicolon(token) { + this.spaces += token[1] + if (this.current.nodes) { + let prev = this.current.nodes[this.current.nodes.length - 1] + if (prev && prev.type === 'rule' && !prev.raws.ownSemicolon) { + prev.raws.ownSemicolon = this.spaces + this.spaces = '' + } + } + } + + // Helpers + + getPosition(offset) { + let pos = this.input.fromOffset(offset) + return { + column: pos.col, + line: pos.line, + offset + } + } + + init(node, offset) { + this.current.push(node) + node.source = { + input: this.input, + start: this.getPosition(offset) + } + node.raws.before = this.spaces + this.spaces = '' + if (node.type !== 'comment') this.semicolon = false + } + + other(start) { + let end = false + let type = null + let colon = false + let bracket = null + let brackets = [] + let customProperty = start[1].startsWith('--') + + let tokens = [] + let token = start + while (token) { + type = token[0] + tokens.push(token) + + if (type === '(' || type === '[') { + if (!bracket) bracket = token + brackets.push(type === '(' ? ')' : ']') + } else if (customProperty && colon && type === '{') { + if (!bracket) bracket = token + brackets.push('}') + } else if (brackets.length === 0) { + if (type === ';') { + if (colon) { + this.decl(tokens, customProperty) + return + } else { + break + } + } else if (type === '{') { + this.rule(tokens) + return + } else if (type === '}') { + this.tokenizer.back(tokens.pop()) + end = true + break + } else if (type === ':') { + colon = true + } + } else if (type === brackets[brackets.length - 1]) { + brackets.pop() + if (brackets.length === 0) bracket = null + } + + token = this.tokenizer.nextToken() + } + + if (this.tokenizer.endOfFile()) end = true + if (brackets.length > 0) this.unclosedBracket(bracket) + + if (end && colon) { + if (!customProperty) { + while (tokens.length) { + token = tokens[tokens.length - 1][0] + if (token !== 'space' && token !== 'comment') break + this.tokenizer.back(tokens.pop()) + } + } + this.decl(tokens, customProperty) + } else { + this.unknownWord(tokens) + } + } + + parse() { + let token + while (!this.tokenizer.endOfFile()) { + token = this.tokenizer.nextToken() + + switch (token[0]) { + case 'space': + this.spaces += token[1] + break + + case ';': + this.freeSemicolon(token) + break + + case '}': + this.end(token) + break + + case 'comment': + this.comment(token) + break + + case 'at-word': + this.atrule(token) + break + + case '{': + this.emptyRule(token) + break + + default: + this.other(token) + break + } + } + this.endFile() + } + + precheckMissedSemicolon(/* tokens */) { + // Hook for Safe Parser + } + + raw(node, prop, tokens, customProperty) { + let token, type + let length = tokens.length + let value = '' + let clean = true + let next, prev + + for (let i = 0; i < length; i += 1) { + token = tokens[i] + type = token[0] + if (type === 'space' && i === length - 1 && !customProperty) { + clean = false + } else if (type === 'comment') { + prev = tokens[i - 1] ? tokens[i - 1][0] : 'empty' + next = tokens[i + 1] ? tokens[i + 1][0] : 'empty' + if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { + if (value.slice(-1) === ',') { + clean = false + } else { + value += token[1] + } + } else { + clean = false + } + } else { + value += token[1] + } + } + if (!clean) { + let raw = tokens.reduce((all, i) => all + i[1], '') + node.raws[prop] = { raw, value } + } + node[prop] = value + } + + rule(tokens) { + tokens.pop() + + let node = new Rule() + this.init(node, tokens[0][2]) + + node.raws.between = this.spacesAndCommentsFromEnd(tokens) + this.raw(node, 'selector', tokens) + this.current = node + } + + spacesAndCommentsFromEnd(tokens) { + let lastTokenType + let spaces = '' + while (tokens.length) { + lastTokenType = tokens[tokens.length - 1][0] + if (lastTokenType !== 'space' && lastTokenType !== 'comment') break + spaces = tokens.pop()[1] + spaces + } + return spaces + } + + // Errors + + spacesAndCommentsFromStart(tokens) { + let next + let spaces = '' + while (tokens.length) { + next = tokens[0][0] + if (next !== 'space' && next !== 'comment') break + spaces += tokens.shift()[1] + } + return spaces + } + + spacesFromEnd(tokens) { + let lastTokenType + let spaces = '' + while (tokens.length) { + lastTokenType = tokens[tokens.length - 1][0] + if (lastTokenType !== 'space') break + spaces = tokens.pop()[1] + spaces + } + return spaces + } + + stringFrom(tokens, from) { + let result = '' + for (let i = from; i < tokens.length; i++) { + result += tokens[i][1] + } + tokens.splice(from, tokens.length - from) + return result + } + + unclosedBlock() { + let pos = this.current.source.start + throw this.input.error('Unclosed block', pos.line, pos.column) + } + + unclosedBracket(bracket) { + throw this.input.error( + 'Unclosed bracket', + { offset: bracket[2] }, + { offset: bracket[2] + 1 } + ) + } + + unexpectedClose(token) { + throw this.input.error( + 'Unexpected }', + { offset: token[2] }, + { offset: token[2] + 1 } + ) + } + + unknownWord(tokens) { + throw this.input.error( + 'Unknown word', + { offset: tokens[0][2] }, + { offset: tokens[0][2] + tokens[0][1].length } + ) + } + + unnamedAtrule(node, token) { + throw this.input.error( + 'At-rule without name', + { offset: token[2] }, + { offset: token[2] + token[1].length } + ) + } +} + +module.exports = Parser diff --git a/node_modules/postcss/lib/postcss.d.mts b/node_modules/postcss/lib/postcss.d.mts new file mode 100644 index 0000000..a8ca8c7 --- /dev/null +++ b/node_modules/postcss/lib/postcss.d.mts @@ -0,0 +1,72 @@ +export { + // postcss function / namespace + default, + + // Value exports from postcss.mjs + stringify, + fromJSON, + // @ts-expect-error This value exists, but it’s untyped. + plugin, + parse, + list, + + document, + comment, + atRule, + rule, + decl, + root, + + CssSyntaxError, + Declaration, + Container, + Processor, + Document, + Comment, + Warning, + AtRule, + Result, + Input, + Rule, + Root, + Node, + + // Type-only exports + AcceptedPlugin, + AnyNode, + AtRuleProps, + Builder, + ChildNode, + ChildProps, + CommentProps, + ContainerProps, + DeclarationProps, + DocumentProps, + FilePosition, + Helpers, + JSONHydrator, + Message, + NodeErrorOptions, + NodeProps, + OldPlugin, + Parser, + Plugin, + PluginCreator, + Position, + Postcss, + ProcessOptions, + RootProps, + RuleProps, + Source, + SourceMap, + SourceMapOptions, + Stringifier, + Syntax, + TransformCallback, + Transformer, + WarningOptions, + + // This is a class, but it’s not re-exported. That’s why it’s exported as type-only here. + type LazyResult, + +} from './postcss.js' diff --git a/node_modules/postcss/lib/postcss.d.ts b/node_modules/postcss/lib/postcss.d.ts new file mode 100644 index 0000000..49af61c --- /dev/null +++ b/node_modules/postcss/lib/postcss.d.ts @@ -0,0 +1,441 @@ +import { RawSourceMap, SourceMapGenerator } from 'source-map-js' + +import AtRule, { AtRuleProps } from './at-rule.js' +import Comment, { CommentProps } from './comment.js' +import Container, { ContainerProps } from './container.js' +import CssSyntaxError from './css-syntax-error.js' +import Declaration, { DeclarationProps } from './declaration.js' +import Document, { DocumentProps } from './document.js' +import Input, { FilePosition } from './input.js' +import LazyResult from './lazy-result.js' +import list from './list.js' +import Node, { + AnyNode, + ChildNode, + ChildProps, + NodeErrorOptions, + NodeProps, + Position, + Source +} from './node.js' +import Processor from './processor.js' +import Result, { Message } from './result.js' +import Root, { RootProps } from './root.js' +import Rule, { RuleProps } from './rule.js' +import Warning, { WarningOptions } from './warning.js' + +type DocumentProcessor = ( + document: Document, + helper: postcss.Helpers +) => Promise | void +type RootProcessor = (root: Root, helper: postcss.Helpers) => Promise | void +type DeclarationProcessor = ( + decl: Declaration, + helper: postcss.Helpers +) => Promise | void +type RuleProcessor = (rule: Rule, helper: postcss.Helpers) => Promise | void +type AtRuleProcessor = (atRule: AtRule, helper: postcss.Helpers) => Promise | void +type CommentProcessor = ( + comment: Comment, + helper: postcss.Helpers +) => Promise | void + +interface Processors { + /** + * Will be called on all`AtRule` nodes. + * + * Will be called again on node or children changes. + */ + AtRule?: { [name: string]: AtRuleProcessor } | AtRuleProcessor + + /** + * Will be called on all `AtRule` nodes, when all children will be processed. + * + * Will be called again on node or children changes. + */ + AtRuleExit?: { [name: string]: AtRuleProcessor } | AtRuleProcessor + + /** + * Will be called on all `Comment` nodes. + * + * Will be called again on node or children changes. + */ + Comment?: CommentProcessor + + /** + * Will be called on all `Comment` nodes after listeners + * for `Comment` event. + * + * Will be called again on node or children changes. + */ + CommentExit?: CommentProcessor + + /** + * Will be called on all `Declaration` nodes after listeners + * for `Declaration` event. + * + * Will be called again on node or children changes. + */ + Declaration?: { [prop: string]: DeclarationProcessor } | DeclarationProcessor + + /** + * Will be called on all `Declaration` nodes. + * + * Will be called again on node or children changes. + */ + DeclarationExit?: + | { [prop: string]: DeclarationProcessor } + | DeclarationProcessor + + /** + * Will be called on `Document` node. + * + * Will be called again on children changes. + */ + Document?: DocumentProcessor + + /** + * Will be called on `Document` node, when all children will be processed. + * + * Will be called again on children changes. + */ + DocumentExit?: DocumentProcessor + + /** + * Will be called on `Root` node once. + */ + Once?: RootProcessor + + /** + * Will be called on `Root` node once, when all children will be processed. + */ + OnceExit?: RootProcessor + + /** + * Will be called on `Root` node. + * + * Will be called again on children changes. + */ + Root?: RootProcessor + + /** + * Will be called on `Root` node, when all children will be processed. + * + * Will be called again on children changes. + */ + RootExit?: RootProcessor + + /** + * Will be called on all `Rule` nodes. + * + * Will be called again on node or children changes. + */ + Rule?: RuleProcessor + + /** + * Will be called on all `Rule` nodes, when all children will be processed. + * + * Will be called again on node or children changes. + */ + RuleExit?: RuleProcessor +} + +declare namespace postcss { + export { + AnyNode, + AtRule, + AtRuleProps, + ChildNode, + ChildProps, + Comment, + CommentProps, + Container, + ContainerProps, + CssSyntaxError, + Declaration, + DeclarationProps, + Document, + DocumentProps, + FilePosition, + Input, + LazyResult, + list, + Message, + Node, + NodeErrorOptions, + NodeProps, + Position, + Processor, + Result, + Root, + RootProps, + Rule, + RuleProps, + Source, + Warning, + WarningOptions + } + + export type SourceMap = SourceMapGenerator & { + toJSON(): RawSourceMap + } + + export type Helpers = { postcss: Postcss; result: Result } & Postcss + + export interface Plugin extends Processors { + postcssPlugin: string + prepare?: (result: Result) => Processors + } + + export interface PluginCreator { + (opts?: PluginOptions): Plugin | Processor + postcss: true + } + + export interface Transformer extends TransformCallback { + postcssPlugin: string + postcssVersion: string + } + + export interface TransformCallback { + (root: Root, result: Result): Promise | void + } + + export interface OldPlugin extends Transformer { + (opts?: T): Transformer + postcss: Transformer + } + + export type AcceptedPlugin = + | { + postcss: Processor | TransformCallback + } + | OldPlugin + | Plugin + | PluginCreator + | Processor + | TransformCallback + + export interface Parser { + ( + css: { toString(): string } | string, + opts?: Pick + ): RootNode + } + + export interface Builder { + (part: string, node?: AnyNode, type?: 'end' | 'start'): void + } + + export interface Stringifier { + (node: AnyNode, builder: Builder): void + } + + export interface JSONHydrator { + (data: object): Node + (data: object[]): Node[] + } + + export interface Syntax { + /** + * Function to generate AST by string. + */ + parse?: Parser + + /** + * Class to generate string by AST. + */ + stringify?: Stringifier + } + + export interface SourceMapOptions { + /** + * Use absolute path in generated source map. + */ + absolute?: boolean + + /** + * Indicates that PostCSS should add annotation comments to the CSS. + * By default, PostCSS will always add a comment with a path + * to the source map. PostCSS will not add annotations to CSS files + * that do not contain any comments. + * + * By default, PostCSS presumes that you want to save the source map as + * `opts.to + '.map'` and will use this path in the annotation comment. + * A different path can be set by providing a string value for annotation. + * + * If you have set `inline: true`, annotation cannot be disabled. + */ + annotation?: ((file: string, root: Root) => string) | boolean | string + + /** + * Override `from` in map’s sources. + */ + from?: string + + /** + * Indicates that the source map should be embedded in the output CSS + * as a Base64-encoded comment. By default, it is `true`. + * But if all previous maps are external, not inline, PostCSS will not embed + * the map even if you do not set this option. + * + * If you have an inline source map, the result.map property will be empty, + * as the source map will be contained within the text of `result.css`. + */ + inline?: boolean + + /** + * Source map content from a previous processing step (e.g., Sass). + * + * PostCSS will try to read the previous source map + * automatically (based on comments within the source CSS), but you can use + * this option to identify it manually. + * + * If desired, you can omit the previous map with prev: `false`. + */ + prev?: ((file: string) => string) | boolean | object | string + + /** + * Indicates that PostCSS should set the origin content (e.g., Sass source) + * of the source map. By default, it is true. But if all previous maps do not + * contain sources content, PostCSS will also leave it out even if you + * do not set this option. + */ + sourcesContent?: boolean + } + + export interface ProcessOptions { + /** + * The path of the CSS source file. You should always set `from`, + * because it is used in source map generation and syntax error messages. + */ + from?: string | undefined + + /** + * Source map options + */ + map?: boolean | SourceMapOptions + + /** + * Function to generate AST by string. + */ + parser?: Parser | Syntax + + /** + * Class to generate string by AST. + */ + stringifier?: Stringifier | Syntax + + /** + * Object with parse and stringify. + */ + syntax?: Syntax + + /** + * The path where you'll put the output CSS file. You should always set `to` + * to generate correct source maps. + */ + to?: string + } + + export type Postcss = typeof postcss + + /** + * Default function to convert a node tree into a CSS string. + */ + export let stringify: Stringifier + + /** + * Parses source css and returns a new `Root` or `Document` node, + * which contains the source CSS nodes. + * + * ```js + * // Simple CSS concatenation with source map support + * const root1 = postcss.parse(css1, { from: file1 }) + * const root2 = postcss.parse(css2, { from: file2 }) + * root1.append(root2).toResult().css + * ``` + */ + export let parse: Parser + + /** + * Rehydrate a JSON AST (from `Node#toJSON`) back into the AST classes. + * + * ```js + * const json = root.toJSON() + * // save to file, send by network, etc + * const root2 = postcss.fromJSON(json) + * ``` + */ + export let fromJSON: JSONHydrator + + /** + * Creates a new `Comment` node. + * + * @param defaults Properties for the new node. + * @return New comment node + */ + export function comment(defaults?: CommentProps): Comment + + /** + * Creates a new `AtRule` node. + * + * @param defaults Properties for the new node. + * @return New at-rule node. + */ + export function atRule(defaults?: AtRuleProps): AtRule + + /** + * Creates a new `Declaration` node. + * + * @param defaults Properties for the new node. + * @return New declaration node. + */ + export function decl(defaults?: DeclarationProps): Declaration + + /** + * Creates a new `Rule` node. + * + * @param default Properties for the new node. + * @return New rule node. + */ + export function rule(defaults?: RuleProps): Rule + + /** + * Creates a new `Root` node. + * + * @param defaults Properties for the new node. + * @return New root node. + */ + export function root(defaults?: RootProps): Root + + /** + * Creates a new `Document` node. + * + * @param defaults Properties for the new node. + * @return New document node. + */ + export function document(defaults?: DocumentProps): Document + + export { postcss as default } +} + +/** + * Create a new `Processor` instance that will apply `plugins` + * as CSS processors. + * + * ```js + * let postcss = require('postcss') + * + * postcss(plugins).process(css, { from, to }).then(result => { + * console.log(result.css) + * }) + * ``` + * + * @param plugins PostCSS plugins. + * @return Processor to process multiple CSS. + */ +declare function postcss(plugins?: postcss.AcceptedPlugin[]): Processor +declare function postcss(...plugins: postcss.AcceptedPlugin[]): Processor + +export = postcss diff --git a/node_modules/postcss/lib/postcss.js b/node_modules/postcss/lib/postcss.js new file mode 100644 index 0000000..080ee83 --- /dev/null +++ b/node_modules/postcss/lib/postcss.js @@ -0,0 +1,101 @@ +'use strict' + +let CssSyntaxError = require('./css-syntax-error') +let Declaration = require('./declaration') +let LazyResult = require('./lazy-result') +let Container = require('./container') +let Processor = require('./processor') +let stringify = require('./stringify') +let fromJSON = require('./fromJSON') +let Document = require('./document') +let Warning = require('./warning') +let Comment = require('./comment') +let AtRule = require('./at-rule') +let Result = require('./result.js') +let Input = require('./input') +let parse = require('./parse') +let list = require('./list') +let Rule = require('./rule') +let Root = require('./root') +let Node = require('./node') + +function postcss(...plugins) { + if (plugins.length === 1 && Array.isArray(plugins[0])) { + plugins = plugins[0] + } + return new Processor(plugins) +} + +postcss.plugin = function plugin(name, initializer) { + let warningPrinted = false + function creator(...args) { + // eslint-disable-next-line no-console + if (console && console.warn && !warningPrinted) { + warningPrinted = true + // eslint-disable-next-line no-console + console.warn( + name + + ': postcss.plugin was deprecated. Migration guide:\n' + + 'https://evilmartians.com/chronicles/postcss-8-plugin-migration' + ) + if (process.env.LANG && process.env.LANG.startsWith('cn')) { + /* c8 ignore next 7 */ + // eslint-disable-next-line no-console + console.warn( + name + + ': 里面 postcss.plugin 被弃用. 迁移指南:\n' + + 'https://www.w3ctech.com/topic/2226' + ) + } + } + let transformer = initializer(...args) + transformer.postcssPlugin = name + transformer.postcssVersion = new Processor().version + return transformer + } + + let cache + Object.defineProperty(creator, 'postcss', { + get() { + if (!cache) cache = creator() + return cache + } + }) + + creator.process = function (css, processOpts, pluginOpts) { + return postcss([creator(pluginOpts)]).process(css, processOpts) + } + + return creator +} + +postcss.stringify = stringify +postcss.parse = parse +postcss.fromJSON = fromJSON +postcss.list = list + +postcss.comment = defaults => new Comment(defaults) +postcss.atRule = defaults => new AtRule(defaults) +postcss.decl = defaults => new Declaration(defaults) +postcss.rule = defaults => new Rule(defaults) +postcss.root = defaults => new Root(defaults) +postcss.document = defaults => new Document(defaults) + +postcss.CssSyntaxError = CssSyntaxError +postcss.Declaration = Declaration +postcss.Container = Container +postcss.Processor = Processor +postcss.Document = Document +postcss.Comment = Comment +postcss.Warning = Warning +postcss.AtRule = AtRule +postcss.Result = Result +postcss.Input = Input +postcss.Rule = Rule +postcss.Root = Root +postcss.Node = Node + +LazyResult.registerPostcss(postcss) + +module.exports = postcss +postcss.default = postcss diff --git a/node_modules/postcss/lib/postcss.mjs b/node_modules/postcss/lib/postcss.mjs new file mode 100644 index 0000000..3507598 --- /dev/null +++ b/node_modules/postcss/lib/postcss.mjs @@ -0,0 +1,30 @@ +import postcss from './postcss.js' + +export default postcss + +export const stringify = postcss.stringify +export const fromJSON = postcss.fromJSON +export const plugin = postcss.plugin +export const parse = postcss.parse +export const list = postcss.list + +export const document = postcss.document +export const comment = postcss.comment +export const atRule = postcss.atRule +export const rule = postcss.rule +export const decl = postcss.decl +export const root = postcss.root + +export const CssSyntaxError = postcss.CssSyntaxError +export const Declaration = postcss.Declaration +export const Container = postcss.Container +export const Processor = postcss.Processor +export const Document = postcss.Document +export const Comment = postcss.Comment +export const Warning = postcss.Warning +export const AtRule = postcss.AtRule +export const Result = postcss.Result +export const Input = postcss.Input +export const Rule = postcss.Rule +export const Root = postcss.Root +export const Node = postcss.Node diff --git a/node_modules/postcss/lib/previous-map.d.ts b/node_modules/postcss/lib/previous-map.d.ts new file mode 100644 index 0000000..23edeb5 --- /dev/null +++ b/node_modules/postcss/lib/previous-map.d.ts @@ -0,0 +1,81 @@ +import { SourceMapConsumer } from 'source-map-js' + +import { ProcessOptions } from './postcss.js' + +declare namespace PreviousMap { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { PreviousMap_ as default } +} + +/** + * Source map information from input CSS. + * For example, source map after Sass compiler. + * + * This class will automatically find source map in input CSS or in file system + * near input file (according `from` option). + * + * ```js + * const root = parse(css, { from: 'a.sass.css' }) + * root.input.map //=> PreviousMap + * ``` + */ +declare class PreviousMap_ { + /** + * `sourceMappingURL` content. + */ + annotation?: string + + /** + * The CSS source identifier. Contains `Input#file` if the user + * set the `from` option, or `Input#id` if they did not. + */ + file?: string + + /** + * Was source map inlined by data-uri to input CSS. + */ + inline: boolean + + /** + * Path to source map file. + */ + mapFile?: string + + /** + * The directory with source map file, if source map is in separated file. + */ + root?: string + + /** + * Source map file content. + */ + text?: string + + /** + * @param css Input CSS source. + * @param opts Process options. + */ + constructor(css: string, opts?: ProcessOptions) + + /** + * Create a instance of `SourceMapGenerator` class + * from the `source-map` library to work with source map information. + * + * It is lazy method, so it will create object only on first call + * and then it will use cache. + * + * @return Object with source map information. + */ + consumer(): SourceMapConsumer + + /** + * Does source map contains `sourcesContent` with input source text. + * + * @return Is `sourcesContent` present. + */ + withContent(): boolean +} + +declare class PreviousMap extends PreviousMap_ {} + +export = PreviousMap diff --git a/node_modules/postcss/lib/previous-map.js b/node_modules/postcss/lib/previous-map.js new file mode 100644 index 0000000..f3093df --- /dev/null +++ b/node_modules/postcss/lib/previous-map.js @@ -0,0 +1,142 @@ +'use strict' + +let { SourceMapConsumer, SourceMapGenerator } = require('source-map-js') +let { existsSync, readFileSync } = require('fs') +let { dirname, join } = require('path') + +function fromBase64(str) { + if (Buffer) { + return Buffer.from(str, 'base64').toString() + } else { + /* c8 ignore next 2 */ + return window.atob(str) + } +} + +class PreviousMap { + constructor(css, opts) { + if (opts.map === false) return + this.loadAnnotation(css) + this.inline = this.startWith(this.annotation, 'data:') + + let prev = opts.map ? opts.map.prev : undefined + let text = this.loadMap(opts.from, prev) + if (!this.mapFile && opts.from) { + this.mapFile = opts.from + } + if (this.mapFile) this.root = dirname(this.mapFile) + if (text) this.text = text + } + + consumer() { + if (!this.consumerCache) { + this.consumerCache = new SourceMapConsumer(this.text) + } + return this.consumerCache + } + + decodeInline(text) { + let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/ + let baseUri = /^data:application\/json;base64,/ + let charsetUri = /^data:application\/json;charset=utf-?8,/ + let uri = /^data:application\/json,/ + + if (charsetUri.test(text) || uri.test(text)) { + return decodeURIComponent(text.substr(RegExp.lastMatch.length)) + } + + if (baseCharsetUri.test(text) || baseUri.test(text)) { + return fromBase64(text.substr(RegExp.lastMatch.length)) + } + + let encoding = text.match(/data:application\/json;([^,]+),/)[1] + throw new Error('Unsupported source map encoding ' + encoding) + } + + getAnnotationURL(sourceMapString) { + return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, '').trim() + } + + isMap(map) { + if (typeof map !== 'object') return false + return ( + typeof map.mappings === 'string' || + typeof map._mappings === 'string' || + Array.isArray(map.sections) + ) + } + + loadAnnotation(css) { + let comments = css.match(/\/\*\s*# sourceMappingURL=/gm) + if (!comments) return + + // sourceMappingURLs from comments, strings, etc. + let start = css.lastIndexOf(comments.pop()) + let end = css.indexOf('*/', start) + + if (start > -1 && end > -1) { + // Locate the last sourceMappingURL to avoid pickin + this.annotation = this.getAnnotationURL(css.substring(start, end)) + } + } + + loadFile(path) { + this.root = dirname(path) + if (existsSync(path)) { + this.mapFile = path + return readFileSync(path, 'utf-8').toString().trim() + } + } + + loadMap(file, prev) { + if (prev === false) return false + + if (prev) { + if (typeof prev === 'string') { + return prev + } else if (typeof prev === 'function') { + let prevPath = prev(file) + if (prevPath) { + let map = this.loadFile(prevPath) + if (!map) { + throw new Error( + 'Unable to load previous source map: ' + prevPath.toString() + ) + } + return map + } + } else if (prev instanceof SourceMapConsumer) { + return SourceMapGenerator.fromSourceMap(prev).toString() + } else if (prev instanceof SourceMapGenerator) { + return prev.toString() + } else if (this.isMap(prev)) { + return JSON.stringify(prev) + } else { + throw new Error( + 'Unsupported previous source map format: ' + prev.toString() + ) + } + } else if (this.inline) { + return this.decodeInline(this.annotation) + } else if (this.annotation) { + let map = this.annotation + if (file) map = join(dirname(file), map) + return this.loadFile(map) + } + } + + startWith(string, start) { + if (!string) return false + return string.substr(0, start.length) === start + } + + withContent() { + return !!( + this.consumer().sourcesContent && + this.consumer().sourcesContent.length > 0 + ) + } +} + +module.exports = PreviousMap +PreviousMap.default = PreviousMap diff --git a/node_modules/postcss/lib/processor.d.ts b/node_modules/postcss/lib/processor.d.ts new file mode 100644 index 0000000..50c9a07 --- /dev/null +++ b/node_modules/postcss/lib/processor.d.ts @@ -0,0 +1,115 @@ +import Document from './document.js' +import LazyResult from './lazy-result.js' +import NoWorkResult from './no-work-result.js' +import { + AcceptedPlugin, + Plugin, + ProcessOptions, + TransformCallback, + Transformer +} from './postcss.js' +import Result from './result.js' +import Root from './root.js' + +declare namespace Processor { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Processor_ as default } +} + +/** + * Contains plugins to process CSS. Create one `Processor` instance, + * initialize its plugins, and then use that instance on numerous CSS files. + * + * ```js + * const processor = postcss([autoprefixer, postcssNested]) + * processor.process(css1).then(result => console.log(result.css)) + * processor.process(css2).then(result => console.log(result.css)) + * ``` + */ +declare class Processor_ { + /** + * Plugins added to this processor. + * + * ```js + * const processor = postcss([autoprefixer, postcssNested]) + * processor.plugins.length //=> 2 + * ``` + */ + plugins: (Plugin | TransformCallback | Transformer)[] + + /** + * Current PostCSS version. + * + * ```js + * if (result.processor.version.split('.')[0] !== '6') { + * throw new Error('This plugin works only with PostCSS 6') + * } + * ``` + */ + version: string + + /** + * @param plugins PostCSS plugins + */ + constructor(plugins?: AcceptedPlugin[]) + + /** + * Parses source CSS and returns a `LazyResult` Promise proxy. + * Because some plugins can be asynchronous it doesn’t make + * any transformations. Transformations will be applied + * in the `LazyResult` methods. + * + * ```js + * processor.process(css, { from: 'a.css', to: 'a.out.css' }) + * .then(result => { + * console.log(result.css) + * }) + * ``` + * + * @param css String with input CSS or any object with a `toString()` method, + * like a Buffer. Optionally, send a `Result` instance + * and the processor will take the `Root` from it. + * @param opts Options. + * @return Promise proxy. + */ + process( + css: { toString(): string } | LazyResult | Result | Root | string + ): LazyResult | NoWorkResult + process( + css: { toString(): string } | LazyResult | Result | Root | string, + options: ProcessOptions + ): LazyResult + + /** + * Adds a plugin to be used as a CSS processor. + * + * PostCSS plugin can be in 4 formats: + * * A plugin in `Plugin` format. + * * A plugin creator function with `pluginCreator.postcss = true`. + * PostCSS will call this function without argument to get plugin. + * * A function. PostCSS will pass the function a {@link Root} + * as the first argument and current `Result` instance + * as the second. + * * Another `Processor` instance. PostCSS will copy plugins + * from that instance into this one. + * + * Plugins can also be added by passing them as arguments when creating + * a `postcss` instance (see [`postcss(plugins)`]). + * + * Asynchronous plugins should return a `Promise` instance. + * + * ```js + * const processor = postcss() + * .use(autoprefixer) + * .use(postcssNested) + * ``` + * + * @param plugin PostCSS plugin or `Processor` with plugins. + * @return Current processor to make methods chain. + */ + use(plugin: AcceptedPlugin): this +} + +declare class Processor extends Processor_ {} + +export = Processor diff --git a/node_modules/postcss/lib/processor.js b/node_modules/postcss/lib/processor.js new file mode 100644 index 0000000..d8a16f4 --- /dev/null +++ b/node_modules/postcss/lib/processor.js @@ -0,0 +1,67 @@ +'use strict' + +let NoWorkResult = require('./no-work-result') +let LazyResult = require('./lazy-result') +let Document = require('./document') +let Root = require('./root') + +class Processor { + constructor(plugins = []) { + this.version = '8.4.38' + this.plugins = this.normalize(plugins) + } + + normalize(plugins) { + let normalized = [] + for (let i of plugins) { + if (i.postcss === true) { + i = i() + } else if (i.postcss) { + i = i.postcss + } + + if (typeof i === 'object' && Array.isArray(i.plugins)) { + normalized = normalized.concat(i.plugins) + } else if (typeof i === 'object' && i.postcssPlugin) { + normalized.push(i) + } else if (typeof i === 'function') { + normalized.push(i) + } else if (typeof i === 'object' && (i.parse || i.stringify)) { + if (process.env.NODE_ENV !== 'production') { + throw new Error( + 'PostCSS syntaxes cannot be used as plugins. Instead, please use ' + + 'one of the syntax/parser/stringifier options as outlined ' + + 'in your PostCSS runner documentation.' + ) + } + } else { + throw new Error(i + ' is not a PostCSS plugin') + } + } + return normalized + } + + process(css, opts = {}) { + if ( + !this.plugins.length && + !opts.parser && + !opts.stringifier && + !opts.syntax + ) { + return new NoWorkResult(this, css, opts) + } else { + return new LazyResult(this, css, opts) + } + } + + use(plugin) { + this.plugins = this.plugins.concat(this.normalize([plugin])) + return this + } +} + +module.exports = Processor +Processor.default = Processor + +Root.registerProcessor(Processor) +Document.registerProcessor(Processor) diff --git a/node_modules/postcss/lib/result.d.ts b/node_modules/postcss/lib/result.d.ts new file mode 100644 index 0000000..c3dcbda --- /dev/null +++ b/node_modules/postcss/lib/result.d.ts @@ -0,0 +1,206 @@ +import { + Document, + Node, + Plugin, + ProcessOptions, + Root, + SourceMap, + TransformCallback, + Warning, + WarningOptions +} from './postcss.js' +import Processor from './processor.js' + +declare namespace Result { + export interface Message { + [others: string]: any + + /** + * Source PostCSS plugin name. + */ + plugin?: string + + /** + * Message type. + */ + type: string + } + + export interface ResultOptions extends ProcessOptions { + /** + * The CSS node that was the source of the warning. + */ + node?: Node + + /** + * Name of plugin that created this warning. `Result#warn` will fill it + * automatically with `Plugin#postcssPlugin` value. + */ + plugin?: string + } + + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Result_ as default } +} + +/** + * Provides the result of the PostCSS transformations. + * + * A Result instance is returned by `LazyResult#then` + * or `Root#toResult` methods. + * + * ```js + * postcss([autoprefixer]).process(css).then(result => { + * console.log(result.css) + * }) + * ``` + * + * ```js + * const result2 = postcss.parse(css).toResult() + * ``` + */ +declare class Result_ { + /** + * A CSS string representing of `Result#root`. + * + * ```js + * postcss.parse('a{}').toResult().css //=> "a{}" + * ``` + */ + css: string + + /** + * Last runned PostCSS plugin. + */ + lastPlugin: Plugin | TransformCallback + + /** + * An instance of `SourceMapGenerator` class from the `source-map` library, + * representing changes to the `Result#root` instance. + * + * ```js + * result.map.toJSON() //=> { version: 3, file: 'a.css', … } + * ``` + * + * ```js + * if (result.map) { + * fs.writeFileSync(result.opts.to + '.map', result.map.toString()) + * } + * ``` + */ + map: SourceMap + + /** + * Contains messages from plugins (e.g., warnings or custom messages). + * Each message should have type and plugin properties. + * + * ```js + * AtRule: { + * import: (atRule, { result }) { + * const importedFile = parseImport(atRule) + * result.messages.push({ + * type: 'dependency', + * plugin: 'postcss-import', + * file: importedFile, + * parent: result.opts.from + * }) + * } + * } + * ``` + */ + messages: Result.Message[] + + /** + * Options from the `Processor#process` or `Root#toResult` call + * that produced this Result instance.] + * + * ```js + * root.toResult(opts).opts === opts + * ``` + */ + opts: Result.ResultOptions + + /** + * The Processor instance used for this transformation. + * + * ```js + * for (const plugin of result.processor.plugins) { + * if (plugin.postcssPlugin === 'postcss-bad') { + * throw 'postcss-good is incompatible with postcss-bad' + * } + * }) + * ``` + */ + processor: Processor + + /** + * Root node after all transformations. + * + * ```js + * root.toResult().root === root + * ``` + */ + root: RootNode + + /** + * @param processor Processor used for this transformation. + * @param root Root node after all transformations. + * @param opts Options from the `Processor#process` or `Root#toResult`. + */ + constructor(processor: Processor, root: RootNode, opts: Result.ResultOptions) + + /** + * Returns for `Result#css` content. + * + * ```js + * result + '' === result.css + * ``` + * + * @return String representing of `Result#root`. + */ + toString(): string + + /** + * Creates an instance of `Warning` and adds it to `Result#messages`. + * + * ```js + * if (decl.important) { + * result.warn('Avoid !important', { node: decl, word: '!important' }) + * } + * ``` + * + * @param text Warning message. + * @param opts Warning options. + * @return Created warning. + */ + warn(message: string, options?: WarningOptions): Warning + + /** + * Returns warnings from plugins. Filters `Warning` instances + * from `Result#messages`. + * + * ```js + * result.warnings().forEach(warn => { + * console.warn(warn.toString()) + * }) + * ``` + * + * @return Warnings from plugins. + */ + warnings(): Warning[] + + /** + * An alias for the `Result#css` property. + * Use it with syntaxes that generate non-CSS output. + * + * ```js + * result.css === result.content + * ``` + */ + get content(): string +} + +declare class Result extends Result_ {} + +export = Result diff --git a/node_modules/postcss/lib/result.js b/node_modules/postcss/lib/result.js new file mode 100644 index 0000000..a39751d --- /dev/null +++ b/node_modules/postcss/lib/result.js @@ -0,0 +1,42 @@ +'use strict' + +let Warning = require('./warning') + +class Result { + constructor(processor, root, opts) { + this.processor = processor + this.messages = [] + this.root = root + this.opts = opts + this.css = undefined + this.map = undefined + } + + toString() { + return this.css + } + + warn(text, opts = {}) { + if (!opts.plugin) { + if (this.lastPlugin && this.lastPlugin.postcssPlugin) { + opts.plugin = this.lastPlugin.postcssPlugin + } + } + + let warning = new Warning(text, opts) + this.messages.push(warning) + + return warning + } + + warnings() { + return this.messages.filter(i => i.type === 'warning') + } + + get content() { + return this.css + } +} + +module.exports = Result +Result.default = Result diff --git a/node_modules/postcss/lib/root.d.ts b/node_modules/postcss/lib/root.d.ts new file mode 100644 index 0000000..9046aac --- /dev/null +++ b/node_modules/postcss/lib/root.d.ts @@ -0,0 +1,87 @@ +import Container, { ContainerProps } from './container.js' +import Document from './document.js' +import { ProcessOptions } from './postcss.js' +import Result from './result.js' + +declare namespace Root { + export interface RootRaws extends Record { + /** + * The space symbols after the last child to the end of file. + */ + after?: string + + /** + * Non-CSS code after `Root`, when `Root` is inside `Document`. + * + * **Experimental:** some aspects of this node could change within minor + * or patch version releases. + */ + codeAfter?: string + + /** + * Non-CSS code before `Root`, when `Root` is inside `Document`. + * + * **Experimental:** some aspects of this node could change within minor + * or patch version releases. + */ + codeBefore?: string + + /** + * Is the last child has an (optional) semicolon. + */ + semicolon?: boolean + } + + export interface RootProps extends ContainerProps { + /** + * Information used to generate byte-to-byte equal node string + * as it was in the origin input. + * */ + raws?: RootRaws + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Root_ as default } +} + +/** + * Represents a CSS file and contains all its parsed nodes. + * + * ```js + * const root = postcss.parse('a{color:black} b{z-index:2}') + * root.type //=> 'root' + * root.nodes.length //=> 2 + * ``` + */ +declare class Root_ extends Container { + nodes: NonNullable + parent: Document | undefined + raws: Root.RootRaws + type: 'root' + + constructor(defaults?: Root.RootProps) + + assign(overrides: object | Root.RootProps): this + clone(overrides?: Partial): Root + cloneAfter(overrides?: Partial): Root + cloneBefore(overrides?: Partial): Root + + /** + * Returns a `Result` instance representing the root’s CSS. + * + * ```js + * const root1 = postcss.parse(css1, { from: 'a.css' }) + * const root2 = postcss.parse(css2, { from: 'b.css' }) + * root1.append(root2) + * const result = root1.toResult({ to: 'all.css', map: true }) + * ``` + * + * @param opts Options. + * @return Result with current root’s CSS. + */ + toResult(options?: ProcessOptions): Result +} + +declare class Root extends Root_ {} + +export = Root diff --git a/node_modules/postcss/lib/root.js b/node_modules/postcss/lib/root.js new file mode 100644 index 0000000..ea574ed --- /dev/null +++ b/node_modules/postcss/lib/root.js @@ -0,0 +1,61 @@ +'use strict' + +let Container = require('./container') + +let LazyResult, Processor + +class Root extends Container { + constructor(defaults) { + super(defaults) + this.type = 'root' + if (!this.nodes) this.nodes = [] + } + + normalize(child, sample, type) { + let nodes = super.normalize(child) + + if (sample) { + if (type === 'prepend') { + if (this.nodes.length > 1) { + sample.raws.before = this.nodes[1].raws.before + } else { + delete sample.raws.before + } + } else if (this.first !== sample) { + for (let node of nodes) { + node.raws.before = sample.raws.before + } + } + } + + return nodes + } + + removeChild(child, ignore) { + let index = this.index(child) + + if (!ignore && index === 0 && this.nodes.length > 1) { + this.nodes[1].raws.before = this.nodes[index].raws.before + } + + return super.removeChild(child) + } + + toResult(opts = {}) { + let lazy = new LazyResult(new Processor(), this, opts) + return lazy.stringify() + } +} + +Root.registerLazyResult = dependant => { + LazyResult = dependant +} + +Root.registerProcessor = dependant => { + Processor = dependant +} + +module.exports = Root +Root.default = Root + +Container.registerRoot(Root) diff --git a/node_modules/postcss/lib/rule.d.ts b/node_modules/postcss/lib/rule.d.ts new file mode 100644 index 0000000..fc5dd72 --- /dev/null +++ b/node_modules/postcss/lib/rule.d.ts @@ -0,0 +1,117 @@ +import Container, { + ContainerProps, + ContainerWithChildren +} from './container.js' + +declare namespace Rule { + export interface RuleRaws extends Record { + /** + * The space symbols after the last child of the node to the end of the node. + */ + after?: string + + /** + * The space symbols before the node. It also stores `*` + * and `_` symbols before the declaration (IE hack). + */ + before?: string + + /** + * The symbols between the selector and `{` for rules. + */ + between?: string + + /** + * Contains `true` if there is semicolon after rule. + */ + ownSemicolon?: string + + /** + * The rule’s selector with comments. + */ + selector?: { + raw: string + value: string + } + + /** + * Contains `true` if the last child has an (optional) semicolon. + */ + semicolon?: boolean + } + + export interface RuleProps extends ContainerProps { + /** Information used to generate byte-to-byte equal node string as it was in the origin input. */ + raws?: RuleRaws + /** Selector or selectors of the rule. */ + selector?: string + /** Selectors of the rule represented as an array of strings. */ + selectors?: string[] + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Rule_ as default } +} + +/** + * Represents a CSS rule: a selector followed by a declaration block. + * + * ```js + * Once (root, { Rule }) { + * let a = new Rule({ selector: 'a' }) + * a.append(…) + * root.append(a) + * } + * ``` + * + * ```js + * const root = postcss.parse('a{}') + * const rule = root.first + * rule.type //=> 'rule' + * rule.toString() //=> 'a{}' + * ``` + */ +declare class Rule_ extends Container { + nodes: NonNullable + parent: ContainerWithChildren | undefined + raws: Rule.RuleRaws + /** + * The rule’s full selector represented as a string. + * + * ```js + * const root = postcss.parse('a, b { }') + * const rule = root.first + * rule.selector //=> 'a, b' + * ``` + */ + selector: string + + /** + * An array containing the rule’s individual selectors. + * Groups of selectors are split at commas. + * + * ```js + * const root = postcss.parse('a, b { }') + * const rule = root.first + * + * rule.selector //=> 'a, b' + * rule.selectors //=> ['a', 'b'] + * + * rule.selectors = ['a', 'strong'] + * rule.selector //=> 'a, strong' + * ``` + */ + selectors: string[] + + type: 'rule' + + constructor(defaults?: Rule.RuleProps) + assign(overrides: object | Rule.RuleProps): this + clone(overrides?: Partial): Rule + cloneAfter(overrides?: Partial): Rule + cloneBefore(overrides?: Partial): Rule +} + +declare class Rule extends Rule_ {} + +export = Rule diff --git a/node_modules/postcss/lib/rule.js b/node_modules/postcss/lib/rule.js new file mode 100644 index 0000000..a93ab25 --- /dev/null +++ b/node_modules/postcss/lib/rule.js @@ -0,0 +1,27 @@ +'use strict' + +let Container = require('./container') +let list = require('./list') + +class Rule extends Container { + constructor(defaults) { + super(defaults) + this.type = 'rule' + if (!this.nodes) this.nodes = [] + } + + get selectors() { + return list.comma(this.selector) + } + + set selectors(values) { + let match = this.selector ? this.selector.match(/,\s*/) : null + let sep = match ? match[0] : ',' + this.raw('between', 'beforeOpen') + this.selector = values.join(sep) + } +} + +module.exports = Rule +Rule.default = Rule + +Container.registerRule(Rule) diff --git a/node_modules/postcss/lib/stringifier.d.ts b/node_modules/postcss/lib/stringifier.d.ts new file mode 100644 index 0000000..f707a6a --- /dev/null +++ b/node_modules/postcss/lib/stringifier.d.ts @@ -0,0 +1,46 @@ +import { + AnyNode, + AtRule, + Builder, + Comment, + Container, + Declaration, + Document, + Root, + Rule +} from './postcss.js' + +declare namespace Stringifier { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Stringifier_ as default } +} + +declare class Stringifier_ { + builder: Builder + constructor(builder: Builder) + atrule(node: AtRule, semicolon?: boolean): void + beforeAfter(node: AnyNode, detect: 'after' | 'before'): string + block(node: AnyNode, start: string): void + body(node: Container): void + comment(node: Comment): void + decl(node: Declaration, semicolon?: boolean): void + document(node: Document): void + raw(node: AnyNode, own: null | string, detect?: string): string + rawBeforeClose(root: Root): string | undefined + rawBeforeComment(root: Root, node: Comment): string | undefined + rawBeforeDecl(root: Root, node: Declaration): string | undefined + rawBeforeOpen(root: Root): string | undefined + rawBeforeRule(root: Root): string | undefined + rawColon(root: Root): string | undefined + rawEmptyBody(root: Root): string | undefined + rawIndent(root: Root): string | undefined + rawSemicolon(root: Root): boolean | undefined + rawValue(node: AnyNode, prop: string): string + root(node: Root): void + rule(node: Rule): void + stringify(node: AnyNode, semicolon?: boolean): void +} + +declare class Stringifier extends Stringifier_ {} + +export = Stringifier diff --git a/node_modules/postcss/lib/stringifier.js b/node_modules/postcss/lib/stringifier.js new file mode 100644 index 0000000..e07ad12 --- /dev/null +++ b/node_modules/postcss/lib/stringifier.js @@ -0,0 +1,353 @@ +'use strict' + +const DEFAULT_RAW = { + after: '\n', + beforeClose: '\n', + beforeComment: '\n', + beforeDecl: '\n', + beforeOpen: ' ', + beforeRule: '\n', + colon: ': ', + commentLeft: ' ', + commentRight: ' ', + emptyBody: '', + indent: ' ', + semicolon: false +} + +function capitalize(str) { + return str[0].toUpperCase() + str.slice(1) +} + +class Stringifier { + constructor(builder) { + this.builder = builder + } + + atrule(node, semicolon) { + let name = '@' + node.name + let params = node.params ? this.rawValue(node, 'params') : '' + + if (typeof node.raws.afterName !== 'undefined') { + name += node.raws.afterName + } else if (params) { + name += ' ' + } + + if (node.nodes) { + this.block(node, name + params) + } else { + let end = (node.raws.between || '') + (semicolon ? ';' : '') + this.builder(name + params + end, node) + } + } + + beforeAfter(node, detect) { + let value + if (node.type === 'decl') { + value = this.raw(node, null, 'beforeDecl') + } else if (node.type === 'comment') { + value = this.raw(node, null, 'beforeComment') + } else if (detect === 'before') { + value = this.raw(node, null, 'beforeRule') + } else { + value = this.raw(node, null, 'beforeClose') + } + + let buf = node.parent + let depth = 0 + while (buf && buf.type !== 'root') { + depth += 1 + buf = buf.parent + } + + if (value.includes('\n')) { + let indent = this.raw(node, null, 'indent') + if (indent.length) { + for (let step = 0; step < depth; step++) value += indent + } + } + + return value + } + + block(node, start) { + let between = this.raw(node, 'between', 'beforeOpen') + this.builder(start + between + '{', node, 'start') + + let after + if (node.nodes && node.nodes.length) { + this.body(node) + after = this.raw(node, 'after') + } else { + after = this.raw(node, 'after', 'emptyBody') + } + + if (after) this.builder(after) + this.builder('}', node, 'end') + } + + body(node) { + let last = node.nodes.length - 1 + while (last > 0) { + if (node.nodes[last].type !== 'comment') break + last -= 1 + } + + let semicolon = this.raw(node, 'semicolon') + for (let i = 0; i < node.nodes.length; i++) { + let child = node.nodes[i] + let before = this.raw(child, 'before') + if (before) this.builder(before) + this.stringify(child, last !== i || semicolon) + } + } + + comment(node) { + let left = this.raw(node, 'left', 'commentLeft') + let right = this.raw(node, 'right', 'commentRight') + this.builder('/*' + left + node.text + right + '*/', node) + } + + decl(node, semicolon) { + let between = this.raw(node, 'between', 'colon') + let string = node.prop + between + this.rawValue(node, 'value') + + if (node.important) { + string += node.raws.important || ' !important' + } + + if (semicolon) string += ';' + this.builder(string, node) + } + + document(node) { + this.body(node) + } + + raw(node, own, detect) { + let value + if (!detect) detect = own + + // Already had + if (own) { + value = node.raws[own] + if (typeof value !== 'undefined') return value + } + + let parent = node.parent + + if (detect === 'before') { + // Hack for first rule in CSS + if (!parent || (parent.type === 'root' && parent.first === node)) { + return '' + } + + // `root` nodes in `document` should use only their own raws + if (parent && parent.type === 'document') { + return '' + } + } + + // Floating child without parent + if (!parent) return DEFAULT_RAW[detect] + + // Detect style by other nodes + let root = node.root() + if (!root.rawCache) root.rawCache = {} + if (typeof root.rawCache[detect] !== 'undefined') { + return root.rawCache[detect] + } + + if (detect === 'before' || detect === 'after') { + return this.beforeAfter(node, detect) + } else { + let method = 'raw' + capitalize(detect) + if (this[method]) { + value = this[method](root, node) + } else { + root.walk(i => { + value = i.raws[own] + if (typeof value !== 'undefined') return false + }) + } + } + + if (typeof value === 'undefined') value = DEFAULT_RAW[detect] + + root.rawCache[detect] = value + return value + } + + rawBeforeClose(root) { + let value + root.walk(i => { + if (i.nodes && i.nodes.length > 0) { + if (typeof i.raws.after !== 'undefined') { + value = i.raws.after + if (value.includes('\n')) { + value = value.replace(/[^\n]+$/, '') + } + return false + } + } + }) + if (value) value = value.replace(/\S/g, '') + return value + } + + rawBeforeComment(root, node) { + let value + root.walkComments(i => { + if (typeof i.raws.before !== 'undefined') { + value = i.raws.before + if (value.includes('\n')) { + value = value.replace(/[^\n]+$/, '') + } + return false + } + }) + if (typeof value === 'undefined') { + value = this.raw(node, null, 'beforeDecl') + } else if (value) { + value = value.replace(/\S/g, '') + } + return value + } + + rawBeforeDecl(root, node) { + let value + root.walkDecls(i => { + if (typeof i.raws.before !== 'undefined') { + value = i.raws.before + if (value.includes('\n')) { + value = value.replace(/[^\n]+$/, '') + } + return false + } + }) + if (typeof value === 'undefined') { + value = this.raw(node, null, 'beforeRule') + } else if (value) { + value = value.replace(/\S/g, '') + } + return value + } + + rawBeforeOpen(root) { + let value + root.walk(i => { + if (i.type !== 'decl') { + value = i.raws.between + if (typeof value !== 'undefined') return false + } + }) + return value + } + + rawBeforeRule(root) { + let value + root.walk(i => { + if (i.nodes && (i.parent !== root || root.first !== i)) { + if (typeof i.raws.before !== 'undefined') { + value = i.raws.before + if (value.includes('\n')) { + value = value.replace(/[^\n]+$/, '') + } + return false + } + } + }) + if (value) value = value.replace(/\S/g, '') + return value + } + + rawColon(root) { + let value + root.walkDecls(i => { + if (typeof i.raws.between !== 'undefined') { + value = i.raws.between.replace(/[^\s:]/g, '') + return false + } + }) + return value + } + + rawEmptyBody(root) { + let value + root.walk(i => { + if (i.nodes && i.nodes.length === 0) { + value = i.raws.after + if (typeof value !== 'undefined') return false + } + }) + return value + } + + rawIndent(root) { + if (root.raws.indent) return root.raws.indent + let value + root.walk(i => { + let p = i.parent + if (p && p !== root && p.parent && p.parent === root) { + if (typeof i.raws.before !== 'undefined') { + let parts = i.raws.before.split('\n') + value = parts[parts.length - 1] + value = value.replace(/\S/g, '') + return false + } + } + }) + return value + } + + rawSemicolon(root) { + let value + root.walk(i => { + if (i.nodes && i.nodes.length && i.last.type === 'decl') { + value = i.raws.semicolon + if (typeof value !== 'undefined') return false + } + }) + return value + } + + rawValue(node, prop) { + let value = node[prop] + let raw = node.raws[prop] + if (raw && raw.value === value) { + return raw.raw + } + + return value + } + + root(node) { + this.body(node) + if (node.raws.after) this.builder(node.raws.after) + } + + rule(node) { + this.block(node, this.rawValue(node, 'selector')) + if (node.raws.ownSemicolon) { + this.builder(node.raws.ownSemicolon, node, 'end') + } + } + + stringify(node, semicolon) { + /* c8 ignore start */ + if (!this[node.type]) { + throw new Error( + 'Unknown AST node type ' + + node.type + + '. ' + + 'Maybe you need to change PostCSS stringifier.' + ) + } + /* c8 ignore stop */ + this[node.type](node, semicolon) + } +} + +module.exports = Stringifier +Stringifier.default = Stringifier diff --git a/node_modules/postcss/lib/stringify.d.ts b/node_modules/postcss/lib/stringify.d.ts new file mode 100644 index 0000000..06ad0b4 --- /dev/null +++ b/node_modules/postcss/lib/stringify.d.ts @@ -0,0 +1,9 @@ +import { Stringifier } from './postcss.js' + +interface Stringify extends Stringifier { + default: Stringify +} + +declare const stringify: Stringify + +export = stringify diff --git a/node_modules/postcss/lib/stringify.js b/node_modules/postcss/lib/stringify.js new file mode 100644 index 0000000..77bd017 --- /dev/null +++ b/node_modules/postcss/lib/stringify.js @@ -0,0 +1,11 @@ +'use strict' + +let Stringifier = require('./stringifier') + +function stringify(node, builder) { + let str = new Stringifier(builder) + str.stringify(node) +} + +module.exports = stringify +stringify.default = stringify diff --git a/node_modules/postcss/lib/symbols.js b/node_modules/postcss/lib/symbols.js new file mode 100644 index 0000000..a142c26 --- /dev/null +++ b/node_modules/postcss/lib/symbols.js @@ -0,0 +1,5 @@ +'use strict' + +module.exports.isClean = Symbol('isClean') + +module.exports.my = Symbol('my') diff --git a/node_modules/postcss/lib/terminal-highlight.js b/node_modules/postcss/lib/terminal-highlight.js new file mode 100644 index 0000000..6196c9d --- /dev/null +++ b/node_modules/postcss/lib/terminal-highlight.js @@ -0,0 +1,70 @@ +'use strict' + +let pico = require('picocolors') + +let tokenizer = require('./tokenize') + +let Input + +function registerInput(dependant) { + Input = dependant +} + +const HIGHLIGHT_THEME = { + ';': pico.yellow, + ':': pico.yellow, + '(': pico.cyan, + ')': pico.cyan, + '[': pico.yellow, + ']': pico.yellow, + '{': pico.yellow, + '}': pico.yellow, + 'at-word': pico.cyan, + 'brackets': pico.cyan, + 'call': pico.cyan, + 'class': pico.yellow, + 'comment': pico.gray, + 'hash': pico.magenta, + 'string': pico.green +} + +function getTokenType([type, value], processor) { + if (type === 'word') { + if (value[0] === '.') { + return 'class' + } + if (value[0] === '#') { + return 'hash' + } + } + + if (!processor.endOfFile()) { + let next = processor.nextToken() + processor.back(next) + if (next[0] === 'brackets' || next[0] === '(') return 'call' + } + + return type +} + +function terminalHighlight(css) { + let processor = tokenizer(new Input(css), { ignoreErrors: true }) + let result = '' + while (!processor.endOfFile()) { + let token = processor.nextToken() + let color = HIGHLIGHT_THEME[getTokenType(token, processor)] + if (color) { + result += token[1] + .split(/\r?\n/) + .map(i => color(i)) + .join('\n') + } else { + result += token[1] + } + } + return result +} + +terminalHighlight.registerInput = registerInput + +module.exports = terminalHighlight diff --git a/node_modules/postcss/lib/tokenize.js b/node_modules/postcss/lib/tokenize.js new file mode 100644 index 0000000..39a20a3 --- /dev/null +++ b/node_modules/postcss/lib/tokenize.js @@ -0,0 +1,266 @@ +'use strict' + +const SINGLE_QUOTE = "'".charCodeAt(0) +const DOUBLE_QUOTE = '"'.charCodeAt(0) +const BACKSLASH = '\\'.charCodeAt(0) +const SLASH = '/'.charCodeAt(0) +const NEWLINE = '\n'.charCodeAt(0) +const SPACE = ' '.charCodeAt(0) +const FEED = '\f'.charCodeAt(0) +const TAB = '\t'.charCodeAt(0) +const CR = '\r'.charCodeAt(0) +const OPEN_SQUARE = '['.charCodeAt(0) +const CLOSE_SQUARE = ']'.charCodeAt(0) +const OPEN_PARENTHESES = '('.charCodeAt(0) +const CLOSE_PARENTHESES = ')'.charCodeAt(0) +const OPEN_CURLY = '{'.charCodeAt(0) +const CLOSE_CURLY = '}'.charCodeAt(0) +const SEMICOLON = ';'.charCodeAt(0) +const ASTERISK = '*'.charCodeAt(0) +const COLON = ':'.charCodeAt(0) +const AT = '@'.charCodeAt(0) + +const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g +const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g +const RE_BAD_BRACKET = /.[\r\n"'(/\\]/ +const RE_HEX_ESCAPE = /[\da-f]/i + +module.exports = function tokenizer(input, options = {}) { + let css = input.css.valueOf() + let ignore = options.ignoreErrors + + let code, next, quote, content, escape + let escaped, escapePos, prev, n, currentToken + + let length = css.length + let pos = 0 + let buffer = [] + let returned = [] + + function position() { + return pos + } + + function unclosed(what) { + throw input.error('Unclosed ' + what, pos) + } + + function endOfFile() { + return returned.length === 0 && pos >= length + } + + function nextToken(opts) { + if (returned.length) return returned.pop() + if (pos >= length) return + + let ignoreUnclosed = opts ? opts.ignoreUnclosed : false + + code = css.charCodeAt(pos) + + switch (code) { + case NEWLINE: + case SPACE: + case TAB: + case CR: + case FEED: { + next = pos + do { + next += 1 + code = css.charCodeAt(next) + } while ( + code === SPACE || + code === NEWLINE || + code === TAB || + code === CR || + code === FEED + ) + + currentToken = ['space', css.slice(pos, next)] + pos = next - 1 + break + } + + case OPEN_SQUARE: + case CLOSE_SQUARE: + case OPEN_CURLY: + case CLOSE_CURLY: + case COLON: + case SEMICOLON: + case CLOSE_PARENTHESES: { + let controlChar = String.fromCharCode(code) + currentToken = [controlChar, controlChar, pos] + break + } + + case OPEN_PARENTHESES: { + prev = buffer.length ? buffer.pop()[1] : '' + n = css.charCodeAt(pos + 1) + if ( + prev === 'url' && + n !== SINGLE_QUOTE && + n !== DOUBLE_QUOTE && + n !== SPACE && + n !== NEWLINE && + n !== TAB && + n !== FEED && + n !== CR + ) { + next = pos + do { + escaped = false + next = css.indexOf(')', next + 1) + if (next === -1) { + if (ignore || ignoreUnclosed) { + next = pos + break + } else { + unclosed('bracket') + } + } + escapePos = next + while (css.charCodeAt(escapePos - 1) === BACKSLASH) { + escapePos -= 1 + escaped = !escaped + } + } while (escaped) + + currentToken = ['brackets', css.slice(pos, next + 1), pos, next] + + pos = next + } else { + next = css.indexOf(')', pos + 1) + content = css.slice(pos, next + 1) + + if (next === -1 || RE_BAD_BRACKET.test(content)) { + currentToken = ['(', '(', pos] + } else { + currentToken = ['brackets', content, pos, next] + pos = next + } + } + + break + } + + case SINGLE_QUOTE: + case DOUBLE_QUOTE: { + quote = code === SINGLE_QUOTE ? "'" : '"' + next = pos + do { + escaped = false + next = css.indexOf(quote, next + 1) + if (next === -1) { + if (ignore || ignoreUnclosed) { + next = pos + 1 + break + } else { + unclosed('string') + } + } + escapePos = next + while (css.charCodeAt(escapePos - 1) === BACKSLASH) { + escapePos -= 1 + escaped = !escaped + } + } while (escaped) + + currentToken = ['string', css.slice(pos, next + 1), pos, next] + pos = next + break + } + + case AT: { + RE_AT_END.lastIndex = pos + 1 + RE_AT_END.test(css) + if (RE_AT_END.lastIndex === 0) { + next = css.length - 1 + } else { + next = RE_AT_END.lastIndex - 2 + } + + currentToken = ['at-word', css.slice(pos, next + 1), pos, next] + + pos = next + break + } + + case BACKSLASH: { + next = pos + escape = true + while (css.charCodeAt(next + 1) === BACKSLASH) { + next += 1 + escape = !escape + } + code = css.charCodeAt(next + 1) + if ( + escape && + code !== SLASH && + code !== SPACE && + code !== NEWLINE && + code !== TAB && + code !== CR && + code !== FEED + ) { + next += 1 + if (RE_HEX_ESCAPE.test(css.charAt(next))) { + while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { + next += 1 + } + if (css.charCodeAt(next + 1) === SPACE) { + next += 1 + } + } + } + + currentToken = ['word', css.slice(pos, next + 1), pos, next] + + pos = next + break + } + + default: { + if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { + next = css.indexOf('*/', pos + 2) + 1 + if (next === 0) { + if (ignore || ignoreUnclosed) { + next = css.length + } else { + unclosed('comment') + } + } + + currentToken = ['comment', css.slice(pos, next + 1), pos, next] + pos = next + } else { + RE_WORD_END.lastIndex = pos + 1 + RE_WORD_END.test(css) + if (RE_WORD_END.lastIndex === 0) { + next = css.length - 1 + } else { + next = RE_WORD_END.lastIndex - 2 + } + + currentToken = ['word', css.slice(pos, next + 1), pos, next] + buffer.push(currentToken) + pos = next + } + + break + } + } + + pos++ + return currentToken + } + + function back(token) { + returned.push(token) + } + + return { + back, + endOfFile, + nextToken, + position + } +} diff --git a/node_modules/postcss/lib/warn-once.js b/node_modules/postcss/lib/warn-once.js new file mode 100644 index 0000000..316e1cf --- /dev/null +++ b/node_modules/postcss/lib/warn-once.js @@ -0,0 +1,13 @@ +/* eslint-disable no-console */ +'use strict' + +let printed = {} + +module.exports = function warnOnce(message) { + if (printed[message]) return + printed[message] = true + + if (typeof console !== 'undefined' && console.warn) { + console.warn(message) + } +} diff --git a/node_modules/postcss/lib/warning.d.ts b/node_modules/postcss/lib/warning.d.ts new file mode 100644 index 0000000..b25bba8 --- /dev/null +++ b/node_modules/postcss/lib/warning.d.ts @@ -0,0 +1,147 @@ +import { RangePosition } from './css-syntax-error.js' +import Node from './node.js' + +declare namespace Warning { + export interface WarningOptions { + /** + * End position, exclusive, in CSS node string that caused the warning. + */ + end?: RangePosition + + /** + * End index, exclusive, in CSS node string that caused the warning. + */ + endIndex?: number + + /** + * Start index, inclusive, in CSS node string that caused the warning. + */ + index?: number + + /** + * CSS node that caused the warning. + */ + node?: Node + + /** + * Name of the plugin that created this warning. `Result#warn` fills + * this property automatically. + */ + plugin?: string + + /** + * Start position, inclusive, in CSS node string that caused the warning. + */ + start?: RangePosition + + /** + * Word in CSS source that caused the warning. + */ + word?: string + } + + // eslint-disable-next-line @typescript-eslint/no-use-before-define + export { Warning_ as default } +} + +/** + * Represents a plugin’s warning. It can be created using `Node#warn`. + * + * ```js + * if (decl.important) { + * decl.warn(result, 'Avoid !important', { word: '!important' }) + * } + * ``` + */ +declare class Warning_ { + /** + * Column for inclusive start position in the input file with this warning’s source. + * + * ```js + * warning.column //=> 6 + * ``` + */ + column: number + + /** + * Column for exclusive end position in the input file with this warning’s source. + * + * ```js + * warning.endColumn //=> 4 + * ``` + */ + endColumn?: number + + /** + * Line for exclusive end position in the input file with this warning’s source. + * + * ```js + * warning.endLine //=> 6 + * ``` + */ + endLine?: number + + /** + * Line for inclusive start position in the input file with this warning’s source. + * + * ```js + * warning.line //=> 5 + * ``` + */ + line: number + + /** + * Contains the CSS node that caused the warning. + * + * ```js + * warning.node.toString() //=> 'color: white !important' + * ``` + */ + node: Node + + /** + * The name of the plugin that created this warning. + * When you call `Node#warn` it will fill this property automatically. + * + * ```js + * warning.plugin //=> 'postcss-important' + * ``` + */ + plugin: string + + /** + * The warning message. + * + * ```js + * warning.text //=> 'Try to avoid !important' + * ``` + */ + text: string + + /** + * Type to filter warnings from `Result#messages`. + * Always equal to `"warning"`. + */ + type: 'warning' + + /** + * @param text Warning message. + * @param opts Warning options. + */ + constructor(text: string, opts?: Warning.WarningOptions) + + /** + * Returns a warning position and message. + * + * ```js + * warning.toString() //=> 'postcss-lint:a.css:10:14: Avoid !important' + * ``` + * + * @return Warning position and message. + */ + toString(): string +} + +declare class Warning extends Warning_ {} + +export = Warning diff --git a/node_modules/postcss/lib/warning.js b/node_modules/postcss/lib/warning.js new file mode 100644 index 0000000..3a3d79c --- /dev/null +++ b/node_modules/postcss/lib/warning.js @@ -0,0 +1,37 @@ +'use strict' + +class Warning { + constructor(text, opts = {}) { + this.type = 'warning' + this.text = text + + if (opts.node && opts.node.source) { + let range = opts.node.rangeBy(opts) + this.line = range.start.line + this.column = range.start.column + this.endLine = range.end.line + this.endColumn = range.end.column + } + + for (let opt in opts) this[opt] = opts[opt] + } + + toString() { + if (this.node) { + return this.node.error(this.text, { + index: this.index, + plugin: this.plugin, + word: this.word + }).message + } + + if (this.plugin) { + return this.plugin + ': ' + this.text + } + + return this.text + } +} + +module.exports = Warning +Warning.default = Warning diff --git a/node_modules/postcss/package.json b/node_modules/postcss/package.json new file mode 100755 index 0000000..2cfe97f --- /dev/null +++ b/node_modules/postcss/package.json @@ -0,0 +1,88 @@ +{ + "name": "postcss", + "version": "8.4.38", + "description": "Tool for transforming styles with JS plugins", + "engines": { + "node": "^10 || ^12 || >=14" + }, + "exports": { + ".": { + "require": "./lib/postcss.js", + "import": "./lib/postcss.mjs" + }, + "./lib/at-rule": "./lib/at-rule.js", + "./lib/comment": "./lib/comment.js", + "./lib/container": "./lib/container.js", + "./lib/css-syntax-error": "./lib/css-syntax-error.js", + "./lib/declaration": "./lib/declaration.js", + "./lib/fromJSON": "./lib/fromJSON.js", + "./lib/input": "./lib/input.js", + "./lib/lazy-result": "./lib/lazy-result.js", + "./lib/no-work-result": "./lib/no-work-result.js", + "./lib/list": "./lib/list.js", + "./lib/map-generator": "./lib/map-generator.js", + "./lib/node": "./lib/node.js", + "./lib/parse": "./lib/parse.js", + "./lib/parser": "./lib/parser.js", + "./lib/postcss": "./lib/postcss.js", + "./lib/previous-map": "./lib/previous-map.js", + "./lib/processor": "./lib/processor.js", + "./lib/result": "./lib/result.js", + "./lib/root": "./lib/root.js", + "./lib/rule": "./lib/rule.js", + "./lib/stringifier": "./lib/stringifier.js", + "./lib/stringify": "./lib/stringify.js", + "./lib/symbols": "./lib/symbols.js", + "./lib/terminal-highlight": "./lib/terminal-highlight.js", + "./lib/tokenize": "./lib/tokenize.js", + "./lib/warn-once": "./lib/warn-once.js", + "./lib/warning": "./lib/warning.js", + "./package.json": "./package.json" + }, + "main": "./lib/postcss.js", + "types": "./lib/postcss.d.ts", + "keywords": [ + "css", + "postcss", + "rework", + "preprocessor", + "parser", + "source map", + "transform", + "manipulation", + "transpiler" + ], + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "author": "Andrey Sitnik ", + "license": "MIT", + "homepage": "https://postcss.org/", + "repository": "postcss/postcss", + "bugs": { + "url": "https://github.com/postcss/postcss/issues" + }, + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "browser": { + "./lib/terminal-highlight": false, + "source-map-js": false, + "path": false, + "url": false, + "fs": false + } +} diff --git a/node_modules/queue-microtask/LICENSE b/node_modules/queue-microtask/LICENSE new file mode 100755 index 0000000..c7e6852 --- /dev/null +++ b/node_modules/queue-microtask/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) Feross Aboukhadijeh + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/queue-microtask/README.md b/node_modules/queue-microtask/README.md new file mode 100644 index 0000000..0be05a6 --- /dev/null +++ b/node_modules/queue-microtask/README.md @@ -0,0 +1,90 @@ +# queue-microtask [![ci][ci-image]][ci-url] [![npm][npm-image]][npm-url] [![downloads][downloads-image]][downloads-url] [![javascript style guide][standard-image]][standard-url] + +[ci-image]: https://img.shields.io/github/workflow/status/feross/queue-microtask/ci/master +[ci-url]: https://github.com/feross/queue-microtask/actions +[npm-image]: https://img.shields.io/npm/v/queue-microtask.svg +[npm-url]: https://npmjs.org/package/queue-microtask +[downloads-image]: https://img.shields.io/npm/dm/queue-microtask.svg +[downloads-url]: https://npmjs.org/package/queue-microtask +[standard-image]: https://img.shields.io/badge/code_style-standard-brightgreen.svg +[standard-url]: https://standardjs.com + +### fast, tiny [`queueMicrotask`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/queueMicrotask) shim for modern engines + +- Use [`queueMicrotask`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/queueMicrotask) in all modern JS engines. +- No dependencies. Less than 10 lines. No shims or complicated fallbacks. +- Optimal performance in all modern environments + - Uses `queueMicrotask` in modern environments + - Fallback to `Promise.resolve().then(fn)` in Node.js 10 and earlier, and old browsers (same performance as `queueMicrotask`) + +## install + +``` +npm install queue-microtask +``` + +## usage + +```js +const queueMicrotask = require('queue-microtask') + +queueMicrotask(() => { /* this will run soon */ }) +``` + +## What is `queueMicrotask` and why would one use it? + +The `queueMicrotask` function is a WHATWG standard. It queues a microtask to be executed prior to control returning to the event loop. + +A microtask is a short function which will run after the current task has completed its work and when there is no other code waiting to be run before control of the execution context is returned to the event loop. + +The code `queueMicrotask(fn)` is equivalent to the code `Promise.resolve().then(fn)`. It is also very similar to [`process.nextTick(fn)`](https://nodejs.org/api/process.html#process_process_nexttick_callback_args) in Node. + +Using microtasks lets code run without interfering with any other, potentially higher priority, code that is pending, but before the JS engine regains control over the execution context. + +See the [spec](https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#microtask-queuing) or [Node documentation](https://nodejs.org/api/globals.html#globals_queuemicrotask_callback) for more information. + +## Who is this package for? + +This package allows you to use `queueMicrotask` safely in all modern JS engines. Use it if you prioritize small JS bundle size over support for old browsers. + +If you just need to support Node 12 and later, use `queueMicrotask` directly. If you need to support all versions of Node, use this package. + +## Why not use `process.nextTick`? + +In Node, `queueMicrotask` and `process.nextTick` are [essentially equivalent](https://nodejs.org/api/globals.html#globals_queuemicrotask_callback), though there are [subtle differences](https://github.com/YuzuJS/setImmediate#macrotasks-and-microtasks) that don't matter in most situations. + +You can think of `queueMicrotask` as a standardized version of `process.nextTick` that works in the browser. No need to rely on your browser bundler to shim `process` for the browser environment. + +## Why not use `setTimeout(fn, 0)`? + +This approach is the most compatible, but it has problems. Modern browsers throttle timers severely, so `setTimeout(…, 0)` usually takes at least 4ms to run. Furthermore, the throttling gets even worse if the page is backgrounded. If you have many `setTimeout` calls, then this can severely limit the performance of your program. + +## Why not use a microtask library like [`immediate`](https://www.npmjs.com/package/immediate) or [`asap`](https://www.npmjs.com/package/asap)? + +These packages are great! However, if you prioritize small JS bundle size over optimal performance in old browsers then you may want to consider this package. + +This package (`queue-microtask`) is four times smaller than `immediate`, twice as small as `asap`, and twice as small as using `process.nextTick` and letting the browser bundler shim it automatically. + +Note: This package throws an exception in JS environments which lack `Promise` support -- which are usually very old browsers and Node.js versions. + +Since the `queueMicrotask` API is supported in Node.js, Chrome, Firefox, Safari, Opera, and Edge, **the vast majority of users will get optimal performance**. Any JS environment with `Promise`, which is almost all of them, also get optimal performance. If you need support for JS environments which lack `Promise` support, use one of the alternative packages. + +## What is a shim? + +> In computer programming, a shim is a library that transparently intercepts API calls and changes the arguments passed, handles the operation itself or redirects the operation elsewhere. – [Wikipedia](https://en.wikipedia.org/wiki/Shim_(computing)) + +This package could also be described as a "ponyfill". + +> A ponyfill is almost the same as a polyfill, but not quite. Instead of patching functionality for older browsers, a ponyfill provides that functionality as a standalone module you can use. – [PonyFoo](https://ponyfoo.com/articles/polyfills-or-ponyfills) + +## API + +### `queueMicrotask(fn)` + +The `queueMicrotask()` method queues a microtask. + +The `fn` argument is a function to be executed after all pending tasks have completed but before yielding control to the browser's event loop. + +## license + +MIT. Copyright (c) [Feross Aboukhadijeh](https://feross.org). diff --git a/node_modules/queue-microtask/index.d.ts b/node_modules/queue-microtask/index.d.ts new file mode 100644 index 0000000..b6a8646 --- /dev/null +++ b/node_modules/queue-microtask/index.d.ts @@ -0,0 +1,2 @@ +declare const queueMicrotask: (cb: () => void) => void +export = queueMicrotask diff --git a/node_modules/queue-microtask/index.js b/node_modules/queue-microtask/index.js new file mode 100644 index 0000000..5560534 --- /dev/null +++ b/node_modules/queue-microtask/index.js @@ -0,0 +1,9 @@ +/*! queue-microtask. MIT License. Feross Aboukhadijeh */ +let promise + +module.exports = typeof queueMicrotask === 'function' + ? queueMicrotask.bind(typeof window !== 'undefined' ? window : global) + // reuse resolved promise, and allocate it lazily + : cb => (promise || (promise = Promise.resolve())) + .then(cb) + .catch(err => setTimeout(() => { throw err }, 0)) diff --git a/node_modules/queue-microtask/package.json b/node_modules/queue-microtask/package.json new file mode 100644 index 0000000..d29a401 --- /dev/null +++ b/node_modules/queue-microtask/package.json @@ -0,0 +1,55 @@ +{ + "name": "queue-microtask", + "description": "fast, tiny `queueMicrotask` shim for modern engines", + "version": "1.2.3", + "author": { + "name": "Feross Aboukhadijeh", + "email": "feross@feross.org", + "url": "https://feross.org" + }, + "bugs": { + "url": "https://github.com/feross/queue-microtask/issues" + }, + "devDependencies": { + "standard": "*", + "tape": "^5.2.2" + }, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "homepage": "https://github.com/feross/queue-microtask", + "keywords": [ + "asap", + "immediate", + "micro task", + "microtask", + "nextTick", + "process.nextTick", + "queue micro task", + "queue microtask", + "queue-microtask", + "queueMicrotask", + "setImmediate", + "task" + ], + "license": "MIT", + "main": "index.js", + "repository": { + "type": "git", + "url": "git://github.com/feross/queue-microtask.git" + }, + "scripts": { + "test": "standard && tape test/*.js" + } +} diff --git a/node_modules/quick-lru/index.d.ts b/node_modules/quick-lru/index.d.ts new file mode 100644 index 0000000..fa58889 --- /dev/null +++ b/node_modules/quick-lru/index.d.ts @@ -0,0 +1,97 @@ +declare namespace QuickLRU { + interface Options { + /** + The maximum number of items before evicting the least recently used items. + */ + readonly maxSize: number; + + /** + Called right before an item is evicted from the cache. + + Useful for side effects or for items like object URLs that need explicit cleanup (`revokeObjectURL`). + */ + onEviction?: (key: KeyType, value: ValueType) => void; + } +} + +declare class QuickLRU + implements Iterable<[KeyType, ValueType]> { + /** + The stored item count. + */ + readonly size: number; + + /** + Simple ["Least Recently Used" (LRU) cache](https://en.m.wikipedia.org/wiki/Cache_replacement_policies#Least_Recently_Used_.28LRU.29). + + The instance is [`iterable`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Iteration_protocols) so you can use it directly in a [`for…of`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/for...of) loop. + + @example + ``` + import QuickLRU = require('quick-lru'); + + const lru = new QuickLRU({maxSize: 1000}); + + lru.set('🦄', '🌈'); + + lru.has('🦄'); + //=> true + + lru.get('🦄'); + //=> '🌈' + ``` + */ + constructor(options: QuickLRU.Options); + + [Symbol.iterator](): IterableIterator<[KeyType, ValueType]>; + + /** + Set an item. + + @returns The list instance. + */ + set(key: KeyType, value: ValueType): this; + + /** + Get an item. + + @returns The stored item or `undefined`. + */ + get(key: KeyType): ValueType | undefined; + + /** + Check if an item exists. + */ + has(key: KeyType): boolean; + + /** + Get an item without marking it as recently used. + + @returns The stored item or `undefined`. + */ + peek(key: KeyType): ValueType | undefined; + + /** + Delete an item. + + @returns `true` if the item is removed or `false` if the item doesn't exist. + */ + delete(key: KeyType): boolean; + + /** + Delete all items. + */ + clear(): void; + + /** + Iterable for all the keys. + */ + keys(): IterableIterator; + + /** + Iterable for all the values. + */ + values(): IterableIterator; +} + +export = QuickLRU; diff --git a/node_modules/quick-lru/index.js b/node_modules/quick-lru/index.js new file mode 100644 index 0000000..7d7032e --- /dev/null +++ b/node_modules/quick-lru/index.js @@ -0,0 +1,123 @@ +'use strict'; + +class QuickLRU { + constructor(options = {}) { + if (!(options.maxSize && options.maxSize > 0)) { + throw new TypeError('`maxSize` must be a number greater than 0'); + } + + this.maxSize = options.maxSize; + this.onEviction = options.onEviction; + this.cache = new Map(); + this.oldCache = new Map(); + this._size = 0; + } + + _set(key, value) { + this.cache.set(key, value); + this._size++; + + if (this._size >= this.maxSize) { + this._size = 0; + + if (typeof this.onEviction === 'function') { + for (const [key, value] of this.oldCache.entries()) { + this.onEviction(key, value); + } + } + + this.oldCache = this.cache; + this.cache = new Map(); + } + } + + get(key) { + if (this.cache.has(key)) { + return this.cache.get(key); + } + + if (this.oldCache.has(key)) { + const value = this.oldCache.get(key); + this.oldCache.delete(key); + this._set(key, value); + return value; + } + } + + set(key, value) { + if (this.cache.has(key)) { + this.cache.set(key, value); + } else { + this._set(key, value); + } + + return this; + } + + has(key) { + return this.cache.has(key) || this.oldCache.has(key); + } + + peek(key) { + if (this.cache.has(key)) { + return this.cache.get(key); + } + + if (this.oldCache.has(key)) { + return this.oldCache.get(key); + } + } + + delete(key) { + const deleted = this.cache.delete(key); + if (deleted) { + this._size--; + } + + return this.oldCache.delete(key) || deleted; + } + + clear() { + this.cache.clear(); + this.oldCache.clear(); + this._size = 0; + } + + * keys() { + for (const [key] of this) { + yield key; + } + } + + * values() { + for (const [, value] of this) { + yield value; + } + } + + * [Symbol.iterator]() { + for (const item of this.cache) { + yield item; + } + + for (const item of this.oldCache) { + const [key] = item; + if (!this.cache.has(key)) { + yield item; + } + } + } + + get size() { + let oldCacheSize = 0; + for (const key of this.oldCache.keys()) { + if (!this.cache.has(key)) { + oldCacheSize++; + } + } + + return Math.min(this._size + oldCacheSize, this.maxSize); + } +} + +module.exports = QuickLRU; diff --git a/node_modules/quick-lru/license b/node_modules/quick-lru/license new file mode 100644 index 0000000..e7af2f7 --- /dev/null +++ b/node_modules/quick-lru/license @@ -0,0 +1,9 @@ +MIT License + +Copyright (c) Sindre Sorhus (sindresorhus.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/quick-lru/package.json b/node_modules/quick-lru/package.json new file mode 100644 index 0000000..ff0dd9a --- /dev/null +++ b/node_modules/quick-lru/package.json @@ -0,0 +1,43 @@ +{ + "name": "quick-lru", + "version": "5.1.1", + "description": "Simple “Least Recently Used” (LRU) cache", + "license": "MIT", + "repository": "sindresorhus/quick-lru", + "funding": "https://github.com/sponsors/sindresorhus", + "author": { + "name": "Sindre Sorhus", + "email": "sindresorhus@gmail.com", + "url": "https://sindresorhus.com" + }, + "engines": { + "node": ">=10" + }, + "scripts": { + "test": "xo && nyc ava && tsd" + }, + "files": [ + "index.js", + "index.d.ts" + ], + "keywords": [ + "lru", + "quick", + "cache", + "caching", + "least", + "recently", + "used", + "fast", + "map", + "hash", + "buffer" + ], + "devDependencies": { + "ava": "^2.0.0", + "coveralls": "^3.0.3", + "nyc": "^15.0.0", + "tsd": "^0.11.0", + "xo": "^0.26.0" + } +} diff --git a/node_modules/quick-lru/readme.md b/node_modules/quick-lru/readme.md new file mode 100644 index 0000000..234294a --- /dev/null +++ b/node_modules/quick-lru/readme.md @@ -0,0 +1,111 @@ +# quick-lru [![Build Status](https://travis-ci.org/sindresorhus/quick-lru.svg?branch=master)](https://travis-ci.org/sindresorhus/quick-lru) [![Coverage Status](https://coveralls.io/repos/github/sindresorhus/quick-lru/badge.svg?branch=master)](https://coveralls.io/github/sindresorhus/quick-lru?branch=master) + +> Simple [“Least Recently Used” (LRU) cache](https://en.m.wikipedia.org/wiki/Cache_replacement_policies#Least_Recently_Used_.28LRU.29) + +Useful when you need to cache something and limit memory usage. + +Inspired by the [`hashlru` algorithm](https://github.com/dominictarr/hashlru#algorithm), but instead uses [`Map`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Map) to support keys of any type, not just strings, and values can be `undefined`. + +## Install + +``` +$ npm install quick-lru +``` + +## Usage + +```js +const QuickLRU = require('quick-lru'); + +const lru = new QuickLRU({maxSize: 1000}); + +lru.set('🦄', '🌈'); + +lru.has('🦄'); +//=> true + +lru.get('🦄'); +//=> '🌈' +``` + +## API + +### new QuickLRU(options?) + +Returns a new instance. + +### options + +Type: `object` + +#### maxSize + +*Required*\ +Type: `number` + +The maximum number of items before evicting the least recently used items. + +#### onEviction + +*Optional*\ +Type: `(key, value) => void` + +Called right before an item is evicted from the cache. + +Useful for side effects or for items like object URLs that need explicit cleanup (`revokeObjectURL`). + +### Instance + +The instance is [`iterable`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Iteration_protocols) so you can use it directly in a [`for…of`](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/for...of) loop. + +Both `key` and `value` can be of any type. + +#### .set(key, value) + +Set an item. Returns the instance. + +#### .get(key) + +Get an item. + +#### .has(key) + +Check if an item exists. + +#### .peek(key) + +Get an item without marking it as recently used. + +#### .delete(key) + +Delete an item. + +Returns `true` if the item is removed or `false` if the item doesn't exist. + +#### .clear() + +Delete all items. + +#### .keys() + +Iterable for all the keys. + +#### .values() + +Iterable for all the values. + +#### .size + +The stored item count. + +--- + +
      + + Get professional support for this package with a Tidelift subscription + +
      + + Tidelift helps make open source sustainable for maintainers while giving companies
      assurances about security, maintenance, and licensing for their dependencies. +
      +
      diff --git a/node_modules/read-cache/LICENSE b/node_modules/read-cache/LICENSE new file mode 100644 index 0000000..4b98a41 --- /dev/null +++ b/node_modules/read-cache/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright 2016 Bogdan Chadkin + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/read-cache/README.md b/node_modules/read-cache/README.md new file mode 100644 index 0000000..16a5c36 --- /dev/null +++ b/node_modules/read-cache/README.md @@ -0,0 +1,46 @@ +# read-cache [![Build Status](https://travis-ci.org/TrySound/read-cache.svg?branch=master)](https://travis-ci.org/TrySound/read-cache) + +Reads and caches the entire contents of a file until it is modified. + + +## Install + +``` +$ npm i read-cache +``` + + +## Usage + +```js +// foo.js +var readCache = require('read-cache'); + +readCache('foo.js').then(function (contents) { + console.log(contents); +}); +``` + + +## API + +### readCache(path[, encoding]) + +Returns a promise that resolves with the file's contents. + +### readCache.sync(path[, encoding]) + +Returns the content of the file. + +### readCache.get(path[, encoding]) + +Returns the content of cached file or null. + +### readCache.clear() + +Clears the contents of the cache. + + +## License + +MIT © [Bogdan Chadkin](mailto:trysound@yandex.ru) diff --git a/node_modules/read-cache/index.js b/node_modules/read-cache/index.js new file mode 100644 index 0000000..b5263e6 --- /dev/null +++ b/node_modules/read-cache/index.js @@ -0,0 +1,78 @@ +var fs = require('fs'); +var path = require('path'); +var pify = require('pify'); + +var stat = pify(fs.stat); +var readFile = pify(fs.readFile); +var resolve = path.resolve; + +var cache = Object.create(null); + +function convert(content, encoding) { + if (Buffer.isEncoding(encoding)) { + return content.toString(encoding); + } + return content; +} + +module.exports = function (path, encoding) { + path = resolve(path); + + return stat(path).then(function (stats) { + var item = cache[path]; + + if (item && item.mtime.getTime() === stats.mtime.getTime()) { + return convert(item.content, encoding); + } + + return readFile(path).then(function (data) { + cache[path] = { + mtime: stats.mtime, + content: data + }; + + return convert(data, encoding); + }); + }).catch(function (err) { + cache[path] = null; + return Promise.reject(err); + }); +}; + +module.exports.sync = function (path, encoding) { + path = resolve(path); + + try { + var stats = fs.statSync(path); + var item = cache[path]; + + if (item && item.mtime.getTime() === stats.mtime.getTime()) { + return convert(item.content, encoding); + } + + var data = fs.readFileSync(path); + + cache[path] = { + mtime: stats.mtime, + content: data + }; + + return convert(data, encoding); + } catch (err) { + cache[path] = null; + throw err; + } + +}; + +module.exports.get = function (path, encoding) { + path = resolve(path); + if (cache[path]) { + return convert(cache[path].content, encoding); + } + return null; +}; + +module.exports.clear = function () { + cache = Object.create(null); +}; diff --git a/node_modules/read-cache/package.json b/node_modules/read-cache/package.json new file mode 100644 index 0000000..87199b0 --- /dev/null +++ b/node_modules/read-cache/package.json @@ -0,0 +1,34 @@ +{ + "name": "read-cache", + "version": "1.0.0", + "description": "Reads and caches the entire contents of a file until it is modified", + "files": [ + "index.js" + ], + "main": "index.js", + "scripts": { + "test": "ava" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/TrySound/read-cache.git" + }, + "keywords": [ + "fs", + "read", + "cache" + ], + "author": "Bogdan Chadkin ", + "license": "MIT", + "bugs": { + "url": "https://github.com/TrySound/read-cache/issues" + }, + "homepage": "https://github.com/TrySound/read-cache#readme", + "devDependencies": { + "ava": "^0.9.1", + "del": "^2.2.0" + }, + "dependencies": { + "pify": "^2.3.0" + } +} diff --git a/node_modules/readdirp/LICENSE b/node_modules/readdirp/LICENSE new file mode 100644 index 0000000..037cbb4 --- /dev/null +++ b/node_modules/readdirp/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2012-2019 Thorsten Lorenz, Paul Miller (https://paulmillr.com) + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/readdirp/README.md b/node_modules/readdirp/README.md new file mode 100644 index 0000000..465593c --- /dev/null +++ b/node_modules/readdirp/README.md @@ -0,0 +1,122 @@ +# readdirp [![Weekly downloads](https://img.shields.io/npm/dw/readdirp.svg)](https://github.com/paulmillr/readdirp) + +Recursive version of [fs.readdir](https://nodejs.org/api/fs.html#fs_fs_readdir_path_options_callback). Exposes a **stream API** and a **promise API**. + + +```sh +npm install readdirp +``` + +```javascript +const readdirp = require('readdirp'); + +// Use streams to achieve small RAM & CPU footprint. +// 1) Streams example with for-await. +for await (const entry of readdirp('.')) { + const {path} = entry; + console.log(`${JSON.stringify({path})}`); +} + +// 2) Streams example, non for-await. +// Print out all JS files along with their size within the current folder & subfolders. +readdirp('.', {fileFilter: '*.js', alwaysStat: true}) + .on('data', (entry) => { + const {path, stats: {size}} = entry; + console.log(`${JSON.stringify({path, size})}`); + }) + // Optionally call stream.destroy() in `warn()` in order to abort and cause 'close' to be emitted + .on('warn', error => console.error('non-fatal error', error)) + .on('error', error => console.error('fatal error', error)) + .on('end', () => console.log('done')); + +// 3) Promise example. More RAM and CPU than streams / for-await. +const files = await readdirp.promise('.'); +console.log(files.map(file => file.path)); + +// Other options. +readdirp('test', { + fileFilter: '*.js', + directoryFilter: ['!.git', '!*modules'] + // directoryFilter: (di) => di.basename.length === 9 + type: 'files_directories', + depth: 1 +}); +``` + +For more examples, check out `examples` directory. + +## API + +`const stream = readdirp(root[, options])` — **Stream API** + +- Reads given root recursively and returns a `stream` of [entry infos](#entryinfo) +- Optionally can be used like `for await (const entry of stream)` with node.js 10+ (`asyncIterator`). +- `on('data', (entry) => {})` [entry info](#entryinfo) for every file / dir. +- `on('warn', (error) => {})` non-fatal `Error` that prevents a file / dir from being processed. Example: inaccessible to the user. +- `on('error', (error) => {})` fatal `Error` which also ends the stream. Example: illegal options where passed. +- `on('end')` — we are done. Called when all entries were found and no more will be emitted. +- `on('close')` — stream is destroyed via `stream.destroy()`. + Could be useful if you want to manually abort even on a non fatal error. + At that point the stream is no longer `readable` and no more entries, warning or errors are emitted +- To learn more about streams, consult the very detailed [nodejs streams documentation](https://nodejs.org/api/stream.html) + or the [stream-handbook](https://github.com/substack/stream-handbook) + +`const entries = await readdirp.promise(root[, options])` — **Promise API**. Returns a list of [entry infos](#entryinfo). + +First argument is awalys `root`, path in which to start reading and recursing into subdirectories. + +### options + +- `fileFilter: ["*.js"]`: filter to include or exclude files. A `Function`, Glob string or Array of glob strings. + - **Function**: a function that takes an entry info as a parameter and returns true to include or false to exclude the entry + - **Glob string**: a string (e.g., `*.js`) which is matched using [picomatch](https://github.com/micromatch/picomatch), so go there for more + information. Globstars (`**`) are not supported since specifying a recursive pattern for an already recursive function doesn't make sense. Negated globs (as explained in the minimatch documentation) are allowed, e.g., `!*.txt` matches everything but text files. + - **Array of glob strings**: either need to be all inclusive or all exclusive (negated) patterns otherwise an error is thrown. + `['*.json', '*.js']` includes all JavaScript and Json files. + `['!.git', '!node_modules']` includes all directories except the '.git' and 'node_modules'. + - Directories that do not pass a filter will not be recursed into. +- `directoryFilter: ['!.git']`: filter to include/exclude directories found and to recurse into. Directories that do not pass a filter will not be recursed into. +- `depth: 5`: depth at which to stop recursing even if more subdirectories are found +- `type: 'files'`: determines if data events on the stream should be emitted for `'files'` (default), `'directories'`, `'files_directories'`, or `'all'`. Setting to `'all'` will also include entries for other types of file descriptors like character devices, unix sockets and named pipes. +- `alwaysStat: false`: always return `stats` property for every file. Default is `false`, readdirp will return `Dirent` entries. Setting it to `true` can double readdir execution time - use it only when you need file `size`, `mtime` etc. Cannot be enabled on node <10.10.0. +- `lstat: false`: include symlink entries in the stream along with files. When `true`, `fs.lstat` would be used instead of `fs.stat` + +### `EntryInfo` + +Has the following properties: + +- `path: 'assets/javascripts/react.js'`: path to the file/directory (relative to given root) +- `fullPath: '/Users/dev/projects/app/assets/javascripts/react.js'`: full path to the file/directory found +- `basename: 'react.js'`: name of the file/directory +- `dirent: fs.Dirent`: built-in [dir entry object](https://nodejs.org/api/fs.html#fs_class_fs_dirent) - only with `alwaysStat: false` +- `stats: fs.Stats`: built in [stat object](https://nodejs.org/api/fs.html#fs_class_fs_stats) - only with `alwaysStat: true` + +## Changelog + +- 3.5 (Oct 13, 2020) disallows recursive directory-based symlinks. + Before, it could have entered infinite loop. +- 3.4 (Mar 19, 2020) adds support for directory-based symlinks. +- 3.3 (Dec 6, 2019) stabilizes RAM consumption and enables perf management with `highWaterMark` option. Fixes race conditions related to `for-await` looping. +- 3.2 (Oct 14, 2019) improves performance by 250% and makes streams implementation more idiomatic. +- 3.1 (Jul 7, 2019) brings `bigint` support to `stat` output on Windows. This is backwards-incompatible for some cases. Be careful. It you use it incorrectly, you'll see "TypeError: Cannot mix BigInt and other types, use explicit conversions". +- 3.0 brings huge performance improvements and stream backpressure support. +- Upgrading 2.x to 3.x: + - Signature changed from `readdirp(options)` to `readdirp(root, options)` + - Replaced callback API with promise API. + - Renamed `entryType` option to `type` + - Renamed `entryType: 'both'` to `'files_directories'` + - `EntryInfo` + - Renamed `stat` to `stats` + - Emitted only when `alwaysStat: true` + - `dirent` is emitted instead of `stats` by default with `alwaysStat: false` + - Renamed `name` to `basename` + - Removed `parentDir` and `fullParentDir` properties +- Supported node.js versions: + - 3.x: node 8+ + - 2.x: node 0.6+ + +## License + +Copyright (c) 2012-2019 Thorsten Lorenz, Paul Miller () + +MIT License, see [LICENSE](LICENSE) file. diff --git a/node_modules/readdirp/index.d.ts b/node_modules/readdirp/index.d.ts new file mode 100644 index 0000000..cbbd76c --- /dev/null +++ b/node_modules/readdirp/index.d.ts @@ -0,0 +1,43 @@ +// TypeScript Version: 3.2 + +/// + +import * as fs from 'fs'; +import { Readable } from 'stream'; + +declare namespace readdir { + interface EntryInfo { + path: string; + fullPath: string; + basename: string; + stats?: fs.Stats; + dirent?: fs.Dirent; + } + + interface ReaddirpOptions { + root?: string; + fileFilter?: string | string[] | ((entry: EntryInfo) => boolean); + directoryFilter?: string | string[] | ((entry: EntryInfo) => boolean); + type?: 'files' | 'directories' | 'files_directories' | 'all'; + lstat?: boolean; + depth?: number; + alwaysStat?: boolean; + } + + interface ReaddirpStream extends Readable, AsyncIterable { + read(): EntryInfo; + [Symbol.asyncIterator](): AsyncIterableIterator; + } + + function promise( + root: string, + options?: ReaddirpOptions + ): Promise; +} + +declare function readdir( + root: string, + options?: readdir.ReaddirpOptions +): readdir.ReaddirpStream; + +export = readdir; diff --git a/node_modules/readdirp/index.js b/node_modules/readdirp/index.js new file mode 100644 index 0000000..cf739b2 --- /dev/null +++ b/node_modules/readdirp/index.js @@ -0,0 +1,287 @@ +'use strict'; + +const fs = require('fs'); +const { Readable } = require('stream'); +const sysPath = require('path'); +const { promisify } = require('util'); +const picomatch = require('picomatch'); + +const readdir = promisify(fs.readdir); +const stat = promisify(fs.stat); +const lstat = promisify(fs.lstat); +const realpath = promisify(fs.realpath); + +/** + * @typedef {Object} EntryInfo + * @property {String} path + * @property {String} fullPath + * @property {fs.Stats=} stats + * @property {fs.Dirent=} dirent + * @property {String} basename + */ + +const BANG = '!'; +const RECURSIVE_ERROR_CODE = 'READDIRP_RECURSIVE_ERROR'; +const NORMAL_FLOW_ERRORS = new Set(['ENOENT', 'EPERM', 'EACCES', 'ELOOP', RECURSIVE_ERROR_CODE]); +const FILE_TYPE = 'files'; +const DIR_TYPE = 'directories'; +const FILE_DIR_TYPE = 'files_directories'; +const EVERYTHING_TYPE = 'all'; +const ALL_TYPES = [FILE_TYPE, DIR_TYPE, FILE_DIR_TYPE, EVERYTHING_TYPE]; + +const isNormalFlowError = error => NORMAL_FLOW_ERRORS.has(error.code); +const [maj, min] = process.versions.node.split('.').slice(0, 2).map(n => Number.parseInt(n, 10)); +const wantBigintFsStats = process.platform === 'win32' && (maj > 10 || (maj === 10 && min >= 5)); + +const normalizeFilter = filter => { + if (filter === undefined) return; + if (typeof filter === 'function') return filter; + + if (typeof filter === 'string') { + const glob = picomatch(filter.trim()); + return entry => glob(entry.basename); + } + + if (Array.isArray(filter)) { + const positive = []; + const negative = []; + for (const item of filter) { + const trimmed = item.trim(); + if (trimmed.charAt(0) === BANG) { + negative.push(picomatch(trimmed.slice(1))); + } else { + positive.push(picomatch(trimmed)); + } + } + + if (negative.length > 0) { + if (positive.length > 0) { + return entry => + positive.some(f => f(entry.basename)) && !negative.some(f => f(entry.basename)); + } + return entry => !negative.some(f => f(entry.basename)); + } + return entry => positive.some(f => f(entry.basename)); + } +}; + +class ReaddirpStream extends Readable { + static get defaultOptions() { + return { + root: '.', + /* eslint-disable no-unused-vars */ + fileFilter: (path) => true, + directoryFilter: (path) => true, + /* eslint-enable no-unused-vars */ + type: FILE_TYPE, + lstat: false, + depth: 2147483648, + alwaysStat: false + }; + } + + constructor(options = {}) { + super({ + objectMode: true, + autoDestroy: true, + highWaterMark: options.highWaterMark || 4096 + }); + const opts = { ...ReaddirpStream.defaultOptions, ...options }; + const { root, type } = opts; + + this._fileFilter = normalizeFilter(opts.fileFilter); + this._directoryFilter = normalizeFilter(opts.directoryFilter); + + const statMethod = opts.lstat ? lstat : stat; + // Use bigint stats if it's windows and stat() supports options (node 10+). + if (wantBigintFsStats) { + this._stat = path => statMethod(path, { bigint: true }); + } else { + this._stat = statMethod; + } + + this._maxDepth = opts.depth; + this._wantsDir = [DIR_TYPE, FILE_DIR_TYPE, EVERYTHING_TYPE].includes(type); + this._wantsFile = [FILE_TYPE, FILE_DIR_TYPE, EVERYTHING_TYPE].includes(type); + this._wantsEverything = type === EVERYTHING_TYPE; + this._root = sysPath.resolve(root); + this._isDirent = ('Dirent' in fs) && !opts.alwaysStat; + this._statsProp = this._isDirent ? 'dirent' : 'stats'; + this._rdOptions = { encoding: 'utf8', withFileTypes: this._isDirent }; + + // Launch stream with one parent, the root dir. + this.parents = [this._exploreDir(root, 1)]; + this.reading = false; + this.parent = undefined; + } + + async _read(batch) { + if (this.reading) return; + this.reading = true; + + try { + while (!this.destroyed && batch > 0) { + const { path, depth, files = [] } = this.parent || {}; + + if (files.length > 0) { + const slice = files.splice(0, batch).map(dirent => this._formatEntry(dirent, path)); + for (const entry of await Promise.all(slice)) { + if (this.destroyed) return; + + const entryType = await this._getEntryType(entry); + if (entryType === 'directory' && this._directoryFilter(entry)) { + if (depth <= this._maxDepth) { + this.parents.push(this._exploreDir(entry.fullPath, depth + 1)); + } + + if (this._wantsDir) { + this.push(entry); + batch--; + } + } else if ((entryType === 'file' || this._includeAsFile(entry)) && this._fileFilter(entry)) { + if (this._wantsFile) { + this.push(entry); + batch--; + } + } + } + } else { + const parent = this.parents.pop(); + if (!parent) { + this.push(null); + break; + } + this.parent = await parent; + if (this.destroyed) return; + } + } + } catch (error) { + this.destroy(error); + } finally { + this.reading = false; + } + } + + async _exploreDir(path, depth) { + let files; + try { + files = await readdir(path, this._rdOptions); + } catch (error) { + this._onError(error); + } + return { files, depth, path }; + } + + async _formatEntry(dirent, path) { + let entry; + try { + const basename = this._isDirent ? dirent.name : dirent; + const fullPath = sysPath.resolve(sysPath.join(path, basename)); + entry = { path: sysPath.relative(this._root, fullPath), fullPath, basename }; + entry[this._statsProp] = this._isDirent ? dirent : await this._stat(fullPath); + } catch (err) { + this._onError(err); + } + return entry; + } + + _onError(err) { + if (isNormalFlowError(err) && !this.destroyed) { + this.emit('warn', err); + } else { + this.destroy(err); + } + } + + async _getEntryType(entry) { + // entry may be undefined, because a warning or an error were emitted + // and the statsProp is undefined + const stats = entry && entry[this._statsProp]; + if (!stats) { + return; + } + if (stats.isFile()) { + return 'file'; + } + if (stats.isDirectory()) { + return 'directory'; + } + if (stats && stats.isSymbolicLink()) { + const full = entry.fullPath; + try { + const entryRealPath = await realpath(full); + const entryRealPathStats = await lstat(entryRealPath); + if (entryRealPathStats.isFile()) { + return 'file'; + } + if (entryRealPathStats.isDirectory()) { + const len = entryRealPath.length; + if (full.startsWith(entryRealPath) && full.substr(len, 1) === sysPath.sep) { + const recursiveError = new Error( + `Circular symlink detected: "${full}" points to "${entryRealPath}"` + ); + recursiveError.code = RECURSIVE_ERROR_CODE; + return this._onError(recursiveError); + } + return 'directory'; + } + } catch (error) { + this._onError(error); + } + } + } + + _includeAsFile(entry) { + const stats = entry && entry[this._statsProp]; + + return stats && this._wantsEverything && !stats.isDirectory(); + } +} + +/** + * @typedef {Object} ReaddirpArguments + * @property {Function=} fileFilter + * @property {Function=} directoryFilter + * @property {String=} type + * @property {Number=} depth + * @property {String=} root + * @property {Boolean=} lstat + * @property {Boolean=} bigint + */ + +/** + * Main function which ends up calling readdirRec and reads all files and directories in given root recursively. + * @param {String} root Root directory + * @param {ReaddirpArguments=} options Options to specify root (start directory), filters and recursion depth + */ +const readdirp = (root, options = {}) => { + let type = options.entryType || options.type; + if (type === 'both') type = FILE_DIR_TYPE; // backwards-compatibility + if (type) options.type = type; + if (!root) { + throw new Error('readdirp: root argument is required. Usage: readdirp(root, options)'); + } else if (typeof root !== 'string') { + throw new TypeError('readdirp: root argument must be a string. Usage: readdirp(root, options)'); + } else if (type && !ALL_TYPES.includes(type)) { + throw new Error(`readdirp: Invalid type passed. Use one of ${ALL_TYPES.join(', ')}`); + } + + options.root = root; + return new ReaddirpStream(options); +}; + +const readdirpPromise = (root, options = {}) => { + return new Promise((resolve, reject) => { + const files = []; + readdirp(root, options) + .on('data', entry => files.push(entry)) + .on('end', () => resolve(files)) + .on('error', error => reject(error)); + }); +}; + +readdirp.promise = readdirpPromise; +readdirp.ReaddirpStream = ReaddirpStream; +readdirp.default = readdirp; + +module.exports = readdirp; diff --git a/node_modules/readdirp/package.json b/node_modules/readdirp/package.json new file mode 100644 index 0000000..dba5388 --- /dev/null +++ b/node_modules/readdirp/package.json @@ -0,0 +1,122 @@ +{ + "name": "readdirp", + "description": "Recursive version of fs.readdir with streaming API.", + "version": "3.6.0", + "homepage": "https://github.com/paulmillr/readdirp", + "repository": { + "type": "git", + "url": "git://github.com/paulmillr/readdirp.git" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/paulmillr/readdirp/issues" + }, + "author": "Thorsten Lorenz (thlorenz.com)", + "contributors": [ + "Thorsten Lorenz (thlorenz.com)", + "Paul Miller (https://paulmillr.com)" + ], + "main": "index.js", + "engines": { + "node": ">=8.10.0" + }, + "files": [ + "index.js", + "index.d.ts" + ], + "keywords": [ + "recursive", + "fs", + "stream", + "streams", + "readdir", + "filesystem", + "find", + "filter" + ], + "scripts": { + "dtslint": "dtslint", + "nyc": "nyc", + "mocha": "mocha --exit", + "lint": "eslint --report-unused-disable-directives --ignore-path .gitignore .", + "test": "npm run lint && nyc npm run mocha" + }, + "dependencies": { + "picomatch": "^2.2.1" + }, + "devDependencies": { + "@types/node": "^14", + "chai": "^4.2", + "chai-subset": "^1.6", + "dtslint": "^3.3.0", + "eslint": "^7.0.0", + "mocha": "^7.1.1", + "nyc": "^15.0.0", + "rimraf": "^3.0.0", + "typescript": "^4.0.3" + }, + "nyc": { + "reporter": [ + "html", + "text" + ] + }, + "eslintConfig": { + "root": true, + "extends": "eslint:recommended", + "parserOptions": { + "ecmaVersion": 9, + "sourceType": "script" + }, + "env": { + "node": true, + "es6": true + }, + "rules": { + "array-callback-return": "error", + "no-empty": [ + "error", + { + "allowEmptyCatch": true + } + ], + "no-else-return": [ + "error", + { + "allowElseIf": false + } + ], + "no-lonely-if": "error", + "no-var": "error", + "object-shorthand": "error", + "prefer-arrow-callback": [ + "error", + { + "allowNamedFunctions": true + } + ], + "prefer-const": [ + "error", + { + "ignoreReadBeforeAssign": true + } + ], + "prefer-destructuring": [ + "error", + { + "object": true, + "array": false + } + ], + "prefer-spread": "error", + "prefer-template": "error", + "radix": "error", + "semi": "error", + "strict": "error", + "quotes": [ + "error", + "single" + ] + } + } +} diff --git a/node_modules/resolve/.DS_Store b/node_modules/resolve/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..afe21193180d8341be7562216fc62273c3084d97 GIT binary patch literal 6148 zcmeHKu};G<5Iwg+tzhZEz-Sgmr1AkMRAEQz0vm)@EmA@%(Mn7x5)1qh0}BHy;uDw{ z8TbP3>`UU*sl)^b-AVRKe0P2Jt8$kBfEp}DeSjVSba4;{>o_$S`Du98;+0KAWqxA{ z3y70Re|VmG(Xt>4hys620eW^junQBofH^qNZ#uJEZ4La0G>f7*$zt?$7kl>~>ht-a zDQfhMsM(aNMZrdO2-*-&{=gvdPS?0Q|P5v5h@J761zpDWDY_jf#MVUnbQ9u+Z6`=Z{aS(=# zxkXbtaH8f&{(z7SuT2j})O;T@<`&U|rfe#rO;!Afp=>&?YmN&UbBi_|Ok2hk#mtJo zP?TZEb&XCm6&jF96c7cL6lmM~9`*mj)!+Y1S#m21hywpf0To2UXn-f;-s+u=y1d45 uii3>ea*HMfC-WkJOLRf4c#E#d(5D$g#@wPwMZZmz7Xea5OceMT1-=06Fr#Jw literal 0 HcmV?d00001 diff --git a/node_modules/resolve/.editorconfig b/node_modules/resolve/.editorconfig new file mode 100644 index 0000000..d63f0bb --- /dev/null +++ b/node_modules/resolve/.editorconfig @@ -0,0 +1,37 @@ +root = true + +[*] +indent_style = space +indent_size = 2 +end_of_line = lf +charset = utf-8 +trim_trailing_whitespace = true +insert_final_newline = true +max_line_length = 200 + +[*.js] +block_comment_start = /* +block_comment = * +block_comment_end = */ + +[*.yml] +indent_size = 1 + +[package.json] +indent_style = tab + +[lib/core.json] +indent_style = tab + +[CHANGELOG.md] +indent_style = space +indent_size = 2 + +[{*.json,Makefile}] +max_line_length = off + +[test/{dotdot,resolver,module_dir,multirepo,node_path,pathfilter,precedence}/**/*] +indent_style = off +indent_size = off +max_line_length = off +insert_final_newline = off diff --git a/node_modules/resolve/.eslintrc b/node_modules/resolve/.eslintrc new file mode 100644 index 0000000..ce1be6e --- /dev/null +++ b/node_modules/resolve/.eslintrc @@ -0,0 +1,65 @@ +{ + "root": true, + + "extends": "@ljharb", + + "rules": { + "indent": [2, 4], + "strict": 0, + "complexity": 0, + "consistent-return": 0, + "curly": 0, + "dot-notation": [2, { "allowKeywords": true }], + "func-name-matching": 0, + "func-style": 0, + "global-require": 1, + "id-length": [2, { "min": 1, "max": 30 }], + "max-lines": [2, 350], + "max-lines-per-function": 0, + "max-nested-callbacks": 0, + "max-params": 0, + "max-statements-per-line": [2, { "max": 2 }], + "max-statements": 0, + "no-magic-numbers": 0, + "no-shadow": 0, + "no-use-before-define": 0, + "sort-keys": 0, + }, + "overrides": [ + { + "files": "bin/**", + "rules": { + "no-process-exit": "off", + }, + }, + { + "files": "example/**", + "rules": { + "no-console": 0, + }, + }, + { + "files": "test/resolver/nested_symlinks/mylib/*.js", + "rules": { + "no-throw-literal": 0, + }, + }, + { + "files": "test/**", + "parserOptions": { + "ecmaVersion": 5, + "allowReserved": false, + }, + "rules": { + "dot-notation": [2, { "allowPattern": "throws" }], + "max-lines": 0, + "max-lines-per-function": 0, + "no-unused-vars": [2, { "vars": "all", "args": "none" }], + }, + }, + ], + + "ignorePatterns": [ + "./test/resolver/malformed_package_json/package.json", + ], +} diff --git a/node_modules/resolve/.github/FUNDING.yml b/node_modules/resolve/.github/FUNDING.yml new file mode 100644 index 0000000..d9c0595 --- /dev/null +++ b/node_modules/resolve/.github/FUNDING.yml @@ -0,0 +1,12 @@ +# These are supported funding model platforms + +github: [ljharb] +patreon: # Replace with a single Patreon username +open_collective: # Replace with a single Open Collective username +ko_fi: # Replace with a single Ko-fi username +tidelift: npm/resolve +community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry +liberapay: # Replace with a single Liberapay username +issuehunt: # Replace with a single IssueHunt username +otechie: # Replace with a single Otechie username +custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2'] diff --git a/node_modules/resolve/LICENSE b/node_modules/resolve/LICENSE new file mode 100644 index 0000000..ff4fce2 --- /dev/null +++ b/node_modules/resolve/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2012 James Halliday + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/resolve/SECURITY.md b/node_modules/resolve/SECURITY.md new file mode 100644 index 0000000..82e4285 --- /dev/null +++ b/node_modules/resolve/SECURITY.md @@ -0,0 +1,3 @@ +# Security + +Please email [@ljharb](https://github.com/ljharb) or see https://tidelift.com/security if you have a potential security vulnerability to report. diff --git a/node_modules/resolve/async.js b/node_modules/resolve/async.js new file mode 100644 index 0000000..f38c581 --- /dev/null +++ b/node_modules/resolve/async.js @@ -0,0 +1,3 @@ +'use strict'; + +module.exports = require('./lib/async'); diff --git a/node_modules/resolve/bin/resolve b/node_modules/resolve/bin/resolve new file mode 100755 index 0000000..5ee329a --- /dev/null +++ b/node_modules/resolve/bin/resolve @@ -0,0 +1,50 @@ +#!/usr/bin/env node + +'use strict'; + +var path = require('path'); +var fs = require('fs'); + +if ( + String(process.env.npm_lifecycle_script).slice(0, 8) !== 'resolve ' + && ( + !process.argv + || process.argv.length < 2 + || (process.argv[1] !== __filename && fs.statSync(process.argv[1]).ino !== fs.statSync(__filename).ino) + || (process.env._ && path.resolve(process.env._) !== __filename) + ) +) { + console.error('Error: `resolve` must be run directly as an executable'); + process.exit(1); +} + +var supportsPreserveSymlinkFlag = require('supports-preserve-symlinks-flag'); + +var preserveSymlinks = false; +for (var i = 2; i < process.argv.length; i += 1) { + if (process.argv[i].slice(0, 2) === '--') { + if (supportsPreserveSymlinkFlag && process.argv[i] === '--preserve-symlinks') { + preserveSymlinks = true; + } else if (process.argv[i].length > 2) { + console.error('Unknown argument ' + process.argv[i].replace(/[=].*$/, '')); + process.exit(2); + } + process.argv.splice(i, 1); + i -= 1; + if (process.argv[i] === '--') { break; } // eslint-disable-line no-restricted-syntax + } +} + +if (process.argv.length < 3) { + console.error('Error: `resolve` expects a specifier'); + process.exit(2); +} + +var resolve = require('../'); + +var result = resolve.sync(process.argv[2], { + basedir: process.cwd(), + preserveSymlinks: preserveSymlinks +}); + +console.log(result); diff --git a/node_modules/resolve/example/async.js b/node_modules/resolve/example/async.js new file mode 100644 index 0000000..20e65dc --- /dev/null +++ b/node_modules/resolve/example/async.js @@ -0,0 +1,5 @@ +var resolve = require('../'); +resolve('tap', { basedir: __dirname }, function (err, res) { + if (err) console.error(err); + else console.log(res); +}); diff --git a/node_modules/resolve/example/sync.js b/node_modules/resolve/example/sync.js new file mode 100644 index 0000000..54b2cc1 --- /dev/null +++ b/node_modules/resolve/example/sync.js @@ -0,0 +1,3 @@ +var resolve = require('../'); +var res = resolve.sync('tap', { basedir: __dirname }); +console.log(res); diff --git a/node_modules/resolve/index.js b/node_modules/resolve/index.js new file mode 100644 index 0000000..125d814 --- /dev/null +++ b/node_modules/resolve/index.js @@ -0,0 +1,6 @@ +var async = require('./lib/async'); +async.core = require('./lib/core'); +async.isCore = require('./lib/is-core'); +async.sync = require('./lib/sync'); + +module.exports = async; diff --git a/node_modules/resolve/lib/async.js b/node_modules/resolve/lib/async.js new file mode 100644 index 0000000..60d2555 --- /dev/null +++ b/node_modules/resolve/lib/async.js @@ -0,0 +1,329 @@ +var fs = require('fs'); +var getHomedir = require('./homedir'); +var path = require('path'); +var caller = require('./caller'); +var nodeModulesPaths = require('./node-modules-paths'); +var normalizeOptions = require('./normalize-options'); +var isCore = require('is-core-module'); + +var realpathFS = process.platform !== 'win32' && fs.realpath && typeof fs.realpath.native === 'function' ? fs.realpath.native : fs.realpath; + +var homedir = getHomedir(); +var defaultPaths = function () { + return [ + path.join(homedir, '.node_modules'), + path.join(homedir, '.node_libraries') + ]; +}; + +var defaultIsFile = function isFile(file, cb) { + fs.stat(file, function (err, stat) { + if (!err) { + return cb(null, stat.isFile() || stat.isFIFO()); + } + if (err.code === 'ENOENT' || err.code === 'ENOTDIR') return cb(null, false); + return cb(err); + }); +}; + +var defaultIsDir = function isDirectory(dir, cb) { + fs.stat(dir, function (err, stat) { + if (!err) { + return cb(null, stat.isDirectory()); + } + if (err.code === 'ENOENT' || err.code === 'ENOTDIR') return cb(null, false); + return cb(err); + }); +}; + +var defaultRealpath = function realpath(x, cb) { + realpathFS(x, function (realpathErr, realPath) { + if (realpathErr && realpathErr.code !== 'ENOENT') cb(realpathErr); + else cb(null, realpathErr ? x : realPath); + }); +}; + +var maybeRealpath = function maybeRealpath(realpath, x, opts, cb) { + if (opts && opts.preserveSymlinks === false) { + realpath(x, cb); + } else { + cb(null, x); + } +}; + +var defaultReadPackage = function defaultReadPackage(readFile, pkgfile, cb) { + readFile(pkgfile, function (readFileErr, body) { + if (readFileErr) cb(readFileErr); + else { + try { + var pkg = JSON.parse(body); + cb(null, pkg); + } catch (jsonErr) { + cb(null); + } + } + }); +}; + +var getPackageCandidates = function getPackageCandidates(x, start, opts) { + var dirs = nodeModulesPaths(start, opts, x); + for (var i = 0; i < dirs.length; i++) { + dirs[i] = path.join(dirs[i], x); + } + return dirs; +}; + +module.exports = function resolve(x, options, callback) { + var cb = callback; + var opts = options; + if (typeof options === 'function') { + cb = opts; + opts = {}; + } + if (typeof x !== 'string') { + var err = new TypeError('Path must be a string.'); + return process.nextTick(function () { + cb(err); + }); + } + + opts = normalizeOptions(x, opts); + + var isFile = opts.isFile || defaultIsFile; + var isDirectory = opts.isDirectory || defaultIsDir; + var readFile = opts.readFile || fs.readFile; + var realpath = opts.realpath || defaultRealpath; + var readPackage = opts.readPackage || defaultReadPackage; + if (opts.readFile && opts.readPackage) { + var conflictErr = new TypeError('`readFile` and `readPackage` are mutually exclusive.'); + return process.nextTick(function () { + cb(conflictErr); + }); + } + var packageIterator = opts.packageIterator; + + var extensions = opts.extensions || ['.js']; + var includeCoreModules = opts.includeCoreModules !== false; + var basedir = opts.basedir || path.dirname(caller()); + var parent = opts.filename || basedir; + + opts.paths = opts.paths || defaultPaths(); + + // ensure that `basedir` is an absolute path at this point, resolving against the process' current working directory + var absoluteStart = path.resolve(basedir); + + maybeRealpath( + realpath, + absoluteStart, + opts, + function (err, realStart) { + if (err) cb(err); + else init(realStart); + } + ); + + var res; + function init(basedir) { + if ((/^(?:\.\.?(?:\/|$)|\/|([A-Za-z]:)?[/\\])/).test(x)) { + res = path.resolve(basedir, x); + if (x === '.' || x === '..' || x.slice(-1) === '/') res += '/'; + if ((/\/$/).test(x) && res === basedir) { + loadAsDirectory(res, opts.package, onfile); + } else loadAsFile(res, opts.package, onfile); + } else if (includeCoreModules && isCore(x)) { + return cb(null, x); + } else loadNodeModules(x, basedir, function (err, n, pkg) { + if (err) cb(err); + else if (n) { + return maybeRealpath(realpath, n, opts, function (err, realN) { + if (err) { + cb(err); + } else { + cb(null, realN, pkg); + } + }); + } else { + var moduleError = new Error("Cannot find module '" + x + "' from '" + parent + "'"); + moduleError.code = 'MODULE_NOT_FOUND'; + cb(moduleError); + } + }); + } + + function onfile(err, m, pkg) { + if (err) cb(err); + else if (m) cb(null, m, pkg); + else loadAsDirectory(res, function (err, d, pkg) { + if (err) cb(err); + else if (d) { + maybeRealpath(realpath, d, opts, function (err, realD) { + if (err) { + cb(err); + } else { + cb(null, realD, pkg); + } + }); + } else { + var moduleError = new Error("Cannot find module '" + x + "' from '" + parent + "'"); + moduleError.code = 'MODULE_NOT_FOUND'; + cb(moduleError); + } + }); + } + + function loadAsFile(x, thePackage, callback) { + var loadAsFilePackage = thePackage; + var cb = callback; + if (typeof loadAsFilePackage === 'function') { + cb = loadAsFilePackage; + loadAsFilePackage = undefined; + } + + var exts = [''].concat(extensions); + load(exts, x, loadAsFilePackage); + + function load(exts, x, loadPackage) { + if (exts.length === 0) return cb(null, undefined, loadPackage); + var file = x + exts[0]; + + var pkg = loadPackage; + if (pkg) onpkg(null, pkg); + else loadpkg(path.dirname(file), onpkg); + + function onpkg(err, pkg_, dir) { + pkg = pkg_; + if (err) return cb(err); + if (dir && pkg && opts.pathFilter) { + var rfile = path.relative(dir, file); + var rel = rfile.slice(0, rfile.length - exts[0].length); + var r = opts.pathFilter(pkg, x, rel); + if (r) return load( + [''].concat(extensions.slice()), + path.resolve(dir, r), + pkg + ); + } + isFile(file, onex); + } + function onex(err, ex) { + if (err) return cb(err); + if (ex) return cb(null, file, pkg); + load(exts.slice(1), x, pkg); + } + } + } + + function loadpkg(dir, cb) { + if (dir === '' || dir === '/') return cb(null); + if (process.platform === 'win32' && (/^\w:[/\\]*$/).test(dir)) { + return cb(null); + } + if ((/[/\\]node_modules[/\\]*$/).test(dir)) return cb(null); + + maybeRealpath(realpath, dir, opts, function (unwrapErr, pkgdir) { + if (unwrapErr) return loadpkg(path.dirname(dir), cb); + var pkgfile = path.join(pkgdir, 'package.json'); + isFile(pkgfile, function (err, ex) { + // on err, ex is false + if (!ex) return loadpkg(path.dirname(dir), cb); + + readPackage(readFile, pkgfile, function (err, pkgParam) { + if (err) cb(err); + + var pkg = pkgParam; + + if (pkg && opts.packageFilter) { + pkg = opts.packageFilter(pkg, pkgfile); + } + cb(null, pkg, dir); + }); + }); + }); + } + + function loadAsDirectory(x, loadAsDirectoryPackage, callback) { + var cb = callback; + var fpkg = loadAsDirectoryPackage; + if (typeof fpkg === 'function') { + cb = fpkg; + fpkg = opts.package; + } + + maybeRealpath(realpath, x, opts, function (unwrapErr, pkgdir) { + if (unwrapErr) return cb(unwrapErr); + var pkgfile = path.join(pkgdir, 'package.json'); + isFile(pkgfile, function (err, ex) { + if (err) return cb(err); + if (!ex) return loadAsFile(path.join(x, 'index'), fpkg, cb); + + readPackage(readFile, pkgfile, function (err, pkgParam) { + if (err) return cb(err); + + var pkg = pkgParam; + + if (pkg && opts.packageFilter) { + pkg = opts.packageFilter(pkg, pkgfile); + } + + if (pkg && pkg.main) { + if (typeof pkg.main !== 'string') { + var mainError = new TypeError('package “' + pkg.name + '” `main` must be a string'); + mainError.code = 'INVALID_PACKAGE_MAIN'; + return cb(mainError); + } + if (pkg.main === '.' || pkg.main === './') { + pkg.main = 'index'; + } + loadAsFile(path.resolve(x, pkg.main), pkg, function (err, m, pkg) { + if (err) return cb(err); + if (m) return cb(null, m, pkg); + if (!pkg) return loadAsFile(path.join(x, 'index'), pkg, cb); + + var dir = path.resolve(x, pkg.main); + loadAsDirectory(dir, pkg, function (err, n, pkg) { + if (err) return cb(err); + if (n) return cb(null, n, pkg); + loadAsFile(path.join(x, 'index'), pkg, cb); + }); + }); + return; + } + + loadAsFile(path.join(x, '/index'), pkg, cb); + }); + }); + }); + } + + function processDirs(cb, dirs) { + if (dirs.length === 0) return cb(null, undefined); + var dir = dirs[0]; + + isDirectory(path.dirname(dir), isdir); + + function isdir(err, isdir) { + if (err) return cb(err); + if (!isdir) return processDirs(cb, dirs.slice(1)); + loadAsFile(dir, opts.package, onfile); + } + + function onfile(err, m, pkg) { + if (err) return cb(err); + if (m) return cb(null, m, pkg); + loadAsDirectory(dir, opts.package, ondir); + } + + function ondir(err, n, pkg) { + if (err) return cb(err); + if (n) return cb(null, n, pkg); + processDirs(cb, dirs.slice(1)); + } + } + function loadNodeModules(x, start, cb) { + var thunk = function () { return getPackageCandidates(x, start, opts); }; + processDirs( + cb, + packageIterator ? packageIterator(x, start, thunk, opts) : thunk() + ); + } +}; diff --git a/node_modules/resolve/lib/caller.js b/node_modules/resolve/lib/caller.js new file mode 100644 index 0000000..b14a280 --- /dev/null +++ b/node_modules/resolve/lib/caller.js @@ -0,0 +1,8 @@ +module.exports = function () { + // see https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi + var origPrepareStackTrace = Error.prepareStackTrace; + Error.prepareStackTrace = function (_, stack) { return stack; }; + var stack = (new Error()).stack; + Error.prepareStackTrace = origPrepareStackTrace; + return stack[2].getFileName(); +}; diff --git a/node_modules/resolve/lib/core.js b/node_modules/resolve/lib/core.js new file mode 100644 index 0000000..ecc5b2e --- /dev/null +++ b/node_modules/resolve/lib/core.js @@ -0,0 +1,52 @@ +var current = (process.versions && process.versions.node && process.versions.node.split('.')) || []; + +function specifierIncluded(specifier) { + var parts = specifier.split(' '); + var op = parts.length > 1 ? parts[0] : '='; + var versionParts = (parts.length > 1 ? parts[1] : parts[0]).split('.'); + + for (var i = 0; i < 3; ++i) { + var cur = parseInt(current[i] || 0, 10); + var ver = parseInt(versionParts[i] || 0, 10); + if (cur === ver) { + continue; // eslint-disable-line no-restricted-syntax, no-continue + } + if (op === '<') { + return cur < ver; + } else if (op === '>=') { + return cur >= ver; + } + return false; + } + return op === '>='; +} + +function matchesRange(range) { + var specifiers = range.split(/ ?&& ?/); + if (specifiers.length === 0) { return false; } + for (var i = 0; i < specifiers.length; ++i) { + if (!specifierIncluded(specifiers[i])) { return false; } + } + return true; +} + +function versionIncluded(specifierValue) { + if (typeof specifierValue === 'boolean') { return specifierValue; } + if (specifierValue && typeof specifierValue === 'object') { + for (var i = 0; i < specifierValue.length; ++i) { + if (matchesRange(specifierValue[i])) { return true; } + } + return false; + } + return matchesRange(specifierValue); +} + +var data = require('./core.json'); + +var core = {}; +for (var mod in data) { // eslint-disable-line no-restricted-syntax + if (Object.prototype.hasOwnProperty.call(data, mod)) { + core[mod] = versionIncluded(data[mod]); + } +} +module.exports = core; diff --git a/node_modules/resolve/lib/core.json b/node_modules/resolve/lib/core.json new file mode 100644 index 0000000..058584b --- /dev/null +++ b/node_modules/resolve/lib/core.json @@ -0,0 +1,153 @@ +{ + "assert": true, + "node:assert": [">= 14.18 && < 15", ">= 16"], + "assert/strict": ">= 15", + "node:assert/strict": ">= 16", + "async_hooks": ">= 8", + "node:async_hooks": [">= 14.18 && < 15", ">= 16"], + "buffer_ieee754": ">= 0.5 && < 0.9.7", + "buffer": true, + "node:buffer": [">= 14.18 && < 15", ">= 16"], + "child_process": true, + "node:child_process": [">= 14.18 && < 15", ">= 16"], + "cluster": ">= 0.5", + "node:cluster": [">= 14.18 && < 15", ">= 16"], + "console": true, + "node:console": [">= 14.18 && < 15", ">= 16"], + "constants": true, + "node:constants": [">= 14.18 && < 15", ">= 16"], + "crypto": true, + "node:crypto": [">= 14.18 && < 15", ">= 16"], + "_debug_agent": ">= 1 && < 8", + "_debugger": "< 8", + "dgram": true, + "node:dgram": [">= 14.18 && < 15", ">= 16"], + "diagnostics_channel": [">= 14.17 && < 15", ">= 15.1"], + "node:diagnostics_channel": [">= 14.18 && < 15", ">= 16"], + "dns": true, + "node:dns": [">= 14.18 && < 15", ">= 16"], + "dns/promises": ">= 15", + "node:dns/promises": ">= 16", + "domain": ">= 0.7.12", + "node:domain": [">= 14.18 && < 15", ">= 16"], + "events": true, + "node:events": [">= 14.18 && < 15", ">= 16"], + "freelist": "< 6", + "fs": true, + "node:fs": [">= 14.18 && < 15", ">= 16"], + "fs/promises": [">= 10 && < 10.1", ">= 14"], + "node:fs/promises": [">= 14.18 && < 15", ">= 16"], + "_http_agent": ">= 0.11.1", + "node:_http_agent": [">= 14.18 && < 15", ">= 16"], + "_http_client": ">= 0.11.1", + "node:_http_client": [">= 14.18 && < 15", ">= 16"], + "_http_common": ">= 0.11.1", + "node:_http_common": [">= 14.18 && < 15", ">= 16"], + "_http_incoming": ">= 0.11.1", + "node:_http_incoming": [">= 14.18 && < 15", ">= 16"], + "_http_outgoing": ">= 0.11.1", + "node:_http_outgoing": [">= 14.18 && < 15", ">= 16"], + "_http_server": ">= 0.11.1", + "node:_http_server": [">= 14.18 && < 15", ">= 16"], + "http": true, + "node:http": [">= 14.18 && < 15", ">= 16"], + "http2": ">= 8.8", + "node:http2": [">= 14.18 && < 15", ">= 16"], + "https": true, + "node:https": [">= 14.18 && < 15", ">= 16"], + "inspector": ">= 8", + "node:inspector": [">= 14.18 && < 15", ">= 16"], + "_linklist": "< 8", + "module": true, + "node:module": [">= 14.18 && < 15", ">= 16"], + "net": true, + "node:net": [">= 14.18 && < 15", ">= 16"], + "node-inspect/lib/_inspect": ">= 7.6 && < 12", + "node-inspect/lib/internal/inspect_client": ">= 7.6 && < 12", + "node-inspect/lib/internal/inspect_repl": ">= 7.6 && < 12", + "os": true, + "node:os": [">= 14.18 && < 15", ">= 16"], + "path": true, + "node:path": [">= 14.18 && < 15", ">= 16"], + "path/posix": ">= 15.3", + "node:path/posix": ">= 16", + "path/win32": ">= 15.3", + "node:path/win32": ">= 16", + "perf_hooks": ">= 8.5", + "node:perf_hooks": [">= 14.18 && < 15", ">= 16"], + "process": ">= 1", + "node:process": [">= 14.18 && < 15", ">= 16"], + "punycode": ">= 0.5", + "node:punycode": [">= 14.18 && < 15", ">= 16"], + "querystring": true, + "node:querystring": [">= 14.18 && < 15", ">= 16"], + "readline": true, + "node:readline": [">= 14.18 && < 15", ">= 16"], + "readline/promises": ">= 17", + "node:readline/promises": ">= 17", + "repl": true, + "node:repl": [">= 14.18 && < 15", ">= 16"], + "smalloc": ">= 0.11.5 && < 3", + "_stream_duplex": ">= 0.9.4", + "node:_stream_duplex": [">= 14.18 && < 15", ">= 16"], + "_stream_transform": ">= 0.9.4", + "node:_stream_transform": [">= 14.18 && < 15", ">= 16"], + "_stream_wrap": ">= 1.4.1", + "node:_stream_wrap": [">= 14.18 && < 15", ">= 16"], + "_stream_passthrough": ">= 0.9.4", + "node:_stream_passthrough": [">= 14.18 && < 15", ">= 16"], + "_stream_readable": ">= 0.9.4", + "node:_stream_readable": [">= 14.18 && < 15", ">= 16"], + "_stream_writable": ">= 0.9.4", + "node:_stream_writable": [">= 14.18 && < 15", ">= 16"], + "stream": true, + "node:stream": [">= 14.18 && < 15", ">= 16"], + "stream/consumers": ">= 16.7", + "node:stream/consumers": ">= 16.7", + "stream/promises": ">= 15", + "node:stream/promises": ">= 16", + "stream/web": ">= 16.5", + "node:stream/web": ">= 16.5", + "string_decoder": true, + "node:string_decoder": [">= 14.18 && < 15", ">= 16"], + "sys": [">= 0.4 && < 0.7", ">= 0.8"], + "node:sys": [">= 14.18 && < 15", ">= 16"], + "node:test": ">= 18", + "timers": true, + "node:timers": [">= 14.18 && < 15", ">= 16"], + "timers/promises": ">= 15", + "node:timers/promises": ">= 16", + "_tls_common": ">= 0.11.13", + "node:_tls_common": [">= 14.18 && < 15", ">= 16"], + "_tls_legacy": ">= 0.11.3 && < 10", + "_tls_wrap": ">= 0.11.3", + "node:_tls_wrap": [">= 14.18 && < 15", ">= 16"], + "tls": true, + "node:tls": [">= 14.18 && < 15", ">= 16"], + "trace_events": ">= 10", + "node:trace_events": [">= 14.18 && < 15", ">= 16"], + "tty": true, + "node:tty": [">= 14.18 && < 15", ">= 16"], + "url": true, + "node:url": [">= 14.18 && < 15", ">= 16"], + "util": true, + "node:util": [">= 14.18 && < 15", ">= 16"], + "util/types": ">= 15.3", + "node:util/types": ">= 16", + "v8/tools/arguments": ">= 10 && < 12", + "v8/tools/codemap": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/consarray": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/csvparser": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/logreader": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/profile_view": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8/tools/splaytree": [">= 4.4 && < 5", ">= 5.2 && < 12"], + "v8": ">= 1", + "node:v8": [">= 14.18 && < 15", ">= 16"], + "vm": true, + "node:vm": [">= 14.18 && < 15", ">= 16"], + "wasi": ">= 13.4 && < 13.5", + "worker_threads": ">= 11.7", + "node:worker_threads": [">= 14.18 && < 15", ">= 16"], + "zlib": ">= 0.5", + "node:zlib": [">= 14.18 && < 15", ">= 16"] +} diff --git a/node_modules/resolve/lib/homedir.js b/node_modules/resolve/lib/homedir.js new file mode 100644 index 0000000..5ffdf73 --- /dev/null +++ b/node_modules/resolve/lib/homedir.js @@ -0,0 +1,24 @@ +'use strict'; + +var os = require('os'); + +// adapted from https://github.com/sindresorhus/os-homedir/blob/11e089f4754db38bb535e5a8416320c4446e8cfd/index.js + +module.exports = os.homedir || function homedir() { + var home = process.env.HOME; + var user = process.env.LOGNAME || process.env.USER || process.env.LNAME || process.env.USERNAME; + + if (process.platform === 'win32') { + return process.env.USERPROFILE || process.env.HOMEDRIVE + process.env.HOMEPATH || home || null; + } + + if (process.platform === 'darwin') { + return home || (user ? '/Users/' + user : null); + } + + if (process.platform === 'linux') { + return home || (process.getuid() === 0 ? '/root' : (user ? '/home/' + user : null)); // eslint-disable-line no-extra-parens + } + + return home || null; +}; diff --git a/node_modules/resolve/lib/is-core.js b/node_modules/resolve/lib/is-core.js new file mode 100644 index 0000000..537f5c7 --- /dev/null +++ b/node_modules/resolve/lib/is-core.js @@ -0,0 +1,5 @@ +var isCoreModule = require('is-core-module'); + +module.exports = function isCore(x) { + return isCoreModule(x); +}; diff --git a/node_modules/resolve/lib/node-modules-paths.js b/node_modules/resolve/lib/node-modules-paths.js new file mode 100644 index 0000000..1cff010 --- /dev/null +++ b/node_modules/resolve/lib/node-modules-paths.js @@ -0,0 +1,42 @@ +var path = require('path'); +var parse = path.parse || require('path-parse'); // eslint-disable-line global-require + +var getNodeModulesDirs = function getNodeModulesDirs(absoluteStart, modules) { + var prefix = '/'; + if ((/^([A-Za-z]:)/).test(absoluteStart)) { + prefix = ''; + } else if ((/^\\\\/).test(absoluteStart)) { + prefix = '\\\\'; + } + + var paths = [absoluteStart]; + var parsed = parse(absoluteStart); + while (parsed.dir !== paths[paths.length - 1]) { + paths.push(parsed.dir); + parsed = parse(parsed.dir); + } + + return paths.reduce(function (dirs, aPath) { + return dirs.concat(modules.map(function (moduleDir) { + return path.resolve(prefix, aPath, moduleDir); + })); + }, []); +}; + +module.exports = function nodeModulesPaths(start, opts, request) { + var modules = opts && opts.moduleDirectory + ? [].concat(opts.moduleDirectory) + : ['node_modules']; + + if (opts && typeof opts.paths === 'function') { + return opts.paths( + request, + start, + function () { return getNodeModulesDirs(start, modules); }, + opts + ); + } + + var dirs = getNodeModulesDirs(start, modules); + return opts && opts.paths ? dirs.concat(opts.paths) : dirs; +}; diff --git a/node_modules/resolve/lib/normalize-options.js b/node_modules/resolve/lib/normalize-options.js new file mode 100644 index 0000000..4b56904 --- /dev/null +++ b/node_modules/resolve/lib/normalize-options.js @@ -0,0 +1,10 @@ +module.exports = function (x, opts) { + /** + * This file is purposefully a passthrough. It's expected that third-party + * environments will override it at runtime in order to inject special logic + * into `resolve` (by manipulating the options). One such example is the PnP + * code path in Yarn. + */ + + return opts || {}; +}; diff --git a/node_modules/resolve/lib/sync.js b/node_modules/resolve/lib/sync.js new file mode 100644 index 0000000..0b6cd58 --- /dev/null +++ b/node_modules/resolve/lib/sync.js @@ -0,0 +1,208 @@ +var isCore = require('is-core-module'); +var fs = require('fs'); +var path = require('path'); +var getHomedir = require('./homedir'); +var caller = require('./caller'); +var nodeModulesPaths = require('./node-modules-paths'); +var normalizeOptions = require('./normalize-options'); + +var realpathFS = process.platform !== 'win32' && fs.realpathSync && typeof fs.realpathSync.native === 'function' ? fs.realpathSync.native : fs.realpathSync; + +var homedir = getHomedir(); +var defaultPaths = function () { + return [ + path.join(homedir, '.node_modules'), + path.join(homedir, '.node_libraries') + ]; +}; + +var defaultIsFile = function isFile(file) { + try { + var stat = fs.statSync(file, { throwIfNoEntry: false }); + } catch (e) { + if (e && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) return false; + throw e; + } + return !!stat && (stat.isFile() || stat.isFIFO()); +}; + +var defaultIsDir = function isDirectory(dir) { + try { + var stat = fs.statSync(dir, { throwIfNoEntry: false }); + } catch (e) { + if (e && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) return false; + throw e; + } + return !!stat && stat.isDirectory(); +}; + +var defaultRealpathSync = function realpathSync(x) { + try { + return realpathFS(x); + } catch (realpathErr) { + if (realpathErr.code !== 'ENOENT') { + throw realpathErr; + } + } + return x; +}; + +var maybeRealpathSync = function maybeRealpathSync(realpathSync, x, opts) { + if (opts && opts.preserveSymlinks === false) { + return realpathSync(x); + } + return x; +}; + +var defaultReadPackageSync = function defaultReadPackageSync(readFileSync, pkgfile) { + var body = readFileSync(pkgfile); + try { + var pkg = JSON.parse(body); + return pkg; + } catch (jsonErr) {} +}; + +var getPackageCandidates = function getPackageCandidates(x, start, opts) { + var dirs = nodeModulesPaths(start, opts, x); + for (var i = 0; i < dirs.length; i++) { + dirs[i] = path.join(dirs[i], x); + } + return dirs; +}; + +module.exports = function resolveSync(x, options) { + if (typeof x !== 'string') { + throw new TypeError('Path must be a string.'); + } + var opts = normalizeOptions(x, options); + + var isFile = opts.isFile || defaultIsFile; + var readFileSync = opts.readFileSync || fs.readFileSync; + var isDirectory = opts.isDirectory || defaultIsDir; + var realpathSync = opts.realpathSync || defaultRealpathSync; + var readPackageSync = opts.readPackageSync || defaultReadPackageSync; + if (opts.readFileSync && opts.readPackageSync) { + throw new TypeError('`readFileSync` and `readPackageSync` are mutually exclusive.'); + } + var packageIterator = opts.packageIterator; + + var extensions = opts.extensions || ['.js']; + var includeCoreModules = opts.includeCoreModules !== false; + var basedir = opts.basedir || path.dirname(caller()); + var parent = opts.filename || basedir; + + opts.paths = opts.paths || defaultPaths(); + + // ensure that `basedir` is an absolute path at this point, resolving against the process' current working directory + var absoluteStart = maybeRealpathSync(realpathSync, path.resolve(basedir), opts); + + if ((/^(?:\.\.?(?:\/|$)|\/|([A-Za-z]:)?[/\\])/).test(x)) { + var res = path.resolve(absoluteStart, x); + if (x === '.' || x === '..' || x.slice(-1) === '/') res += '/'; + var m = loadAsFileSync(res) || loadAsDirectorySync(res); + if (m) return maybeRealpathSync(realpathSync, m, opts); + } else if (includeCoreModules && isCore(x)) { + return x; + } else { + var n = loadNodeModulesSync(x, absoluteStart); + if (n) return maybeRealpathSync(realpathSync, n, opts); + } + + var err = new Error("Cannot find module '" + x + "' from '" + parent + "'"); + err.code = 'MODULE_NOT_FOUND'; + throw err; + + function loadAsFileSync(x) { + var pkg = loadpkg(path.dirname(x)); + + if (pkg && pkg.dir && pkg.pkg && opts.pathFilter) { + var rfile = path.relative(pkg.dir, x); + var r = opts.pathFilter(pkg.pkg, x, rfile); + if (r) { + x = path.resolve(pkg.dir, r); // eslint-disable-line no-param-reassign + } + } + + if (isFile(x)) { + return x; + } + + for (var i = 0; i < extensions.length; i++) { + var file = x + extensions[i]; + if (isFile(file)) { + return file; + } + } + } + + function loadpkg(dir) { + if (dir === '' || dir === '/') return; + if (process.platform === 'win32' && (/^\w:[/\\]*$/).test(dir)) { + return; + } + if ((/[/\\]node_modules[/\\]*$/).test(dir)) return; + + var pkgfile = path.join(maybeRealpathSync(realpathSync, dir, opts), 'package.json'); + + if (!isFile(pkgfile)) { + return loadpkg(path.dirname(dir)); + } + + var pkg = readPackageSync(readFileSync, pkgfile); + + if (pkg && opts.packageFilter) { + // v2 will pass pkgfile + pkg = opts.packageFilter(pkg, /*pkgfile,*/ dir); // eslint-disable-line spaced-comment + } + + return { pkg: pkg, dir: dir }; + } + + function loadAsDirectorySync(x) { + var pkgfile = path.join(maybeRealpathSync(realpathSync, x, opts), '/package.json'); + if (isFile(pkgfile)) { + try { + var pkg = readPackageSync(readFileSync, pkgfile); + } catch (e) {} + + if (pkg && opts.packageFilter) { + // v2 will pass pkgfile + pkg = opts.packageFilter(pkg, /*pkgfile,*/ x); // eslint-disable-line spaced-comment + } + + if (pkg && pkg.main) { + if (typeof pkg.main !== 'string') { + var mainError = new TypeError('package “' + pkg.name + '” `main` must be a string'); + mainError.code = 'INVALID_PACKAGE_MAIN'; + throw mainError; + } + if (pkg.main === '.' || pkg.main === './') { + pkg.main = 'index'; + } + try { + var m = loadAsFileSync(path.resolve(x, pkg.main)); + if (m) return m; + var n = loadAsDirectorySync(path.resolve(x, pkg.main)); + if (n) return n; + } catch (e) {} + } + } + + return loadAsFileSync(path.join(x, '/index')); + } + + function loadNodeModulesSync(x, start) { + var thunk = function () { return getPackageCandidates(x, start, opts); }; + var dirs = packageIterator ? packageIterator(x, start, thunk, opts) : thunk(); + + for (var i = 0; i < dirs.length; i++) { + var dir = dirs[i]; + if (isDirectory(path.dirname(dir))) { + var m = loadAsFileSync(dir); + if (m) return m; + var n = loadAsDirectorySync(dir); + if (n) return n; + } + } + } +}; diff --git a/node_modules/resolve/package.json b/node_modules/resolve/package.json new file mode 100644 index 0000000..7177e0f --- /dev/null +++ b/node_modules/resolve/package.json @@ -0,0 +1,71 @@ +{ + "name": "resolve", + "description": "resolve like require.resolve() on behalf of files asynchronously and synchronously", + "version": "1.22.1", + "repository": { + "type": "git", + "url": "git://github.com/browserify/resolve.git" + }, + "bin": { + "resolve": "./bin/resolve" + }, + "main": "index.js", + "keywords": [ + "resolve", + "require", + "node", + "module" + ], + "scripts": { + "prepack": "npmignore --auto --commentLines=autogenerated", + "prepublishOnly": "safe-publish-latest && cp node_modules/is-core-module/core.json ./lib/ ||:", + "prepublish": "not-in-publish || npm run prepublishOnly", + "prelint": "eclint check $(git ls-files | xargs find 2> /dev/null | grep -vE 'node_modules|\\.git')", + "lint": "eslint --ext=js,mjs --no-eslintrc -c .eslintrc . 'bin/**'", + "pretests-only": "cd ./test/resolver/nested_symlinks && node mylib/sync && node mylib/async", + "tests-only": "tape test/*.js", + "pretest": "npm run lint", + "test": "npm run --silent tests-only", + "posttest": "npm run test:multirepo && aud --production", + "test:multirepo": "cd ./test/resolver/multirepo && npm install && npm test" + }, + "devDependencies": { + "@ljharb/eslint-config": "^21.0.0", + "array.prototype.map": "^1.0.4", + "aud": "^2.0.0", + "copy-dir": "^1.3.0", + "eclint": "^2.8.1", + "eslint": "=8.8.0", + "in-publish": "^2.0.1", + "mkdirp": "^0.5.5", + "mv": "^2.1.1", + "npmignore": "^0.3.0", + "object-keys": "^1.1.1", + "rimraf": "^2.7.1", + "safe-publish-latest": "^2.0.0", + "semver": "^6.3.0", + "tap": "0.4.13", + "tape": "^5.5.3", + "tmp": "^0.0.31" + }, + "license": "MIT", + "author": { + "name": "James Halliday", + "email": "mail@substack.net", + "url": "http://substack.net" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + }, + "dependencies": { + "is-core-module": "^2.9.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "publishConfig": { + "ignore": [ + ".github/workflows", + "appveyor.yml" + ] + } +} diff --git a/node_modules/resolve/readme.markdown b/node_modules/resolve/readme.markdown new file mode 100644 index 0000000..ad34d60 --- /dev/null +++ b/node_modules/resolve/readme.markdown @@ -0,0 +1,301 @@ +# resolve [![Version Badge][2]][1] + +implements the [node `require.resolve()` algorithm](https://nodejs.org/api/modules.html#modules_all_together) such that you can `require.resolve()` on behalf of a file asynchronously and synchronously + +[![github actions][actions-image]][actions-url] +[![coverage][codecov-image]][codecov-url] +[![dependency status][5]][6] +[![dev dependency status][7]][8] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] + +[![npm badge][11]][1] + +# example + +asynchronously resolve: + +```js +var resolve = require('resolve/async'); // or, require('resolve') +resolve('tap', { basedir: __dirname }, function (err, res) { + if (err) console.error(err); + else console.log(res); +}); +``` + +``` +$ node example/async.js +/home/substack/projects/node-resolve/node_modules/tap/lib/main.js +``` + +synchronously resolve: + +```js +var resolve = require('resolve/sync'); // or, `require('resolve').sync +var res = resolve('tap', { basedir: __dirname }); +console.log(res); +``` + +``` +$ node example/sync.js +/home/substack/projects/node-resolve/node_modules/tap/lib/main.js +``` + +# methods + +```js +var resolve = require('resolve'); +var async = require('resolve/async'); +var sync = require('resolve/sync'); +``` + +For both the synchronous and asynchronous methods, errors may have any of the following `err.code` values: + +- `MODULE_NOT_FOUND`: the given path string (`id`) could not be resolved to a module +- `INVALID_BASEDIR`: the specified `opts.basedir` doesn't exist, or is not a directory +- `INVALID_PACKAGE_MAIN`: a `package.json` was encountered with an invalid `main` property (eg. not a string) + +## resolve(id, opts={}, cb) + +Asynchronously resolve the module path string `id` into `cb(err, res [, pkg])`, where `pkg` (if defined) is the data from `package.json`. + +options are: + +* opts.basedir - directory to begin resolving from + +* opts.package - `package.json` data applicable to the module being loaded + +* opts.extensions - array of file extensions to search in order + +* opts.includeCoreModules - set to `false` to exclude node core modules (e.g. `fs`) from the search + +* opts.readFile - how to read files asynchronously + +* opts.isFile - function to asynchronously test whether a file exists + +* opts.isDirectory - function to asynchronously test whether a file exists and is a directory + +* opts.realpath - function to asynchronously resolve a potential symlink to its real path + +* `opts.readPackage(readFile, pkgfile, cb)` - function to asynchronously read and parse a package.json file + * readFile - the passed `opts.readFile` or `fs.readFile` if not specified + * pkgfile - path to package.json + * cb - callback + +* `opts.packageFilter(pkg, pkgfile, dir)` - transform the parsed package.json contents before looking at the "main" field + * pkg - package data + * pkgfile - path to package.json + * dir - directory that contains package.json + +* `opts.pathFilter(pkg, path, relativePath)` - transform a path within a package + * pkg - package data + * path - the path being resolved + * relativePath - the path relative from the package.json location + * returns - a relative path that will be joined from the package.json location + +* opts.paths - require.paths array to use if nothing is found on the normal `node_modules` recursive walk (probably don't use this) + + For advanced users, `paths` can also be a `opts.paths(request, start, opts)` function + * request - the import specifier being resolved + * start - lookup path + * getNodeModulesDirs - a thunk (no-argument function) that returns the paths using standard `node_modules` resolution + * opts - the resolution options + +* `opts.packageIterator(request, start, opts)` - return the list of candidate paths where the packages sources may be found (probably don't use this) + * request - the import specifier being resolved + * start - lookup path + * getPackageCandidates - a thunk (no-argument function) that returns the paths using standard `node_modules` resolution + * opts - the resolution options + +* opts.moduleDirectory - directory (or directories) in which to recursively look for modules. default: `"node_modules"` + +* opts.preserveSymlinks - if true, doesn't resolve `basedir` to real path before resolving. +This is the way Node resolves dependencies when executed with the [--preserve-symlinks](https://nodejs.org/api/all.html#cli_preserve_symlinks) flag. +**Note:** this property is currently `true` by default but it will be changed to +`false` in the next major version because *Node's resolution algorithm does not preserve symlinks by default*. + +default `opts` values: + +```js +{ + paths: [], + basedir: __dirname, + extensions: ['.js'], + includeCoreModules: true, + readFile: fs.readFile, + isFile: function isFile(file, cb) { + fs.stat(file, function (err, stat) { + if (!err) { + return cb(null, stat.isFile() || stat.isFIFO()); + } + if (err.code === 'ENOENT' || err.code === 'ENOTDIR') return cb(null, false); + return cb(err); + }); + }, + isDirectory: function isDirectory(dir, cb) { + fs.stat(dir, function (err, stat) { + if (!err) { + return cb(null, stat.isDirectory()); + } + if (err.code === 'ENOENT' || err.code === 'ENOTDIR') return cb(null, false); + return cb(err); + }); + }, + realpath: function realpath(file, cb) { + var realpath = typeof fs.realpath.native === 'function' ? fs.realpath.native : fs.realpath; + realpath(file, function (realPathErr, realPath) { + if (realPathErr && realPathErr.code !== 'ENOENT') cb(realPathErr); + else cb(null, realPathErr ? file : realPath); + }); + }, + readPackage: function defaultReadPackage(readFile, pkgfile, cb) { + readFile(pkgfile, function (readFileErr, body) { + if (readFileErr) cb(readFileErr); + else { + try { + var pkg = JSON.parse(body); + cb(null, pkg); + } catch (jsonErr) { + cb(null); + } + } + }); + }, + moduleDirectory: 'node_modules', + preserveSymlinks: true +} +``` + +## resolve.sync(id, opts) + +Synchronously resolve the module path string `id`, returning the result and +throwing an error when `id` can't be resolved. + +options are: + +* opts.basedir - directory to begin resolving from + +* opts.extensions - array of file extensions to search in order + +* opts.includeCoreModules - set to `false` to exclude node core modules (e.g. `fs`) from the search + +* opts.readFileSync - how to read files synchronously + +* opts.isFile - function to synchronously test whether a file exists + +* opts.isDirectory - function to synchronously test whether a file exists and is a directory + +* opts.realpathSync - function to synchronously resolve a potential symlink to its real path + +* `opts.readPackageSync(readFileSync, pkgfile)` - function to synchronously read and parse a package.json file + * readFileSync - the passed `opts.readFileSync` or `fs.readFileSync` if not specified + * pkgfile - path to package.json + +* `opts.packageFilter(pkg, dir)` - transform the parsed package.json contents before looking at the "main" field + * pkg - package data + * dir - directory that contains package.json (Note: the second argument will change to "pkgfile" in v2) + +* `opts.pathFilter(pkg, path, relativePath)` - transform a path within a package + * pkg - package data + * path - the path being resolved + * relativePath - the path relative from the package.json location + * returns - a relative path that will be joined from the package.json location + +* opts.paths - require.paths array to use if nothing is found on the normal `node_modules` recursive walk (probably don't use this) + + For advanced users, `paths` can also be a `opts.paths(request, start, opts)` function + * request - the import specifier being resolved + * start - lookup path + * getNodeModulesDirs - a thunk (no-argument function) that returns the paths using standard `node_modules` resolution + * opts - the resolution options + +* `opts.packageIterator(request, start, opts)` - return the list of candidate paths where the packages sources may be found (probably don't use this) + * request - the import specifier being resolved + * start - lookup path + * getPackageCandidates - a thunk (no-argument function) that returns the paths using standard `node_modules` resolution + * opts - the resolution options + +* opts.moduleDirectory - directory (or directories) in which to recursively look for modules. default: `"node_modules"` + +* opts.preserveSymlinks - if true, doesn't resolve `basedir` to real path before resolving. +This is the way Node resolves dependencies when executed with the [--preserve-symlinks](https://nodejs.org/api/all.html#cli_preserve_symlinks) flag. +**Note:** this property is currently `true` by default but it will be changed to +`false` in the next major version because *Node's resolution algorithm does not preserve symlinks by default*. + +default `opts` values: + +```js +{ + paths: [], + basedir: __dirname, + extensions: ['.js'], + includeCoreModules: true, + readFileSync: fs.readFileSync, + isFile: function isFile(file) { + try { + var stat = fs.statSync(file); + } catch (e) { + if (e && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) return false; + throw e; + } + return stat.isFile() || stat.isFIFO(); + }, + isDirectory: function isDirectory(dir) { + try { + var stat = fs.statSync(dir); + } catch (e) { + if (e && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) return false; + throw e; + } + return stat.isDirectory(); + }, + realpathSync: function realpathSync(file) { + try { + var realpath = typeof fs.realpathSync.native === 'function' ? fs.realpathSync.native : fs.realpathSync; + return realpath(file); + } catch (realPathErr) { + if (realPathErr.code !== 'ENOENT') { + throw realPathErr; + } + } + return file; + }, + readPackageSync: function defaultReadPackageSync(readFileSync, pkgfile) { + var body = readFileSync(pkgfile); + try { + var pkg = JSON.parse(body); + return pkg; + } catch (jsonErr) {} + }, + moduleDirectory: 'node_modules', + preserveSymlinks: true +} +``` + +# install + +With [npm](https://npmjs.org) do: + +```sh +npm install resolve +``` + +# license + +MIT + +[1]: https://npmjs.org/package/resolve +[2]: https://versionbadg.es/browserify/resolve.svg +[5]: https://david-dm.org/browserify/resolve.svg +[6]: https://david-dm.org/browserify/resolve +[7]: https://david-dm.org/browserify/resolve/dev-status.svg +[8]: https://david-dm.org/browserify/resolve#info=devDependencies +[11]: https://nodei.co/npm/resolve.png?downloads=true&stars=true +[license-image]: https://img.shields.io/npm/l/resolve.svg +[license-url]: LICENSE +[downloads-image]: https://img.shields.io/npm/dm/resolve.svg +[downloads-url]: https://npm-stat.com/charts.html?package=resolve +[codecov-image]: https://codecov.io/gh/browserify/resolve/branch/main/graphs/badge.svg +[codecov-url]: https://app.codecov.io/gh/browserify/resolve/ +[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/browserify/resolve +[actions-url]: https://github.com/browserify/resolve/actions diff --git a/node_modules/resolve/sync.js b/node_modules/resolve/sync.js new file mode 100644 index 0000000..cd0ee04 --- /dev/null +++ b/node_modules/resolve/sync.js @@ -0,0 +1,3 @@ +'use strict'; + +module.exports = require('./lib/sync'); diff --git a/node_modules/resolve/test/core.js b/node_modules/resolve/test/core.js new file mode 100644 index 0000000..a477adc --- /dev/null +++ b/node_modules/resolve/test/core.js @@ -0,0 +1,88 @@ +var test = require('tape'); +var keys = require('object-keys'); +var semver = require('semver'); + +var resolve = require('../'); + +var brokenNode = semver.satisfies(process.version, '11.11 - 11.13'); + +test('core modules', function (t) { + t.test('isCore()', function (st) { + st.ok(resolve.isCore('fs')); + st.ok(resolve.isCore('net')); + st.ok(resolve.isCore('http')); + + st.ok(!resolve.isCore('seq')); + st.ok(!resolve.isCore('../')); + + st.ok(!resolve.isCore('toString')); + + st.end(); + }); + + t.test('core list', function (st) { + var cores = keys(resolve.core); + st.plan(cores.length); + + for (var i = 0; i < cores.length; ++i) { + var mod = cores[i]; + // note: this must be require, not require.resolve, due to https://github.com/nodejs/node/issues/43274 + var requireFunc = function () { require(mod); }; // eslint-disable-line no-loop-func + t.comment(mod + ': ' + resolve.core[mod]); + if (resolve.core[mod]) { + st.doesNotThrow(requireFunc, mod + ' supported; requiring does not throw'); + } else if (brokenNode) { + st.ok(true, 'this version of node is broken: attempting to require things that fail to resolve breaks "home_paths" tests'); + } else { + st.throws(requireFunc, mod + ' not supported; requiring throws'); + } + } + + st.end(); + }); + + t.test('core via repl module', { skip: !resolve.core.repl }, function (st) { + var libs = require('repl')._builtinLibs; // eslint-disable-line no-underscore-dangle + if (!libs) { + st.skip('module.builtinModules does not exist'); + return st.end(); + } + for (var i = 0; i < libs.length; ++i) { + var mod = libs[i]; + st.ok(resolve.core[mod], mod + ' is a core module'); + st.doesNotThrow( + function () { require(mod); }, // eslint-disable-line no-loop-func + 'requiring ' + mod + ' does not throw' + ); + } + st.end(); + }); + + t.test('core via builtinModules list', { skip: !resolve.core.module }, function (st) { + var libs = require('module').builtinModules; + if (!libs) { + st.skip('module.builtinModules does not exist'); + return st.end(); + } + var blacklist = [ + '_debug_agent', + 'v8/tools/tickprocessor-driver', + 'v8/tools/SourceMap', + 'v8/tools/tickprocessor', + 'v8/tools/profile' + ]; + for (var i = 0; i < libs.length; ++i) { + var mod = libs[i]; + if (blacklist.indexOf(mod) === -1) { + st.ok(resolve.core[mod], mod + ' is a core module'); + st.doesNotThrow( + function () { require(mod); }, // eslint-disable-line no-loop-func + 'requiring ' + mod + ' does not throw' + ); + } + } + st.end(); + }); + + t.end(); +}); diff --git a/node_modules/resolve/test/dotdot.js b/node_modules/resolve/test/dotdot.js new file mode 100644 index 0000000..3080665 --- /dev/null +++ b/node_modules/resolve/test/dotdot.js @@ -0,0 +1,29 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('dotdot', function (t) { + t.plan(4); + var dir = path.join(__dirname, '/dotdot/abc'); + + resolve('..', { basedir: dir }, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(__dirname, 'dotdot/index.js')); + }); + + resolve('.', { basedir: dir }, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, 'index.js')); + }); +}); + +test('dotdot sync', function (t) { + t.plan(2); + var dir = path.join(__dirname, '/dotdot/abc'); + + var a = resolve.sync('..', { basedir: dir }); + t.equal(a, path.join(__dirname, 'dotdot/index.js')); + + var b = resolve.sync('.', { basedir: dir }); + t.equal(b, path.join(dir, 'index.js')); +}); diff --git a/node_modules/resolve/test/dotdot/abc/index.js b/node_modules/resolve/test/dotdot/abc/index.js new file mode 100644 index 0000000..67f2534 --- /dev/null +++ b/node_modules/resolve/test/dotdot/abc/index.js @@ -0,0 +1,2 @@ +var x = require('..'); +console.log(x); diff --git a/node_modules/resolve/test/dotdot/index.js b/node_modules/resolve/test/dotdot/index.js new file mode 100644 index 0000000..643f9fc --- /dev/null +++ b/node_modules/resolve/test/dotdot/index.js @@ -0,0 +1 @@ +module.exports = 'whatever'; diff --git a/node_modules/resolve/test/faulty_basedir.js b/node_modules/resolve/test/faulty_basedir.js new file mode 100644 index 0000000..5f2141a --- /dev/null +++ b/node_modules/resolve/test/faulty_basedir.js @@ -0,0 +1,29 @@ +var test = require('tape'); +var path = require('path'); +var resolve = require('../'); + +test('faulty basedir must produce error in windows', { skip: process.platform !== 'win32' }, function (t) { + t.plan(1); + + var resolverDir = 'C:\\a\\b\\c\\d'; + + resolve('tape/lib/test.js', { basedir: resolverDir }, function (err, res, pkg) { + t.equal(!!err, true); + }); +}); + +test('non-existent basedir should not throw when preserveSymlinks is false', function (t) { + t.plan(2); + + var opts = { + basedir: path.join(path.sep, 'unreal', 'path', 'that', 'does', 'not', 'exist'), + preserveSymlinks: false + }; + + var module = './dotdot/abc'; + + resolve(module, opts, function (err, res) { + t.equal(err.code, 'MODULE_NOT_FOUND'); + t.equal(res, undefined); + }); +}); diff --git a/node_modules/resolve/test/filter.js b/node_modules/resolve/test/filter.js new file mode 100644 index 0000000..8f8cccd --- /dev/null +++ b/node_modules/resolve/test/filter.js @@ -0,0 +1,34 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('filter', function (t) { + t.plan(4); + var dir = path.join(__dirname, 'resolver'); + var packageFilterArgs; + resolve('./baz', { + basedir: dir, + packageFilter: function (pkg, pkgfile) { + pkg.main = 'doom'; // eslint-disable-line no-param-reassign + packageFilterArgs = [pkg, pkgfile]; + return pkg; + } + }, function (err, res, pkg) { + if (err) t.fail(err); + + t.equal(res, path.join(dir, 'baz/doom.js'), 'changing the package "main" works'); + + var packageData = packageFilterArgs[0]; + t.equal(pkg, packageData, 'first packageFilter argument is "pkg"'); + t.equal(packageData.main, 'doom', 'package "main" was altered'); + + var packageFile = packageFilterArgs[1]; + t.equal( + packageFile, + path.join(dir, 'baz/package.json'), + 'second packageFilter argument is "pkgfile"' + ); + + t.end(); + }); +}); diff --git a/node_modules/resolve/test/filter_sync.js b/node_modules/resolve/test/filter_sync.js new file mode 100644 index 0000000..8a43b98 --- /dev/null +++ b/node_modules/resolve/test/filter_sync.js @@ -0,0 +1,33 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('filter', function (t) { + var dir = path.join(__dirname, 'resolver'); + var packageFilterArgs; + var res = resolve.sync('./baz', { + basedir: dir, + // NOTE: in v2.x, this will be `pkg, pkgfile, dir`, but must remain "broken" here in v1.x for compatibility + packageFilter: function (pkg, /*pkgfile,*/ dir) { // eslint-disable-line spaced-comment + pkg.main = 'doom'; // eslint-disable-line no-param-reassign + packageFilterArgs = 'is 1.x' ? [pkg, dir] : [pkg, pkgfile, dir]; // eslint-disable-line no-constant-condition, no-undef + return pkg; + } + }); + + t.equal(res, path.join(dir, 'baz/doom.js'), 'changing the package "main" works'); + + var packageData = packageFilterArgs[0]; + t.equal(packageData.main, 'doom', 'package "main" was altered'); + + if (!'is 1.x') { // eslint-disable-line no-constant-condition + var packageFile = packageFilterArgs[1]; + t.equal(packageFile, path.join(dir, 'baz', 'package.json'), 'package.json path is correct'); + } + + var packageDir = packageFilterArgs['is 1.x' ? 1 : 2]; // eslint-disable-line no-constant-condition + // eslint-disable-next-line no-constant-condition + t.equal(packageDir, path.join(dir, 'baz'), ('is 1.x' ? 'second' : 'third') + ' packageFilter argument is "dir"'); + + t.end(); +}); diff --git a/node_modules/resolve/test/home_paths.js b/node_modules/resolve/test/home_paths.js new file mode 100644 index 0000000..3b8c9b3 --- /dev/null +++ b/node_modules/resolve/test/home_paths.js @@ -0,0 +1,127 @@ +'use strict'; + +var fs = require('fs'); +var homedir = require('../lib/homedir'); +var path = require('path'); + +var test = require('tape'); +var mkdirp = require('mkdirp'); +var rimraf = require('rimraf'); +var mv = require('mv'); +var copyDir = require('copy-dir'); +var tmp = require('tmp'); + +var HOME = homedir(); + +var hnm = path.join(HOME, '.node_modules'); +var hnl = path.join(HOME, '.node_libraries'); + +var resolve = require('../async'); + +function makeDir(t, dir, cb) { + mkdirp(dir, function (err) { + if (err) { + cb(err); + } else { + t.teardown(function cleanup() { + rimraf.sync(dir); + }); + cb(); + } + }); +} + +function makeTempDir(t, dir, cb) { + if (fs.existsSync(dir)) { + var tmpResult = tmp.dirSync(); + t.teardown(tmpResult.removeCallback); + var backup = path.join(tmpResult.name, path.basename(dir)); + mv(dir, backup, function (err) { + if (err) { + cb(err); + } else { + t.teardown(function () { + mv(backup, dir, cb); + }); + makeDir(t, dir, cb); + } + }); + } else { + makeDir(t, dir, cb); + } +} + +test('homedir module paths', function (t) { + t.plan(7); + + makeTempDir(t, hnm, function (err) { + t.error(err, 'no error with HNM temp dir'); + if (err) { + return t.end(); + } + + var bazHNMDir = path.join(hnm, 'baz'); + var dotMainDir = path.join(hnm, 'dot_main'); + copyDir.sync(path.join(__dirname, 'resolver/baz'), bazHNMDir); + copyDir.sync(path.join(__dirname, 'resolver/dot_main'), dotMainDir); + + var bazPkg = { name: 'baz', main: 'quux.js' }; + var dotMainPkg = { main: 'index' }; + + var bazHNMmain = path.join(bazHNMDir, 'quux.js'); + t.equal(require.resolve('baz'), bazHNMmain, 'sanity check: require.resolve finds HNM `baz`'); + var dotMainMain = path.join(dotMainDir, 'index.js'); + t.equal(require.resolve('dot_main'), dotMainMain, 'sanity check: require.resolve finds `dot_main`'); + + makeTempDir(t, hnl, function (err) { + t.error(err, 'no error with HNL temp dir'); + if (err) { + return t.end(); + } + var bazHNLDir = path.join(hnl, 'baz'); + copyDir.sync(path.join(__dirname, 'resolver/baz'), bazHNLDir); + + var dotSlashMainDir = path.join(hnl, 'dot_slash_main'); + var dotSlashMainMain = path.join(dotSlashMainDir, 'index.js'); + var dotSlashMainPkg = { main: 'index' }; + copyDir.sync(path.join(__dirname, 'resolver/dot_slash_main'), dotSlashMainDir); + + t.equal(require.resolve('baz'), bazHNMmain, 'sanity check: require.resolve finds HNM `baz`'); + t.equal(require.resolve('dot_slash_main'), dotSlashMainMain, 'sanity check: require.resolve finds HNL `dot_slash_main`'); + + t.test('with temp dirs', function (st) { + st.plan(3); + + st.test('just in `$HOME/.node_modules`', function (s2t) { + s2t.plan(3); + + resolve('dot_main', function (err, res, pkg) { + s2t.error(err, 'no error resolving `dot_main`'); + s2t.equal(res, dotMainMain, '`dot_main` resolves in `$HOME/.node_modules`'); + s2t.deepEqual(pkg, dotMainPkg); + }); + }); + + st.test('just in `$HOME/.node_libraries`', function (s2t) { + s2t.plan(3); + + resolve('dot_slash_main', function (err, res, pkg) { + s2t.error(err, 'no error resolving `dot_slash_main`'); + s2t.equal(res, dotSlashMainMain, '`dot_slash_main` resolves in `$HOME/.node_libraries`'); + s2t.deepEqual(pkg, dotSlashMainPkg); + }); + }); + + st.test('in `$HOME/.node_libraries` and `$HOME/.node_modules`', function (s2t) { + s2t.plan(3); + + resolve('baz', function (err, res, pkg) { + s2t.error(err, 'no error resolving `baz`'); + s2t.equal(res, bazHNMmain, '`baz` resolves in `$HOME/.node_modules` when in both'); + s2t.deepEqual(pkg, bazPkg); + }); + }); + }); + }); + }); +}); diff --git a/node_modules/resolve/test/home_paths_sync.js b/node_modules/resolve/test/home_paths_sync.js new file mode 100644 index 0000000..5d2c56f --- /dev/null +++ b/node_modules/resolve/test/home_paths_sync.js @@ -0,0 +1,114 @@ +'use strict'; + +var fs = require('fs'); +var homedir = require('../lib/homedir'); +var path = require('path'); + +var test = require('tape'); +var mkdirp = require('mkdirp'); +var rimraf = require('rimraf'); +var mv = require('mv'); +var copyDir = require('copy-dir'); +var tmp = require('tmp'); + +var HOME = homedir(); + +var hnm = path.join(HOME, '.node_modules'); +var hnl = path.join(HOME, '.node_libraries'); + +var resolve = require('../sync'); + +function makeDir(t, dir, cb) { + mkdirp(dir, function (err) { + if (err) { + cb(err); + } else { + t.teardown(function cleanup() { + rimraf.sync(dir); + }); + cb(); + } + }); +} + +function makeTempDir(t, dir, cb) { + if (fs.existsSync(dir)) { + var tmpResult = tmp.dirSync(); + t.teardown(tmpResult.removeCallback); + var backup = path.join(tmpResult.name, path.basename(dir)); + mv(dir, backup, function (err) { + if (err) { + cb(err); + } else { + t.teardown(function () { + mv(backup, dir, cb); + }); + makeDir(t, dir, cb); + } + }); + } else { + makeDir(t, dir, cb); + } +} + +test('homedir module paths', function (t) { + t.plan(7); + + makeTempDir(t, hnm, function (err) { + t.error(err, 'no error with HNM temp dir'); + if (err) { + return t.end(); + } + + var bazHNMDir = path.join(hnm, 'baz'); + var dotMainDir = path.join(hnm, 'dot_main'); + copyDir.sync(path.join(__dirname, 'resolver/baz'), bazHNMDir); + copyDir.sync(path.join(__dirname, 'resolver/dot_main'), dotMainDir); + + var bazHNMmain = path.join(bazHNMDir, 'quux.js'); + t.equal(require.resolve('baz'), bazHNMmain, 'sanity check: require.resolve finds HNM `baz`'); + var dotMainMain = path.join(dotMainDir, 'index.js'); + t.equal(require.resolve('dot_main'), dotMainMain, 'sanity check: require.resolve finds `dot_main`'); + + makeTempDir(t, hnl, function (err) { + t.error(err, 'no error with HNL temp dir'); + if (err) { + return t.end(); + } + var bazHNLDir = path.join(hnl, 'baz'); + copyDir.sync(path.join(__dirname, 'resolver/baz'), bazHNLDir); + + var dotSlashMainDir = path.join(hnl, 'dot_slash_main'); + var dotSlashMainMain = path.join(dotSlashMainDir, 'index.js'); + copyDir.sync(path.join(__dirname, 'resolver/dot_slash_main'), dotSlashMainDir); + + t.equal(require.resolve('baz'), bazHNMmain, 'sanity check: require.resolve finds HNM `baz`'); + t.equal(require.resolve('dot_slash_main'), dotSlashMainMain, 'sanity check: require.resolve finds HNL `dot_slash_main`'); + + t.test('with temp dirs', function (st) { + st.plan(3); + + st.test('just in `$HOME/.node_modules`', function (s2t) { + s2t.plan(1); + + var res = resolve('dot_main'); + s2t.equal(res, dotMainMain, '`dot_main` resolves in `$HOME/.node_modules`'); + }); + + st.test('just in `$HOME/.node_libraries`', function (s2t) { + s2t.plan(1); + + var res = resolve('dot_slash_main'); + s2t.equal(res, dotSlashMainMain, '`dot_slash_main` resolves in `$HOME/.node_libraries`'); + }); + + st.test('in `$HOME/.node_libraries` and `$HOME/.node_modules`', function (s2t) { + s2t.plan(1); + + var res = resolve('baz'); + s2t.equal(res, bazHNMmain, '`baz` resolves in `$HOME/.node_modules` when in both'); + }); + }); + }); + }); +}); diff --git a/node_modules/resolve/test/mock.js b/node_modules/resolve/test/mock.js new file mode 100644 index 0000000..6116275 --- /dev/null +++ b/node_modules/resolve/test/mock.js @@ -0,0 +1,315 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('mock', function (t) { + t.plan(8); + + var files = {}; + files[path.resolve('/foo/bar/baz.js')] = 'beep'; + + var dirs = {}; + dirs[path.resolve('/foo/bar')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, path.resolve(file))); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + readFile: function (file, cb) { + cb(null, files[path.resolve(file)]); + }, + realpath: function (file, cb) { + cb(null, file); + } + }; + } + + resolve('./baz', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/baz.js')); + t.equal(pkg, undefined); + }); + + resolve('./baz.js', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/baz.js')); + t.equal(pkg, undefined); + }); + + resolve('baz', opts('/foo/bar'), function (err, res) { + t.equal(err.message, "Cannot find module 'baz' from '" + path.resolve('/foo/bar') + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); + + resolve('../baz', opts('/foo/bar'), function (err, res) { + t.equal(err.message, "Cannot find module '../baz' from '" + path.resolve('/foo/bar') + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); +}); + +test('mock from package', function (t) { + t.plan(8); + + var files = {}; + files[path.resolve('/foo/bar/baz.js')] = 'beep'; + + var dirs = {}; + dirs[path.resolve('/foo/bar')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, file)); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + 'package': { main: 'bar' }, + readFile: function (file, cb) { + cb(null, files[file]); + }, + realpath: function (file, cb) { + cb(null, file); + } + }; + } + + resolve('./baz', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/baz.js')); + t.equal(pkg && pkg.main, 'bar'); + }); + + resolve('./baz.js', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/baz.js')); + t.equal(pkg && pkg.main, 'bar'); + }); + + resolve('baz', opts('/foo/bar'), function (err, res) { + t.equal(err.message, "Cannot find module 'baz' from '" + path.resolve('/foo/bar') + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); + + resolve('../baz', opts('/foo/bar'), function (err, res) { + t.equal(err.message, "Cannot find module '../baz' from '" + path.resolve('/foo/bar') + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); +}); + +test('mock package', function (t) { + t.plan(2); + + var files = {}; + files[path.resolve('/foo/node_modules/bar/baz.js')] = 'beep'; + files[path.resolve('/foo/node_modules/bar/package.json')] = JSON.stringify({ + main: './baz.js' + }); + + var dirs = {}; + dirs[path.resolve('/foo')] = true; + dirs[path.resolve('/foo/node_modules')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, path.resolve(file))); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + readFile: function (file, cb) { + cb(null, files[path.resolve(file)]); + }, + realpath: function (file, cb) { + cb(null, file); + } + }; + } + + resolve('bar', opts('/foo'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/node_modules/bar/baz.js')); + t.equal(pkg && pkg.main, './baz.js'); + }); +}); + +test('mock package from package', function (t) { + t.plan(2); + + var files = {}; + files[path.resolve('/foo/node_modules/bar/baz.js')] = 'beep'; + files[path.resolve('/foo/node_modules/bar/package.json')] = JSON.stringify({ + main: './baz.js' + }); + + var dirs = {}; + dirs[path.resolve('/foo')] = true; + dirs[path.resolve('/foo/node_modules')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, path.resolve(file))); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + 'package': { main: 'bar' }, + readFile: function (file, cb) { + cb(null, files[path.resolve(file)]); + }, + realpath: function (file, cb) { + cb(null, file); + } + }; + } + + resolve('bar', opts('/foo'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/node_modules/bar/baz.js')); + t.equal(pkg && pkg.main, './baz.js'); + }); +}); + +test('symlinked', function (t) { + t.plan(4); + + var files = {}; + files[path.resolve('/foo/bar/baz.js')] = 'beep'; + files[path.resolve('/foo/bar/symlinked/baz.js')] = 'beep'; + + var dirs = {}; + dirs[path.resolve('/foo/bar')] = true; + dirs[path.resolve('/foo/bar/symlinked')] = true; + + function opts(basedir) { + return { + preserveSymlinks: false, + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, path.resolve(file))); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + readFile: function (file, cb) { + cb(null, files[path.resolve(file)]); + }, + realpath: function (file, cb) { + var resolved = path.resolve(file); + + if (resolved.indexOf('symlinked') >= 0) { + cb(null, resolved); + return; + } + + var ext = path.extname(resolved); + + if (ext) { + var dir = path.dirname(resolved); + var base = path.basename(resolved); + cb(null, path.join(dir, 'symlinked', base)); + } else { + cb(null, path.join(resolved, 'symlinked')); + } + } + }; + } + + resolve('./baz', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/symlinked/baz.js')); + t.equal(pkg, undefined); + }); + + resolve('./baz.js', opts('/foo/bar'), function (err, res, pkg) { + if (err) return t.fail(err); + t.equal(res, path.resolve('/foo/bar/symlinked/baz.js')); + t.equal(pkg, undefined); + }); +}); + +test('readPackage', function (t) { + t.plan(3); + + var files = {}; + files[path.resolve('/foo/node_modules/bar/something-else.js')] = 'beep'; + files[path.resolve('/foo/node_modules/bar/package.json')] = JSON.stringify({ + main: './baz.js' + }); + files[path.resolve('/foo/node_modules/bar/baz.js')] = 'boop'; + + var dirs = {}; + dirs[path.resolve('/foo')] = true; + dirs[path.resolve('/foo/node_modules')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file, cb) { + cb(null, Object.prototype.hasOwnProperty.call(files, path.resolve(file))); + }, + isDirectory: function (dir, cb) { + cb(null, !!dirs[path.resolve(dir)]); + }, + 'package': { main: 'bar' }, + readFile: function (file, cb) { + cb(null, files[path.resolve(file)]); + }, + realpath: function (file, cb) { + cb(null, file); + } + }; + } + + t.test('with readFile', function (st) { + st.plan(3); + + resolve('bar', opts('/foo'), function (err, res, pkg) { + st.error(err); + st.equal(res, path.resolve('/foo/node_modules/bar/baz.js')); + st.equal(pkg && pkg.main, './baz.js'); + }); + }); + + var readPackage = function (readFile, file, cb) { + var barPackage = path.join('bar', 'package.json'); + if (file.slice(-barPackage.length) === barPackage) { + cb(null, { main: './something-else.js' }); + } else { + cb(null, JSON.parse(files[path.resolve(file)])); + } + }; + + t.test('with readPackage', function (st) { + st.plan(3); + + var options = opts('/foo'); + delete options.readFile; + options.readPackage = readPackage; + resolve('bar', options, function (err, res, pkg) { + st.error(err); + st.equal(res, path.resolve('/foo/node_modules/bar/something-else.js')); + st.equal(pkg && pkg.main, './something-else.js'); + }); + }); + + t.test('with readFile and readPackage', function (st) { + st.plan(1); + + var options = opts('/foo'); + options.readPackage = readPackage; + resolve('bar', options, function (err) { + st.throws(function () { throw err; }, TypeError, 'errors when both readFile and readPackage are provided'); + }); + }); +}); diff --git a/node_modules/resolve/test/mock_sync.js b/node_modules/resolve/test/mock_sync.js new file mode 100644 index 0000000..c5a7e2a --- /dev/null +++ b/node_modules/resolve/test/mock_sync.js @@ -0,0 +1,214 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('mock', function (t) { + t.plan(4); + + var files = {}; + files[path.resolve('/foo/bar/baz.js')] = 'beep'; + + var dirs = {}; + dirs[path.resolve('/foo/bar')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file) { + return Object.prototype.hasOwnProperty.call(files, path.resolve(file)); + }, + isDirectory: function (dir) { + return !!dirs[path.resolve(dir)]; + }, + readFileSync: function (file) { + return files[path.resolve(file)]; + }, + realpathSync: function (file) { + return file; + } + }; + } + + t.equal( + resolve.sync('./baz', opts('/foo/bar')), + path.resolve('/foo/bar/baz.js') + ); + + t.equal( + resolve.sync('./baz.js', opts('/foo/bar')), + path.resolve('/foo/bar/baz.js') + ); + + t.throws(function () { + resolve.sync('baz', opts('/foo/bar')); + }); + + t.throws(function () { + resolve.sync('../baz', opts('/foo/bar')); + }); +}); + +test('mock package', function (t) { + t.plan(1); + + var files = {}; + files[path.resolve('/foo/node_modules/bar/baz.js')] = 'beep'; + files[path.resolve('/foo/node_modules/bar/package.json')] = JSON.stringify({ + main: './baz.js' + }); + + var dirs = {}; + dirs[path.resolve('/foo')] = true; + dirs[path.resolve('/foo/node_modules')] = true; + + function opts(basedir) { + return { + basedir: path.resolve(basedir), + isFile: function (file) { + return Object.prototype.hasOwnProperty.call(files, path.resolve(file)); + }, + isDirectory: function (dir) { + return !!dirs[path.resolve(dir)]; + }, + readFileSync: function (file) { + return files[path.resolve(file)]; + }, + realpathSync: function (file) { + return file; + } + }; + } + + t.equal( + resolve.sync('bar', opts('/foo')), + path.resolve('/foo/node_modules/bar/baz.js') + ); +}); + +test('symlinked', function (t) { + t.plan(2); + + var files = {}; + files[path.resolve('/foo/bar/baz.js')] = 'beep'; + files[path.resolve('/foo/bar/symlinked/baz.js')] = 'beep'; + + var dirs = {}; + dirs[path.resolve('/foo/bar')] = true; + dirs[path.resolve('/foo/bar/symlinked')] = true; + + function opts(basedir) { + return { + preserveSymlinks: false, + basedir: path.resolve(basedir), + isFile: function (file) { + return Object.prototype.hasOwnProperty.call(files, path.resolve(file)); + }, + isDirectory: function (dir) { + return !!dirs[path.resolve(dir)]; + }, + readFileSync: function (file) { + return files[path.resolve(file)]; + }, + realpathSync: function (file) { + var resolved = path.resolve(file); + + if (resolved.indexOf('symlinked') >= 0) { + return resolved; + } + + var ext = path.extname(resolved); + + if (ext) { + var dir = path.dirname(resolved); + var base = path.basename(resolved); + return path.join(dir, 'symlinked', base); + } + return path.join(resolved, 'symlinked'); + } + }; + } + + t.equal( + resolve.sync('./baz', opts('/foo/bar')), + path.resolve('/foo/bar/symlinked/baz.js') + ); + + t.equal( + resolve.sync('./baz.js', opts('/foo/bar')), + path.resolve('/foo/bar/symlinked/baz.js') + ); +}); + +test('readPackageSync', function (t) { + t.plan(3); + + var files = {}; + files[path.resolve('/foo/node_modules/bar/something-else.js')] = 'beep'; + files[path.resolve('/foo/node_modules/bar/package.json')] = JSON.stringify({ + main: './baz.js' + }); + files[path.resolve('/foo/node_modules/bar/baz.js')] = 'boop'; + + var dirs = {}; + dirs[path.resolve('/foo')] = true; + dirs[path.resolve('/foo/node_modules')] = true; + + function opts(basedir, useReadPackage) { + return { + basedir: path.resolve(basedir), + isFile: function (file) { + return Object.prototype.hasOwnProperty.call(files, path.resolve(file)); + }, + isDirectory: function (dir) { + return !!dirs[path.resolve(dir)]; + }, + readFileSync: useReadPackage ? null : function (file) { + return files[path.resolve(file)]; + }, + realpathSync: function (file) { + return file; + } + }; + } + t.test('with readFile', function (st) { + st.plan(1); + + st.equal( + resolve.sync('bar', opts('/foo')), + path.resolve('/foo/node_modules/bar/baz.js') + ); + }); + + var readPackageSync = function (readFileSync, file) { + if (file.indexOf(path.join('bar', 'package.json')) >= 0) { + return { main: './something-else.js' }; + } + return JSON.parse(files[path.resolve(file)]); + }; + + t.test('with readPackage', function (st) { + st.plan(1); + + var options = opts('/foo'); + delete options.readFileSync; + options.readPackageSync = readPackageSync; + + st.equal( + resolve.sync('bar', options), + path.resolve('/foo/node_modules/bar/something-else.js') + ); + }); + + t.test('with readFile and readPackage', function (st) { + st.plan(1); + + var options = opts('/foo'); + options.readPackageSync = readPackageSync; + st.throws( + function () { resolve.sync('bar', options); }, + TypeError, + 'errors when both readFile and readPackage are provided' + ); + }); +}); + diff --git a/node_modules/resolve/test/module_dir.js b/node_modules/resolve/test/module_dir.js new file mode 100644 index 0000000..b50e5bb --- /dev/null +++ b/node_modules/resolve/test/module_dir.js @@ -0,0 +1,56 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('moduleDirectory strings', function (t) { + t.plan(4); + var dir = path.join(__dirname, 'module_dir'); + var xopts = { + basedir: dir, + moduleDirectory: 'xmodules' + }; + resolve('aaa', xopts, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, '/xmodules/aaa/index.js')); + }); + + var yopts = { + basedir: dir, + moduleDirectory: 'ymodules' + }; + resolve('aaa', yopts, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, '/ymodules/aaa/index.js')); + }); +}); + +test('moduleDirectory array', function (t) { + t.plan(6); + var dir = path.join(__dirname, 'module_dir'); + var aopts = { + basedir: dir, + moduleDirectory: ['xmodules', 'ymodules', 'zmodules'] + }; + resolve('aaa', aopts, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, '/xmodules/aaa/index.js')); + }); + + var bopts = { + basedir: dir, + moduleDirectory: ['zmodules', 'ymodules', 'xmodules'] + }; + resolve('aaa', bopts, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, '/ymodules/aaa/index.js')); + }); + + var copts = { + basedir: dir, + moduleDirectory: ['xmodules', 'ymodules', 'zmodules'] + }; + resolve('bbb', copts, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, '/zmodules/bbb/main.js')); + }); +}); diff --git a/node_modules/resolve/test/module_dir/xmodules/aaa/index.js b/node_modules/resolve/test/module_dir/xmodules/aaa/index.js new file mode 100644 index 0000000..dd7cf7b --- /dev/null +++ b/node_modules/resolve/test/module_dir/xmodules/aaa/index.js @@ -0,0 +1 @@ +module.exports = function (x) { return x * 100; }; diff --git a/node_modules/resolve/test/module_dir/ymodules/aaa/index.js b/node_modules/resolve/test/module_dir/ymodules/aaa/index.js new file mode 100644 index 0000000..ef2d4d4 --- /dev/null +++ b/node_modules/resolve/test/module_dir/ymodules/aaa/index.js @@ -0,0 +1 @@ +module.exports = function (x) { return x + 100; }; diff --git a/node_modules/resolve/test/module_dir/zmodules/bbb/main.js b/node_modules/resolve/test/module_dir/zmodules/bbb/main.js new file mode 100644 index 0000000..e8ba629 --- /dev/null +++ b/node_modules/resolve/test/module_dir/zmodules/bbb/main.js @@ -0,0 +1 @@ +module.exports = function (n) { return n * 111; }; diff --git a/node_modules/resolve/test/module_dir/zmodules/bbb/package.json b/node_modules/resolve/test/module_dir/zmodules/bbb/package.json new file mode 100644 index 0000000..c13b8cf --- /dev/null +++ b/node_modules/resolve/test/module_dir/zmodules/bbb/package.json @@ -0,0 +1,3 @@ +{ + "main": "main.js" +} diff --git a/node_modules/resolve/test/node-modules-paths.js b/node_modules/resolve/test/node-modules-paths.js new file mode 100644 index 0000000..675441d --- /dev/null +++ b/node_modules/resolve/test/node-modules-paths.js @@ -0,0 +1,143 @@ +var test = require('tape'); +var path = require('path'); +var parse = path.parse || require('path-parse'); +var keys = require('object-keys'); + +var nodeModulesPaths = require('../lib/node-modules-paths'); + +var verifyDirs = function verifyDirs(t, start, dirs, moduleDirectories, paths) { + var moduleDirs = [].concat(moduleDirectories || 'node_modules'); + if (paths) { + for (var k = 0; k < paths.length; ++k) { + moduleDirs.push(path.basename(paths[k])); + } + } + + var foundModuleDirs = {}; + var uniqueDirs = {}; + var parsedDirs = {}; + for (var i = 0; i < dirs.length; ++i) { + var parsed = parse(dirs[i]); + if (!foundModuleDirs[parsed.base]) { foundModuleDirs[parsed.base] = 0; } + foundModuleDirs[parsed.base] += 1; + parsedDirs[parsed.dir] = true; + uniqueDirs[dirs[i]] = true; + } + t.equal(keys(parsedDirs).length >= start.split(path.sep).length, true, 'there are >= dirs than "start" has'); + var foundModuleDirNames = keys(foundModuleDirs); + t.deepEqual(foundModuleDirNames, moduleDirs, 'all desired module dirs were found'); + t.equal(keys(uniqueDirs).length, dirs.length, 'all dirs provided were unique'); + + var counts = {}; + for (var j = 0; j < foundModuleDirNames.length; ++j) { + counts[foundModuleDirs[j]] = true; + } + t.equal(keys(counts).length, 1, 'all found module directories had the same count'); +}; + +test('node-modules-paths', function (t) { + t.test('no options', function (t) { + var start = path.join(__dirname, 'resolver'); + var dirs = nodeModulesPaths(start); + + verifyDirs(t, start, dirs); + + t.end(); + }); + + t.test('empty options', function (t) { + var start = path.join(__dirname, 'resolver'); + var dirs = nodeModulesPaths(start, {}); + + verifyDirs(t, start, dirs); + + t.end(); + }); + + t.test('with paths=array option', function (t) { + var start = path.join(__dirname, 'resolver'); + var paths = ['a', 'b']; + var dirs = nodeModulesPaths(start, { paths: paths }); + + verifyDirs(t, start, dirs, null, paths); + + t.end(); + }); + + t.test('with paths=function option', function (t) { + var paths = function paths(request, absoluteStart, getNodeModulesDirs, opts) { + return getNodeModulesDirs().concat(path.join(absoluteStart, 'not node modules', request)); + }; + + var start = path.join(__dirname, 'resolver'); + var dirs = nodeModulesPaths(start, { paths: paths }, 'pkg'); + + verifyDirs(t, start, dirs, null, [path.join(start, 'not node modules', 'pkg')]); + + t.end(); + }); + + t.test('with paths=function skipping node modules resolution', function (t) { + var paths = function paths(request, absoluteStart, getNodeModulesDirs, opts) { + return []; + }; + var start = path.join(__dirname, 'resolver'); + var dirs = nodeModulesPaths(start, { paths: paths }); + t.deepEqual(dirs, [], 'no node_modules was computed'); + t.end(); + }); + + t.test('with moduleDirectory option', function (t) { + var start = path.join(__dirname, 'resolver'); + var moduleDirectory = 'not node modules'; + var dirs = nodeModulesPaths(start, { moduleDirectory: moduleDirectory }); + + verifyDirs(t, start, dirs, moduleDirectory); + + t.end(); + }); + + t.test('with 1 moduleDirectory and paths options', function (t) { + var start = path.join(__dirname, 'resolver'); + var paths = ['a', 'b']; + var moduleDirectory = 'not node modules'; + var dirs = nodeModulesPaths(start, { paths: paths, moduleDirectory: moduleDirectory }); + + verifyDirs(t, start, dirs, moduleDirectory, paths); + + t.end(); + }); + + t.test('with 1+ moduleDirectory and paths options', function (t) { + var start = path.join(__dirname, 'resolver'); + var paths = ['a', 'b']; + var moduleDirectories = ['not node modules', 'other modules']; + var dirs = nodeModulesPaths(start, { paths: paths, moduleDirectory: moduleDirectories }); + + verifyDirs(t, start, dirs, moduleDirectories, paths); + + t.end(); + }); + + t.test('combine paths correctly on Windows', function (t) { + var start = 'C:\\Users\\username\\myProject\\src'; + var paths = []; + var moduleDirectories = ['node_modules', start]; + var dirs = nodeModulesPaths(start, { paths: paths, moduleDirectory: moduleDirectories }); + + t.equal(dirs.indexOf(path.resolve(start)) > -1, true, 'should contain start dir'); + + t.end(); + }); + + t.test('combine paths correctly on non-Windows', { skip: process.platform === 'win32' }, function (t) { + var start = '/Users/username/git/myProject/src'; + var paths = []; + var moduleDirectories = ['node_modules', '/Users/username/git/myProject/src']; + var dirs = nodeModulesPaths(start, { paths: paths, moduleDirectory: moduleDirectories }); + + t.equal(dirs.indexOf(path.resolve(start)) > -1, true, 'should contain start dir'); + + t.end(); + }); +}); diff --git a/node_modules/resolve/test/node_path.js b/node_modules/resolve/test/node_path.js new file mode 100644 index 0000000..e463d6c --- /dev/null +++ b/node_modules/resolve/test/node_path.js @@ -0,0 +1,70 @@ +var fs = require('fs'); +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('$NODE_PATH', function (t) { + t.plan(8); + + var isDir = function (dir, cb) { + if (dir === '/node_path' || dir === 'node_path/x') { + return cb(null, true); + } + fs.stat(dir, function (err, stat) { + if (!err) { + return cb(null, stat.isDirectory()); + } + if (err.code === 'ENOENT' || err.code === 'ENOTDIR') return cb(null, false); + return cb(err); + }); + }; + + resolve('aaa', { + paths: [ + path.join(__dirname, '/node_path/x'), + path.join(__dirname, '/node_path/y') + ], + basedir: __dirname, + isDirectory: isDir + }, function (err, res) { + t.error(err); + t.equal(res, path.join(__dirname, '/node_path/x/aaa/index.js'), 'aaa resolves'); + }); + + resolve('bbb', { + paths: [ + path.join(__dirname, '/node_path/x'), + path.join(__dirname, '/node_path/y') + ], + basedir: __dirname, + isDirectory: isDir + }, function (err, res) { + t.error(err); + t.equal(res, path.join(__dirname, '/node_path/y/bbb/index.js'), 'bbb resolves'); + }); + + resolve('ccc', { + paths: [ + path.join(__dirname, '/node_path/x'), + path.join(__dirname, '/node_path/y') + ], + basedir: __dirname, + isDirectory: isDir + }, function (err, res) { + t.error(err); + t.equal(res, path.join(__dirname, '/node_path/x/ccc/index.js'), 'ccc resolves'); + }); + + // ensure that relative paths still resolve against the regular `node_modules` correctly + resolve('tap', { + paths: [ + 'node_path' + ], + basedir: path.join(__dirname, 'node_path/x'), + isDirectory: isDir + }, function (err, res) { + var root = require('tap/package.json').main; // eslint-disable-line global-require + t.error(err); + t.equal(res, path.resolve(__dirname, '..', 'node_modules/tap', root), 'tap resolves'); + }); +}); diff --git a/node_modules/resolve/test/node_path/x/aaa/index.js b/node_modules/resolve/test/node_path/x/aaa/index.js new file mode 100644 index 0000000..ad70d0b --- /dev/null +++ b/node_modules/resolve/test/node_path/x/aaa/index.js @@ -0,0 +1 @@ +module.exports = 'A'; diff --git a/node_modules/resolve/test/node_path/x/ccc/index.js b/node_modules/resolve/test/node_path/x/ccc/index.js new file mode 100644 index 0000000..a64132e --- /dev/null +++ b/node_modules/resolve/test/node_path/x/ccc/index.js @@ -0,0 +1 @@ +module.exports = 'C'; diff --git a/node_modules/resolve/test/node_path/y/bbb/index.js b/node_modules/resolve/test/node_path/y/bbb/index.js new file mode 100644 index 0000000..4d0f32e --- /dev/null +++ b/node_modules/resolve/test/node_path/y/bbb/index.js @@ -0,0 +1 @@ +module.exports = 'B'; diff --git a/node_modules/resolve/test/node_path/y/ccc/index.js b/node_modules/resolve/test/node_path/y/ccc/index.js new file mode 100644 index 0000000..793315e --- /dev/null +++ b/node_modules/resolve/test/node_path/y/ccc/index.js @@ -0,0 +1 @@ +module.exports = 'CY'; diff --git a/node_modules/resolve/test/nonstring.js b/node_modules/resolve/test/nonstring.js new file mode 100644 index 0000000..ef63c40 --- /dev/null +++ b/node_modules/resolve/test/nonstring.js @@ -0,0 +1,9 @@ +var test = require('tape'); +var resolve = require('../'); + +test('nonstring', function (t) { + t.plan(1); + resolve(555, function (err, res, pkg) { + t.ok(err); + }); +}); diff --git a/node_modules/resolve/test/pathfilter.js b/node_modules/resolve/test/pathfilter.js new file mode 100644 index 0000000..16519ae --- /dev/null +++ b/node_modules/resolve/test/pathfilter.js @@ -0,0 +1,75 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +var resolverDir = path.join(__dirname, '/pathfilter/deep_ref'); + +var pathFilterFactory = function (t) { + return function (pkg, x, remainder) { + t.equal(pkg.version, '1.2.3'); + t.equal(x, path.join(resolverDir, 'node_modules/deep/ref')); + t.equal(remainder, 'ref'); + return 'alt'; + }; +}; + +test('#62: deep module references and the pathFilter', function (t) { + t.test('deep/ref.js', function (st) { + st.plan(3); + + resolve('deep/ref', { basedir: resolverDir }, function (err, res, pkg) { + if (err) st.fail(err); + + st.equal(pkg.version, '1.2.3'); + st.equal(res, path.join(resolverDir, 'node_modules/deep/ref.js')); + }); + + var res = resolve.sync('deep/ref', { basedir: resolverDir }); + st.equal(res, path.join(resolverDir, 'node_modules/deep/ref.js')); + }); + + t.test('deep/deeper/ref', function (st) { + st.plan(4); + + resolve( + 'deep/deeper/ref', + { basedir: resolverDir }, + function (err, res, pkg) { + if (err) t.fail(err); + st.notEqual(pkg, undefined); + st.equal(pkg.version, '1.2.3'); + st.equal(res, path.join(resolverDir, 'node_modules/deep/deeper/ref.js')); + } + ); + + var res = resolve.sync( + 'deep/deeper/ref', + { basedir: resolverDir } + ); + st.equal(res, path.join(resolverDir, 'node_modules/deep/deeper/ref.js')); + }); + + t.test('deep/ref alt', function (st) { + st.plan(8); + + var pathFilter = pathFilterFactory(st); + + var res = resolve.sync( + 'deep/ref', + { basedir: resolverDir, pathFilter: pathFilter } + ); + st.equal(res, path.join(resolverDir, 'node_modules/deep/alt.js')); + + resolve( + 'deep/ref', + { basedir: resolverDir, pathFilter: pathFilter }, + function (err, res, pkg) { + if (err) st.fail(err); + st.equal(res, path.join(resolverDir, 'node_modules/deep/alt.js')); + st.end(); + } + ); + }); + + t.end(); +}); diff --git a/node_modules/resolve/test/pathfilter/deep_ref/main.js b/node_modules/resolve/test/pathfilter/deep_ref/main.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/precedence.js b/node_modules/resolve/test/precedence.js new file mode 100644 index 0000000..2febb59 --- /dev/null +++ b/node_modules/resolve/test/precedence.js @@ -0,0 +1,23 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); + +test('precedence', function (t) { + t.plan(3); + var dir = path.join(__dirname, 'precedence/aaa'); + + resolve('./', { basedir: dir }, function (err, res, pkg) { + t.ifError(err); + t.equal(res, path.join(dir, 'index.js')); + t.equal(pkg.name, 'resolve'); + }); +}); + +test('./ should not load ${dir}.js', function (t) { // eslint-disable-line no-template-curly-in-string + t.plan(1); + var dir = path.join(__dirname, 'precedence/bbb'); + + resolve('./', { basedir: dir }, function (err, res, pkg) { + t.ok(err); + }); +}); diff --git a/node_modules/resolve/test/precedence/aaa.js b/node_modules/resolve/test/precedence/aaa.js new file mode 100644 index 0000000..b83a3e7 --- /dev/null +++ b/node_modules/resolve/test/precedence/aaa.js @@ -0,0 +1 @@ +module.exports = 'wtf'; diff --git a/node_modules/resolve/test/precedence/aaa/index.js b/node_modules/resolve/test/precedence/aaa/index.js new file mode 100644 index 0000000..e0f8f6a --- /dev/null +++ b/node_modules/resolve/test/precedence/aaa/index.js @@ -0,0 +1 @@ +module.exports = 'okok'; diff --git a/node_modules/resolve/test/precedence/aaa/main.js b/node_modules/resolve/test/precedence/aaa/main.js new file mode 100644 index 0000000..93542a9 --- /dev/null +++ b/node_modules/resolve/test/precedence/aaa/main.js @@ -0,0 +1 @@ +console.log(require('./')); diff --git a/node_modules/resolve/test/precedence/bbb.js b/node_modules/resolve/test/precedence/bbb.js new file mode 100644 index 0000000..2298f47 --- /dev/null +++ b/node_modules/resolve/test/precedence/bbb.js @@ -0,0 +1 @@ +module.exports = '>_<'; diff --git a/node_modules/resolve/test/precedence/bbb/main.js b/node_modules/resolve/test/precedence/bbb/main.js new file mode 100644 index 0000000..716b81d --- /dev/null +++ b/node_modules/resolve/test/precedence/bbb/main.js @@ -0,0 +1 @@ +console.log(require('./')); // should throw diff --git a/node_modules/resolve/test/resolver.js b/node_modules/resolve/test/resolver.js new file mode 100644 index 0000000..4903165 --- /dev/null +++ b/node_modules/resolve/test/resolver.js @@ -0,0 +1,595 @@ +var path = require('path'); +var test = require('tape'); +var resolve = require('../'); +var async = require('../async'); + +test('`./async` entry point', function (t) { + t.equal(resolve, async, '`./async` entry point is the same as `main`'); + t.end(); +}); + +test('async foo', function (t) { + t.plan(12); + var dir = path.join(__dirname, 'resolver'); + + resolve('./foo', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.name, 'resolve'); + }); + + resolve('./foo.js', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.name, 'resolve'); + }); + + resolve('./foo', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.main, 'resolver'); + }); + + resolve('./foo.js', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg.main, 'resolver'); + }); + + resolve('./foo', { basedir: dir, filename: path.join(dir, 'baz.js') }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo.js')); + }); + + resolve('foo', { basedir: dir }, function (err) { + t.equal(err.message, "Cannot find module 'foo' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); + + // Test that filename is reported as the "from" value when passed. + resolve('foo', { basedir: dir, filename: path.join(dir, 'baz.js') }, function (err) { + t.equal(err.message, "Cannot find module 'foo' from '" + path.join(dir, 'baz.js') + "'"); + }); +}); + +test('bar', function (t) { + t.plan(6); + var dir = path.join(__dirname, 'resolver'); + + resolve('foo', { basedir: dir + '/bar' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); + t.equal(pkg, undefined); + }); + + resolve('foo', { basedir: dir + '/bar' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); + t.equal(pkg, undefined); + }); + + resolve('foo', { basedir: dir + '/bar', 'package': { main: 'bar' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); + t.equal(pkg.main, 'bar'); + }); +}); + +test('baz', function (t) { + t.plan(4); + var dir = path.join(__dirname, 'resolver'); + + resolve('./baz', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'baz/quux.js')); + t.equal(pkg.main, 'quux.js'); + }); + + resolve('./baz', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'baz/quux.js')); + t.equal(pkg.main, 'quux.js'); + }); +}); + +test('biz', function (t) { + t.plan(24); + var dir = path.join(__dirname, 'resolver/biz/node_modules'); + + resolve('./grux', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'grux/index.js')); + t.equal(pkg, undefined); + }); + + resolve('./grux', { basedir: dir, 'package': { main: 'biz' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'grux/index.js')); + t.equal(pkg.main, 'biz'); + }); + + resolve('./garply', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'garply/lib/index.js')); + t.equal(pkg.main, './lib'); + }); + + resolve('./garply', { basedir: dir, 'package': { main: 'biz' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'garply/lib/index.js')); + t.equal(pkg.main, './lib'); + }); + + resolve('tiv', { basedir: dir + '/grux' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'tiv/index.js')); + t.equal(pkg, undefined); + }); + + resolve('tiv', { basedir: dir + '/grux', 'package': { main: 'grux' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'tiv/index.js')); + t.equal(pkg.main, 'grux'); + }); + + resolve('tiv', { basedir: dir + '/garply' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'tiv/index.js')); + t.equal(pkg, undefined); + }); + + resolve('tiv', { basedir: dir + '/garply', 'package': { main: './lib' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'tiv/index.js')); + t.equal(pkg.main, './lib'); + }); + + resolve('grux', { basedir: dir + '/tiv' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'grux/index.js')); + t.equal(pkg, undefined); + }); + + resolve('grux', { basedir: dir + '/tiv', 'package': { main: 'tiv' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'grux/index.js')); + t.equal(pkg.main, 'tiv'); + }); + + resolve('garply', { basedir: dir + '/tiv' }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'garply/lib/index.js')); + t.equal(pkg.main, './lib'); + }); + + resolve('garply', { basedir: dir + '/tiv', 'package': { main: 'tiv' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'garply/lib/index.js')); + t.equal(pkg.main, './lib'); + }); +}); + +test('quux', function (t) { + t.plan(2); + var dir = path.join(__dirname, 'resolver/quux'); + + resolve('./foo', { basedir: dir, 'package': { main: 'quux' } }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'foo/index.js')); + t.equal(pkg.main, 'quux'); + }); +}); + +test('normalize', function (t) { + t.plan(2); + var dir = path.join(__dirname, 'resolver/biz/node_modules/grux'); + + resolve('../grux', { basedir: dir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'index.js')); + t.equal(pkg, undefined); + }); +}); + +test('cup', function (t) { + t.plan(5); + var dir = path.join(__dirname, 'resolver'); + + resolve('./cup', { basedir: dir, extensions: ['.js', '.coffee'] }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'cup.coffee')); + }); + + resolve('./cup.coffee', { basedir: dir }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'cup.coffee')); + }); + + resolve('./cup', { basedir: dir, extensions: ['.js'] }, function (err, res) { + t.equal(err.message, "Cannot find module './cup' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); + + // Test that filename is reported as the "from" value when passed. + resolve('./cup', { basedir: dir, extensions: ['.js'], filename: path.join(dir, 'cupboard.js') }, function (err, res) { + t.equal(err.message, "Cannot find module './cup' from '" + path.join(dir, 'cupboard.js') + "'"); + }); +}); + +test('mug', function (t) { + t.plan(3); + var dir = path.join(__dirname, 'resolver'); + + resolve('./mug', { basedir: dir }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'mug.js')); + }); + + resolve('./mug', { basedir: dir, extensions: ['.coffee', '.js'] }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(dir, '/mug.coffee')); + }); + + resolve('./mug', { basedir: dir, extensions: ['.js', '.coffee'] }, function (err, res) { + t.equal(res, path.join(dir, '/mug.js')); + }); +}); + +test('other path', function (t) { + t.plan(6); + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'bar'); + var otherDir = path.join(resolverDir, 'other_path'); + + resolve('root', { basedir: dir, paths: [otherDir] }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(resolverDir, 'other_path/root.js')); + }); + + resolve('lib/other-lib', { basedir: dir, paths: [otherDir] }, function (err, res) { + if (err) t.fail(err); + t.equal(res, path.join(resolverDir, 'other_path/lib/other-lib.js')); + }); + + resolve('root', { basedir: dir }, function (err, res) { + t.equal(err.message, "Cannot find module 'root' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); + + resolve('zzz', { basedir: dir, paths: [otherDir] }, function (err, res) { + t.equal(err.message, "Cannot find module 'zzz' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); + }); +}); + +test('path iterator', function (t) { + t.plan(2); + + var resolverDir = path.join(__dirname, 'resolver'); + + var exactIterator = function (x, start, getPackageCandidates, opts) { + return [path.join(resolverDir, x)]; + }; + + resolve('baz', { packageIterator: exactIterator }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(resolverDir, 'baz/quux.js')); + t.equal(pkg && pkg.name, 'baz'); + }); +}); + +test('incorrect main', function (t) { + t.plan(1); + + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'incorrect_main'); + + resolve('./incorrect_main', { basedir: resolverDir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'index.js')); + }); +}); + +test('missing index', function (t) { + t.plan(2); + + var resolverDir = path.join(__dirname, 'resolver'); + resolve('./missing_index', { basedir: resolverDir }, function (err, res, pkg) { + t.ok(err instanceof Error); + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + }); +}); + +test('missing main', function (t) { + t.plan(1); + + var resolverDir = path.join(__dirname, 'resolver'); + + resolve('./missing_main', { basedir: resolverDir }, function (err, res, pkg) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + }); +}); + +test('null main', function (t) { + t.plan(1); + + var resolverDir = path.join(__dirname, 'resolver'); + + resolve('./null_main', { basedir: resolverDir }, function (err, res, pkg) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + }); +}); + +test('main: false', function (t) { + t.plan(2); + + var basedir = path.join(__dirname, 'resolver'); + var dir = path.join(basedir, 'false_main'); + resolve('./false_main', { basedir: basedir }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal( + res, + path.join(dir, 'index.js'), + '`"main": false`: resolves to `index.js`' + ); + t.deepEqual(pkg, { + name: 'false_main', + main: false + }); + }); +}); + +test('without basedir', function (t) { + t.plan(1); + + var dir = path.join(__dirname, 'resolver/without_basedir'); + var tester = require(path.join(dir, 'main.js')); // eslint-disable-line global-require + + tester(t, function (err, res, pkg) { + if (err) { + t.fail(err); + } else { + t.equal(res, path.join(dir, 'node_modules/mymodule.js')); + } + }); +}); + +test('#52 - incorrectly resolves module-paths like "./someFolder/" when there is a file of the same name', function (t) { + t.plan(2); + + var dir = path.join(__dirname, 'resolver'); + + resolve('./foo', { basedir: path.join(dir, 'same_names') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo.js')); + }); + + resolve('./foo/', { basedir: path.join(dir, 'same_names') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo/index.js')); + }); +}); + +test('#211 - incorrectly resolves module-paths like "." when from inside a folder with a sibling file of the same name', function (t) { + t.plan(2); + + var dir = path.join(__dirname, 'resolver'); + + resolve('./', { basedir: path.join(dir, 'same_names/foo') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo/index.js')); + }); + + resolve('.', { basedir: path.join(dir, 'same_names/foo') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo/index.js')); + }); +}); + +test('async: #121 - treating an existing file as a dir when no basedir', function (t) { + var testFile = path.basename(__filename); + + t.test('sanity check', function (st) { + st.plan(1); + resolve('./' + testFile, function (err, res, pkg) { + if (err) t.fail(err); + st.equal(res, __filename, 'sanity check'); + }); + }); + + t.test('with a fake directory', function (st) { + st.plan(4); + + resolve('./' + testFile + '/blah', function (err, res, pkg) { + st.ok(err, 'there is an error'); + st.notOk(res, 'no result'); + + st.equal(err && err.code, 'MODULE_NOT_FOUND', 'error code matches require.resolve'); + st.equal( + err && err.message, + 'Cannot find module \'./' + testFile + '/blah\' from \'' + __dirname + '\'', + 'can not find nonexistent module' + ); + st.end(); + }); + }); + + t.end(); +}); + +test('async dot main', function (t) { + var start = new Date(); + t.plan(3); + resolve('./resolver/dot_main', function (err, ret) { + t.notOk(err); + t.equal(ret, path.join(__dirname, 'resolver/dot_main/index.js')); + t.ok(new Date() - start < 50, 'resolve.sync timedout'); + t.end(); + }); +}); + +test('async dot slash main', function (t) { + var start = new Date(); + t.plan(3); + resolve('./resolver/dot_slash_main', function (err, ret) { + t.notOk(err); + t.equal(ret, path.join(__dirname, 'resolver/dot_slash_main/index.js')); + t.ok(new Date() - start < 50, 'resolve.sync timedout'); + t.end(); + }); +}); + +test('not a directory', function (t) { + t.plan(6); + var path = './foo'; + resolve(path, { basedir: __filename }, function (err, res, pkg) { + t.ok(err, 'a non-directory errors'); + t.equal(arguments.length, 1); + t.equal(res, undefined); + t.equal(pkg, undefined); + + t.equal(err && err.message, 'Cannot find module \'' + path + '\' from \'' + __filename + '\''); + t.equal(err && err.code, 'MODULE_NOT_FOUND'); + }); +}); + +test('non-string "main" field in package.json', function (t) { + t.plan(5); + + var dir = path.join(__dirname, 'resolver'); + resolve('./invalid_main', { basedir: dir }, function (err, res, pkg) { + t.ok(err, 'errors on non-string main'); + t.equal(err.message, 'package “invalid_main” `main` must be a string'); + t.equal(err.code, 'INVALID_PACKAGE_MAIN'); + t.equal(res, undefined, 'res is undefined'); + t.equal(pkg, undefined, 'pkg is undefined'); + }); +}); + +test('non-string "main" field in package.json', function (t) { + t.plan(5); + + var dir = path.join(__dirname, 'resolver'); + resolve('./invalid_main', { basedir: dir }, function (err, res, pkg) { + t.ok(err, 'errors on non-string main'); + t.equal(err.message, 'package “invalid_main” `main` must be a string'); + t.equal(err.code, 'INVALID_PACKAGE_MAIN'); + t.equal(res, undefined, 'res is undefined'); + t.equal(pkg, undefined, 'pkg is undefined'); + }); +}); + +test('browser field in package.json', function (t) { + t.plan(3); + + var dir = path.join(__dirname, 'resolver'); + resolve( + './browser_field', + { + basedir: dir, + packageFilter: function packageFilter(pkg) { + if (pkg.browser) { + pkg.main = pkg.browser; // eslint-disable-line no-param-reassign + delete pkg.browser; // eslint-disable-line no-param-reassign + } + return pkg; + } + }, + function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'browser_field', 'b.js')); + t.equal(pkg && pkg.main, 'b'); + t.equal(pkg && pkg.browser, undefined); + } + ); +}); + +test('absolute paths', function (t) { + t.plan(4); + + var extensionless = __filename.slice(0, -path.extname(__filename).length); + + resolve(__filename, function (err, res) { + t.equal( + res, + __filename, + 'absolute path to this file resolves' + ); + }); + resolve(extensionless, function (err, res) { + t.equal( + res, + __filename, + 'extensionless absolute path to this file resolves' + ); + }); + resolve(__filename, { basedir: process.cwd() }, function (err, res) { + t.equal( + res, + __filename, + 'absolute path to this file with a basedir resolves' + ); + }); + resolve(extensionless, { basedir: process.cwd() }, function (err, res) { + t.equal( + res, + __filename, + 'extensionless absolute path to this file with a basedir resolves' + ); + }); +}); + +test('malformed package.json', function (t) { + /* eslint operator-linebreak: ["error", "before"], function-paren-newline: "off" */ + t.plan( + (3 * 3) // 3 sets of 3 assertions in the final callback + + 2 // 1 readPackage call with malformed package.json + ); + + var basedir = path.join(__dirname, 'resolver/malformed_package_json'); + var expected = path.join(basedir, 'index.js'); + + resolve('./index.js', { basedir: basedir }, function (err, res, pkg) { + t.error(err, 'no error'); + t.equal(res, expected, 'malformed package.json is silently ignored'); + t.equal(pkg, undefined, 'malformed package.json gives an undefined `pkg` argument'); + }); + + resolve( + './index.js', + { + basedir: basedir, + packageFilter: function (pkg, pkgfile, dir) { + t.fail('should not reach here'); + } + }, + function (err, res, pkg) { + t.error(err, 'with packageFilter: no error'); + t.equal(res, expected, 'with packageFilter: malformed package.json is silently ignored'); + t.equal(pkg, undefined, 'with packageFilter: malformed package.json gives an undefined `pkg` argument'); + } + ); + + resolve( + './index.js', + { + basedir: basedir, + readPackage: function (readFile, pkgfile, cb) { + t.equal(pkgfile, path.join(basedir, 'package.json'), 'readPackageSync: `pkgfile` is package.json path'); + readFile(pkgfile, function (err, result) { + try { + cb(null, JSON.parse(result)); + } catch (e) { + t.ok(e instanceof SyntaxError, 'readPackage: malformed package.json parses as a syntax error'); + cb(null); + } + }); + } + }, + function (err, res, pkg) { + t.error(err, 'with readPackage: no error'); + t.equal(res, expected, 'with readPackage: malformed package.json is silently ignored'); + t.equal(pkg, undefined, 'with readPackage: malformed package.json gives an undefined `pkg` argument'); + } + ); +}); diff --git a/node_modules/resolve/test/resolver/baz/doom.js b/node_modules/resolve/test/resolver/baz/doom.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/baz/package.json b/node_modules/resolve/test/resolver/baz/package.json new file mode 100644 index 0000000..2f77720 --- /dev/null +++ b/node_modules/resolve/test/resolver/baz/package.json @@ -0,0 +1,4 @@ +{ + "name": "baz", + "main": "quux.js" +} diff --git a/node_modules/resolve/test/resolver/baz/quux.js b/node_modules/resolve/test/resolver/baz/quux.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/baz/quux.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/browser_field/a.js b/node_modules/resolve/test/resolver/browser_field/a.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/browser_field/b.js b/node_modules/resolve/test/resolver/browser_field/b.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/browser_field/package.json b/node_modules/resolve/test/resolver/browser_field/package.json new file mode 100644 index 0000000..bf406f0 --- /dev/null +++ b/node_modules/resolve/test/resolver/browser_field/package.json @@ -0,0 +1,5 @@ +{ + "name": "browser_field", + "main": "a", + "browser": "b" +} diff --git a/node_modules/resolve/test/resolver/cup.coffee b/node_modules/resolve/test/resolver/cup.coffee new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/node_modules/resolve/test/resolver/cup.coffee @@ -0,0 +1 @@ + diff --git a/node_modules/resolve/test/resolver/dot_main/index.js b/node_modules/resolve/test/resolver/dot_main/index.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/dot_main/index.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/dot_main/package.json b/node_modules/resolve/test/resolver/dot_main/package.json new file mode 100644 index 0000000..d7f4fc8 --- /dev/null +++ b/node_modules/resolve/test/resolver/dot_main/package.json @@ -0,0 +1,3 @@ +{ + "main": "." +} diff --git a/node_modules/resolve/test/resolver/dot_slash_main/index.js b/node_modules/resolve/test/resolver/dot_slash_main/index.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/dot_slash_main/index.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/dot_slash_main/package.json b/node_modules/resolve/test/resolver/dot_slash_main/package.json new file mode 100644 index 0000000..f51287b --- /dev/null +++ b/node_modules/resolve/test/resolver/dot_slash_main/package.json @@ -0,0 +1,3 @@ +{ + "main": "./" +} diff --git a/node_modules/resolve/test/resolver/false_main/index.js b/node_modules/resolve/test/resolver/false_main/index.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/false_main/package.json b/node_modules/resolve/test/resolver/false_main/package.json new file mode 100644 index 0000000..a7416c0 --- /dev/null +++ b/node_modules/resolve/test/resolver/false_main/package.json @@ -0,0 +1,4 @@ +{ + "name": "false_main", + "main": false +} diff --git a/node_modules/resolve/test/resolver/foo.js b/node_modules/resolve/test/resolver/foo.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/foo.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/incorrect_main/index.js b/node_modules/resolve/test/resolver/incorrect_main/index.js new file mode 100644 index 0000000..bc1fb0a --- /dev/null +++ b/node_modules/resolve/test/resolver/incorrect_main/index.js @@ -0,0 +1,2 @@ +// this is the actual main file 'index.js', not 'wrong.js' like the package.json would indicate +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/incorrect_main/package.json b/node_modules/resolve/test/resolver/incorrect_main/package.json new file mode 100644 index 0000000..b718804 --- /dev/null +++ b/node_modules/resolve/test/resolver/incorrect_main/package.json @@ -0,0 +1,3 @@ +{ + "main": "wrong.js" +} diff --git a/node_modules/resolve/test/resolver/invalid_main/package.json b/node_modules/resolve/test/resolver/invalid_main/package.json new file mode 100644 index 0000000..0590748 --- /dev/null +++ b/node_modules/resolve/test/resolver/invalid_main/package.json @@ -0,0 +1,7 @@ +{ + "name": "invalid_main", + "main": [ + "why is this a thing", + "srsly omg wtf" + ] +} diff --git a/node_modules/resolve/test/resolver/malformed_package_json/index.js b/node_modules/resolve/test/resolver/malformed_package_json/index.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/malformed_package_json/package.json b/node_modules/resolve/test/resolver/malformed_package_json/package.json new file mode 100644 index 0000000..98232c6 --- /dev/null +++ b/node_modules/resolve/test/resolver/malformed_package_json/package.json @@ -0,0 +1 @@ +{ diff --git a/node_modules/resolve/test/resolver/mug.coffee b/node_modules/resolve/test/resolver/mug.coffee new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/mug.js b/node_modules/resolve/test/resolver/mug.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/multirepo/lerna.json b/node_modules/resolve/test/resolver/multirepo/lerna.json new file mode 100644 index 0000000..d6707ca --- /dev/null +++ b/node_modules/resolve/test/resolver/multirepo/lerna.json @@ -0,0 +1,6 @@ +{ + "packages": [ + "packages/*" + ], + "version": "0.0.0" +} diff --git a/node_modules/resolve/test/resolver/multirepo/package.json b/node_modules/resolve/test/resolver/multirepo/package.json new file mode 100644 index 0000000..8508f9d --- /dev/null +++ b/node_modules/resolve/test/resolver/multirepo/package.json @@ -0,0 +1,20 @@ +{ + "name": "monorepo-symlink-test", + "private": true, + "version": "0.0.0", + "description": "", + "main": "index.js", + "scripts": { + "postinstall": "lerna bootstrap", + "test": "node packages/package-a" + }, + "author": "", + "license": "MIT", + "dependencies": { + "jquery": "^3.3.1", + "resolve": "../../../" + }, + "devDependencies": { + "lerna": "^3.4.3" + } +} diff --git a/node_modules/resolve/test/resolver/multirepo/packages/package-a/index.js b/node_modules/resolve/test/resolver/multirepo/packages/package-a/index.js new file mode 100644 index 0000000..8875a32 --- /dev/null +++ b/node_modules/resolve/test/resolver/multirepo/packages/package-a/index.js @@ -0,0 +1,35 @@ +'use strict'; + +var assert = require('assert'); +var path = require('path'); +var resolve = require('resolve'); + +var basedir = __dirname + '/node_modules/@my-scope/package-b'; + +var expected = path.join(__dirname, '../../node_modules/jquery/dist/jquery.js'); + +/* + * preserveSymlinks === false + * will search NPM package from + * - packages/package-b/node_modules + * - packages/node_modules + * - node_modules + */ +assert.equal(resolve.sync('jquery', { basedir: basedir, preserveSymlinks: false }), expected); +assert.equal(resolve.sync('../../node_modules/jquery', { basedir: basedir, preserveSymlinks: false }), expected); + +/* + * preserveSymlinks === true + * will search NPM package from + * - packages/package-a/node_modules/@my-scope/packages/package-b/node_modules + * - packages/package-a/node_modules/@my-scope/packages/node_modules + * - packages/package-a/node_modules/@my-scope/node_modules + * - packages/package-a/node_modules/node_modules + * - packages/package-a/node_modules + * - packages/node_modules + * - node_modules + */ +assert.equal(resolve.sync('jquery', { basedir: basedir, preserveSymlinks: true }), expected); +assert.equal(resolve.sync('../../../../../node_modules/jquery', { basedir: basedir, preserveSymlinks: true }), expected); + +console.log(' * all monorepo paths successfully resolved through symlinks'); diff --git a/node_modules/resolve/test/resolver/multirepo/packages/package-a/package.json b/node_modules/resolve/test/resolver/multirepo/packages/package-a/package.json new file mode 100644 index 0000000..204de51 --- /dev/null +++ b/node_modules/resolve/test/resolver/multirepo/packages/package-a/package.json @@ -0,0 +1,14 @@ +{ + "name": "@my-scope/package-a", + "version": "0.0.0", + "private": true, + "description": "", + "license": "MIT", + "main": "index.js", + "scripts": { + "test": "echo \"Error: run tests from root\" && exit 1" + }, + "dependencies": { + "@my-scope/package-b": "^0.0.0" + } +} diff --git a/node_modules/resolve/test/resolver/multirepo/packages/package-b/index.js b/node_modules/resolve/test/resolver/multirepo/packages/package-b/index.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/multirepo/packages/package-b/package.json b/node_modules/resolve/test/resolver/multirepo/packages/package-b/package.json new file mode 100644 index 0000000..f57c3b5 --- /dev/null +++ b/node_modules/resolve/test/resolver/multirepo/packages/package-b/package.json @@ -0,0 +1,14 @@ +{ + "name": "@my-scope/package-b", + "private": true, + "version": "0.0.0", + "description": "", + "license": "MIT", + "main": "index.js", + "scripts": { + "test": "echo \"Error: run tests from root\" && exit 1" + }, + "dependencies": { + "@my-scope/package-a": "^0.0.0" + } +} diff --git a/node_modules/resolve/test/resolver/nested_symlinks/mylib/async.js b/node_modules/resolve/test/resolver/nested_symlinks/mylib/async.js new file mode 100644 index 0000000..9b4846a --- /dev/null +++ b/node_modules/resolve/test/resolver/nested_symlinks/mylib/async.js @@ -0,0 +1,26 @@ +var a = require.resolve('buffer/').replace(process.cwd(), '$CWD'); +var b; +var c; + +var test = function test() { + console.log(a, ': require.resolve, preserveSymlinks ' + (process.execArgv.indexOf('preserve-symlinks') > -1 ? 'true' : 'false')); + console.log(b, ': preserveSymlinks true'); + console.log(c, ': preserveSymlinks false'); + + if (a !== b && a !== c) { + throw 'async: no match'; + } + console.log('async: success! a matched either b or c\n'); +}; + +require('resolve')('buffer/', { preserveSymlinks: true }, function (err, result) { + if (err) { throw err; } + b = result.replace(process.cwd(), '$CWD'); + if (b && c) { test(); } +}); +require('resolve')('buffer/', { preserveSymlinks: false }, function (err, result) { + if (err) { throw err; } + c = result.replace(process.cwd(), '$CWD'); + if (b && c) { test(); } +}); + diff --git a/node_modules/resolve/test/resolver/nested_symlinks/mylib/package.json b/node_modules/resolve/test/resolver/nested_symlinks/mylib/package.json new file mode 100644 index 0000000..acfe9e9 --- /dev/null +++ b/node_modules/resolve/test/resolver/nested_symlinks/mylib/package.json @@ -0,0 +1,15 @@ +{ + "name": "mylib", + "version": "0.0.0", + "description": "", + "private": true, + "scripts": { + "test": "echo \"Error: no test specified\" && exit 1" + }, + "keywords": [], + "author": "", + "license": "ISC", + "dependencies": { + "buffer": "*" + } +} diff --git a/node_modules/resolve/test/resolver/nested_symlinks/mylib/sync.js b/node_modules/resolve/test/resolver/nested_symlinks/mylib/sync.js new file mode 100644 index 0000000..3283efc --- /dev/null +++ b/node_modules/resolve/test/resolver/nested_symlinks/mylib/sync.js @@ -0,0 +1,12 @@ +var a = require.resolve('buffer/').replace(process.cwd(), '$CWD'); +var b = require('resolve').sync('buffer/', { preserveSymlinks: true }).replace(process.cwd(), '$CWD'); +var c = require('resolve').sync('buffer/', { preserveSymlinks: false }).replace(process.cwd(), '$CWD'); + +console.log(a, ': require.resolve, preserveSymlinks ' + (process.execArgv.indexOf('preserve-symlinks') > -1 ? 'true' : 'false')); +console.log(b, ': preserveSymlinks true'); +console.log(c, ': preserveSymlinks false'); + +if (a !== b && a !== c) { + throw 'sync: no match'; +} +console.log('sync: success! a matched either b or c\n'); diff --git a/node_modules/resolve/test/resolver/other_path/lib/other-lib.js b/node_modules/resolve/test/resolver/other_path/lib/other-lib.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/other_path/root.js b/node_modules/resolve/test/resolver/other_path/root.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/quux/foo/index.js b/node_modules/resolve/test/resolver/quux/foo/index.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/quux/foo/index.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/same_names/foo.js b/node_modules/resolve/test/resolver/same_names/foo.js new file mode 100644 index 0000000..888cae3 --- /dev/null +++ b/node_modules/resolve/test/resolver/same_names/foo.js @@ -0,0 +1 @@ +module.exports = 42; diff --git a/node_modules/resolve/test/resolver/same_names/foo/index.js b/node_modules/resolve/test/resolver/same_names/foo/index.js new file mode 100644 index 0000000..bd816ea --- /dev/null +++ b/node_modules/resolve/test/resolver/same_names/foo/index.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/node_modules/resolve/test/resolver/symlinked/_/node_modules/foo.js b/node_modules/resolve/test/resolver/symlinked/_/node_modules/foo.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/symlinked/_/symlink_target/.gitkeep b/node_modules/resolve/test/resolver/symlinked/_/symlink_target/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/resolver/symlinked/package/bar.js b/node_modules/resolve/test/resolver/symlinked/package/bar.js new file mode 100644 index 0000000..cb1c2c0 --- /dev/null +++ b/node_modules/resolve/test/resolver/symlinked/package/bar.js @@ -0,0 +1 @@ +module.exports = 'bar'; diff --git a/node_modules/resolve/test/resolver/symlinked/package/package.json b/node_modules/resolve/test/resolver/symlinked/package/package.json new file mode 100644 index 0000000..8e1b585 --- /dev/null +++ b/node_modules/resolve/test/resolver/symlinked/package/package.json @@ -0,0 +1,3 @@ +{ + "main": "bar.js" +} \ No newline at end of file diff --git a/node_modules/resolve/test/resolver/without_basedir/main.js b/node_modules/resolve/test/resolver/without_basedir/main.js new file mode 100644 index 0000000..5b31975 --- /dev/null +++ b/node_modules/resolve/test/resolver/without_basedir/main.js @@ -0,0 +1,5 @@ +var resolve = require('../../../'); + +module.exports = function (t, cb) { + resolve('mymodule', null, cb); +}; diff --git a/node_modules/resolve/test/resolver_sync.js b/node_modules/resolve/test/resolver_sync.js new file mode 100644 index 0000000..53453d6 --- /dev/null +++ b/node_modules/resolve/test/resolver_sync.js @@ -0,0 +1,726 @@ +var path = require('path'); +var fs = require('fs'); +var test = require('tape'); + +var resolve = require('../'); +var sync = require('../sync'); + +var requireResolveSupportsPaths = require.resolve.length > 1 + && !(/^v12\.[012]\./).test(process.version); // broken in v12.0-12.2, see https://github.com/nodejs/node/issues/27794 + +test('`./sync` entry point', function (t) { + t.equal(resolve.sync, sync, '`./sync` entry point is the same as `.sync` on `main`'); + t.end(); +}); + +test('foo', function (t) { + var dir = path.join(__dirname, 'resolver'); + + t.equal( + resolve.sync('./foo', { basedir: dir }), + path.join(dir, 'foo.js'), + './foo' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./foo', { basedir: dir }), + require.resolve('./foo', { paths: [dir] }), + './foo: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync('./foo.js', { basedir: dir }), + path.join(dir, 'foo.js'), + './foo.js' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./foo.js', { basedir: dir }), + require.resolve('./foo.js', { paths: [dir] }), + './foo.js: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync('./foo.js', { basedir: dir, filename: path.join(dir, 'bar.js') }), + path.join(dir, 'foo.js') + ); + + t.throws(function () { + resolve.sync('foo', { basedir: dir }); + }); + + // Test that filename is reported as the "from" value when passed. + t.throws( + function () { + resolve.sync('foo', { basedir: dir, filename: path.join(dir, 'bar.js') }); + }, + { + name: 'Error', + message: "Cannot find module 'foo' from '" + path.join(dir, 'bar.js') + "'" + } + ); + + t.end(); +}); + +test('bar', function (t) { + var dir = path.join(__dirname, 'resolver'); + + var basedir = path.join(dir, 'bar'); + + t.equal( + resolve.sync('foo', { basedir: basedir }), + path.join(dir, 'bar/node_modules/foo/index.js'), + 'foo in bar' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('foo', { basedir: basedir }), + require.resolve('foo', { paths: [basedir] }), + 'foo in bar: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('baz', function (t) { + var dir = path.join(__dirname, 'resolver'); + + t.equal( + resolve.sync('./baz', { basedir: dir }), + path.join(dir, 'baz/quux.js'), + './baz' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./baz', { basedir: dir }), + require.resolve('./baz', { paths: [dir] }), + './baz: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('biz', function (t) { + var dir = path.join(__dirname, 'resolver/biz/node_modules'); + + t.equal( + resolve.sync('./grux', { basedir: dir }), + path.join(dir, 'grux/index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./grux', { basedir: dir }), + require.resolve('./grux', { paths: [dir] }), + './grux: resolve.sync === require.resolve' + ); + } + + var tivDir = path.join(dir, 'grux'); + t.equal( + resolve.sync('tiv', { basedir: tivDir }), + path.join(dir, 'tiv/index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('tiv', { basedir: tivDir }), + require.resolve('tiv', { paths: [tivDir] }), + 'tiv: resolve.sync === require.resolve' + ); + } + + var gruxDir = path.join(dir, 'tiv'); + t.equal( + resolve.sync('grux', { basedir: gruxDir }), + path.join(dir, 'grux/index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('grux', { basedir: gruxDir }), + require.resolve('grux', { paths: [gruxDir] }), + 'grux: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('normalize', function (t) { + var dir = path.join(__dirname, 'resolver/biz/node_modules/grux'); + + t.equal( + resolve.sync('../grux', { basedir: dir }), + path.join(dir, 'index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('../grux', { basedir: dir }), + require.resolve('../grux', { paths: [dir] }), + '../grux: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('cup', function (t) { + var dir = path.join(__dirname, 'resolver'); + + t.equal( + resolve.sync('./cup', { + basedir: dir, + extensions: ['.js', '.coffee'] + }), + path.join(dir, 'cup.coffee'), + './cup -> ./cup.coffee' + ); + + t.equal( + resolve.sync('./cup.coffee', { basedir: dir }), + path.join(dir, 'cup.coffee'), + './cup.coffee' + ); + + t.throws(function () { + resolve.sync('./cup', { + basedir: dir, + extensions: ['.js'] + }); + }); + + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./cup.coffee', { basedir: dir, extensions: ['.js', '.coffee'] }), + require.resolve('./cup.coffee', { paths: [dir] }), + './cup.coffee: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('mug', function (t) { + var dir = path.join(__dirname, 'resolver'); + + t.equal( + resolve.sync('./mug', { basedir: dir }), + path.join(dir, 'mug.js'), + './mug -> ./mug.js' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./mug', { basedir: dir }), + require.resolve('./mug', { paths: [dir] }), + './mug: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync('./mug', { + basedir: dir, + extensions: ['.coffee', '.js'] + }), + path.join(dir, 'mug.coffee'), + './mug -> ./mug.coffee' + ); + + t.equal( + resolve.sync('./mug', { + basedir: dir, + extensions: ['.js', '.coffee'] + }), + path.join(dir, 'mug.js'), + './mug -> ./mug.js' + ); + + t.end(); +}); + +test('other path', function (t) { + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'bar'); + var otherDir = path.join(resolverDir, 'other_path'); + + t.equal( + resolve.sync('root', { + basedir: dir, + paths: [otherDir] + }), + path.join(resolverDir, 'other_path/root.js') + ); + + t.equal( + resolve.sync('lib/other-lib', { + basedir: dir, + paths: [otherDir] + }), + path.join(resolverDir, 'other_path/lib/other-lib.js') + ); + + t.throws(function () { + resolve.sync('root', { basedir: dir }); + }); + + t.throws(function () { + resolve.sync('zzz', { + basedir: dir, + paths: [otherDir] + }); + }); + + t.end(); +}); + +test('path iterator', function (t) { + var resolverDir = path.join(__dirname, 'resolver'); + + var exactIterator = function (x, start, getPackageCandidates, opts) { + return [path.join(resolverDir, x)]; + }; + + t.equal( + resolve.sync('baz', { packageIterator: exactIterator }), + path.join(resolverDir, 'baz/quux.js') + ); + + t.end(); +}); + +test('incorrect main', function (t) { + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'incorrect_main'); + + t.equal( + resolve.sync('./incorrect_main', { basedir: resolverDir }), + path.join(dir, 'index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./incorrect_main', { basedir: resolverDir }), + require.resolve('./incorrect_main', { paths: [resolverDir] }), + './incorrect_main: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('missing index', function (t) { + t.plan(requireResolveSupportsPaths ? 2 : 1); + + var resolverDir = path.join(__dirname, 'resolver'); + try { + resolve.sync('./missing_index', { basedir: resolverDir }); + t.fail('did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + if (requireResolveSupportsPaths) { + try { + require.resolve('./missing_index', { basedir: resolverDir }); + t.fail('require.resolve did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + } +}); + +test('missing main', function (t) { + var resolverDir = path.join(__dirname, 'resolver'); + + try { + resolve.sync('./missing_main', { basedir: resolverDir }); + t.fail('require.resolve did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + if (requireResolveSupportsPaths) { + try { + resolve.sync('./missing_main', { basedir: resolverDir }); + t.fail('require.resolve did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + } + + t.end(); +}); + +test('null main', function (t) { + var resolverDir = path.join(__dirname, 'resolver'); + + try { + resolve.sync('./null_main', { basedir: resolverDir }); + t.fail('require.resolve did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + if (requireResolveSupportsPaths) { + try { + resolve.sync('./null_main', { basedir: resolverDir }); + t.fail('require.resolve did not fail'); + } catch (err) { + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error has correct error code'); + } + } + + t.end(); +}); + +test('main: false', function (t) { + var basedir = path.join(__dirname, 'resolver'); + var dir = path.join(basedir, 'false_main'); + t.equal( + resolve.sync('./false_main', { basedir: basedir }), + path.join(dir, 'index.js'), + '`"main": false`: resolves to `index.js`' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./false_main', { basedir: basedir }), + require.resolve('./false_main', { paths: [basedir] }), + '`"main": false`: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +var stubStatSync = function stubStatSync(fn) { + var statSync = fs.statSync; + try { + fs.statSync = function () { + throw new EvalError('Unknown Error'); + }; + return fn(); + } finally { + fs.statSync = statSync; + } +}; + +test('#79 - re-throw non ENOENT errors from stat', function (t) { + var dir = path.join(__dirname, 'resolver'); + + stubStatSync(function () { + t.throws(function () { + resolve.sync('foo', { basedir: dir }); + }, /Unknown Error/); + }); + + t.end(); +}); + +test('#52 - incorrectly resolves module-paths like "./someFolder/" when there is a file of the same name', function (t) { + var dir = path.join(__dirname, 'resolver'); + var basedir = path.join(dir, 'same_names'); + + t.equal( + resolve.sync('./foo', { basedir: basedir }), + path.join(dir, 'same_names/foo.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./foo', { basedir: basedir }), + require.resolve('./foo', { paths: [basedir] }), + './foo: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync('./foo/', { basedir: basedir }), + path.join(dir, 'same_names/foo/index.js') + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./foo/', { basedir: basedir }), + require.resolve('./foo/', { paths: [basedir] }), + './foo/: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('#211 - incorrectly resolves module-paths like "." when from inside a folder with a sibling file of the same name', function (t) { + var dir = path.join(__dirname, 'resolver'); + var basedir = path.join(dir, 'same_names/foo'); + + t.equal( + resolve.sync('./', { basedir: basedir }), + path.join(dir, 'same_names/foo/index.js'), + './' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./', { basedir: basedir }), + require.resolve('./', { paths: [basedir] }), + './: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync('.', { basedir: basedir }), + path.join(dir, 'same_names/foo/index.js'), + '.' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('.', { basedir: basedir }), + require.resolve('.', { paths: [basedir] }), + '.: resolve.sync === require.resolve', + { todo: true } + ); + } + + t.end(); +}); + +test('sync: #121 - treating an existing file as a dir when no basedir', function (t) { + var testFile = path.basename(__filename); + + t.test('sanity check', function (st) { + st.equal( + resolve.sync('./' + testFile), + __filename, + 'sanity check' + ); + st.equal( + resolve.sync('./' + testFile), + require.resolve('./' + testFile), + 'sanity check: resolve.sync === require.resolve' + ); + + st.end(); + }); + + t.test('with a fake directory', function (st) { + function run() { return resolve.sync('./' + testFile + '/blah'); } + + st.throws(run, 'throws an error'); + + try { + run(); + } catch (e) { + st.equal(e.code, 'MODULE_NOT_FOUND', 'error code matches require.resolve'); + st.equal( + e.message, + 'Cannot find module \'./' + testFile + '/blah\' from \'' + __dirname + '\'', + 'can not find nonexistent module' + ); + } + + st.end(); + }); + + t.end(); +}); + +test('sync dot main', function (t) { + var start = new Date(); + + t.equal( + resolve.sync('./resolver/dot_main'), + path.join(__dirname, 'resolver/dot_main/index.js'), + './resolver/dot_main' + ); + t.equal( + resolve.sync('./resolver/dot_main'), + require.resolve('./resolver/dot_main'), + './resolver/dot_main: resolve.sync === require.resolve' + ); + + t.ok(new Date() - start < 50, 'resolve.sync timedout'); + + t.end(); +}); + +test('sync dot slash main', function (t) { + var start = new Date(); + + t.equal( + resolve.sync('./resolver/dot_slash_main'), + path.join(__dirname, 'resolver/dot_slash_main/index.js') + ); + t.equal( + resolve.sync('./resolver/dot_slash_main'), + require.resolve('./resolver/dot_slash_main'), + './resolver/dot_slash_main: resolve.sync === require.resolve' + ); + + t.ok(new Date() - start < 50, 'resolve.sync timedout'); + + t.end(); +}); + +test('not a directory', function (t) { + var path = './foo'; + try { + resolve.sync(path, { basedir: __filename }); + t.fail(); + } catch (err) { + t.ok(err, 'a non-directory errors'); + t.equal(err && err.message, 'Cannot find module \'' + path + "' from '" + __filename + "'"); + t.equal(err && err.code, 'MODULE_NOT_FOUND'); + } + t.end(); +}); + +test('non-string "main" field in package.json', function (t) { + var dir = path.join(__dirname, 'resolver'); + try { + var result = resolve.sync('./invalid_main', { basedir: dir }); + t.equal(result, undefined, 'result should not exist'); + t.fail('should not get here'); + } catch (err) { + t.ok(err, 'errors on non-string main'); + t.equal(err.message, 'package “invalid_main” `main` must be a string'); + t.equal(err.code, 'INVALID_PACKAGE_MAIN'); + } + t.end(); +}); + +test('non-string "main" field in package.json', function (t) { + var dir = path.join(__dirname, 'resolver'); + try { + var result = resolve.sync('./invalid_main', { basedir: dir }); + t.equal(result, undefined, 'result should not exist'); + t.fail('should not get here'); + } catch (err) { + t.ok(err, 'errors on non-string main'); + t.equal(err.message, 'package “invalid_main” `main` must be a string'); + t.equal(err.code, 'INVALID_PACKAGE_MAIN'); + } + t.end(); +}); + +test('browser field in package.json', function (t) { + var dir = path.join(__dirname, 'resolver'); + var res = resolve.sync('./browser_field', { + basedir: dir, + packageFilter: function packageFilter(pkg) { + if (pkg.browser) { + pkg.main = pkg.browser; // eslint-disable-line no-param-reassign + delete pkg.browser; // eslint-disable-line no-param-reassign + } + return pkg; + } + }); + t.equal(res, path.join(dir, 'browser_field', 'b.js')); + t.end(); +}); + +test('absolute paths', function (t) { + var extensionless = __filename.slice(0, -path.extname(__filename).length); + + t.equal( + resolve.sync(__filename), + __filename, + 'absolute path to this file resolves' + ); + t.equal( + resolve.sync(__filename), + require.resolve(__filename), + 'absolute path to this file: resolve.sync === require.resolve' + ); + + t.equal( + resolve.sync(extensionless), + __filename, + 'extensionless absolute path to this file resolves' + ); + t.equal( + resolve.sync(__filename), + require.resolve(__filename), + 'absolute path to this file: resolve.sync === require.resolve' + ); + + t.equal( + resolve.sync(__filename, { basedir: process.cwd() }), + __filename, + 'absolute path to this file with a basedir resolves' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync(__filename, { basedir: process.cwd() }), + require.resolve(__filename, { paths: [process.cwd()] }), + 'absolute path to this file + basedir: resolve.sync === require.resolve' + ); + } + + t.equal( + resolve.sync(extensionless, { basedir: process.cwd() }), + __filename, + 'extensionless absolute path to this file with a basedir resolves' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync(extensionless, { basedir: process.cwd() }), + require.resolve(extensionless, { paths: [process.cwd()] }), + 'extensionless absolute path to this file + basedir: resolve.sync === require.resolve' + ); + } + + t.end(); +}); + +test('malformed package.json', function (t) { + t.plan(5 + (requireResolveSupportsPaths ? 1 : 0)); + + var basedir = path.join(__dirname, 'resolver/malformed_package_json'); + var expected = path.join(basedir, 'index.js'); + + t.equal( + resolve.sync('./index.js', { basedir: basedir }), + expected, + 'malformed package.json is silently ignored' + ); + if (requireResolveSupportsPaths) { + t.equal( + resolve.sync('./index.js', { basedir: basedir }), + require.resolve('./index.js', { paths: [basedir] }), + 'malformed package.json: resolve.sync === require.resolve' + ); + } + + var res1 = resolve.sync( + './index.js', + { + basedir: basedir, + packageFilter: function (pkg, pkgfile, dir) { + t.fail('should not reach here'); + } + } + ); + + t.equal( + res1, + expected, + 'with packageFilter: malformed package.json is silently ignored' + ); + + var res2 = resolve.sync( + './index.js', + { + basedir: basedir, + readPackageSync: function (readFileSync, pkgfile) { + t.equal(pkgfile, path.join(basedir, 'package.json'), 'readPackageSync: `pkgfile` is package.json path'); + var result = String(readFileSync(pkgfile)); + try { + return JSON.parse(result); + } catch (e) { + t.ok(e instanceof SyntaxError, 'readPackageSync: malformed package.json parses as a syntax error'); + } + } + } + ); + + t.equal( + res2, + expected, + 'with readPackageSync: malformed package.json is silently ignored' + ); +}); diff --git a/node_modules/resolve/test/shadowed_core.js b/node_modules/resolve/test/shadowed_core.js new file mode 100644 index 0000000..3a5f4fc --- /dev/null +++ b/node_modules/resolve/test/shadowed_core.js @@ -0,0 +1,54 @@ +var test = require('tape'); +var resolve = require('../'); +var path = require('path'); + +test('shadowed core modules still return core module', function (t) { + t.plan(2); + + resolve('util', { basedir: path.join(__dirname, 'shadowed_core') }, function (err, res) { + t.ifError(err); + t.equal(res, 'util'); + }); +}); + +test('shadowed core modules still return core module [sync]', function (t) { + t.plan(1); + + var res = resolve.sync('util', { basedir: path.join(__dirname, 'shadowed_core') }); + + t.equal(res, 'util'); +}); + +test('shadowed core modules return shadow when appending `/`', function (t) { + t.plan(2); + + resolve('util/', { basedir: path.join(__dirname, 'shadowed_core') }, function (err, res) { + t.ifError(err); + t.equal(res, path.join(__dirname, 'shadowed_core/node_modules/util/index.js')); + }); +}); + +test('shadowed core modules return shadow when appending `/` [sync]', function (t) { + t.plan(1); + + var res = resolve.sync('util/', { basedir: path.join(__dirname, 'shadowed_core') }); + + t.equal(res, path.join(__dirname, 'shadowed_core/node_modules/util/index.js')); +}); + +test('shadowed core modules return shadow with `includeCoreModules: false`', function (t) { + t.plan(2); + + resolve('util', { basedir: path.join(__dirname, 'shadowed_core'), includeCoreModules: false }, function (err, res) { + t.ifError(err); + t.equal(res, path.join(__dirname, 'shadowed_core/node_modules/util/index.js')); + }); +}); + +test('shadowed core modules return shadow with `includeCoreModules: false` [sync]', function (t) { + t.plan(1); + + var res = resolve.sync('util', { basedir: path.join(__dirname, 'shadowed_core'), includeCoreModules: false }); + + t.equal(res, path.join(__dirname, 'shadowed_core/node_modules/util/index.js')); +}); diff --git a/node_modules/resolve/test/shadowed_core/node_modules/util/index.js b/node_modules/resolve/test/shadowed_core/node_modules/util/index.js new file mode 100644 index 0000000..e69de29 diff --git a/node_modules/resolve/test/subdirs.js b/node_modules/resolve/test/subdirs.js new file mode 100644 index 0000000..b7b8450 --- /dev/null +++ b/node_modules/resolve/test/subdirs.js @@ -0,0 +1,13 @@ +var test = require('tape'); +var resolve = require('../'); +var path = require('path'); + +test('subdirs', function (t) { + t.plan(2); + + var dir = path.join(__dirname, '/subdirs'); + resolve('a/b/c/x.json', { basedir: dir }, function (err, res) { + t.ifError(err); + t.equal(res, path.join(dir, 'node_modules/a/b/c/x.json')); + }); +}); diff --git a/node_modules/resolve/test/symlinks.js b/node_modules/resolve/test/symlinks.js new file mode 100644 index 0000000..35f881a --- /dev/null +++ b/node_modules/resolve/test/symlinks.js @@ -0,0 +1,176 @@ +var path = require('path'); +var fs = require('fs'); +var test = require('tape'); +var map = require('array.prototype.map'); +var resolve = require('../'); + +var symlinkDir = path.join(__dirname, 'resolver', 'symlinked', 'symlink'); +var packageDir = path.join(__dirname, 'resolver', 'symlinked', '_', 'node_modules', 'package'); +var modADir = path.join(__dirname, 'symlinks', 'source', 'node_modules', 'mod-a'); +var symlinkModADir = path.join(__dirname, 'symlinks', 'dest', 'node_modules', 'mod-a'); +try { + fs.unlinkSync(symlinkDir); +} catch (err) {} +try { + fs.unlinkSync(packageDir); +} catch (err) {} +try { + fs.unlinkSync(modADir); +} catch (err) {} +try { + fs.unlinkSync(symlinkModADir); +} catch (err) {} + +try { + fs.symlinkSync('./_/symlink_target', symlinkDir, 'dir'); +} catch (err) { + // if fails then it is probably on Windows and lets try to create a junction + fs.symlinkSync(path.join(__dirname, 'resolver', 'symlinked', '_', 'symlink_target') + '\\', symlinkDir, 'junction'); +} +try { + fs.symlinkSync('../../package', packageDir, 'dir'); +} catch (err) { + // if fails then it is probably on Windows and lets try to create a junction + fs.symlinkSync(path.join(__dirname, '..', '..', 'package') + '\\', packageDir, 'junction'); +} +try { + fs.symlinkSync('../../source/node_modules/mod-a', symlinkModADir, 'dir'); +} catch (err) { + // if fails then it is probably on Windows and lets try to create a junction + fs.symlinkSync(path.join(__dirname, '..', '..', 'source', 'node_modules', 'mod-a') + '\\', symlinkModADir, 'junction'); +} + +test('symlink', function (t) { + t.plan(2); + + resolve('foo', { basedir: symlinkDir, preserveSymlinks: false }, function (err, res, pkg) { + t.error(err); + t.equal(res, path.join(__dirname, 'resolver', 'symlinked', '_', 'node_modules', 'foo.js')); + }); +}); + +test('sync symlink when preserveSymlinks = true', function (t) { + t.plan(4); + + resolve('foo', { basedir: symlinkDir }, function (err, res, pkg) { + t.ok(err, 'there is an error'); + t.notOk(res, 'no result'); + + t.equal(err && err.code, 'MODULE_NOT_FOUND', 'error code matches require.resolve'); + t.equal( + err && err.message, + 'Cannot find module \'foo\' from \'' + symlinkDir + '\'', + 'can not find nonexistent module' + ); + }); +}); + +test('sync symlink', function (t) { + var start = new Date(); + t.doesNotThrow(function () { + t.equal( + resolve.sync('foo', { basedir: symlinkDir, preserveSymlinks: false }), + path.join(__dirname, 'resolver', 'symlinked', '_', 'node_modules', 'foo.js') + ); + }); + t.ok(new Date() - start < 50, 'resolve.sync timedout'); + t.end(); +}); + +test('sync symlink when preserveSymlinks = true', function (t) { + t.throws(function () { + resolve.sync('foo', { basedir: symlinkDir }); + }, /Cannot find module 'foo'/); + t.end(); +}); + +test('sync symlink from node_modules to other dir when preserveSymlinks = false', function (t) { + var basedir = path.join(__dirname, 'resolver', 'symlinked', '_'); + var fn = resolve.sync('package', { basedir: basedir, preserveSymlinks: false }); + + t.equal(fn, path.resolve(__dirname, 'resolver/symlinked/package/bar.js')); + t.end(); +}); + +test('async symlink from node_modules to other dir when preserveSymlinks = false', function (t) { + t.plan(2); + var basedir = path.join(__dirname, 'resolver', 'symlinked', '_'); + resolve('package', { basedir: basedir, preserveSymlinks: false }, function (err, result) { + t.notOk(err, 'no error'); + t.equal(result, path.resolve(__dirname, 'resolver/symlinked/package/bar.js')); + }); +}); + +test('packageFilter', function (t) { + function relative(x) { + return path.relative(__dirname, x); + } + + function testPackageFilter(preserveSymlinks) { + return function (st) { + st.plan('is 1.x' ? 3 : 5); // eslint-disable-line no-constant-condition + + var destMain = 'symlinks/dest/node_modules/mod-a/index.js'; + var destPkg = 'symlinks/dest/node_modules/mod-a/package.json'; + var sourceMain = 'symlinks/source/node_modules/mod-a/index.js'; + var sourcePkg = 'symlinks/source/node_modules/mod-a/package.json'; + var destDir = path.join(__dirname, 'symlinks', 'dest'); + + /* eslint multiline-comment-style: 0 */ + /* v2.x will restore these tests + var packageFilterPath = []; + var actualPath = resolve.sync('mod-a', { + basedir: destDir, + preserveSymlinks: preserveSymlinks, + packageFilter: function (pkg, pkgfile, dir) { + packageFilterPath.push(pkgfile); + } + }); + st.equal( + relative(actualPath), + path.normalize(preserveSymlinks ? destMain : sourceMain), + 'sync: actual path is correct' + ); + st.deepEqual( + map(packageFilterPath, relative), + map(preserveSymlinks ? [destPkg, destPkg] : [sourcePkg, sourcePkg], path.normalize), + 'sync: packageFilter pkgfile arg is correct' + ); + */ + + var asyncPackageFilterPath = []; + resolve( + 'mod-a', + { + basedir: destDir, + preserveSymlinks: preserveSymlinks, + packageFilter: function (pkg, pkgfile) { + asyncPackageFilterPath.push(pkgfile); + } + }, + function (err, actualPath) { + st.error(err, 'no error'); + st.equal( + relative(actualPath), + path.normalize(preserveSymlinks ? destMain : sourceMain), + 'async: actual path is correct' + ); + st.deepEqual( + map(asyncPackageFilterPath, relative), + map( + preserveSymlinks ? [destPkg, destPkg, destPkg] : [sourcePkg, sourcePkg, sourcePkg], + path.normalize + ), + 'async: packageFilter pkgfile arg is correct' + ); + } + ); + }; + } + + t.test('preserveSymlinks: false', testPackageFilter(false)); + + t.test('preserveSymlinks: true', testPackageFilter(true)); + + t.end(); +}); diff --git a/node_modules/reusify/.coveralls.yml b/node_modules/reusify/.coveralls.yml new file mode 100644 index 0000000..359f683 --- /dev/null +++ b/node_modules/reusify/.coveralls.yml @@ -0,0 +1 @@ +repo_token: yIxhFqtaaz5iGVYfie9mODehFYogm8S8L diff --git a/node_modules/reusify/.travis.yml b/node_modules/reusify/.travis.yml new file mode 100644 index 0000000..1970476 --- /dev/null +++ b/node_modules/reusify/.travis.yml @@ -0,0 +1,28 @@ +language: node_js +sudo: false + +node_js: + - 9 + - 8 + - 7 + - 6 + - 5 + - 4 + - 4.0 + - iojs-v3 + - iojs-v2 + - iojs-v1 + - 0.12 + - 0.10 + +cache: + directories: + - node_modules + +after_script: +- npm run coverage + +notifications: + email: + on_success: never + on_failure: always diff --git a/node_modules/reusify/LICENSE b/node_modules/reusify/LICENSE new file mode 100644 index 0000000..fbf3a01 --- /dev/null +++ b/node_modules/reusify/LICENSE @@ -0,0 +1,22 @@ +The MIT License (MIT) + +Copyright (c) 2015 Matteo Collina + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + diff --git a/node_modules/reusify/README.md b/node_modules/reusify/README.md new file mode 100644 index 0000000..badcb7c --- /dev/null +++ b/node_modules/reusify/README.md @@ -0,0 +1,145 @@ +# reusify + +[![npm version][npm-badge]][npm-url] +[![Build Status][travis-badge]][travis-url] +[![Coverage Status][coveralls-badge]][coveralls-url] + +Reuse your objects and functions for maximum speed. This technique will +make any function run ~10% faster. You call your functions a +lot, and it adds up quickly in hot code paths. + +``` +$ node benchmarks/createNoCodeFunction.js +Total time 53133 +Total iterations 100000000 +Iteration/s 1882069.5236482036 + +$ node benchmarks/reuseNoCodeFunction.js +Total time 50617 +Total iterations 100000000 +Iteration/s 1975620.838848608 +``` + +The above benchmark uses fibonacci to simulate a real high-cpu load. +The actual numbers might differ for your use case, but the difference +should not. + +The benchmark was taken using Node v6.10.0. + +This library was extracted from +[fastparallel](http://npm.im/fastparallel). + +## Example + +```js +var reusify = require('reusify') +var fib = require('reusify/benchmarks/fib') +var instance = reusify(MyObject) + +// get an object from the cache, +// or creates a new one when cache is empty +var obj = instance.get() + +// set the state +obj.num = 100 +obj.func() + +// reset the state. +// if the state contains any external object +// do not use delete operator (it is slow) +// prefer set them to null +obj.num = 0 + +// store an object in the cache +instance.release(obj) + +function MyObject () { + // you need to define this property + // so V8 can compile MyObject into an + // hidden class + this.next = null + this.num = 0 + + var that = this + + // this function is never reallocated, + // so it can be optimized by V8 + this.func = function () { + if (null) { + // do nothing + } else { + // calculates fibonacci + fib(that.num) + } + } +} +``` + +The above example was intended for synchronous code, let's see async: +```js +var reusify = require('reusify') +var instance = reusify(MyObject) + +for (var i = 0; i < 100; i++) { + getData(i, console.log) +} + +function getData (value, cb) { + var obj = instance.get() + + obj.value = value + obj.cb = cb + obj.run() +} + +function MyObject () { + this.next = null + this.value = null + + var that = this + + this.run = function () { + asyncOperation(that.value, that.handle) + } + + this.handle = function (err, result) { + that.cb(err, result) + that.value = null + that.cb = null + instance.release(that) + } +} +``` + +Also note how in the above examples, the code, that consumes an istance of `MyObject`, +reset the state to initial condition, just before storing it in the cache. +That's needed so that every subsequent request for an instance from the cache, +could get a clean instance. + +## Why + +It is faster because V8 doesn't have to collect all the functions you +create. On a short-lived benchmark, it is as fast as creating the +nested function, but on a longer time frame it creates less +pressure on the garbage collector. + +## Other examples +If you want to see some complex example, checkout [middie](https://github.com/fastify/middie) and [steed](https://github.com/mcollina/steed). + +## Acknowledgements + +Thanks to [Trevor Norris](https://github.com/trevnorris) for +getting me down the rabbit hole of performance, and thanks to [Mathias +Buss](http://github.com/mafintosh) for suggesting me to share this +trick. + +## License + +MIT + +[npm-badge]: https://badge.fury.io/js/reusify.svg +[npm-url]: https://badge.fury.io/js/reusify +[travis-badge]: https://api.travis-ci.org/mcollina/reusify.svg +[travis-url]: https://travis-ci.org/mcollina/reusify +[coveralls-badge]: https://coveralls.io/repos/mcollina/reusify/badge.svg?branch=master&service=github +[coveralls-url]: https://coveralls.io/github/mcollina/reusify?branch=master diff --git a/node_modules/reusify/benchmarks/createNoCodeFunction.js b/node_modules/reusify/benchmarks/createNoCodeFunction.js new file mode 100644 index 0000000..ce1aac7 --- /dev/null +++ b/node_modules/reusify/benchmarks/createNoCodeFunction.js @@ -0,0 +1,30 @@ +'use strict' + +var fib = require('./fib') +var max = 100000000 +var start = Date.now() + +// create a funcion with the typical error +// pattern, that delegates the heavy load +// to something else +function createNoCodeFunction () { + /* eslint no-constant-condition: "off" */ + var num = 100 + + ;(function () { + if (null) { + // do nothing + } else { + fib(num) + } + })() +} + +for (var i = 0; i < max; i++) { + createNoCodeFunction() +} + +var time = Date.now() - start +console.log('Total time', time) +console.log('Total iterations', max) +console.log('Iteration/s', max / time * 1000) diff --git a/node_modules/reusify/benchmarks/fib.js b/node_modules/reusify/benchmarks/fib.js new file mode 100644 index 0000000..e22cc48 --- /dev/null +++ b/node_modules/reusify/benchmarks/fib.js @@ -0,0 +1,13 @@ +'use strict' + +function fib (num) { + var fib = [] + + fib[0] = 0 + fib[1] = 1 + for (var i = 2; i <= num; i++) { + fib[i] = fib[i - 2] + fib[i - 1] + } +} + +module.exports = fib diff --git a/node_modules/reusify/benchmarks/reuseNoCodeFunction.js b/node_modules/reusify/benchmarks/reuseNoCodeFunction.js new file mode 100644 index 0000000..3358d6e --- /dev/null +++ b/node_modules/reusify/benchmarks/reuseNoCodeFunction.js @@ -0,0 +1,38 @@ +'use strict' + +var reusify = require('../') +var fib = require('./fib') +var instance = reusify(MyObject) +var max = 100000000 +var start = Date.now() + +function reuseNoCodeFunction () { + var obj = instance.get() + obj.num = 100 + obj.func() + obj.num = 0 + instance.release(obj) +} + +function MyObject () { + this.next = null + var that = this + this.num = 0 + this.func = function () { + /* eslint no-constant-condition: "off" */ + if (null) { + // do nothing + } else { + fib(that.num) + } + } +} + +for (var i = 0; i < max; i++) { + reuseNoCodeFunction() +} + +var time = Date.now() - start +console.log('Total time', time) +console.log('Total iterations', max) +console.log('Iteration/s', max / time * 1000) diff --git a/node_modules/reusify/package.json b/node_modules/reusify/package.json new file mode 100644 index 0000000..ee66aee --- /dev/null +++ b/node_modules/reusify/package.json @@ -0,0 +1,45 @@ +{ + "name": "reusify", + "version": "1.0.4", + "description": "Reuse objects and functions with style", + "main": "reusify.js", + "scripts": { + "lint": "standard", + "test": "tape test.js | faucet", + "istanbul": "istanbul cover tape test.js", + "coverage": "npm run istanbul; cat coverage/lcov.info | coveralls" + }, + "pre-commit": [ + "lint", + "test" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/mcollina/reusify.git" + }, + "keywords": [ + "reuse", + "object", + "performance", + "function", + "fast" + ], + "author": "Matteo Collina ", + "license": "MIT", + "bugs": { + "url": "https://github.com/mcollina/reusify/issues" + }, + "homepage": "https://github.com/mcollina/reusify#readme", + "engines": { + "node": ">=0.10.0", + "iojs": ">=1.0.0" + }, + "devDependencies": { + "coveralls": "^2.13.3", + "faucet": "0.0.1", + "istanbul": "^0.4.5", + "pre-commit": "^1.2.2", + "standard": "^10.0.3", + "tape": "^4.8.0" + } +} diff --git a/node_modules/reusify/reusify.js b/node_modules/reusify/reusify.js new file mode 100644 index 0000000..e6f36f3 --- /dev/null +++ b/node_modules/reusify/reusify.js @@ -0,0 +1,33 @@ +'use strict' + +function reusify (Constructor) { + var head = new Constructor() + var tail = head + + function get () { + var current = head + + if (current.next) { + head = current.next + } else { + head = new Constructor() + tail = head + } + + current.next = null + + return current + } + + function release (obj) { + tail.next = obj + tail = obj + } + + return { + get: get, + release: release + } +} + +module.exports = reusify diff --git a/node_modules/reusify/test.js b/node_modules/reusify/test.js new file mode 100644 index 0000000..929cfd7 --- /dev/null +++ b/node_modules/reusify/test.js @@ -0,0 +1,66 @@ +'use strict' + +var test = require('tape') +var reusify = require('./') + +test('reuse objects', function (t) { + t.plan(6) + + function MyObject () { + t.pass('constructor called') + this.next = null + } + + var instance = reusify(MyObject) + var obj = instance.get() + + t.notEqual(obj, instance.get(), 'two instance created') + t.notOk(obj.next, 'next must be null') + + instance.release(obj) + + // the internals keeps a hot copy ready for reuse + // putting this one back in the queue + instance.release(instance.get()) + + // comparing the old one with the one we got + // never do this in real code, after release you + // should never reuse that instance + t.equal(obj, instance.get(), 'instance must be reused') +}) + +test('reuse more than 2 objects', function (t) { + function MyObject () { + t.pass('constructor called') + this.next = null + } + + var instance = reusify(MyObject) + var obj = instance.get() + var obj2 = instance.get() + var obj3 = instance.get() + + t.notOk(obj.next, 'next must be null') + t.notOk(obj2.next, 'next must be null') + t.notOk(obj3.next, 'next must be null') + + t.notEqual(obj, obj2) + t.notEqual(obj, obj3) + t.notEqual(obj3, obj2) + + instance.release(obj) + instance.release(obj2) + instance.release(obj3) + + // skip one + instance.get() + + var obj4 = instance.get() + var obj5 = instance.get() + var obj6 = instance.get() + + t.equal(obj4, obj) + t.equal(obj5, obj2) + t.equal(obj6, obj3) + t.end() +}) diff --git a/node_modules/run-parallel/LICENSE b/node_modules/run-parallel/LICENSE new file mode 100644 index 0000000..c7e6852 --- /dev/null +++ b/node_modules/run-parallel/LICENSE @@ -0,0 +1,20 @@ +The MIT License (MIT) + +Copyright (c) Feross Aboukhadijeh + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of +the Software, and to permit persons to whom the Software is furnished to do so, +subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR +COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER +IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/node_modules/run-parallel/README.md b/node_modules/run-parallel/README.md new file mode 100644 index 0000000..edc3da4 --- /dev/null +++ b/node_modules/run-parallel/README.md @@ -0,0 +1,85 @@ +# run-parallel [![travis][travis-image]][travis-url] [![npm][npm-image]][npm-url] [![downloads][downloads-image]][downloads-url] [![javascript style guide][standard-image]][standard-url] + +[travis-image]: https://img.shields.io/travis/feross/run-parallel/master.svg +[travis-url]: https://travis-ci.org/feross/run-parallel +[npm-image]: https://img.shields.io/npm/v/run-parallel.svg +[npm-url]: https://npmjs.org/package/run-parallel +[downloads-image]: https://img.shields.io/npm/dm/run-parallel.svg +[downloads-url]: https://npmjs.org/package/run-parallel +[standard-image]: https://img.shields.io/badge/code_style-standard-brightgreen.svg +[standard-url]: https://standardjs.com + +### Run an array of functions in parallel + +![parallel](https://raw.githubusercontent.com/feross/run-parallel/master/img.png) [![Sauce Test Status](https://saucelabs.com/browser-matrix/run-parallel.svg)](https://saucelabs.com/u/run-parallel) + +### install + +``` +npm install run-parallel +``` + +### usage + +#### parallel(tasks, [callback]) + +Run the `tasks` array of functions in parallel, without waiting until the previous +function has completed. If any of the functions pass an error to its callback, the main +`callback` is immediately called with the value of the error. Once the `tasks` have +completed, the results are passed to the final `callback` as an array. + +It is also possible to use an object instead of an array. Each property will be run as a +function and the results will be passed to the final `callback` as an object instead of +an array. This can be a more readable way of handling the results. + +##### arguments + +- `tasks` - An array or object containing functions to run. Each function is passed a +`callback(err, result)` which it must call on completion with an error `err` (which can +be `null`) and an optional `result` value. +- `callback(err, results)` - An optional callback to run once all the functions have +completed. This function gets a results array (or object) containing all the result +arguments passed to the task callbacks. + +##### example + +```js +var parallel = require('run-parallel') + +parallel([ + function (callback) { + setTimeout(function () { + callback(null, 'one') + }, 200) + }, + function (callback) { + setTimeout(function () { + callback(null, 'two') + }, 100) + } +], +// optional callback +function (err, results) { + // the results array will equal ['one','two'] even though + // the second function had a shorter timeout. +}) +``` + +This module is basically equavalent to +[`async.parallel`](https://github.com/caolan/async#paralleltasks-callback), but it's +handy to just have the one function you need instead of the kitchen sink. Modularity! +Especially handy if you're serving to the browser and need to reduce your javascript +bundle size. + +Works great in the browser with [browserify](http://browserify.org/)! + +### see also + +- [run-auto](https://github.com/feross/run-auto) +- [run-parallel-limit](https://github.com/feross/run-parallel-limit) +- [run-series](https://github.com/feross/run-series) +- [run-waterfall](https://github.com/feross/run-waterfall) + +### license + +MIT. Copyright (c) [Feross Aboukhadijeh](http://feross.org). diff --git a/node_modules/run-parallel/index.js b/node_modules/run-parallel/index.js new file mode 100644 index 0000000..6307141 --- /dev/null +++ b/node_modules/run-parallel/index.js @@ -0,0 +1,51 @@ +/*! run-parallel. MIT License. Feross Aboukhadijeh */ +module.exports = runParallel + +const queueMicrotask = require('queue-microtask') + +function runParallel (tasks, cb) { + let results, pending, keys + let isSync = true + + if (Array.isArray(tasks)) { + results = [] + pending = tasks.length + } else { + keys = Object.keys(tasks) + results = {} + pending = keys.length + } + + function done (err) { + function end () { + if (cb) cb(err, results) + cb = null + } + if (isSync) queueMicrotask(end) + else end() + } + + function each (i, err, result) { + results[i] = result + if (--pending === 0 || err) { + done(err) + } + } + + if (!pending) { + // empty + done(null) + } else if (keys) { + // object + keys.forEach(function (key) { + tasks[key](function (err, result) { each(key, err, result) }) + }) + } else { + // array + tasks.forEach(function (task, i) { + task(function (err, result) { each(i, err, result) }) + }) + } + + isSync = false +} diff --git a/node_modules/run-parallel/package.json b/node_modules/run-parallel/package.json new file mode 100644 index 0000000..1f14757 --- /dev/null +++ b/node_modules/run-parallel/package.json @@ -0,0 +1,58 @@ +{ + "name": "run-parallel", + "description": "Run an array of functions in parallel", + "version": "1.2.0", + "author": { + "name": "Feross Aboukhadijeh", + "email": "feross@feross.org", + "url": "https://feross.org" + }, + "bugs": { + "url": "https://github.com/feross/run-parallel/issues" + }, + "dependencies": { + "queue-microtask": "^1.2.2" + }, + "devDependencies": { + "airtap": "^3.0.0", + "standard": "*", + "tape": "^5.0.1" + }, + "homepage": "https://github.com/feross/run-parallel", + "keywords": [ + "parallel", + "async", + "function", + "callback", + "asynchronous", + "run", + "array", + "run parallel" + ], + "license": "MIT", + "main": "index.js", + "repository": { + "type": "git", + "url": "git://github.com/feross/run-parallel.git" + }, + "scripts": { + "test": "standard && npm run test-node && npm run test-browser", + "test-browser": "airtap -- test/*.js", + "test-browser-local": "airtap --local -- test/*.js", + "test-node": "tape test/*.js" + }, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] +} diff --git a/node_modules/source-map-js/LICENSE b/node_modules/source-map-js/LICENSE new file mode 100644 index 0000000..ed1b7cf --- /dev/null +++ b/node_modules/source-map-js/LICENSE @@ -0,0 +1,28 @@ + +Copyright (c) 2009-2011, Mozilla Foundation and contributors +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +* Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +* Neither the names of the Mozilla Foundation nor the names of project + contributors may be used to endorse or promote products derived from this + software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/node_modules/source-map-js/README.md b/node_modules/source-map-js/README.md new file mode 100644 index 0000000..614962d --- /dev/null +++ b/node_modules/source-map-js/README.md @@ -0,0 +1,765 @@ +# Source Map JS + +[![NPM](https://nodei.co/npm/source-map-js.png?downloads=true&downloadRank=true)](https://www.npmjs.com/package/source-map-js) + +Difference between original [source-map](https://github.com/mozilla/source-map): + +> TL,DR: it's fork of original source-map@0.6, but with perfomance optimizations. + +This journey starts from [source-map@0.7.0](https://github.com/mozilla/source-map/blob/master/CHANGELOG.md#070). Some part of it was rewritten to Rust and WASM and API became async. + +It's still a major block for many libraries like PostCSS or Sass for example because they need to migrate the whole API to the async way. This is the reason why 0.6.1 has 2x more downloads than 0.7.3 while it's faster several times. + +![Downloads count](media/downloads.png) + +More important that WASM version has some optimizations in JS code too. This is why [community asked to create branch for 0.6 version](https://github.com/mozilla/source-map/issues/324) and port these optimizations but, sadly, the answer was «no». A bit later I discovered [the issue](https://github.com/mozilla/source-map/issues/370) created by [Ben Rothman (@benthemonkey)](https://github.com/benthemonkey) with no response at all. + +[Roman Dvornov (@lahmatiy)](https://github.com/lahmatiy) wrote a [serveral posts](https://t.me/gorshochekvarit/76) (russian, only, sorry) about source-map library in his own Telegram channel. He mentioned the article [«Maybe you don't need Rust and WASM to speed up your JS»](https://mrale.ph/blog/2018/02/03/maybe-you-dont-need-rust-to-speed-up-your-js.html) written by [Vyacheslav Egorov (@mraleph)](https://github.com/mraleph). This article contains optimizations and hacks that lead to almost the same performance compare to WASM implementation. + +I decided to fork the original source-map and port these optimizations from the article and several others PR from the original source-map. + +--------- + +This is a library to generate and consume the source map format +[described here][format]. + +[format]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit + +## Use with Node + + $ npm install source-map-js + + + +-------------------------------------------------------------------------------- + + + + + +## Table of Contents + +- [Examples](#examples) + - [Consuming a source map](#consuming-a-source-map) + - [Generating a source map](#generating-a-source-map) + - [With SourceNode (high level API)](#with-sourcenode-high-level-api) + - [With SourceMapGenerator (low level API)](#with-sourcemapgenerator-low-level-api) +- [API](#api) + - [SourceMapConsumer](#sourcemapconsumer) + - [new SourceMapConsumer(rawSourceMap)](#new-sourcemapconsumerrawsourcemap) + - [SourceMapConsumer.prototype.computeColumnSpans()](#sourcemapconsumerprototypecomputecolumnspans) + - [SourceMapConsumer.prototype.originalPositionFor(generatedPosition)](#sourcemapconsumerprototypeoriginalpositionforgeneratedposition) + - [SourceMapConsumer.prototype.generatedPositionFor(originalPosition)](#sourcemapconsumerprototypegeneratedpositionfororiginalposition) + - [SourceMapConsumer.prototype.allGeneratedPositionsFor(originalPosition)](#sourcemapconsumerprototypeallgeneratedpositionsfororiginalposition) + - [SourceMapConsumer.prototype.hasContentsOfAllSources()](#sourcemapconsumerprototypehascontentsofallsources) + - [SourceMapConsumer.prototype.sourceContentFor(source[, returnNullOnMissing])](#sourcemapconsumerprototypesourcecontentforsource-returnnullonmissing) + - [SourceMapConsumer.prototype.eachMapping(callback, context, order)](#sourcemapconsumerprototypeeachmappingcallback-context-order) + - [SourceMapGenerator](#sourcemapgenerator) + - [new SourceMapGenerator([startOfSourceMap])](#new-sourcemapgeneratorstartofsourcemap) + - [SourceMapGenerator.fromSourceMap(sourceMapConsumer)](#sourcemapgeneratorfromsourcemapsourcemapconsumer) + - [SourceMapGenerator.prototype.addMapping(mapping)](#sourcemapgeneratorprototypeaddmappingmapping) + - [SourceMapGenerator.prototype.setSourceContent(sourceFile, sourceContent)](#sourcemapgeneratorprototypesetsourcecontentsourcefile-sourcecontent) + - [SourceMapGenerator.prototype.applySourceMap(sourceMapConsumer[, sourceFile[, sourceMapPath]])](#sourcemapgeneratorprototypeapplysourcemapsourcemapconsumer-sourcefile-sourcemappath) + - [SourceMapGenerator.prototype.toString()](#sourcemapgeneratorprototypetostring) + - [SourceNode](#sourcenode) + - [new SourceNode([line, column, source[, chunk[, name]]])](#new-sourcenodeline-column-source-chunk-name) + - [SourceNode.fromStringWithSourceMap(code, sourceMapConsumer[, relativePath])](#sourcenodefromstringwithsourcemapcode-sourcemapconsumer-relativepath) + - [SourceNode.prototype.add(chunk)](#sourcenodeprototypeaddchunk) + - [SourceNode.prototype.prepend(chunk)](#sourcenodeprototypeprependchunk) + - [SourceNode.prototype.setSourceContent(sourceFile, sourceContent)](#sourcenodeprototypesetsourcecontentsourcefile-sourcecontent) + - [SourceNode.prototype.walk(fn)](#sourcenodeprototypewalkfn) + - [SourceNode.prototype.walkSourceContents(fn)](#sourcenodeprototypewalksourcecontentsfn) + - [SourceNode.prototype.join(sep)](#sourcenodeprototypejoinsep) + - [SourceNode.prototype.replaceRight(pattern, replacement)](#sourcenodeprototypereplacerightpattern-replacement) + - [SourceNode.prototype.toString()](#sourcenodeprototypetostring) + - [SourceNode.prototype.toStringWithSourceMap([startOfSourceMap])](#sourcenodeprototypetostringwithsourcemapstartofsourcemap) + + + +## Examples + +### Consuming a source map + +```js +var rawSourceMap = { + version: 3, + file: 'min.js', + names: ['bar', 'baz', 'n'], + sources: ['one.js', 'two.js'], + sourceRoot: 'http://example.com/www/js/', + mappings: 'CAAC,IAAI,IAAM,SAAUA,GAClB,OAAOC,IAAID;CCDb,IAAI,IAAM,SAAUE,GAClB,OAAOA' +}; + +var smc = new SourceMapConsumer(rawSourceMap); + +console.log(smc.sources); +// [ 'http://example.com/www/js/one.js', +// 'http://example.com/www/js/two.js' ] + +console.log(smc.originalPositionFor({ + line: 2, + column: 28 +})); +// { source: 'http://example.com/www/js/two.js', +// line: 2, +// column: 10, +// name: 'n' } + +console.log(smc.generatedPositionFor({ + source: 'http://example.com/www/js/two.js', + line: 2, + column: 10 +})); +// { line: 2, column: 28 } + +smc.eachMapping(function (m) { + // ... +}); +``` + +### Generating a source map + +In depth guide: +[**Compiling to JavaScript, and Debugging with Source Maps**](https://hacks.mozilla.org/2013/05/compiling-to-javascript-and-debugging-with-source-maps/) + +#### With SourceNode (high level API) + +```js +function compile(ast) { + switch (ast.type) { + case 'BinaryExpression': + return new SourceNode( + ast.location.line, + ast.location.column, + ast.location.source, + [compile(ast.left), " + ", compile(ast.right)] + ); + case 'Literal': + return new SourceNode( + ast.location.line, + ast.location.column, + ast.location.source, + String(ast.value) + ); + // ... + default: + throw new Error("Bad AST"); + } +} + +var ast = parse("40 + 2", "add.js"); +console.log(compile(ast).toStringWithSourceMap({ + file: 'add.js' +})); +// { code: '40 + 2', +// map: [object SourceMapGenerator] } +``` + +#### With SourceMapGenerator (low level API) + +```js +var map = new SourceMapGenerator({ + file: "source-mapped.js" +}); + +map.addMapping({ + generated: { + line: 10, + column: 35 + }, + source: "foo.js", + original: { + line: 33, + column: 2 + }, + name: "christopher" +}); + +console.log(map.toString()); +// '{"version":3,"file":"source-mapped.js","sources":["foo.js"],"names":["christopher"],"mappings":";;;;;;;;;mCAgCEA"}' +``` + +## API + +Get a reference to the module: + +```js +// Node.js +var sourceMap = require('source-map'); + +// Browser builds +var sourceMap = window.sourceMap; + +// Inside Firefox +const sourceMap = require("devtools/toolkit/sourcemap/source-map.js"); +``` + +### SourceMapConsumer + +A SourceMapConsumer instance represents a parsed source map which we can query +for information about the original file positions by giving it a file position +in the generated source. + +#### new SourceMapConsumer(rawSourceMap) + +The only parameter is the raw source map (either as a string which can be +`JSON.parse`'d, or an object). According to the spec, source maps have the +following attributes: + +* `version`: Which version of the source map spec this map is following. + +* `sources`: An array of URLs to the original source files. + +* `names`: An array of identifiers which can be referenced by individual + mappings. + +* `sourceRoot`: Optional. The URL root from which all sources are relative. + +* `sourcesContent`: Optional. An array of contents of the original source files. + +* `mappings`: A string of base64 VLQs which contain the actual mappings. + +* `file`: Optional. The generated filename this source map is associated with. + +```js +var consumer = new sourceMap.SourceMapConsumer(rawSourceMapJsonData); +``` + +#### SourceMapConsumer.prototype.computeColumnSpans() + +Compute the last column for each generated mapping. The last column is +inclusive. + +```js +// Before: +consumer.allGeneratedPositionsFor({ line: 2, source: "foo.coffee" }) +// [ { line: 2, +// column: 1 }, +// { line: 2, +// column: 10 }, +// { line: 2, +// column: 20 } ] + +consumer.computeColumnSpans(); + +// After: +consumer.allGeneratedPositionsFor({ line: 2, source: "foo.coffee" }) +// [ { line: 2, +// column: 1, +// lastColumn: 9 }, +// { line: 2, +// column: 10, +// lastColumn: 19 }, +// { line: 2, +// column: 20, +// lastColumn: Infinity } ] + +``` + +#### SourceMapConsumer.prototype.originalPositionFor(generatedPosition) + +Returns the original source, line, and column information for the generated +source's line and column positions provided. The only argument is an object with +the following properties: + +* `line`: The line number in the generated source. Line numbers in + this library are 1-based (note that the underlying source map + specification uses 0-based line numbers -- this library handles the + translation). + +* `column`: The column number in the generated source. Column numbers + in this library are 0-based. + +* `bias`: Either `SourceMapConsumer.GREATEST_LOWER_BOUND` or + `SourceMapConsumer.LEAST_UPPER_BOUND`. Specifies whether to return the closest + element that is smaller than or greater than the one we are searching for, + respectively, if the exact element cannot be found. Defaults to + `SourceMapConsumer.GREATEST_LOWER_BOUND`. + +and an object is returned with the following properties: + +* `source`: The original source file, or null if this information is not + available. + +* `line`: The line number in the original source, or null if this information is + not available. The line number is 1-based. + +* `column`: The column number in the original source, or null if this + information is not available. The column number is 0-based. + +* `name`: The original identifier, or null if this information is not available. + +```js +consumer.originalPositionFor({ line: 2, column: 10 }) +// { source: 'foo.coffee', +// line: 2, +// column: 2, +// name: null } + +consumer.originalPositionFor({ line: 99999999999999999, column: 999999999999999 }) +// { source: null, +// line: null, +// column: null, +// name: null } +``` + +#### SourceMapConsumer.prototype.generatedPositionFor(originalPosition) + +Returns the generated line and column information for the original source, +line, and column positions provided. The only argument is an object with +the following properties: + +* `source`: The filename of the original source. + +* `line`: The line number in the original source. The line number is + 1-based. + +* `column`: The column number in the original source. The column + number is 0-based. + +and an object is returned with the following properties: + +* `line`: The line number in the generated source, or null. The line + number is 1-based. + +* `column`: The column number in the generated source, or null. The + column number is 0-based. + +```js +consumer.generatedPositionFor({ source: "example.js", line: 2, column: 10 }) +// { line: 1, +// column: 56 } +``` + +#### SourceMapConsumer.prototype.allGeneratedPositionsFor(originalPosition) + +Returns all generated line and column information for the original source, line, +and column provided. If no column is provided, returns all mappings +corresponding to a either the line we are searching for or the next closest line +that has any mappings. Otherwise, returns all mappings corresponding to the +given line and either the column we are searching for or the next closest column +that has any offsets. + +The only argument is an object with the following properties: + +* `source`: The filename of the original source. + +* `line`: The line number in the original source. The line number is + 1-based. + +* `column`: Optional. The column number in the original source. The + column number is 0-based. + +and an array of objects is returned, each with the following properties: + +* `line`: The line number in the generated source, or null. The line + number is 1-based. + +* `column`: The column number in the generated source, or null. The + column number is 0-based. + +```js +consumer.allGeneratedpositionsfor({ line: 2, source: "foo.coffee" }) +// [ { line: 2, +// column: 1 }, +// { line: 2, +// column: 10 }, +// { line: 2, +// column: 20 } ] +``` + +#### SourceMapConsumer.prototype.hasContentsOfAllSources() + +Return true if we have the embedded source content for every source listed in +the source map, false otherwise. + +In other words, if this method returns `true`, then +`consumer.sourceContentFor(s)` will succeed for every source `s` in +`consumer.sources`. + +```js +// ... +if (consumer.hasContentsOfAllSources()) { + consumerReadyCallback(consumer); +} else { + fetchSources(consumer, consumerReadyCallback); +} +// ... +``` + +#### SourceMapConsumer.prototype.sourceContentFor(source[, returnNullOnMissing]) + +Returns the original source content for the source provided. The only +argument is the URL of the original source file. + +If the source content for the given source is not found, then an error is +thrown. Optionally, pass `true` as the second param to have `null` returned +instead. + +```js +consumer.sources +// [ "my-cool-lib.clj" ] + +consumer.sourceContentFor("my-cool-lib.clj") +// "..." + +consumer.sourceContentFor("this is not in the source map"); +// Error: "this is not in the source map" is not in the source map + +consumer.sourceContentFor("this is not in the source map", true); +// null +``` + +#### SourceMapConsumer.prototype.eachMapping(callback, context, order) + +Iterate over each mapping between an original source/line/column and a +generated line/column in this source map. + +* `callback`: The function that is called with each mapping. Mappings have the + form `{ source, generatedLine, generatedColumn, originalLine, originalColumn, + name }` + +* `context`: Optional. If specified, this object will be the value of `this` + every time that `callback` is called. + +* `order`: Either `SourceMapConsumer.GENERATED_ORDER` or + `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to iterate over + the mappings sorted by the generated file's line/column order or the + original's source/line/column order, respectively. Defaults to + `SourceMapConsumer.GENERATED_ORDER`. + +```js +consumer.eachMapping(function (m) { console.log(m); }) +// ... +// { source: 'illmatic.js', +// generatedLine: 1, +// generatedColumn: 0, +// originalLine: 1, +// originalColumn: 0, +// name: null } +// { source: 'illmatic.js', +// generatedLine: 2, +// generatedColumn: 0, +// originalLine: 2, +// originalColumn: 0, +// name: null } +// ... +``` +### SourceMapGenerator + +An instance of the SourceMapGenerator represents a source map which is being +built incrementally. + +#### new SourceMapGenerator([startOfSourceMap]) + +You may pass an object with the following properties: + +* `file`: The filename of the generated source that this source map is + associated with. + +* `sourceRoot`: A root for all relative URLs in this source map. + +* `skipValidation`: Optional. When `true`, disables validation of mappings as + they are added. This can improve performance but should be used with + discretion, as a last resort. Even then, one should avoid using this flag when + running tests, if possible. + +* `ignoreInvalidMapping`: Optional. When `true`, instead of throwing error on + invalid mapping, it will be ignored. + +```js +var generator = new sourceMap.SourceMapGenerator({ + file: "my-generated-javascript-file.js", + sourceRoot: "http://example.com/app/js/" +}); +``` + +#### SourceMapGenerator.fromSourceMap(sourceMapConsumer, sourceMapGeneratorOptions) + +Creates a new `SourceMapGenerator` from an existing `SourceMapConsumer` instance. + +* `sourceMapConsumer` The SourceMap. + +* `sourceMapGeneratorOptions` options that will be passed to the SourceMapGenerator constructor which used under the hood. + +```js +var generator = sourceMap.SourceMapGenerator.fromSourceMap(consumer, { + ignoreInvalidMapping: true, +}); +``` + +#### SourceMapGenerator.prototype.addMapping(mapping) + +Add a single mapping from original source line and column to the generated +source's line and column for this source map being created. The mapping object +should have the following properties: + +* `generated`: An object with the generated line and column positions. + +* `original`: An object with the original line and column positions. + +* `source`: The original source file (relative to the sourceRoot). + +* `name`: An optional original token name for this mapping. + +```js +generator.addMapping({ + source: "module-one.scm", + original: { line: 128, column: 0 }, + generated: { line: 3, column: 456 } +}) +``` + +#### SourceMapGenerator.prototype.setSourceContent(sourceFile, sourceContent) + +Set the source content for an original source file. + +* `sourceFile` the URL of the original source file. + +* `sourceContent` the content of the source file. + +```js +generator.setSourceContent("module-one.scm", + fs.readFileSync("path/to/module-one.scm")) +``` + +#### SourceMapGenerator.prototype.applySourceMap(sourceMapConsumer[, sourceFile[, sourceMapPath]]) + +Applies a SourceMap for a source file to the SourceMap. +Each mapping to the supplied source file is rewritten using the +supplied SourceMap. Note: The resolution for the resulting mappings +is the minimum of this map and the supplied map. + +* `sourceMapConsumer`: The SourceMap to be applied. + +* `sourceFile`: Optional. The filename of the source file. + If omitted, sourceMapConsumer.file will be used, if it exists. + Otherwise an error will be thrown. + +* `sourceMapPath`: Optional. The dirname of the path to the SourceMap + to be applied. If relative, it is relative to the SourceMap. + + This parameter is needed when the two SourceMaps aren't in the same + directory, and the SourceMap to be applied contains relative source + paths. If so, those relative source paths need to be rewritten + relative to the SourceMap. + + If omitted, it is assumed that both SourceMaps are in the same directory, + thus not needing any rewriting. (Supplying `'.'` has the same effect.) + +#### SourceMapGenerator.prototype.toString() + +Renders the source map being generated to a string. + +```js +generator.toString() +// '{"version":3,"sources":["module-one.scm"],"names":[],"mappings":"...snip...","file":"my-generated-javascript-file.js","sourceRoot":"http://example.com/app/js/"}' +``` + +### SourceNode + +SourceNodes provide a way to abstract over interpolating and/or concatenating +snippets of generated JavaScript source code, while maintaining the line and +column information associated between those snippets and the original source +code. This is useful as the final intermediate representation a compiler might +use before outputting the generated JS and source map. + +#### new SourceNode([line, column, source[, chunk[, name]]]) + +* `line`: The original line number associated with this source node, or null if + it isn't associated with an original line. The line number is 1-based. + +* `column`: The original column number associated with this source node, or null + if it isn't associated with an original column. The column number + is 0-based. + +* `source`: The original source's filename; null if no filename is provided. + +* `chunk`: Optional. Is immediately passed to `SourceNode.prototype.add`, see + below. + +* `name`: Optional. The original identifier. + +```js +var node = new SourceNode(1, 2, "a.cpp", [ + new SourceNode(3, 4, "b.cpp", "extern int status;\n"), + new SourceNode(5, 6, "c.cpp", "std::string* make_string(size_t n);\n"), + new SourceNode(7, 8, "d.cpp", "int main(int argc, char** argv) {}\n"), +]); +``` + +#### SourceNode.fromStringWithSourceMap(code, sourceMapConsumer[, relativePath]) + +Creates a SourceNode from generated code and a SourceMapConsumer. + +* `code`: The generated code + +* `sourceMapConsumer` The SourceMap for the generated code + +* `relativePath` The optional path that relative sources in `sourceMapConsumer` + should be relative to. + +```js +var consumer = new SourceMapConsumer(fs.readFileSync("path/to/my-file.js.map", "utf8")); +var node = SourceNode.fromStringWithSourceMap(fs.readFileSync("path/to/my-file.js"), + consumer); +``` + +#### SourceNode.prototype.add(chunk) + +Add a chunk of generated JS to this source node. + +* `chunk`: A string snippet of generated JS code, another instance of + `SourceNode`, or an array where each member is one of those things. + +```js +node.add(" + "); +node.add(otherNode); +node.add([leftHandOperandNode, " + ", rightHandOperandNode]); +``` + +#### SourceNode.prototype.prepend(chunk) + +Prepend a chunk of generated JS to this source node. + +* `chunk`: A string snippet of generated JS code, another instance of + `SourceNode`, or an array where each member is one of those things. + +```js +node.prepend("/** Build Id: f783haef86324gf **/\n\n"); +``` + +#### SourceNode.prototype.setSourceContent(sourceFile, sourceContent) + +Set the source content for a source file. This will be added to the +`SourceMap` in the `sourcesContent` field. + +* `sourceFile`: The filename of the source file + +* `sourceContent`: The content of the source file + +```js +node.setSourceContent("module-one.scm", + fs.readFileSync("path/to/module-one.scm")) +``` + +#### SourceNode.prototype.walk(fn) + +Walk over the tree of JS snippets in this node and its children. The walking +function is called once for each snippet of JS and is passed that snippet and +the its original associated source's line/column location. + +* `fn`: The traversal function. + +```js +var node = new SourceNode(1, 2, "a.js", [ + new SourceNode(3, 4, "b.js", "uno"), + "dos", + [ + "tres", + new SourceNode(5, 6, "c.js", "quatro") + ] +]); + +node.walk(function (code, loc) { console.log("WALK:", code, loc); }) +// WALK: uno { source: 'b.js', line: 3, column: 4, name: null } +// WALK: dos { source: 'a.js', line: 1, column: 2, name: null } +// WALK: tres { source: 'a.js', line: 1, column: 2, name: null } +// WALK: quatro { source: 'c.js', line: 5, column: 6, name: null } +``` + +#### SourceNode.prototype.walkSourceContents(fn) + +Walk over the tree of SourceNodes. The walking function is called for each +source file content and is passed the filename and source content. + +* `fn`: The traversal function. + +```js +var a = new SourceNode(1, 2, "a.js", "generated from a"); +a.setSourceContent("a.js", "original a"); +var b = new SourceNode(1, 2, "b.js", "generated from b"); +b.setSourceContent("b.js", "original b"); +var c = new SourceNode(1, 2, "c.js", "generated from c"); +c.setSourceContent("c.js", "original c"); + +var node = new SourceNode(null, null, null, [a, b, c]); +node.walkSourceContents(function (source, contents) { console.log("WALK:", source, ":", contents); }) +// WALK: a.js : original a +// WALK: b.js : original b +// WALK: c.js : original c +``` + +#### SourceNode.prototype.join(sep) + +Like `Array.prototype.join` except for SourceNodes. Inserts the separator +between each of this source node's children. + +* `sep`: The separator. + +```js +var lhs = new SourceNode(1, 2, "a.rs", "my_copy"); +var operand = new SourceNode(3, 4, "a.rs", "="); +var rhs = new SourceNode(5, 6, "a.rs", "orig.clone()"); + +var node = new SourceNode(null, null, null, [ lhs, operand, rhs ]); +var joinedNode = node.join(" "); +``` + +#### SourceNode.prototype.replaceRight(pattern, replacement) + +Call `String.prototype.replace` on the very right-most source snippet. Useful +for trimming white space from the end of a source node, etc. + +* `pattern`: The pattern to replace. + +* `replacement`: The thing to replace the pattern with. + +```js +// Trim trailing white space. +node.replaceRight(/\s*$/, ""); +``` + +#### SourceNode.prototype.toString() + +Return the string representation of this source node. Walks over the tree and +concatenates all the various snippets together to one string. + +```js +var node = new SourceNode(1, 2, "a.js", [ + new SourceNode(3, 4, "b.js", "uno"), + "dos", + [ + "tres", + new SourceNode(5, 6, "c.js", "quatro") + ] +]); + +node.toString() +// 'unodostresquatro' +``` + +#### SourceNode.prototype.toStringWithSourceMap([startOfSourceMap]) + +Returns the string representation of this tree of source nodes, plus a +SourceMapGenerator which contains all the mappings between the generated and +original sources. + +The arguments are the same as those to `new SourceMapGenerator`. + +```js +var node = new SourceNode(1, 2, "a.js", [ + new SourceNode(3, 4, "b.js", "uno"), + "dos", + [ + "tres", + new SourceNode(5, 6, "c.js", "quatro") + ] +]); + +node.toStringWithSourceMap({ file: "my-output-file.js" }) +// { code: 'unodostresquatro', +// map: [object SourceMapGenerator] } +``` diff --git a/node_modules/source-map-js/lib/array-set.js b/node_modules/source-map-js/lib/array-set.js new file mode 100644 index 0000000..fbd5c81 --- /dev/null +++ b/node_modules/source-map-js/lib/array-set.js @@ -0,0 +1,121 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var util = require('./util'); +var has = Object.prototype.hasOwnProperty; +var hasNativeMap = typeof Map !== "undefined"; + +/** + * A data structure which is a combination of an array and a set. Adding a new + * member is O(1), testing for membership is O(1), and finding the index of an + * element is O(1). Removing elements from the set is not supported. Only + * strings are supported for membership. + */ +function ArraySet() { + this._array = []; + this._set = hasNativeMap ? new Map() : Object.create(null); +} + +/** + * Static method for creating ArraySet instances from an existing array. + */ +ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) { + var set = new ArraySet(); + for (var i = 0, len = aArray.length; i < len; i++) { + set.add(aArray[i], aAllowDuplicates); + } + return set; +}; + +/** + * Return how many unique items are in this ArraySet. If duplicates have been + * added, than those do not count towards the size. + * + * @returns Number + */ +ArraySet.prototype.size = function ArraySet_size() { + return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length; +}; + +/** + * Add the given string to this set. + * + * @param String aStr + */ +ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) { + var sStr = hasNativeMap ? aStr : util.toSetString(aStr); + var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr); + var idx = this._array.length; + if (!isDuplicate || aAllowDuplicates) { + this._array.push(aStr); + } + if (!isDuplicate) { + if (hasNativeMap) { + this._set.set(aStr, idx); + } else { + this._set[sStr] = idx; + } + } +}; + +/** + * Is the given string a member of this set? + * + * @param String aStr + */ +ArraySet.prototype.has = function ArraySet_has(aStr) { + if (hasNativeMap) { + return this._set.has(aStr); + } else { + var sStr = util.toSetString(aStr); + return has.call(this._set, sStr); + } +}; + +/** + * What is the index of the given string in the array? + * + * @param String aStr + */ +ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) { + if (hasNativeMap) { + var idx = this._set.get(aStr); + if (idx >= 0) { + return idx; + } + } else { + var sStr = util.toSetString(aStr); + if (has.call(this._set, sStr)) { + return this._set[sStr]; + } + } + + throw new Error('"' + aStr + '" is not in the set.'); +}; + +/** + * What is the element at the given index? + * + * @param Number aIdx + */ +ArraySet.prototype.at = function ArraySet_at(aIdx) { + if (aIdx >= 0 && aIdx < this._array.length) { + return this._array[aIdx]; + } + throw new Error('No element indexed by ' + aIdx); +}; + +/** + * Returns the array representation of this set (which has the proper indices + * indicated by indexOf). Note that this is a copy of the internal array used + * for storing the members so that no one can mess with internal state. + */ +ArraySet.prototype.toArray = function ArraySet_toArray() { + return this._array.slice(); +}; + +exports.ArraySet = ArraySet; diff --git a/node_modules/source-map-js/lib/base64-vlq.js b/node_modules/source-map-js/lib/base64-vlq.js new file mode 100644 index 0000000..612b404 --- /dev/null +++ b/node_modules/source-map-js/lib/base64-vlq.js @@ -0,0 +1,140 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + * + * Based on the Base 64 VLQ implementation in Closure Compiler: + * https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java + * + * Copyright 2011 The Closure Compiler Authors. All rights reserved. + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials provided + * with the distribution. + * * Neither the name of Google Inc. nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +var base64 = require('./base64'); + +// A single base 64 digit can contain 6 bits of data. For the base 64 variable +// length quantities we use in the source map spec, the first bit is the sign, +// the next four bits are the actual value, and the 6th bit is the +// continuation bit. The continuation bit tells us whether there are more +// digits in this value following this digit. +// +// Continuation +// | Sign +// | | +// V V +// 101011 + +var VLQ_BASE_SHIFT = 5; + +// binary: 100000 +var VLQ_BASE = 1 << VLQ_BASE_SHIFT; + +// binary: 011111 +var VLQ_BASE_MASK = VLQ_BASE - 1; + +// binary: 100000 +var VLQ_CONTINUATION_BIT = VLQ_BASE; + +/** + * Converts from a two-complement value to a value where the sign bit is + * placed in the least significant bit. For example, as decimals: + * 1 becomes 2 (10 binary), -1 becomes 3 (11 binary) + * 2 becomes 4 (100 binary), -2 becomes 5 (101 binary) + */ +function toVLQSigned(aValue) { + return aValue < 0 + ? ((-aValue) << 1) + 1 + : (aValue << 1) + 0; +} + +/** + * Converts to a two-complement value from a value where the sign bit is + * placed in the least significant bit. For example, as decimals: + * 2 (10 binary) becomes 1, 3 (11 binary) becomes -1 + * 4 (100 binary) becomes 2, 5 (101 binary) becomes -2 + */ +function fromVLQSigned(aValue) { + var isNegative = (aValue & 1) === 1; + var shifted = aValue >> 1; + return isNegative + ? -shifted + : shifted; +} + +/** + * Returns the base 64 VLQ encoded value. + */ +exports.encode = function base64VLQ_encode(aValue) { + var encoded = ""; + var digit; + + var vlq = toVLQSigned(aValue); + + do { + digit = vlq & VLQ_BASE_MASK; + vlq >>>= VLQ_BASE_SHIFT; + if (vlq > 0) { + // There are still more digits in this value, so we must make sure the + // continuation bit is marked. + digit |= VLQ_CONTINUATION_BIT; + } + encoded += base64.encode(digit); + } while (vlq > 0); + + return encoded; +}; + +/** + * Decodes the next base 64 VLQ value from the given string and returns the + * value and the rest of the string via the out parameter. + */ +exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) { + var strLen = aStr.length; + var result = 0; + var shift = 0; + var continuation, digit; + + do { + if (aIndex >= strLen) { + throw new Error("Expected more digits in base 64 VLQ value."); + } + + digit = base64.decode(aStr.charCodeAt(aIndex++)); + if (digit === -1) { + throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1)); + } + + continuation = !!(digit & VLQ_CONTINUATION_BIT); + digit &= VLQ_BASE_MASK; + result = result + (digit << shift); + shift += VLQ_BASE_SHIFT; + } while (continuation); + + aOutParam.value = fromVLQSigned(result); + aOutParam.rest = aIndex; +}; diff --git a/node_modules/source-map-js/lib/base64.js b/node_modules/source-map-js/lib/base64.js new file mode 100644 index 0000000..8aa86b3 --- /dev/null +++ b/node_modules/source-map-js/lib/base64.js @@ -0,0 +1,67 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split(''); + +/** + * Encode an integer in the range of 0 to 63 to a single base 64 digit. + */ +exports.encode = function (number) { + if (0 <= number && number < intToCharMap.length) { + return intToCharMap[number]; + } + throw new TypeError("Must be between 0 and 63: " + number); +}; + +/** + * Decode a single base 64 character code digit to an integer. Returns -1 on + * failure. + */ +exports.decode = function (charCode) { + var bigA = 65; // 'A' + var bigZ = 90; // 'Z' + + var littleA = 97; // 'a' + var littleZ = 122; // 'z' + + var zero = 48; // '0' + var nine = 57; // '9' + + var plus = 43; // '+' + var slash = 47; // '/' + + var littleOffset = 26; + var numberOffset = 52; + + // 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ + if (bigA <= charCode && charCode <= bigZ) { + return (charCode - bigA); + } + + // 26 - 51: abcdefghijklmnopqrstuvwxyz + if (littleA <= charCode && charCode <= littleZ) { + return (charCode - littleA + littleOffset); + } + + // 52 - 61: 0123456789 + if (zero <= charCode && charCode <= nine) { + return (charCode - zero + numberOffset); + } + + // 62: + + if (charCode == plus) { + return 62; + } + + // 63: / + if (charCode == slash) { + return 63; + } + + // Invalid base64 digit. + return -1; +}; diff --git a/node_modules/source-map-js/lib/binary-search.js b/node_modules/source-map-js/lib/binary-search.js new file mode 100644 index 0000000..010ac94 --- /dev/null +++ b/node_modules/source-map-js/lib/binary-search.js @@ -0,0 +1,111 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +exports.GREATEST_LOWER_BOUND = 1; +exports.LEAST_UPPER_BOUND = 2; + +/** + * Recursive implementation of binary search. + * + * @param aLow Indices here and lower do not contain the needle. + * @param aHigh Indices here and higher do not contain the needle. + * @param aNeedle The element being searched for. + * @param aHaystack The non-empty array being searched. + * @param aCompare Function which takes two elements and returns -1, 0, or 1. + * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or + * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + */ +function recursiveSearch(aLow, aHigh, aNeedle, aHaystack, aCompare, aBias) { + // This function terminates when one of the following is true: + // + // 1. We find the exact element we are looking for. + // + // 2. We did not find the exact element, but we can return the index of + // the next-closest element. + // + // 3. We did not find the exact element, and there is no next-closest + // element than the one we are searching for, so we return -1. + var mid = Math.floor((aHigh - aLow) / 2) + aLow; + var cmp = aCompare(aNeedle, aHaystack[mid], true); + if (cmp === 0) { + // Found the element we are looking for. + return mid; + } + else if (cmp > 0) { + // Our needle is greater than aHaystack[mid]. + if (aHigh - mid > 1) { + // The element is in the upper half. + return recursiveSearch(mid, aHigh, aNeedle, aHaystack, aCompare, aBias); + } + + // The exact needle element was not found in this haystack. Determine if + // we are in termination case (3) or (2) and return the appropriate thing. + if (aBias == exports.LEAST_UPPER_BOUND) { + return aHigh < aHaystack.length ? aHigh : -1; + } else { + return mid; + } + } + else { + // Our needle is less than aHaystack[mid]. + if (mid - aLow > 1) { + // The element is in the lower half. + return recursiveSearch(aLow, mid, aNeedle, aHaystack, aCompare, aBias); + } + + // we are in termination case (3) or (2) and return the appropriate thing. + if (aBias == exports.LEAST_UPPER_BOUND) { + return mid; + } else { + return aLow < 0 ? -1 : aLow; + } + } +} + +/** + * This is an implementation of binary search which will always try and return + * the index of the closest element if there is no exact hit. This is because + * mappings between original and generated line/col pairs are single points, + * and there is an implicit region between each of them, so a miss just means + * that you aren't on the very start of a region. + * + * @param aNeedle The element you are looking for. + * @param aHaystack The array that is being searched. + * @param aCompare A function which takes the needle and an element in the + * array and returns -1, 0, or 1 depending on whether the needle is less + * than, equal to, or greater than the element, respectively. + * @param aBias Either 'binarySearch.GREATEST_LOWER_BOUND' or + * 'binarySearch.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'binarySearch.GREATEST_LOWER_BOUND'. + */ +exports.search = function search(aNeedle, aHaystack, aCompare, aBias) { + if (aHaystack.length === 0) { + return -1; + } + + var index = recursiveSearch(-1, aHaystack.length, aNeedle, aHaystack, + aCompare, aBias || exports.GREATEST_LOWER_BOUND); + if (index < 0) { + return -1; + } + + // We have found either the exact element, or the next-closest element than + // the one we are searching for. However, there may be more than one such + // element. Make sure we always return the smallest of these. + while (index - 1 >= 0) { + if (aCompare(aHaystack[index], aHaystack[index - 1], true) !== 0) { + break; + } + --index; + } + + return index; +}; diff --git a/node_modules/source-map-js/lib/mapping-list.js b/node_modules/source-map-js/lib/mapping-list.js new file mode 100644 index 0000000..06d1274 --- /dev/null +++ b/node_modules/source-map-js/lib/mapping-list.js @@ -0,0 +1,79 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2014 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var util = require('./util'); + +/** + * Determine whether mappingB is after mappingA with respect to generated + * position. + */ +function generatedPositionAfter(mappingA, mappingB) { + // Optimized for most common case + var lineA = mappingA.generatedLine; + var lineB = mappingB.generatedLine; + var columnA = mappingA.generatedColumn; + var columnB = mappingB.generatedColumn; + return lineB > lineA || lineB == lineA && columnB >= columnA || + util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0; +} + +/** + * A data structure to provide a sorted view of accumulated mappings in a + * performance conscious manner. It trades a neglibable overhead in general + * case for a large speedup in case of mappings being added in order. + */ +function MappingList() { + this._array = []; + this._sorted = true; + // Serves as infimum + this._last = {generatedLine: -1, generatedColumn: 0}; +} + +/** + * Iterate through internal items. This method takes the same arguments that + * `Array.prototype.forEach` takes. + * + * NOTE: The order of the mappings is NOT guaranteed. + */ +MappingList.prototype.unsortedForEach = + function MappingList_forEach(aCallback, aThisArg) { + this._array.forEach(aCallback, aThisArg); + }; + +/** + * Add the given source mapping. + * + * @param Object aMapping + */ +MappingList.prototype.add = function MappingList_add(aMapping) { + if (generatedPositionAfter(this._last, aMapping)) { + this._last = aMapping; + this._array.push(aMapping); + } else { + this._sorted = false; + this._array.push(aMapping); + } +}; + +/** + * Returns the flat, sorted array of mappings. The mappings are sorted by + * generated position. + * + * WARNING: This method returns internal data without copying, for + * performance. The return value must NOT be mutated, and should be treated as + * an immutable borrow. If you want to take ownership, you must make your own + * copy. + */ +MappingList.prototype.toArray = function MappingList_toArray() { + if (!this._sorted) { + this._array.sort(util.compareByGeneratedPositionsInflated); + this._sorted = true; + } + return this._array; +}; + +exports.MappingList = MappingList; diff --git a/node_modules/source-map-js/lib/quick-sort.js b/node_modules/source-map-js/lib/quick-sort.js new file mode 100644 index 0000000..23f9eda --- /dev/null +++ b/node_modules/source-map-js/lib/quick-sort.js @@ -0,0 +1,132 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +// It turns out that some (most?) JavaScript engines don't self-host +// `Array.prototype.sort`. This makes sense because C++ will likely remain +// faster than JS when doing raw CPU-intensive sorting. However, when using a +// custom comparator function, calling back and forth between the VM's C++ and +// JIT'd JS is rather slow *and* loses JIT type information, resulting in +// worse generated code for the comparator function than would be optimal. In +// fact, when sorting with a comparator, these costs outweigh the benefits of +// sorting in C++. By using our own JS-implemented Quick Sort (below), we get +// a ~3500ms mean speed-up in `bench/bench.html`. + +function SortTemplate(comparator) { + +/** + * Swap the elements indexed by `x` and `y` in the array `ary`. + * + * @param {Array} ary + * The array. + * @param {Number} x + * The index of the first item. + * @param {Number} y + * The index of the second item. + */ +function swap(ary, x, y) { + var temp = ary[x]; + ary[x] = ary[y]; + ary[y] = temp; +} + +/** + * Returns a random integer within the range `low .. high` inclusive. + * + * @param {Number} low + * The lower bound on the range. + * @param {Number} high + * The upper bound on the range. + */ +function randomIntInRange(low, high) { + return Math.round(low + (Math.random() * (high - low))); +} + +/** + * The Quick Sort algorithm. + * + * @param {Array} ary + * An array to sort. + * @param {function} comparator + * Function to use to compare two items. + * @param {Number} p + * Start index of the array + * @param {Number} r + * End index of the array + */ +function doQuickSort(ary, comparator, p, r) { + // If our lower bound is less than our upper bound, we (1) partition the + // array into two pieces and (2) recurse on each half. If it is not, this is + // the empty array and our base case. + + if (p < r) { + // (1) Partitioning. + // + // The partitioning chooses a pivot between `p` and `r` and moves all + // elements that are less than or equal to the pivot to the before it, and + // all the elements that are greater than it after it. The effect is that + // once partition is done, the pivot is in the exact place it will be when + // the array is put in sorted order, and it will not need to be moved + // again. This runs in O(n) time. + + // Always choose a random pivot so that an input array which is reverse + // sorted does not cause O(n^2) running time. + var pivotIndex = randomIntInRange(p, r); + var i = p - 1; + + swap(ary, pivotIndex, r); + var pivot = ary[r]; + + // Immediately after `j` is incremented in this loop, the following hold + // true: + // + // * Every element in `ary[p .. i]` is less than or equal to the pivot. + // + // * Every element in `ary[i+1 .. j-1]` is greater than the pivot. + for (var j = p; j < r; j++) { + if (comparator(ary[j], pivot, false) <= 0) { + i += 1; + swap(ary, i, j); + } + } + + swap(ary, i + 1, j); + var q = i + 1; + + // (2) Recurse on each half. + + doQuickSort(ary, comparator, p, q - 1); + doQuickSort(ary, comparator, q + 1, r); + } +} + + return doQuickSort; +} + +function cloneSort(comparator) { + let template = SortTemplate.toString(); + let templateFn = new Function(`return ${template}`)(); + return templateFn(comparator); +} + +/** + * Sort the given array in-place with the given comparator function. + * + * @param {Array} ary + * An array to sort. + * @param {function} comparator + * Function to use to compare two items. + */ + +let sortCache = new WeakMap(); +exports.quickSort = function (ary, comparator, start = 0) { + let doQuickSort = sortCache.get(comparator); + if (doQuickSort === void 0) { + doQuickSort = cloneSort(comparator); + sortCache.set(comparator, doQuickSort); + } + doQuickSort(ary, comparator, start, ary.length - 1); +}; diff --git a/node_modules/source-map-js/lib/source-map-consumer.js b/node_modules/source-map-js/lib/source-map-consumer.js new file mode 100644 index 0000000..db0a532 --- /dev/null +++ b/node_modules/source-map-js/lib/source-map-consumer.js @@ -0,0 +1,1184 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var util = require('./util'); +var binarySearch = require('./binary-search'); +var ArraySet = require('./array-set').ArraySet; +var base64VLQ = require('./base64-vlq'); +var quickSort = require('./quick-sort').quickSort; + +function SourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); + } + + return sourceMap.sections != null + ? new IndexedSourceMapConsumer(sourceMap, aSourceMapURL) + : new BasicSourceMapConsumer(sourceMap, aSourceMapURL); +} + +SourceMapConsumer.fromSourceMap = function(aSourceMap, aSourceMapURL) { + return BasicSourceMapConsumer.fromSourceMap(aSourceMap, aSourceMapURL); +} + +/** + * The version of the source mapping spec that we are consuming. + */ +SourceMapConsumer.prototype._version = 3; + +// `__generatedMappings` and `__originalMappings` are arrays that hold the +// parsed mapping coordinates from the source map's "mappings" attribute. They +// are lazily instantiated, accessed via the `_generatedMappings` and +// `_originalMappings` getters respectively, and we only parse the mappings +// and create these arrays once queried for a source location. We jump through +// these hoops because there can be many thousands of mappings, and parsing +// them is expensive, so we only want to do it if we must. +// +// Each object in the arrays is of the form: +// +// { +// generatedLine: The line number in the generated code, +// generatedColumn: The column number in the generated code, +// source: The path to the original source file that generated this +// chunk of code, +// originalLine: The line number in the original source that +// corresponds to this chunk of generated code, +// originalColumn: The column number in the original source that +// corresponds to this chunk of generated code, +// name: The name of the original symbol which generated this chunk of +// code. +// } +// +// All properties except for `generatedLine` and `generatedColumn` can be +// `null`. +// +// `_generatedMappings` is ordered by the generated positions. +// +// `_originalMappings` is ordered by the original positions. + +SourceMapConsumer.prototype.__generatedMappings = null; +Object.defineProperty(SourceMapConsumer.prototype, '_generatedMappings', { + configurable: true, + enumerable: true, + get: function () { + if (!this.__generatedMappings) { + this._parseMappings(this._mappings, this.sourceRoot); + } + + return this.__generatedMappings; + } +}); + +SourceMapConsumer.prototype.__originalMappings = null; +Object.defineProperty(SourceMapConsumer.prototype, '_originalMappings', { + configurable: true, + enumerable: true, + get: function () { + if (!this.__originalMappings) { + this._parseMappings(this._mappings, this.sourceRoot); + } + + return this.__originalMappings; + } +}); + +SourceMapConsumer.prototype._charIsMappingSeparator = + function SourceMapConsumer_charIsMappingSeparator(aStr, index) { + var c = aStr.charAt(index); + return c === ";" || c === ","; + }; + +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ +SourceMapConsumer.prototype._parseMappings = + function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { + throw new Error("Subclasses must implement _parseMappings"); + }; + +SourceMapConsumer.GENERATED_ORDER = 1; +SourceMapConsumer.ORIGINAL_ORDER = 2; + +SourceMapConsumer.GREATEST_LOWER_BOUND = 1; +SourceMapConsumer.LEAST_UPPER_BOUND = 2; + +/** + * Iterate over each mapping between an original source/line/column and a + * generated line/column in this source map. + * + * @param Function aCallback + * The function that is called with each mapping. + * @param Object aContext + * Optional. If specified, this object will be the value of `this` every + * time that `aCallback` is called. + * @param aOrder + * Either `SourceMapConsumer.GENERATED_ORDER` or + * `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to + * iterate over the mappings sorted by the generated file's line/column + * order or the original's source/line/column order, respectively. Defaults to + * `SourceMapConsumer.GENERATED_ORDER`. + */ +SourceMapConsumer.prototype.eachMapping = + function SourceMapConsumer_eachMapping(aCallback, aContext, aOrder) { + var context = aContext || null; + var order = aOrder || SourceMapConsumer.GENERATED_ORDER; + + var mappings; + switch (order) { + case SourceMapConsumer.GENERATED_ORDER: + mappings = this._generatedMappings; + break; + case SourceMapConsumer.ORIGINAL_ORDER: + mappings = this._originalMappings; + break; + default: + throw new Error("Unknown order of iteration."); + } + + var sourceRoot = this.sourceRoot; + var boundCallback = aCallback.bind(context); + var names = this._names; + var sources = this._sources; + var sourceMapURL = this._sourceMapURL; + + for (var i = 0, n = mappings.length; i < n; i++) { + var mapping = mappings[i]; + var source = mapping.source === null ? null : sources.at(mapping.source); + source = util.computeSourceURL(sourceRoot, source, sourceMapURL); + boundCallback({ + source: source, + generatedLine: mapping.generatedLine, + generatedColumn: mapping.generatedColumn, + originalLine: mapping.originalLine, + originalColumn: mapping.originalColumn, + name: mapping.name === null ? null : names.at(mapping.name) + }); + } + }; + +/** + * Returns all generated line and column information for the original source, + * line, and column provided. If no column is provided, returns all mappings + * corresponding to a either the line we are searching for or the next + * closest line that has any mappings. Otherwise, returns all mappings + * corresponding to the given line and either the column we are searching for + * or the next closest column that has any offsets. + * + * The only argument is an object with the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number is 1-based. + * - column: Optional. the column number in the original source. + * The column number is 0-based. + * + * and an array of objects is returned, each with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +SourceMapConsumer.prototype.allGeneratedPositionsFor = + function SourceMapConsumer_allGeneratedPositionsFor(aArgs) { + var line = util.getArg(aArgs, 'line'); + + // When there is no exact match, BasicSourceMapConsumer.prototype._findMapping + // returns the index of the closest mapping less than the needle. By + // setting needle.originalColumn to 0, we thus find the last mapping for + // the given line, provided such a mapping exists. + var needle = { + source: util.getArg(aArgs, 'source'), + originalLine: line, + originalColumn: util.getArg(aArgs, 'column', 0) + }; + + needle.source = this._findSourceIndex(needle.source); + if (needle.source < 0) { + return []; + } + + var mappings = []; + + var index = this._findMapping(needle, + this._originalMappings, + "originalLine", + "originalColumn", + util.compareByOriginalPositions, + binarySearch.LEAST_UPPER_BOUND); + if (index >= 0) { + var mapping = this._originalMappings[index]; + + if (aArgs.column === undefined) { + var originalLine = mapping.originalLine; + + // Iterate until either we run out of mappings, or we run into + // a mapping for a different line than the one we found. Since + // mappings are sorted, this is guaranteed to find all mappings for + // the line we found. + while (mapping && mapping.originalLine === originalLine) { + mappings.push({ + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }); + + mapping = this._originalMappings[++index]; + } + } else { + var originalColumn = mapping.originalColumn; + + // Iterate until either we run out of mappings, or we run into + // a mapping for a different line than the one we were searching for. + // Since mappings are sorted, this is guaranteed to find all mappings for + // the line we are searching for. + while (mapping && + mapping.originalLine === line && + mapping.originalColumn == originalColumn) { + mappings.push({ + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }); + + mapping = this._originalMappings[++index]; + } + } + } + + return mappings; + }; + +exports.SourceMapConsumer = SourceMapConsumer; + +/** + * A BasicSourceMapConsumer instance represents a parsed source map which we can + * query for information about the original file positions by giving it a file + * position in the generated source. + * + * The first parameter is the raw source map (either as a JSON string, or + * already parsed to an object). According to the spec, source maps have the + * following attributes: + * + * - version: Which version of the source map spec this map is following. + * - sources: An array of URLs to the original source files. + * - names: An array of identifiers which can be referrenced by individual mappings. + * - sourceRoot: Optional. The URL root from which all sources are relative. + * - sourcesContent: Optional. An array of contents of the original source files. + * - mappings: A string of base64 VLQs which contain the actual mappings. + * - file: Optional. The generated file this source map is associated with. + * + * Here is an example source map, taken from the source map spec[0]: + * + * { + * version : 3, + * file: "out.js", + * sourceRoot : "", + * sources: ["foo.js", "bar.js"], + * names: ["src", "maps", "are", "fun"], + * mappings: "AA,AB;;ABCDE;" + * } + * + * The second parameter, if given, is a string whose value is the URL + * at which the source map was found. This URL is used to compute the + * sources array. + * + * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit?pli=1# + */ +function BasicSourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); + } + + var version = util.getArg(sourceMap, 'version'); + var sources = util.getArg(sourceMap, 'sources'); + // Sass 3.3 leaves out the 'names' array, so we deviate from the spec (which + // requires the array) to play nice here. + var names = util.getArg(sourceMap, 'names', []); + var sourceRoot = util.getArg(sourceMap, 'sourceRoot', null); + var sourcesContent = util.getArg(sourceMap, 'sourcesContent', null); + var mappings = util.getArg(sourceMap, 'mappings'); + var file = util.getArg(sourceMap, 'file', null); + + // Once again, Sass deviates from the spec and supplies the version as a + // string rather than a number, so we use loose equality checking here. + if (version != this._version) { + throw new Error('Unsupported version: ' + version); + } + + if (sourceRoot) { + sourceRoot = util.normalize(sourceRoot); + } + + sources = sources + .map(String) + // Some source maps produce relative source paths like "./foo.js" instead of + // "foo.js". Normalize these first so that future comparisons will succeed. + // See bugzil.la/1090768. + .map(util.normalize) + // Always ensure that absolute sources are internally stored relative to + // the source root, if the source root is absolute. Not doing this would + // be particularly problematic when the source root is a prefix of the + // source (valid, but why??). See github issue #199 and bugzil.la/1188982. + .map(function (source) { + return sourceRoot && util.isAbsolute(sourceRoot) && util.isAbsolute(source) + ? util.relative(sourceRoot, source) + : source; + }); + + // Pass `true` below to allow duplicate names and sources. While source maps + // are intended to be compressed and deduplicated, the TypeScript compiler + // sometimes generates source maps with duplicates in them. See Github issue + // #72 and bugzil.la/889492. + this._names = ArraySet.fromArray(names.map(String), true); + this._sources = ArraySet.fromArray(sources, true); + + this._absoluteSources = this._sources.toArray().map(function (s) { + return util.computeSourceURL(sourceRoot, s, aSourceMapURL); + }); + + this.sourceRoot = sourceRoot; + this.sourcesContent = sourcesContent; + this._mappings = mappings; + this._sourceMapURL = aSourceMapURL; + this.file = file; +} + +BasicSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); +BasicSourceMapConsumer.prototype.consumer = SourceMapConsumer; + +/** + * Utility function to find the index of a source. Returns -1 if not + * found. + */ +BasicSourceMapConsumer.prototype._findSourceIndex = function(aSource) { + var relativeSource = aSource; + if (this.sourceRoot != null) { + relativeSource = util.relative(this.sourceRoot, relativeSource); + } + + if (this._sources.has(relativeSource)) { + return this._sources.indexOf(relativeSource); + } + + // Maybe aSource is an absolute URL as returned by |sources|. In + // this case we can't simply undo the transform. + var i; + for (i = 0; i < this._absoluteSources.length; ++i) { + if (this._absoluteSources[i] == aSource) { + return i; + } + } + + return -1; +}; + +/** + * Create a BasicSourceMapConsumer from a SourceMapGenerator. + * + * @param SourceMapGenerator aSourceMap + * The source map that will be consumed. + * @param String aSourceMapURL + * The URL at which the source map can be found (optional) + * @returns BasicSourceMapConsumer + */ +BasicSourceMapConsumer.fromSourceMap = + function SourceMapConsumer_fromSourceMap(aSourceMap, aSourceMapURL) { + var smc = Object.create(BasicSourceMapConsumer.prototype); + + var names = smc._names = ArraySet.fromArray(aSourceMap._names.toArray(), true); + var sources = smc._sources = ArraySet.fromArray(aSourceMap._sources.toArray(), true); + smc.sourceRoot = aSourceMap._sourceRoot; + smc.sourcesContent = aSourceMap._generateSourcesContent(smc._sources.toArray(), + smc.sourceRoot); + smc.file = aSourceMap._file; + smc._sourceMapURL = aSourceMapURL; + smc._absoluteSources = smc._sources.toArray().map(function (s) { + return util.computeSourceURL(smc.sourceRoot, s, aSourceMapURL); + }); + + // Because we are modifying the entries (by converting string sources and + // names to indices into the sources and names ArraySets), we have to make + // a copy of the entry or else bad things happen. Shared mutable state + // strikes again! See github issue #191. + + var generatedMappings = aSourceMap._mappings.toArray().slice(); + var destGeneratedMappings = smc.__generatedMappings = []; + var destOriginalMappings = smc.__originalMappings = []; + + for (var i = 0, length = generatedMappings.length; i < length; i++) { + var srcMapping = generatedMappings[i]; + var destMapping = new Mapping; + destMapping.generatedLine = srcMapping.generatedLine; + destMapping.generatedColumn = srcMapping.generatedColumn; + + if (srcMapping.source) { + destMapping.source = sources.indexOf(srcMapping.source); + destMapping.originalLine = srcMapping.originalLine; + destMapping.originalColumn = srcMapping.originalColumn; + + if (srcMapping.name) { + destMapping.name = names.indexOf(srcMapping.name); + } + + destOriginalMappings.push(destMapping); + } + + destGeneratedMappings.push(destMapping); + } + + quickSort(smc.__originalMappings, util.compareByOriginalPositions); + + return smc; + }; + +/** + * The version of the source mapping spec that we are consuming. + */ +BasicSourceMapConsumer.prototype._version = 3; + +/** + * The list of original sources. + */ +Object.defineProperty(BasicSourceMapConsumer.prototype, 'sources', { + get: function () { + return this._absoluteSources.slice(); + } +}); + +/** + * Provide the JIT with a nice shape / hidden class. + */ +function Mapping() { + this.generatedLine = 0; + this.generatedColumn = 0; + this.source = null; + this.originalLine = null; + this.originalColumn = null; + this.name = null; +} + +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ + +const compareGenerated = util.compareByGeneratedPositionsDeflatedNoLine; +function sortGenerated(array, start) { + let l = array.length; + let n = array.length - start; + if (n <= 1) { + return; + } else if (n == 2) { + let a = array[start]; + let b = array[start + 1]; + if (compareGenerated(a, b) > 0) { + array[start] = b; + array[start + 1] = a; + } + } else if (n < 20) { + for (let i = start; i < l; i++) { + for (let j = i; j > start; j--) { + let a = array[j - 1]; + let b = array[j]; + if (compareGenerated(a, b) <= 0) { + break; + } + array[j - 1] = b; + array[j] = a; + } + } + } else { + quickSort(array, compareGenerated, start); + } +} +BasicSourceMapConsumer.prototype._parseMappings = + function SourceMapConsumer_parseMappings(aStr, aSourceRoot) { + var generatedLine = 1; + var previousGeneratedColumn = 0; + var previousOriginalLine = 0; + var previousOriginalColumn = 0; + var previousSource = 0; + var previousName = 0; + var length = aStr.length; + var index = 0; + var cachedSegments = {}; + var temp = {}; + var originalMappings = []; + var generatedMappings = []; + var mapping, str, segment, end, value; + + let subarrayStart = 0; + while (index < length) { + if (aStr.charAt(index) === ';') { + generatedLine++; + index++; + previousGeneratedColumn = 0; + + sortGenerated(generatedMappings, subarrayStart); + subarrayStart = generatedMappings.length; + } + else if (aStr.charAt(index) === ',') { + index++; + } + else { + mapping = new Mapping(); + mapping.generatedLine = generatedLine; + + for (end = index; end < length; end++) { + if (this._charIsMappingSeparator(aStr, end)) { + break; + } + } + str = aStr.slice(index, end); + + segment = []; + while (index < end) { + base64VLQ.decode(aStr, index, temp); + value = temp.value; + index = temp.rest; + segment.push(value); + } + + if (segment.length === 2) { + throw new Error('Found a source, but no line and column'); + } + + if (segment.length === 3) { + throw new Error('Found a source and line, but no column'); + } + + // Generated column. + mapping.generatedColumn = previousGeneratedColumn + segment[0]; + previousGeneratedColumn = mapping.generatedColumn; + + if (segment.length > 1) { + // Original source. + mapping.source = previousSource + segment[1]; + previousSource += segment[1]; + + // Original line. + mapping.originalLine = previousOriginalLine + segment[2]; + previousOriginalLine = mapping.originalLine; + // Lines are stored 0-based + mapping.originalLine += 1; + + // Original column. + mapping.originalColumn = previousOriginalColumn + segment[3]; + previousOriginalColumn = mapping.originalColumn; + + if (segment.length > 4) { + // Original name. + mapping.name = previousName + segment[4]; + previousName += segment[4]; + } + } + + generatedMappings.push(mapping); + if (typeof mapping.originalLine === 'number') { + let currentSource = mapping.source; + while (originalMappings.length <= currentSource) { + originalMappings.push(null); + } + if (originalMappings[currentSource] === null) { + originalMappings[currentSource] = []; + } + originalMappings[currentSource].push(mapping); + } + } + } + + sortGenerated(generatedMappings, subarrayStart); + this.__generatedMappings = generatedMappings; + + for (var i = 0; i < originalMappings.length; i++) { + if (originalMappings[i] != null) { + quickSort(originalMappings[i], util.compareByOriginalPositionsNoSource); + } + } + this.__originalMappings = [].concat(...originalMappings); + }; + +/** + * Find the mapping that best matches the hypothetical "needle" mapping that + * we are searching for in the given "haystack" of mappings. + */ +BasicSourceMapConsumer.prototype._findMapping = + function SourceMapConsumer_findMapping(aNeedle, aMappings, aLineName, + aColumnName, aComparator, aBias) { + // To return the position we are searching for, we must first find the + // mapping for the given position and then return the opposite position it + // points to. Because the mappings are sorted, we can use binary search to + // find the best mapping. + + if (aNeedle[aLineName] <= 0) { + throw new TypeError('Line must be greater than or equal to 1, got ' + + aNeedle[aLineName]); + } + if (aNeedle[aColumnName] < 0) { + throw new TypeError('Column must be greater than or equal to 0, got ' + + aNeedle[aColumnName]); + } + + return binarySearch.search(aNeedle, aMappings, aComparator, aBias); + }; + +/** + * Compute the last column for each generated mapping. The last column is + * inclusive. + */ +BasicSourceMapConsumer.prototype.computeColumnSpans = + function SourceMapConsumer_computeColumnSpans() { + for (var index = 0; index < this._generatedMappings.length; ++index) { + var mapping = this._generatedMappings[index]; + + // Mappings do not contain a field for the last generated columnt. We + // can come up with an optimistic estimate, however, by assuming that + // mappings are contiguous (i.e. given two consecutive mappings, the + // first mapping ends where the second one starts). + if (index + 1 < this._generatedMappings.length) { + var nextMapping = this._generatedMappings[index + 1]; + + if (mapping.generatedLine === nextMapping.generatedLine) { + mapping.lastGeneratedColumn = nextMapping.generatedColumn - 1; + continue; + } + } + + // The last mapping for each line spans the entire line. + mapping.lastGeneratedColumn = Infinity; + } + }; + +/** + * Returns the original source, line, and column information for the generated + * source's line and column positions provided. The only argument is an object + * with the following properties: + * + * - line: The line number in the generated source. The line number + * is 1-based. + * - column: The column number in the generated source. The column + * number is 0-based. + * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or + * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. + * + * and an object is returned with the following properties: + * + * - source: The original source file, or null. + * - line: The line number in the original source, or null. The + * line number is 1-based. + * - column: The column number in the original source, or null. The + * column number is 0-based. + * - name: The original identifier, or null. + */ +BasicSourceMapConsumer.prototype.originalPositionFor = + function SourceMapConsumer_originalPositionFor(aArgs) { + var needle = { + generatedLine: util.getArg(aArgs, 'line'), + generatedColumn: util.getArg(aArgs, 'column') + }; + + var index = this._findMapping( + needle, + this._generatedMappings, + "generatedLine", + "generatedColumn", + util.compareByGeneratedPositionsDeflated, + util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) + ); + + if (index >= 0) { + var mapping = this._generatedMappings[index]; + + if (mapping.generatedLine === needle.generatedLine) { + var source = util.getArg(mapping, 'source', null); + if (source !== null) { + source = this._sources.at(source); + source = util.computeSourceURL(this.sourceRoot, source, this._sourceMapURL); + } + var name = util.getArg(mapping, 'name', null); + if (name !== null) { + name = this._names.at(name); + } + return { + source: source, + line: util.getArg(mapping, 'originalLine', null), + column: util.getArg(mapping, 'originalColumn', null), + name: name + }; + } + } + + return { + source: null, + line: null, + column: null, + name: null + }; + }; + +/** + * Return true if we have the source content for every source in the source + * map, false otherwise. + */ +BasicSourceMapConsumer.prototype.hasContentsOfAllSources = + function BasicSourceMapConsumer_hasContentsOfAllSources() { + if (!this.sourcesContent) { + return false; + } + return this.sourcesContent.length >= this._sources.size() && + !this.sourcesContent.some(function (sc) { return sc == null; }); + }; + +/** + * Returns the original source content. The only argument is the url of the + * original source file. Returns null if no original source content is + * available. + */ +BasicSourceMapConsumer.prototype.sourceContentFor = + function SourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { + if (!this.sourcesContent) { + return null; + } + + var index = this._findSourceIndex(aSource); + if (index >= 0) { + return this.sourcesContent[index]; + } + + var relativeSource = aSource; + if (this.sourceRoot != null) { + relativeSource = util.relative(this.sourceRoot, relativeSource); + } + + var url; + if (this.sourceRoot != null + && (url = util.urlParse(this.sourceRoot))) { + // XXX: file:// URIs and absolute paths lead to unexpected behavior for + // many users. We can help them out when they expect file:// URIs to + // behave like it would if they were running a local HTTP server. See + // https://bugzilla.mozilla.org/show_bug.cgi?id=885597. + var fileUriAbsPath = relativeSource.replace(/^file:\/\//, ""); + if (url.scheme == "file" + && this._sources.has(fileUriAbsPath)) { + return this.sourcesContent[this._sources.indexOf(fileUriAbsPath)] + } + + if ((!url.path || url.path == "/") + && this._sources.has("/" + relativeSource)) { + return this.sourcesContent[this._sources.indexOf("/" + relativeSource)]; + } + } + + // This function is used recursively from + // IndexedSourceMapConsumer.prototype.sourceContentFor. In that case, we + // don't want to throw if we can't find the source - we just want to + // return null, so we provide a flag to exit gracefully. + if (nullOnMissing) { + return null; + } + else { + throw new Error('"' + relativeSource + '" is not in the SourceMap.'); + } + }; + +/** + * Returns the generated line and column information for the original source, + * line, and column positions provided. The only argument is an object with + * the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number + * is 1-based. + * - column: The column number in the original source. The column + * number is 0-based. + * - bias: Either 'SourceMapConsumer.GREATEST_LOWER_BOUND' or + * 'SourceMapConsumer.LEAST_UPPER_BOUND'. Specifies whether to return the + * closest element that is smaller than or greater than the one we are + * searching for, respectively, if the exact element cannot be found. + * Defaults to 'SourceMapConsumer.GREATEST_LOWER_BOUND'. + * + * and an object is returned with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +BasicSourceMapConsumer.prototype.generatedPositionFor = + function SourceMapConsumer_generatedPositionFor(aArgs) { + var source = util.getArg(aArgs, 'source'); + source = this._findSourceIndex(source); + if (source < 0) { + return { + line: null, + column: null, + lastColumn: null + }; + } + + var needle = { + source: source, + originalLine: util.getArg(aArgs, 'line'), + originalColumn: util.getArg(aArgs, 'column') + }; + + var index = this._findMapping( + needle, + this._originalMappings, + "originalLine", + "originalColumn", + util.compareByOriginalPositions, + util.getArg(aArgs, 'bias', SourceMapConsumer.GREATEST_LOWER_BOUND) + ); + + if (index >= 0) { + var mapping = this._originalMappings[index]; + + if (mapping.source === needle.source) { + return { + line: util.getArg(mapping, 'generatedLine', null), + column: util.getArg(mapping, 'generatedColumn', null), + lastColumn: util.getArg(mapping, 'lastGeneratedColumn', null) + }; + } + } + + return { + line: null, + column: null, + lastColumn: null + }; + }; + +exports.BasicSourceMapConsumer = BasicSourceMapConsumer; + +/** + * An IndexedSourceMapConsumer instance represents a parsed source map which + * we can query for information. It differs from BasicSourceMapConsumer in + * that it takes "indexed" source maps (i.e. ones with a "sections" field) as + * input. + * + * The first parameter is a raw source map (either as a JSON string, or already + * parsed to an object). According to the spec for indexed source maps, they + * have the following attributes: + * + * - version: Which version of the source map spec this map is following. + * - file: Optional. The generated file this source map is associated with. + * - sections: A list of section definitions. + * + * Each value under the "sections" field has two fields: + * - offset: The offset into the original specified at which this section + * begins to apply, defined as an object with a "line" and "column" + * field. + * - map: A source map definition. This source map could also be indexed, + * but doesn't have to be. + * + * Instead of the "map" field, it's also possible to have a "url" field + * specifying a URL to retrieve a source map from, but that's currently + * unsupported. + * + * Here's an example source map, taken from the source map spec[0], but + * modified to omit a section which uses the "url" field. + * + * { + * version : 3, + * file: "app.js", + * sections: [{ + * offset: {line:100, column:10}, + * map: { + * version : 3, + * file: "section.js", + * sources: ["foo.js", "bar.js"], + * names: ["src", "maps", "are", "fun"], + * mappings: "AAAA,E;;ABCDE;" + * } + * }], + * } + * + * The second parameter, if given, is a string whose value is the URL + * at which the source map was found. This URL is used to compute the + * sources array. + * + * [0]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit#heading=h.535es3xeprgt + */ +function IndexedSourceMapConsumer(aSourceMap, aSourceMapURL) { + var sourceMap = aSourceMap; + if (typeof aSourceMap === 'string') { + sourceMap = util.parseSourceMapInput(aSourceMap); + } + + var version = util.getArg(sourceMap, 'version'); + var sections = util.getArg(sourceMap, 'sections'); + + if (version != this._version) { + throw new Error('Unsupported version: ' + version); + } + + this._sources = new ArraySet(); + this._names = new ArraySet(); + + var lastOffset = { + line: -1, + column: 0 + }; + this._sections = sections.map(function (s) { + if (s.url) { + // The url field will require support for asynchronicity. + // See https://github.com/mozilla/source-map/issues/16 + throw new Error('Support for url field in sections not implemented.'); + } + var offset = util.getArg(s, 'offset'); + var offsetLine = util.getArg(offset, 'line'); + var offsetColumn = util.getArg(offset, 'column'); + + if (offsetLine < lastOffset.line || + (offsetLine === lastOffset.line && offsetColumn < lastOffset.column)) { + throw new Error('Section offsets must be ordered and non-overlapping.'); + } + lastOffset = offset; + + return { + generatedOffset: { + // The offset fields are 0-based, but we use 1-based indices when + // encoding/decoding from VLQ. + generatedLine: offsetLine + 1, + generatedColumn: offsetColumn + 1 + }, + consumer: new SourceMapConsumer(util.getArg(s, 'map'), aSourceMapURL) + } + }); +} + +IndexedSourceMapConsumer.prototype = Object.create(SourceMapConsumer.prototype); +IndexedSourceMapConsumer.prototype.constructor = SourceMapConsumer; + +/** + * The version of the source mapping spec that we are consuming. + */ +IndexedSourceMapConsumer.prototype._version = 3; + +/** + * The list of original sources. + */ +Object.defineProperty(IndexedSourceMapConsumer.prototype, 'sources', { + get: function () { + var sources = []; + for (var i = 0; i < this._sections.length; i++) { + for (var j = 0; j < this._sections[i].consumer.sources.length; j++) { + sources.push(this._sections[i].consumer.sources[j]); + } + } + return sources; + } +}); + +/** + * Returns the original source, line, and column information for the generated + * source's line and column positions provided. The only argument is an object + * with the following properties: + * + * - line: The line number in the generated source. The line number + * is 1-based. + * - column: The column number in the generated source. The column + * number is 0-based. + * + * and an object is returned with the following properties: + * + * - source: The original source file, or null. + * - line: The line number in the original source, or null. The + * line number is 1-based. + * - column: The column number in the original source, or null. The + * column number is 0-based. + * - name: The original identifier, or null. + */ +IndexedSourceMapConsumer.prototype.originalPositionFor = + function IndexedSourceMapConsumer_originalPositionFor(aArgs) { + var needle = { + generatedLine: util.getArg(aArgs, 'line'), + generatedColumn: util.getArg(aArgs, 'column') + }; + + // Find the section containing the generated position we're trying to map + // to an original position. + var sectionIndex = binarySearch.search(needle, this._sections, + function(needle, section) { + var cmp = needle.generatedLine - section.generatedOffset.generatedLine; + if (cmp) { + return cmp; + } + + return (needle.generatedColumn - + section.generatedOffset.generatedColumn); + }); + var section = this._sections[sectionIndex]; + + if (!section) { + return { + source: null, + line: null, + column: null, + name: null + }; + } + + return section.consumer.originalPositionFor({ + line: needle.generatedLine - + (section.generatedOffset.generatedLine - 1), + column: needle.generatedColumn - + (section.generatedOffset.generatedLine === needle.generatedLine + ? section.generatedOffset.generatedColumn - 1 + : 0), + bias: aArgs.bias + }); + }; + +/** + * Return true if we have the source content for every source in the source + * map, false otherwise. + */ +IndexedSourceMapConsumer.prototype.hasContentsOfAllSources = + function IndexedSourceMapConsumer_hasContentsOfAllSources() { + return this._sections.every(function (s) { + return s.consumer.hasContentsOfAllSources(); + }); + }; + +/** + * Returns the original source content. The only argument is the url of the + * original source file. Returns null if no original source content is + * available. + */ +IndexedSourceMapConsumer.prototype.sourceContentFor = + function IndexedSourceMapConsumer_sourceContentFor(aSource, nullOnMissing) { + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; + + var content = section.consumer.sourceContentFor(aSource, true); + if (content || content === '') { + return content; + } + } + if (nullOnMissing) { + return null; + } + else { + throw new Error('"' + aSource + '" is not in the SourceMap.'); + } + }; + +/** + * Returns the generated line and column information for the original source, + * line, and column positions provided. The only argument is an object with + * the following properties: + * + * - source: The filename of the original source. + * - line: The line number in the original source. The line number + * is 1-based. + * - column: The column number in the original source. The column + * number is 0-based. + * + * and an object is returned with the following properties: + * + * - line: The line number in the generated source, or null. The + * line number is 1-based. + * - column: The column number in the generated source, or null. + * The column number is 0-based. + */ +IndexedSourceMapConsumer.prototype.generatedPositionFor = + function IndexedSourceMapConsumer_generatedPositionFor(aArgs) { + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; + + // Only consider this section if the requested source is in the list of + // sources of the consumer. + if (section.consumer._findSourceIndex(util.getArg(aArgs, 'source')) === -1) { + continue; + } + var generatedPosition = section.consumer.generatedPositionFor(aArgs); + if (generatedPosition) { + var ret = { + line: generatedPosition.line + + (section.generatedOffset.generatedLine - 1), + column: generatedPosition.column + + (section.generatedOffset.generatedLine === generatedPosition.line + ? section.generatedOffset.generatedColumn - 1 + : 0) + }; + return ret; + } + } + + return { + line: null, + column: null + }; + }; + +/** + * Parse the mappings in a string in to a data structure which we can easily + * query (the ordered arrays in the `this.__generatedMappings` and + * `this.__originalMappings` properties). + */ +IndexedSourceMapConsumer.prototype._parseMappings = + function IndexedSourceMapConsumer_parseMappings(aStr, aSourceRoot) { + this.__generatedMappings = []; + this.__originalMappings = []; + for (var i = 0; i < this._sections.length; i++) { + var section = this._sections[i]; + var sectionMappings = section.consumer._generatedMappings; + for (var j = 0; j < sectionMappings.length; j++) { + var mapping = sectionMappings[j]; + + var source = section.consumer._sources.at(mapping.source); + source = util.computeSourceURL(section.consumer.sourceRoot, source, this._sourceMapURL); + this._sources.add(source); + source = this._sources.indexOf(source); + + var name = null; + if (mapping.name) { + name = section.consumer._names.at(mapping.name); + this._names.add(name); + name = this._names.indexOf(name); + } + + // The mappings coming from the consumer for the section have + // generated positions relative to the start of the section, so we + // need to offset them to be relative to the start of the concatenated + // generated file. + var adjustedMapping = { + source: source, + generatedLine: mapping.generatedLine + + (section.generatedOffset.generatedLine - 1), + generatedColumn: mapping.generatedColumn + + (section.generatedOffset.generatedLine === mapping.generatedLine + ? section.generatedOffset.generatedColumn - 1 + : 0), + originalLine: mapping.originalLine, + originalColumn: mapping.originalColumn, + name: name + }; + + this.__generatedMappings.push(adjustedMapping); + if (typeof adjustedMapping.originalLine === 'number') { + this.__originalMappings.push(adjustedMapping); + } + } + } + + quickSort(this.__generatedMappings, util.compareByGeneratedPositionsDeflated); + quickSort(this.__originalMappings, util.compareByOriginalPositions); + }; + +exports.IndexedSourceMapConsumer = IndexedSourceMapConsumer; diff --git a/node_modules/source-map-js/lib/source-map-generator.js b/node_modules/source-map-js/lib/source-map-generator.js new file mode 100644 index 0000000..bab04ff --- /dev/null +++ b/node_modules/source-map-js/lib/source-map-generator.js @@ -0,0 +1,444 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var base64VLQ = require('./base64-vlq'); +var util = require('./util'); +var ArraySet = require('./array-set').ArraySet; +var MappingList = require('./mapping-list').MappingList; + +/** + * An instance of the SourceMapGenerator represents a source map which is + * being built incrementally. You may pass an object with the following + * properties: + * + * - file: The filename of the generated source. + * - sourceRoot: A root for all relative URLs in this source map. + */ +function SourceMapGenerator(aArgs) { + if (!aArgs) { + aArgs = {}; + } + this._file = util.getArg(aArgs, 'file', null); + this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null); + this._skipValidation = util.getArg(aArgs, 'skipValidation', false); + this._ignoreInvalidMapping = util.getArg(aArgs, 'ignoreInvalidMapping', false); + this._sources = new ArraySet(); + this._names = new ArraySet(); + this._mappings = new MappingList(); + this._sourcesContents = null; +} + +SourceMapGenerator.prototype._version = 3; + +/** + * Creates a new SourceMapGenerator based on a SourceMapConsumer + * + * @param aSourceMapConsumer The SourceMap. + */ +SourceMapGenerator.fromSourceMap = + function SourceMapGenerator_fromSourceMap(aSourceMapConsumer, generatorOps) { + var sourceRoot = aSourceMapConsumer.sourceRoot; + var generator = new SourceMapGenerator(Object.assign(generatorOps || {}, { + file: aSourceMapConsumer.file, + sourceRoot: sourceRoot + })); + aSourceMapConsumer.eachMapping(function (mapping) { + var newMapping = { + generated: { + line: mapping.generatedLine, + column: mapping.generatedColumn + } + }; + + if (mapping.source != null) { + newMapping.source = mapping.source; + if (sourceRoot != null) { + newMapping.source = util.relative(sourceRoot, newMapping.source); + } + + newMapping.original = { + line: mapping.originalLine, + column: mapping.originalColumn + }; + + if (mapping.name != null) { + newMapping.name = mapping.name; + } + } + + generator.addMapping(newMapping); + }); + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var sourceRelative = sourceFile; + if (sourceRoot !== null) { + sourceRelative = util.relative(sourceRoot, sourceFile); + } + + if (!generator._sources.has(sourceRelative)) { + generator._sources.add(sourceRelative); + } + + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + generator.setSourceContent(sourceFile, content); + } + }); + return generator; + }; + +/** + * Add a single mapping from original source line and column to the generated + * source's line and column for this source map being created. The mapping + * object should have the following properties: + * + * - generated: An object with the generated line and column positions. + * - original: An object with the original line and column positions. + * - source: The original source file (relative to the sourceRoot). + * - name: An optional original token name for this mapping. + */ +SourceMapGenerator.prototype.addMapping = + function SourceMapGenerator_addMapping(aArgs) { + var generated = util.getArg(aArgs, 'generated'); + var original = util.getArg(aArgs, 'original', null); + var source = util.getArg(aArgs, 'source', null); + var name = util.getArg(aArgs, 'name', null); + + if (!this._skipValidation) { + if (this._validateMapping(generated, original, source, name) === false) { + return; + } + } + + if (source != null) { + source = String(source); + if (!this._sources.has(source)) { + this._sources.add(source); + } + } + + if (name != null) { + name = String(name); + if (!this._names.has(name)) { + this._names.add(name); + } + } + + this._mappings.add({ + generatedLine: generated.line, + generatedColumn: generated.column, + originalLine: original != null && original.line, + originalColumn: original != null && original.column, + source: source, + name: name + }); + }; + +/** + * Set the source content for a source file. + */ +SourceMapGenerator.prototype.setSourceContent = + function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) { + var source = aSourceFile; + if (this._sourceRoot != null) { + source = util.relative(this._sourceRoot, source); + } + + if (aSourceContent != null) { + // Add the source content to the _sourcesContents map. + // Create a new _sourcesContents map if the property is null. + if (!this._sourcesContents) { + this._sourcesContents = Object.create(null); + } + this._sourcesContents[util.toSetString(source)] = aSourceContent; + } else if (this._sourcesContents) { + // Remove the source file from the _sourcesContents map. + // If the _sourcesContents map is empty, set the property to null. + delete this._sourcesContents[util.toSetString(source)]; + if (Object.keys(this._sourcesContents).length === 0) { + this._sourcesContents = null; + } + } + }; + +/** + * Applies the mappings of a sub-source-map for a specific source file to the + * source map being generated. Each mapping to the supplied source file is + * rewritten using the supplied source map. Note: The resolution for the + * resulting mappings is the minimium of this map and the supplied map. + * + * @param aSourceMapConsumer The source map to be applied. + * @param aSourceFile Optional. The filename of the source file. + * If omitted, SourceMapConsumer's file property will be used. + * @param aSourceMapPath Optional. The dirname of the path to the source map + * to be applied. If relative, it is relative to the SourceMapConsumer. + * This parameter is needed when the two source maps aren't in the same + * directory, and the source map to be applied contains relative source + * paths. If so, those relative source paths need to be rewritten + * relative to the SourceMapGenerator. + */ +SourceMapGenerator.prototype.applySourceMap = + function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) { + var sourceFile = aSourceFile; + // If aSourceFile is omitted, we will use the file property of the SourceMap + if (aSourceFile == null) { + if (aSourceMapConsumer.file == null) { + throw new Error( + 'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' + + 'or the source map\'s "file" property. Both were omitted.' + ); + } + sourceFile = aSourceMapConsumer.file; + } + var sourceRoot = this._sourceRoot; + // Make "sourceFile" relative if an absolute Url is passed. + if (sourceRoot != null) { + sourceFile = util.relative(sourceRoot, sourceFile); + } + // Applying the SourceMap can add and remove items from the sources and + // the names array. + var newSources = new ArraySet(); + var newNames = new ArraySet(); + + // Find mappings for the "sourceFile" + this._mappings.unsortedForEach(function (mapping) { + if (mapping.source === sourceFile && mapping.originalLine != null) { + // Check if it can be mapped by the source map, then update the mapping. + var original = aSourceMapConsumer.originalPositionFor({ + line: mapping.originalLine, + column: mapping.originalColumn + }); + if (original.source != null) { + // Copy mapping + mapping.source = original.source; + if (aSourceMapPath != null) { + mapping.source = util.join(aSourceMapPath, mapping.source) + } + if (sourceRoot != null) { + mapping.source = util.relative(sourceRoot, mapping.source); + } + mapping.originalLine = original.line; + mapping.originalColumn = original.column; + if (original.name != null) { + mapping.name = original.name; + } + } + } + + var source = mapping.source; + if (source != null && !newSources.has(source)) { + newSources.add(source); + } + + var name = mapping.name; + if (name != null && !newNames.has(name)) { + newNames.add(name); + } + + }, this); + this._sources = newSources; + this._names = newNames; + + // Copy sourcesContents of applied map. + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + if (aSourceMapPath != null) { + sourceFile = util.join(aSourceMapPath, sourceFile); + } + if (sourceRoot != null) { + sourceFile = util.relative(sourceRoot, sourceFile); + } + this.setSourceContent(sourceFile, content); + } + }, this); + }; + +/** + * A mapping can have one of the three levels of data: + * + * 1. Just the generated position. + * 2. The Generated position, original position, and original source. + * 3. Generated and original position, original source, as well as a name + * token. + * + * To maintain consistency, we validate that any new mapping being added falls + * in to one of these categories. + */ +SourceMapGenerator.prototype._validateMapping = + function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource, + aName) { + // When aOriginal is truthy but has empty values for .line and .column, + // it is most likely a programmer error. In this case we throw a very + // specific error message to try to guide them the right way. + // For example: https://github.com/Polymer/polymer-bundler/pull/519 + if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') { + var message = 'original.line and original.column are not numbers -- you probably meant to omit ' + + 'the original mapping entirely and only map the generated position. If so, pass ' + + 'null for the original mapping instead of an object with empty or null values.' + + if (this._ignoreInvalidMapping) { + if (typeof console !== 'undefined' && console.warn) { + console.warn(message); + } + return false; + } else { + throw new Error(message); + } + } + + if (aGenerated && 'line' in aGenerated && 'column' in aGenerated + && aGenerated.line > 0 && aGenerated.column >= 0 + && !aOriginal && !aSource && !aName) { + // Case 1. + return; + } + else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated + && aOriginal && 'line' in aOriginal && 'column' in aOriginal + && aGenerated.line > 0 && aGenerated.column >= 0 + && aOriginal.line > 0 && aOriginal.column >= 0 + && aSource) { + // Cases 2 and 3. + return; + } + else { + var message = 'Invalid mapping: ' + JSON.stringify({ + generated: aGenerated, + source: aSource, + original: aOriginal, + name: aName + }); + + if (this._ignoreInvalidMapping) { + if (typeof console !== 'undefined' && console.warn) { + console.warn(message); + } + return false; + } else { + throw new Error(message) + } + } + }; + +/** + * Serialize the accumulated mappings in to the stream of base 64 VLQs + * specified by the source map format. + */ +SourceMapGenerator.prototype._serializeMappings = + function SourceMapGenerator_serializeMappings() { + var previousGeneratedColumn = 0; + var previousGeneratedLine = 1; + var previousOriginalColumn = 0; + var previousOriginalLine = 0; + var previousName = 0; + var previousSource = 0; + var result = ''; + var next; + var mapping; + var nameIdx; + var sourceIdx; + + var mappings = this._mappings.toArray(); + for (var i = 0, len = mappings.length; i < len; i++) { + mapping = mappings[i]; + next = '' + + if (mapping.generatedLine !== previousGeneratedLine) { + previousGeneratedColumn = 0; + while (mapping.generatedLine !== previousGeneratedLine) { + next += ';'; + previousGeneratedLine++; + } + } + else { + if (i > 0) { + if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) { + continue; + } + next += ','; + } + } + + next += base64VLQ.encode(mapping.generatedColumn + - previousGeneratedColumn); + previousGeneratedColumn = mapping.generatedColumn; + + if (mapping.source != null) { + sourceIdx = this._sources.indexOf(mapping.source); + next += base64VLQ.encode(sourceIdx - previousSource); + previousSource = sourceIdx; + + // lines are stored 0-based in SourceMap spec version 3 + next += base64VLQ.encode(mapping.originalLine - 1 + - previousOriginalLine); + previousOriginalLine = mapping.originalLine - 1; + + next += base64VLQ.encode(mapping.originalColumn + - previousOriginalColumn); + previousOriginalColumn = mapping.originalColumn; + + if (mapping.name != null) { + nameIdx = this._names.indexOf(mapping.name); + next += base64VLQ.encode(nameIdx - previousName); + previousName = nameIdx; + } + } + + result += next; + } + + return result; + }; + +SourceMapGenerator.prototype._generateSourcesContent = + function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) { + return aSources.map(function (source) { + if (!this._sourcesContents) { + return null; + } + if (aSourceRoot != null) { + source = util.relative(aSourceRoot, source); + } + var key = util.toSetString(source); + return Object.prototype.hasOwnProperty.call(this._sourcesContents, key) + ? this._sourcesContents[key] + : null; + }, this); + }; + +/** + * Externalize the source map. + */ +SourceMapGenerator.prototype.toJSON = + function SourceMapGenerator_toJSON() { + var map = { + version: this._version, + sources: this._sources.toArray(), + names: this._names.toArray(), + mappings: this._serializeMappings() + }; + if (this._file != null) { + map.file = this._file; + } + if (this._sourceRoot != null) { + map.sourceRoot = this._sourceRoot; + } + if (this._sourcesContents) { + map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot); + } + + return map; + }; + +/** + * Render the source map being generated to a string. + */ +SourceMapGenerator.prototype.toString = + function SourceMapGenerator_toString() { + return JSON.stringify(this.toJSON()); + }; + +exports.SourceMapGenerator = SourceMapGenerator; diff --git a/node_modules/source-map-js/lib/source-node.js b/node_modules/source-map-js/lib/source-node.js new file mode 100644 index 0000000..8bcdbe3 --- /dev/null +++ b/node_modules/source-map-js/lib/source-node.js @@ -0,0 +1,413 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +var SourceMapGenerator = require('./source-map-generator').SourceMapGenerator; +var util = require('./util'); + +// Matches a Windows-style `\r\n` newline or a `\n` newline used by all other +// operating systems these days (capturing the result). +var REGEX_NEWLINE = /(\r?\n)/; + +// Newline character code for charCodeAt() comparisons +var NEWLINE_CODE = 10; + +// Private symbol for identifying `SourceNode`s when multiple versions of +// the source-map library are loaded. This MUST NOT CHANGE across +// versions! +var isSourceNode = "$$$isSourceNode$$$"; + +/** + * SourceNodes provide a way to abstract over interpolating/concatenating + * snippets of generated JavaScript source code while maintaining the line and + * column information associated with the original source code. + * + * @param aLine The original line number. + * @param aColumn The original column number. + * @param aSource The original source's filename. + * @param aChunks Optional. An array of strings which are snippets of + * generated JS, or other SourceNodes. + * @param aName The original identifier. + */ +function SourceNode(aLine, aColumn, aSource, aChunks, aName) { + this.children = []; + this.sourceContents = {}; + this.line = aLine == null ? null : aLine; + this.column = aColumn == null ? null : aColumn; + this.source = aSource == null ? null : aSource; + this.name = aName == null ? null : aName; + this[isSourceNode] = true; + if (aChunks != null) this.add(aChunks); +} + +/** + * Creates a SourceNode from generated code and a SourceMapConsumer. + * + * @param aGeneratedCode The generated code + * @param aSourceMapConsumer The SourceMap for the generated code + * @param aRelativePath Optional. The path that relative sources in the + * SourceMapConsumer should be relative to. + */ +SourceNode.fromStringWithSourceMap = + function SourceNode_fromStringWithSourceMap(aGeneratedCode, aSourceMapConsumer, aRelativePath) { + // The SourceNode we want to fill with the generated code + // and the SourceMap + var node = new SourceNode(); + + // All even indices of this array are one line of the generated code, + // while all odd indices are the newlines between two adjacent lines + // (since `REGEX_NEWLINE` captures its match). + // Processed fragments are accessed by calling `shiftNextLine`. + var remainingLines = aGeneratedCode.split(REGEX_NEWLINE); + var remainingLinesIndex = 0; + var shiftNextLine = function() { + var lineContents = getNextLine(); + // The last line of a file might not have a newline. + var newLine = getNextLine() || ""; + return lineContents + newLine; + + function getNextLine() { + return remainingLinesIndex < remainingLines.length ? + remainingLines[remainingLinesIndex++] : undefined; + } + }; + + // We need to remember the position of "remainingLines" + var lastGeneratedLine = 1, lastGeneratedColumn = 0; + + // The generate SourceNodes we need a code range. + // To extract it current and last mapping is used. + // Here we store the last mapping. + var lastMapping = null; + + aSourceMapConsumer.eachMapping(function (mapping) { + if (lastMapping !== null) { + // We add the code from "lastMapping" to "mapping": + // First check if there is a new line in between. + if (lastGeneratedLine < mapping.generatedLine) { + // Associate first line with "lastMapping" + addMappingWithCode(lastMapping, shiftNextLine()); + lastGeneratedLine++; + lastGeneratedColumn = 0; + // The remaining code is added without mapping + } else { + // There is no new line in between. + // Associate the code between "lastGeneratedColumn" and + // "mapping.generatedColumn" with "lastMapping" + var nextLine = remainingLines[remainingLinesIndex] || ''; + var code = nextLine.substr(0, mapping.generatedColumn - + lastGeneratedColumn); + remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn - + lastGeneratedColumn); + lastGeneratedColumn = mapping.generatedColumn; + addMappingWithCode(lastMapping, code); + // No more remaining code, continue + lastMapping = mapping; + return; + } + } + // We add the generated code until the first mapping + // to the SourceNode without any mapping. + // Each line is added as separate string. + while (lastGeneratedLine < mapping.generatedLine) { + node.add(shiftNextLine()); + lastGeneratedLine++; + } + if (lastGeneratedColumn < mapping.generatedColumn) { + var nextLine = remainingLines[remainingLinesIndex] || ''; + node.add(nextLine.substr(0, mapping.generatedColumn)); + remainingLines[remainingLinesIndex] = nextLine.substr(mapping.generatedColumn); + lastGeneratedColumn = mapping.generatedColumn; + } + lastMapping = mapping; + }, this); + // We have processed all mappings. + if (remainingLinesIndex < remainingLines.length) { + if (lastMapping) { + // Associate the remaining code in the current line with "lastMapping" + addMappingWithCode(lastMapping, shiftNextLine()); + } + // and add the remaining lines without any mapping + node.add(remainingLines.splice(remainingLinesIndex).join("")); + } + + // Copy sourcesContent into SourceNode + aSourceMapConsumer.sources.forEach(function (sourceFile) { + var content = aSourceMapConsumer.sourceContentFor(sourceFile); + if (content != null) { + if (aRelativePath != null) { + sourceFile = util.join(aRelativePath, sourceFile); + } + node.setSourceContent(sourceFile, content); + } + }); + + return node; + + function addMappingWithCode(mapping, code) { + if (mapping === null || mapping.source === undefined) { + node.add(code); + } else { + var source = aRelativePath + ? util.join(aRelativePath, mapping.source) + : mapping.source; + node.add(new SourceNode(mapping.originalLine, + mapping.originalColumn, + source, + code, + mapping.name)); + } + } + }; + +/** + * Add a chunk of generated JS to this source node. + * + * @param aChunk A string snippet of generated JS code, another instance of + * SourceNode, or an array where each member is one of those things. + */ +SourceNode.prototype.add = function SourceNode_add(aChunk) { + if (Array.isArray(aChunk)) { + aChunk.forEach(function (chunk) { + this.add(chunk); + }, this); + } + else if (aChunk[isSourceNode] || typeof aChunk === "string") { + if (aChunk) { + this.children.push(aChunk); + } + } + else { + throw new TypeError( + "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk + ); + } + return this; +}; + +/** + * Add a chunk of generated JS to the beginning of this source node. + * + * @param aChunk A string snippet of generated JS code, another instance of + * SourceNode, or an array where each member is one of those things. + */ +SourceNode.prototype.prepend = function SourceNode_prepend(aChunk) { + if (Array.isArray(aChunk)) { + for (var i = aChunk.length-1; i >= 0; i--) { + this.prepend(aChunk[i]); + } + } + else if (aChunk[isSourceNode] || typeof aChunk === "string") { + this.children.unshift(aChunk); + } + else { + throw new TypeError( + "Expected a SourceNode, string, or an array of SourceNodes and strings. Got " + aChunk + ); + } + return this; +}; + +/** + * Walk over the tree of JS snippets in this node and its children. The + * walking function is called once for each snippet of JS and is passed that + * snippet and the its original associated source's line/column location. + * + * @param aFn The traversal function. + */ +SourceNode.prototype.walk = function SourceNode_walk(aFn) { + var chunk; + for (var i = 0, len = this.children.length; i < len; i++) { + chunk = this.children[i]; + if (chunk[isSourceNode]) { + chunk.walk(aFn); + } + else { + if (chunk !== '') { + aFn(chunk, { source: this.source, + line: this.line, + column: this.column, + name: this.name }); + } + } + } +}; + +/** + * Like `String.prototype.join` except for SourceNodes. Inserts `aStr` between + * each of `this.children`. + * + * @param aSep The separator. + */ +SourceNode.prototype.join = function SourceNode_join(aSep) { + var newChildren; + var i; + var len = this.children.length; + if (len > 0) { + newChildren = []; + for (i = 0; i < len-1; i++) { + newChildren.push(this.children[i]); + newChildren.push(aSep); + } + newChildren.push(this.children[i]); + this.children = newChildren; + } + return this; +}; + +/** + * Call String.prototype.replace on the very right-most source snippet. Useful + * for trimming whitespace from the end of a source node, etc. + * + * @param aPattern The pattern to replace. + * @param aReplacement The thing to replace the pattern with. + */ +SourceNode.prototype.replaceRight = function SourceNode_replaceRight(aPattern, aReplacement) { + var lastChild = this.children[this.children.length - 1]; + if (lastChild[isSourceNode]) { + lastChild.replaceRight(aPattern, aReplacement); + } + else if (typeof lastChild === 'string') { + this.children[this.children.length - 1] = lastChild.replace(aPattern, aReplacement); + } + else { + this.children.push(''.replace(aPattern, aReplacement)); + } + return this; +}; + +/** + * Set the source content for a source file. This will be added to the SourceMapGenerator + * in the sourcesContent field. + * + * @param aSourceFile The filename of the source file + * @param aSourceContent The content of the source file + */ +SourceNode.prototype.setSourceContent = + function SourceNode_setSourceContent(aSourceFile, aSourceContent) { + this.sourceContents[util.toSetString(aSourceFile)] = aSourceContent; + }; + +/** + * Walk over the tree of SourceNodes. The walking function is called for each + * source file content and is passed the filename and source content. + * + * @param aFn The traversal function. + */ +SourceNode.prototype.walkSourceContents = + function SourceNode_walkSourceContents(aFn) { + for (var i = 0, len = this.children.length; i < len; i++) { + if (this.children[i][isSourceNode]) { + this.children[i].walkSourceContents(aFn); + } + } + + var sources = Object.keys(this.sourceContents); + for (var i = 0, len = sources.length; i < len; i++) { + aFn(util.fromSetString(sources[i]), this.sourceContents[sources[i]]); + } + }; + +/** + * Return the string representation of this source node. Walks over the tree + * and concatenates all the various snippets together to one string. + */ +SourceNode.prototype.toString = function SourceNode_toString() { + var str = ""; + this.walk(function (chunk) { + str += chunk; + }); + return str; +}; + +/** + * Returns the string representation of this source node along with a source + * map. + */ +SourceNode.prototype.toStringWithSourceMap = function SourceNode_toStringWithSourceMap(aArgs) { + var generated = { + code: "", + line: 1, + column: 0 + }; + var map = new SourceMapGenerator(aArgs); + var sourceMappingActive = false; + var lastOriginalSource = null; + var lastOriginalLine = null; + var lastOriginalColumn = null; + var lastOriginalName = null; + this.walk(function (chunk, original) { + generated.code += chunk; + if (original.source !== null + && original.line !== null + && original.column !== null) { + if(lastOriginalSource !== original.source + || lastOriginalLine !== original.line + || lastOriginalColumn !== original.column + || lastOriginalName !== original.name) { + map.addMapping({ + source: original.source, + original: { + line: original.line, + column: original.column + }, + generated: { + line: generated.line, + column: generated.column + }, + name: original.name + }); + } + lastOriginalSource = original.source; + lastOriginalLine = original.line; + lastOriginalColumn = original.column; + lastOriginalName = original.name; + sourceMappingActive = true; + } else if (sourceMappingActive) { + map.addMapping({ + generated: { + line: generated.line, + column: generated.column + } + }); + lastOriginalSource = null; + sourceMappingActive = false; + } + for (var idx = 0, length = chunk.length; idx < length; idx++) { + if (chunk.charCodeAt(idx) === NEWLINE_CODE) { + generated.line++; + generated.column = 0; + // Mappings end at eol + if (idx + 1 === length) { + lastOriginalSource = null; + sourceMappingActive = false; + } else if (sourceMappingActive) { + map.addMapping({ + source: original.source, + original: { + line: original.line, + column: original.column + }, + generated: { + line: generated.line, + column: generated.column + }, + name: original.name + }); + } + } else { + generated.column++; + } + } + }); + this.walkSourceContents(function (sourceFile, sourceContent) { + map.setSourceContent(sourceFile, sourceContent); + }); + + return { code: generated.code, map: map }; +}; + +exports.SourceNode = SourceNode; diff --git a/node_modules/source-map-js/lib/util.js b/node_modules/source-map-js/lib/util.js new file mode 100644 index 0000000..430e2d0 --- /dev/null +++ b/node_modules/source-map-js/lib/util.js @@ -0,0 +1,594 @@ +/* -*- Mode: js; js-indent-level: 2; -*- */ +/* + * Copyright 2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE or: + * http://opensource.org/licenses/BSD-3-Clause + */ + +/** + * This is a helper function for getting values from parameter/options + * objects. + * + * @param args The object we are extracting values from + * @param name The name of the property we are getting. + * @param defaultValue An optional value to return if the property is missing + * from the object. If this is not specified and the property is missing, an + * error will be thrown. + */ +function getArg(aArgs, aName, aDefaultValue) { + if (aName in aArgs) { + return aArgs[aName]; + } else if (arguments.length === 3) { + return aDefaultValue; + } else { + throw new Error('"' + aName + '" is a required argument.'); + } +} +exports.getArg = getArg; + +var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/; +var dataUrlRegexp = /^data:.+\,.+$/; + +function urlParse(aUrl) { + var match = aUrl.match(urlRegexp); + if (!match) { + return null; + } + return { + scheme: match[1], + auth: match[2], + host: match[3], + port: match[4], + path: match[5] + }; +} +exports.urlParse = urlParse; + +function urlGenerate(aParsedUrl) { + var url = ''; + if (aParsedUrl.scheme) { + url += aParsedUrl.scheme + ':'; + } + url += '//'; + if (aParsedUrl.auth) { + url += aParsedUrl.auth + '@'; + } + if (aParsedUrl.host) { + url += aParsedUrl.host; + } + if (aParsedUrl.port) { + url += ":" + aParsedUrl.port + } + if (aParsedUrl.path) { + url += aParsedUrl.path; + } + return url; +} +exports.urlGenerate = urlGenerate; + +var MAX_CACHED_INPUTS = 32; + +/** + * Takes some function `f(input) -> result` and returns a memoized version of + * `f`. + * + * We keep at most `MAX_CACHED_INPUTS` memoized results of `f` alive. The + * memoization is a dumb-simple, linear least-recently-used cache. + */ +function lruMemoize(f) { + var cache = []; + + return function(input) { + for (var i = 0; i < cache.length; i++) { + if (cache[i].input === input) { + var temp = cache[0]; + cache[0] = cache[i]; + cache[i] = temp; + return cache[0].result; + } + } + + var result = f(input); + + cache.unshift({ + input, + result, + }); + + if (cache.length > MAX_CACHED_INPUTS) { + cache.pop(); + } + + return result; + }; +} + +/** + * Normalizes a path, or the path portion of a URL: + * + * - Replaces consecutive slashes with one slash. + * - Removes unnecessary '.' parts. + * - Removes unnecessary '/..' parts. + * + * Based on code in the Node.js 'path' core module. + * + * @param aPath The path or url to normalize. + */ +var normalize = lruMemoize(function normalize(aPath) { + var path = aPath; + var url = urlParse(aPath); + if (url) { + if (!url.path) { + return aPath; + } + path = url.path; + } + var isAbsolute = exports.isAbsolute(path); + // Split the path into parts between `/` characters. This is much faster than + // using `.split(/\/+/g)`. + var parts = []; + var start = 0; + var i = 0; + while (true) { + start = i; + i = path.indexOf("/", start); + if (i === -1) { + parts.push(path.slice(start)); + break; + } else { + parts.push(path.slice(start, i)); + while (i < path.length && path[i] === "/") { + i++; + } + } + } + + for (var part, up = 0, i = parts.length - 1; i >= 0; i--) { + part = parts[i]; + if (part === '.') { + parts.splice(i, 1); + } else if (part === '..') { + up++; + } else if (up > 0) { + if (part === '') { + // The first part is blank if the path is absolute. Trying to go + // above the root is a no-op. Therefore we can remove all '..' parts + // directly after the root. + parts.splice(i + 1, up); + up = 0; + } else { + parts.splice(i, 2); + up--; + } + } + } + path = parts.join('/'); + + if (path === '') { + path = isAbsolute ? '/' : '.'; + } + + if (url) { + url.path = path; + return urlGenerate(url); + } + return path; +}); +exports.normalize = normalize; + +/** + * Joins two paths/URLs. + * + * @param aRoot The root path or URL. + * @param aPath The path or URL to be joined with the root. + * + * - If aPath is a URL or a data URI, aPath is returned, unless aPath is a + * scheme-relative URL: Then the scheme of aRoot, if any, is prepended + * first. + * - Otherwise aPath is a path. If aRoot is a URL, then its path portion + * is updated with the result and aRoot is returned. Otherwise the result + * is returned. + * - If aPath is absolute, the result is aPath. + * - Otherwise the two paths are joined with a slash. + * - Joining for example 'http://' and 'www.example.com' is also supported. + */ +function join(aRoot, aPath) { + if (aRoot === "") { + aRoot = "."; + } + if (aPath === "") { + aPath = "."; + } + var aPathUrl = urlParse(aPath); + var aRootUrl = urlParse(aRoot); + if (aRootUrl) { + aRoot = aRootUrl.path || '/'; + } + + // `join(foo, '//www.example.org')` + if (aPathUrl && !aPathUrl.scheme) { + if (aRootUrl) { + aPathUrl.scheme = aRootUrl.scheme; + } + return urlGenerate(aPathUrl); + } + + if (aPathUrl || aPath.match(dataUrlRegexp)) { + return aPath; + } + + // `join('http://', 'www.example.com')` + if (aRootUrl && !aRootUrl.host && !aRootUrl.path) { + aRootUrl.host = aPath; + return urlGenerate(aRootUrl); + } + + var joined = aPath.charAt(0) === '/' + ? aPath + : normalize(aRoot.replace(/\/+$/, '') + '/' + aPath); + + if (aRootUrl) { + aRootUrl.path = joined; + return urlGenerate(aRootUrl); + } + return joined; +} +exports.join = join; + +exports.isAbsolute = function (aPath) { + return aPath.charAt(0) === '/' || urlRegexp.test(aPath); +}; + +/** + * Make a path relative to a URL or another path. + * + * @param aRoot The root path or URL. + * @param aPath The path or URL to be made relative to aRoot. + */ +function relative(aRoot, aPath) { + if (aRoot === "") { + aRoot = "."; + } + + aRoot = aRoot.replace(/\/$/, ''); + + // It is possible for the path to be above the root. In this case, simply + // checking whether the root is a prefix of the path won't work. Instead, we + // need to remove components from the root one by one, until either we find + // a prefix that fits, or we run out of components to remove. + var level = 0; + while (aPath.indexOf(aRoot + '/') !== 0) { + var index = aRoot.lastIndexOf("/"); + if (index < 0) { + return aPath; + } + + // If the only part of the root that is left is the scheme (i.e. http://, + // file:///, etc.), one or more slashes (/), or simply nothing at all, we + // have exhausted all components, so the path is not relative to the root. + aRoot = aRoot.slice(0, index); + if (aRoot.match(/^([^\/]+:\/)?\/*$/)) { + return aPath; + } + + ++level; + } + + // Make sure we add a "../" for each component we removed from the root. + return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1); +} +exports.relative = relative; + +var supportsNullProto = (function () { + var obj = Object.create(null); + return !('__proto__' in obj); +}()); + +function identity (s) { + return s; +} + +/** + * Because behavior goes wacky when you set `__proto__` on objects, we + * have to prefix all the strings in our set with an arbitrary character. + * + * See https://github.com/mozilla/source-map/pull/31 and + * https://github.com/mozilla/source-map/issues/30 + * + * @param String aStr + */ +function toSetString(aStr) { + if (isProtoString(aStr)) { + return '$' + aStr; + } + + return aStr; +} +exports.toSetString = supportsNullProto ? identity : toSetString; + +function fromSetString(aStr) { + if (isProtoString(aStr)) { + return aStr.slice(1); + } + + return aStr; +} +exports.fromSetString = supportsNullProto ? identity : fromSetString; + +function isProtoString(s) { + if (!s) { + return false; + } + + var length = s.length; + + if (length < 9 /* "__proto__".length */) { + return false; + } + + if (s.charCodeAt(length - 1) !== 95 /* '_' */ || + s.charCodeAt(length - 2) !== 95 /* '_' */ || + s.charCodeAt(length - 3) !== 111 /* 'o' */ || + s.charCodeAt(length - 4) !== 116 /* 't' */ || + s.charCodeAt(length - 5) !== 111 /* 'o' */ || + s.charCodeAt(length - 6) !== 114 /* 'r' */ || + s.charCodeAt(length - 7) !== 112 /* 'p' */ || + s.charCodeAt(length - 8) !== 95 /* '_' */ || + s.charCodeAt(length - 9) !== 95 /* '_' */) { + return false; + } + + for (var i = length - 10; i >= 0; i--) { + if (s.charCodeAt(i) !== 36 /* '$' */) { + return false; + } + } + + return true; +} + +/** + * Comparator between two mappings where the original positions are compared. + * + * Optionally pass in `true` as `onlyCompareGenerated` to consider two + * mappings with the same original source/line/column, but different generated + * line and column the same. Useful when searching for a mapping with a + * stubbed out mapping. + */ +function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) { + var cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0 || onlyCompareOriginal) { + return cmp; + } + + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByOriginalPositions = compareByOriginalPositions; + +function compareByOriginalPositionsNoSource(mappingA, mappingB, onlyCompareOriginal) { + var cmp + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0 || onlyCompareOriginal) { + return cmp; + } + + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByOriginalPositionsNoSource = compareByOriginalPositionsNoSource; + +/** + * Comparator between two mappings with deflated source and name indices where + * the generated positions are compared. + * + * Optionally pass in `true` as `onlyCompareGenerated` to consider two + * mappings with the same generated line and column, but different + * source/name/original line and column the same. Useful when searching for a + * mapping with a stubbed out mapping. + */ +function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) { + var cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0 || onlyCompareGenerated) { + return cmp; + } + + cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated; + +function compareByGeneratedPositionsDeflatedNoLine(mappingA, mappingB, onlyCompareGenerated) { + var cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0 || onlyCompareGenerated) { + return cmp; + } + + cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByGeneratedPositionsDeflatedNoLine = compareByGeneratedPositionsDeflatedNoLine; + +function strcmp(aStr1, aStr2) { + if (aStr1 === aStr2) { + return 0; + } + + if (aStr1 === null) { + return 1; // aStr2 !== null + } + + if (aStr2 === null) { + return -1; // aStr1 !== null + } + + if (aStr1 > aStr2) { + return 1; + } + + return -1; +} + +/** + * Comparator between two mappings with inflated source and name strings where + * the generated positions are compared. + */ +function compareByGeneratedPositionsInflated(mappingA, mappingB) { + var cmp = mappingA.generatedLine - mappingB.generatedLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.generatedColumn - mappingB.generatedColumn; + if (cmp !== 0) { + return cmp; + } + + cmp = strcmp(mappingA.source, mappingB.source); + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalLine - mappingB.originalLine; + if (cmp !== 0) { + return cmp; + } + + cmp = mappingA.originalColumn - mappingB.originalColumn; + if (cmp !== 0) { + return cmp; + } + + return strcmp(mappingA.name, mappingB.name); +} +exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated; + +/** + * Strip any JSON XSSI avoidance prefix from the string (as documented + * in the source maps specification), and then parse the string as + * JSON. + */ +function parseSourceMapInput(str) { + return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, '')); +} +exports.parseSourceMapInput = parseSourceMapInput; + +/** + * Compute the URL of a source given the the source root, the source's + * URL, and the source map's URL. + */ +function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) { + sourceURL = sourceURL || ''; + + if (sourceRoot) { + // This follows what Chrome does. + if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') { + sourceRoot += '/'; + } + // The spec says: + // Line 4: An optional source root, useful for relocating source + // files on a server or removing repeated values in the + // “sources” entry. This value is prepended to the individual + // entries in the “source” field. + sourceURL = sourceRoot + sourceURL; + } + + // Historically, SourceMapConsumer did not take the sourceMapURL as + // a parameter. This mode is still somewhat supported, which is why + // this code block is conditional. However, it's preferable to pass + // the source map URL to SourceMapConsumer, so that this function + // can implement the source URL resolution algorithm as outlined in + // the spec. This block is basically the equivalent of: + // new URL(sourceURL, sourceMapURL).toString() + // ... except it avoids using URL, which wasn't available in the + // older releases of node still supported by this library. + // + // The spec says: + // If the sources are not absolute URLs after prepending of the + // “sourceRoot”, the sources are resolved relative to the + // SourceMap (like resolving script src in a html document). + if (sourceMapURL) { + var parsed = urlParse(sourceMapURL); + if (!parsed) { + throw new Error("sourceMapURL could not be parsed"); + } + if (parsed.path) { + // Strip the last path component, but keep the "/". + var index = parsed.path.lastIndexOf('/'); + if (index >= 0) { + parsed.path = parsed.path.substring(0, index + 1); + } + } + sourceURL = join(urlGenerate(parsed), sourceURL); + } + + return normalize(sourceURL); +} +exports.computeSourceURL = computeSourceURL; diff --git a/node_modules/source-map-js/package.json b/node_modules/source-map-js/package.json new file mode 100644 index 0000000..f16eb36 --- /dev/null +++ b/node_modules/source-map-js/package.json @@ -0,0 +1,71 @@ +{ + "name": "source-map-js", + "description": "Generates and consumes source maps", + "version": "1.2.0", + "homepage": "https://github.com/7rulnik/source-map-js", + "author": "Valentin 7rulnik Semirulnik ", + "contributors": [ + "Nick Fitzgerald ", + "Tobias Koppers ", + "Duncan Beevers ", + "Stephen Crane ", + "Ryan Seddon ", + "Miles Elam ", + "Mihai Bazon ", + "Michael Ficarra ", + "Todd Wolfson ", + "Alexander Solovyov ", + "Felix Gnass ", + "Conrad Irwin ", + "usrbincc ", + "David Glasser ", + "Chase Douglas ", + "Evan Wallace ", + "Heather Arthur ", + "Hugh Kennedy ", + "David Glasser ", + "Simon Lydell ", + "Jmeas Smith ", + "Michael Z Goddard ", + "azu ", + "John Gozde ", + "Adam Kirkton ", + "Chris Montgomery ", + "J. Ryan Stinnett ", + "Jack Herrington ", + "Chris Truter ", + "Daniel Espeset ", + "Jamie Wong ", + "Eddy Bruël ", + "Hawken Rives ", + "Gilad Peleg ", + "djchie ", + "Gary Ye ", + "Nicolas Lalevée " + ], + "repository": "7rulnik/source-map-js", + "main": "./source-map.js", + "files": [ + "source-map.js", + "source-map.d.ts", + "lib/" + ], + "engines": { + "node": ">=0.10.0" + }, + "license": "BSD-3-Clause", + "scripts": { + "test": "npm run build && node test/run-tests.js", + "build": "webpack --color", + "toc": "doctoc --title '## Table of Contents' README.md && doctoc --title '## Table of Contents' CONTRIBUTING.md" + }, + "devDependencies": { + "clean-publish": "^3.1.0", + "doctoc": "^0.15.0", + "webpack": "^1.12.0" + }, + "clean-publish": { + "cleanDocs": true + }, + "typings": "source-map.d.ts" +} diff --git a/node_modules/source-map-js/source-map.d.ts b/node_modules/source-map-js/source-map.d.ts new file mode 100644 index 0000000..9f8a4b3 --- /dev/null +++ b/node_modules/source-map-js/source-map.d.ts @@ -0,0 +1,115 @@ +declare module 'source-map-js' { + export interface StartOfSourceMap { + file?: string; + sourceRoot?: string; + } + + export interface RawSourceMap extends StartOfSourceMap { + version: string; + sources: string[]; + names: string[]; + sourcesContent?: string[]; + mappings: string; + } + + export interface Position { + line: number; + column: number; + } + + export interface LineRange extends Position { + lastColumn: number; + } + + export interface FindPosition extends Position { + // SourceMapConsumer.GREATEST_LOWER_BOUND or SourceMapConsumer.LEAST_UPPER_BOUND + bias?: number; + } + + export interface SourceFindPosition extends FindPosition { + source: string; + } + + export interface MappedPosition extends Position { + source: string; + name?: string; + } + + export interface MappingItem { + source: string; + generatedLine: number; + generatedColumn: number; + originalLine: number; + originalColumn: number; + name: string; + } + + export class SourceMapConsumer { + static GENERATED_ORDER: number; + static ORIGINAL_ORDER: number; + + static GREATEST_LOWER_BOUND: number; + static LEAST_UPPER_BOUND: number; + + constructor(rawSourceMap: RawSourceMap); + computeColumnSpans(): void; + originalPositionFor(generatedPosition: FindPosition): MappedPosition; + generatedPositionFor(originalPosition: SourceFindPosition): LineRange; + allGeneratedPositionsFor(originalPosition: MappedPosition): Position[]; + hasContentsOfAllSources(): boolean; + sourceContentFor(source: string, returnNullOnMissing?: boolean): string; + eachMapping(callback: (mapping: MappingItem) => void, context?: any, order?: number): void; + } + + export interface Mapping { + generated: Position; + original: Position; + source: string; + name?: string; + } + + export class SourceMapGenerator { + constructor(startOfSourceMap?: StartOfSourceMap); + static fromSourceMap(sourceMapConsumer: SourceMapConsumer): SourceMapGenerator; + addMapping(mapping: Mapping): void; + setSourceContent(sourceFile: string, sourceContent: string): void; + applySourceMap(sourceMapConsumer: SourceMapConsumer, sourceFile?: string, sourceMapPath?: string): void; + toString(): string; + } + + export interface CodeWithSourceMap { + code: string; + map: SourceMapGenerator; + } + + export class SourceNode { + constructor(); + constructor(line: number, column: number, source: string); + constructor(line: number, column: number, source: string, chunk?: string, name?: string); + static fromStringWithSourceMap(code: string, sourceMapConsumer: SourceMapConsumer, relativePath?: string): SourceNode; + add(chunk: string): void; + prepend(chunk: string): void; + setSourceContent(sourceFile: string, sourceContent: string): void; + walk(fn: (chunk: string, mapping: MappedPosition) => void): void; + walkSourceContents(fn: (file: string, content: string) => void): void; + join(sep: string): SourceNode; + replaceRight(pattern: string, replacement: string): SourceNode; + toString(): string; + toStringWithSourceMap(startOfSourceMap?: StartOfSourceMap): CodeWithSourceMap; + } +} + +declare module 'source-map-js/lib/source-map-generator' { + import { SourceMapGenerator } from 'source-map-js' + export { SourceMapGenerator } +} + +declare module 'source-map-js/lib/source-map-consumer' { + import { SourceMapConsumer } from 'source-map-js' + export { SourceMapConsumer } +} + +declare module 'source-map-js/lib/source-node' { + import { SourceNode } from 'source-map-js' + export { SourceNode } +} diff --git a/node_modules/source-map-js/source-map.js b/node_modules/source-map-js/source-map.js new file mode 100644 index 0000000..bc88fe8 --- /dev/null +++ b/node_modules/source-map-js/source-map.js @@ -0,0 +1,8 @@ +/* + * Copyright 2009-2011 Mozilla Foundation and contributors + * Licensed under the New BSD license. See LICENSE.txt or: + * http://opensource.org/licenses/BSD-3-Clause + */ +exports.SourceMapGenerator = require('./lib/source-map-generator').SourceMapGenerator; +exports.SourceMapConsumer = require('./lib/source-map-consumer').SourceMapConsumer; +exports.SourceNode = require('./lib/source-node').SourceNode; diff --git a/node_modules/supports-preserve-symlinks-flag/.DS_Store b/node_modules/supports-preserve-symlinks-flag/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..6887bdeac243d119b6e9cbbe4074a41b150c8d3b GIT binary patch literal 6148 zcmeHKO-jR15T1zvBW}8MCGP}6ZxBm7L09f1R$8GU1zX$(J&xz_7H+(N3s2xTGcPeE z5nPGr49xpp<|p&=<&nuFBA)FQQ=$nGWl+K72*ZeoUvwZzw1|`S9xK{Wxn54^*YzOU z4Zo2Ad3T3&MoYS-E%n}CwXx+Um&1svE{bwpm+)k#_m6M<{(L?bwfIKVW+l6&ttR`B zQmo{L?r3W}sr4nVeP4eKFHaBc8oJ!7{;WRcAE_&~U7P`Dz!~@t44`L=WXFa+Is?vt zGte<0--iGd%p*32`su)+M*v_7vkK<=4+jil0Ok=JLs%eesX$BRc*I~!hdso&JYr*L z>BL$Y_lcD`o={k;!yYu8I5+gs8E^*n891=ZiS+-Auh0McNq*%FI0Ju*0Zxl~F~cLp x-a2?V>9qlR1r?FF#;{AlL|ZXpr4^q*RbUS?0p<}KLs%gGBcL?+;0*jI10QG!ON9Uc literal 0 HcmV?d00001 diff --git a/node_modules/supports-preserve-symlinks-flag/.eslintrc b/node_modules/supports-preserve-symlinks-flag/.eslintrc new file mode 100644 index 0000000..346ffec --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/.eslintrc @@ -0,0 +1,14 @@ +{ + "root": true, + + "extends": "@ljharb", + + "env": { + "browser": true, + "node": true, + }, + + "rules": { + "id-length": "off", + }, +} diff --git a/node_modules/supports-preserve-symlinks-flag/.github/FUNDING.yml b/node_modules/supports-preserve-symlinks-flag/.github/FUNDING.yml new file mode 100644 index 0000000..e8d64f3 --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/.github/FUNDING.yml @@ -0,0 +1,12 @@ +# These are supported funding model platforms + +github: [ljharb] +patreon: # Replace with a single Patreon username +open_collective: # Replace with a single Open Collective username +ko_fi: # Replace with a single Ko-fi username +tidelift: npm/supports-preserve-symlink-flag +community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry +liberapay: # Replace with a single Liberapay username +issuehunt: # Replace with a single IssueHunt username +otechie: # Replace with a single Otechie username +custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2'] diff --git a/node_modules/supports-preserve-symlinks-flag/.nycrc b/node_modules/supports-preserve-symlinks-flag/.nycrc new file mode 100644 index 0000000..bdd626c --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/.nycrc @@ -0,0 +1,9 @@ +{ + "all": true, + "check-coverage": false, + "reporter": ["text-summary", "text", "html", "json"], + "exclude": [ + "coverage", + "test" + ] +} diff --git a/node_modules/supports-preserve-symlinks-flag/CHANGELOG.md b/node_modules/supports-preserve-symlinks-flag/CHANGELOG.md new file mode 100644 index 0000000..61f607f --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/CHANGELOG.md @@ -0,0 +1,22 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) +and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). + +## v1.0.0 - 2022-01-02 + +### Commits + +- Tests [`e2f59ad`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/e2f59ad74e2ae0f5f4899fcde6a6f693ab7cc074) +- Initial commit [`dc222aa`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/dc222aad3c0b940d8d3af1ca9937d108bd2dc4b9) +- [meta] do not publish workflow files [`5ef77f7`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/5ef77f7cb6946d16ee38672be9ec0f1bbdf63262) +- npm init [`992b068`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/992b068503a461f7e8676f40ca2aab255fd8d6ff) +- read me [`6c9afa9`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/6c9afa9fabc8eaf0814aaed6dd01e6df0931b76d) +- Initial implementation [`2f98925`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/2f9892546396d4ab0ad9f1ff83e76c3f01234ae8) +- [meta] add `auto-changelog` [`6c476ae`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/6c476ae1ed7ce68b0480344f090ac2844f35509d) +- [Dev Deps] add `eslint`, `@ljharb/eslint-config` [`d0fffc8`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/d0fffc886d25fba119355520750a909d64da0087) +- Only apps should have lockfiles [`ab318ed`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/ab318ed7ae62f6c2c0e80a50398d40912afd8f69) +- [meta] add `safe-publish-latest` [`2bb23b3`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/2bb23b3ebab02dc4135c4cdf0217db82835b9fca) +- [meta] add `sideEffects` flag [`600223b`](https://github.com/inspect-js/node-supports-preserve-symlinks-flag/commit/600223ba24f30779f209d9097721eff35ed62741) diff --git a/node_modules/supports-preserve-symlinks-flag/LICENSE b/node_modules/supports-preserve-symlinks-flag/LICENSE new file mode 100644 index 0000000..2e7b9a3 --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2022 Inspect JS + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/supports-preserve-symlinks-flag/README.md b/node_modules/supports-preserve-symlinks-flag/README.md new file mode 100644 index 0000000..eb05b12 --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/README.md @@ -0,0 +1,42 @@ +# node-supports-preserve-symlinks-flag [![Version Badge][npm-version-svg]][package-url] + +[![github actions][actions-image]][actions-url] +[![coverage][codecov-image]][codecov-url] +[![dependency status][deps-svg]][deps-url] +[![dev dependency status][dev-deps-svg]][dev-deps-url] +[![License][license-image]][license-url] +[![Downloads][downloads-image]][downloads-url] + +[![npm badge][npm-badge-png]][package-url] + +Determine if the current node version supports the `--preserve-symlinks` flag. + +## Example + +```js +var supportsPreserveSymlinks = require('node-supports-preserve-symlinks-flag'); +var assert = require('assert'); + +assert.equal(supportsPreserveSymlinks, null); // in a browser +assert.equal(supportsPreserveSymlinks, false); // in node < v6.2 +assert.equal(supportsPreserveSymlinks, true); // in node v6.2+ +``` + +## Tests +Simply clone the repo, `npm install`, and run `npm test` + +[package-url]: https://npmjs.org/package/node-supports-preserve-symlinks-flag +[npm-version-svg]: https://versionbadg.es/inspect-js/node-supports-preserve-symlinks-flag.svg +[deps-svg]: https://david-dm.org/inspect-js/node-supports-preserve-symlinks-flag.svg +[deps-url]: https://david-dm.org/inspect-js/node-supports-preserve-symlinks-flag +[dev-deps-svg]: https://david-dm.org/inspect-js/node-supports-preserve-symlinks-flag/dev-status.svg +[dev-deps-url]: https://david-dm.org/inspect-js/node-supports-preserve-symlinks-flag#info=devDependencies +[npm-badge-png]: https://nodei.co/npm/node-supports-preserve-symlinks-flag.png?downloads=true&stars=true +[license-image]: https://img.shields.io/npm/l/node-supports-preserve-symlinks-flag.svg +[license-url]: LICENSE +[downloads-image]: https://img.shields.io/npm/dm/node-supports-preserve-symlinks-flag.svg +[downloads-url]: https://npm-stat.com/charts.html?package=node-supports-preserve-symlinks-flag +[codecov-image]: https://codecov.io/gh/inspect-js/node-supports-preserve-symlinks-flag/branch/main/graphs/badge.svg +[codecov-url]: https://app.codecov.io/gh/inspect-js/node-supports-preserve-symlinks-flag/ +[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/inspect-js/node-supports-preserve-symlinks-flag +[actions-url]: https://github.com/inspect-js/node-supports-preserve-symlinks-flag/actions diff --git a/node_modules/supports-preserve-symlinks-flag/browser.js b/node_modules/supports-preserve-symlinks-flag/browser.js new file mode 100644 index 0000000..087be1f --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/browser.js @@ -0,0 +1,3 @@ +'use strict'; + +module.exports = null; diff --git a/node_modules/supports-preserve-symlinks-flag/index.js b/node_modules/supports-preserve-symlinks-flag/index.js new file mode 100644 index 0000000..86fd5d3 --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/index.js @@ -0,0 +1,9 @@ +'use strict'; + +module.exports = ( +// node 12+ + process.allowedNodeEnvironmentFlags && process.allowedNodeEnvironmentFlags.has('--preserve-symlinks') +) || ( +// node v6.2 - v11 + String(module.constructor._findPath).indexOf('preserveSymlinks') >= 0 // eslint-disable-line no-underscore-dangle +); diff --git a/node_modules/supports-preserve-symlinks-flag/package.json b/node_modules/supports-preserve-symlinks-flag/package.json new file mode 100644 index 0000000..56edadc --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/package.json @@ -0,0 +1,70 @@ +{ + "name": "supports-preserve-symlinks-flag", + "version": "1.0.0", + "description": "Determine if the current node version supports the `--preserve-symlinks` flag.", + "main": "./index.js", + "browser": "./browser.js", + "exports": { + ".": [ + { + "browser": "./browser.js", + "default": "./index.js" + }, + "./index.js" + ], + "./package.json": "./package.json" + }, + "sideEffects": false, + "scripts": { + "prepublishOnly": "safe-publish-latest", + "prepublish": "not-in-publish || npm run prepublishOnly", + "lint": "eslint --ext=js,mjs .", + "pretest": "npm run lint", + "tests-only": "nyc tape 'test/**/*.js'", + "test": "npm run tests-only", + "posttest": "aud --production", + "version": "auto-changelog && git add CHANGELOG.md", + "postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\"" + }, + "repository": { + "type": "git", + "url": "git+https://github.com/inspect-js/node-supports-preserve-symlinks-flag.git" + }, + "keywords": [ + "node", + "flag", + "symlink", + "symlinks", + "preserve-symlinks" + ], + "author": "Jordan Harband ", + "funding": { + "url": "https://github.com/sponsors/ljharb" + }, + "license": "MIT", + "bugs": { + "url": "https://github.com/inspect-js/node-supports-preserve-symlinks-flag/issues" + }, + "homepage": "https://github.com/inspect-js/node-supports-preserve-symlinks-flag#readme", + "devDependencies": { + "@ljharb/eslint-config": "^20.1.0", + "aud": "^1.1.5", + "auto-changelog": "^2.3.0", + "eslint": "^8.6.0", + "nyc": "^10.3.2", + "safe-publish-latest": "^2.0.0", + "semver": "^6.3.0", + "tape": "^5.4.0" + }, + "engines": { + "node": ">= 0.4" + }, + "auto-changelog": { + "output": "CHANGELOG.md", + "template": "keepachangelog", + "unreleased": false, + "commitLimit": false, + "backfillLimit": false, + "hideCredit": true + } +} diff --git a/node_modules/supports-preserve-symlinks-flag/test/index.js b/node_modules/supports-preserve-symlinks-flag/test/index.js new file mode 100644 index 0000000..9938d67 --- /dev/null +++ b/node_modules/supports-preserve-symlinks-flag/test/index.js @@ -0,0 +1,29 @@ +'use strict'; + +var test = require('tape'); +var semver = require('semver'); + +var supportsPreserveSymlinks = require('../'); +var browser = require('../browser'); + +test('supportsPreserveSymlinks', function (t) { + t.equal(typeof supportsPreserveSymlinks, 'boolean', 'is a boolean'); + + t.equal(browser, null, 'browser file is `null`'); + t.equal( + supportsPreserveSymlinks, + null, + 'in a browser, is null', + { skip: typeof window === 'undefined' } + ); + + var expected = semver.satisfies(process.version, '>= 6.2'); + t.equal( + supportsPreserveSymlinks, + expected, + 'is true in node v6.2+, false otherwise (actual: ' + supportsPreserveSymlinks + ', expected ' + expected + ')', + { skip: typeof window !== 'undefined' } + ); + + t.end(); +}); diff --git a/node_modules/tailwindcss/.DS_Store b/node_modules/tailwindcss/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..27da6901111a45e72d2788d5ef3c1078710fe5f8 GIT binary patch literal 6148 zcmeHKyKWOf6g`6%$A-oY5=a#L0WL`4eu<2bkb;ohAf-XJqhQJFwPGhyy6uvJPv8sk z7b#NkA4pVCq@>EZGsEs3uT2RE&6Q@(`ab5|J^L6h0CR9Q-3NLAIvj$@BTidP;xZcc zzu5c8X9fKrlYUxU=MPLkyW;nCnztDZ_&T!hP+_?j&M@9Q_xDF( zRP)}vsd!br=H8wW@S}A6Yh2iSAiVxK{BHTHsOJCnMe(bQ`ucCr2>IP+DNXzZ?Z&*q1zgd?K_>Aii4PWEFIEAGp>~AN{#=- zFs_{b)aPX$ONXu;#xipq&ush`im~kUr#2lXa~S8SKvW=9pyht{WdDD)`};pEioc=) zQGx$T0h0_z!vmg@-&-3eCwpzm@qt53@=Axcgp=Qn?SX8?PdThHmdXJ!^H@5hhZg?` NSQ+9J75JkH+yjk6` when using `theme()` ([#8652](https://github.com/tailwindlabs/tailwindcss/pull/8652)) +- Detect arbitrary variants with quotes ([#8687](https://github.com/tailwindlabs/tailwindcss/pull/8687)) +- Don’t add spaces around raw `/` that are preceded by numbers ([#8688](https://github.com/tailwindlabs/tailwindcss/pull/8688)) + +## [3.1.3] - 2022-06-14 + +### Fixed + +- Fix extraction of multi-word utilities with arbitrary values and quotes ([#8604](https://github.com/tailwindlabs/tailwindcss/pull/8604)) +- Fix casing of import of `corePluginList` type definition ([#8587](https://github.com/tailwindlabs/tailwindcss/pull/8587)) +- Ignore PostCSS nodes returned by `addVariant` ([#8608](https://github.com/tailwindlabs/tailwindcss/pull/8608)) +- Fix missing spaces around arithmetic operators ([#8615](https://github.com/tailwindlabs/tailwindcss/pull/8615)) +- Detect alpha value in CSS `theme()` function when using quotes ([#8625](https://github.com/tailwindlabs/tailwindcss/pull/8625)) +- Fix "Maximum call stack size exceeded" bug ([#8636](https://github.com/tailwindlabs/tailwindcss/pull/8636)) +- Allow functions returning parallel variants to mutate the container ([#8622](https://github.com/tailwindlabs/tailwindcss/pull/8622)) +- Remove text opacity CSS variables from `::marker` ([#8622](https://github.com/tailwindlabs/tailwindcss/pull/8622)) + +## [3.1.2] - 2022-06-10 + +### Fixed + +- Ensure `\` is a valid arbitrary variant token ([#8576](https://github.com/tailwindlabs/tailwindcss/pull/8576)) +- Enable `postcss-import` in the CLI by default in watch mode ([#8574](https://github.com/tailwindlabs/tailwindcss/pull/8574), [#8580](https://github.com/tailwindlabs/tailwindcss/pull/8580)) + +## [3.1.1] - 2022-06-09 + +### Fixed + +- Fix candidate extractor regression ([#8558](https://github.com/tailwindlabs/tailwindcss/pull/8558)) +- Split `::backdrop` into separate defaults group ([#8567](https://github.com/tailwindlabs/tailwindcss/pull/8567)) +- Fix postcss plugin type ([#8564](https://github.com/tailwindlabs/tailwindcss/pull/8564)) +- Fix class detection in markdown code fences and slim templates ([#8569](https://github.com/tailwindlabs/tailwindcss/pull/8569)) + +## [3.1.0] - 2022-06-08 + +### Fixed + +- Types: allow for arbitrary theme values (for 3rd party plugins) ([#7926](https://github.com/tailwindlabs/tailwindcss/pull/7926)) +- Don’t split vars with numbers in them inside arbitrary values ([#8091](https://github.com/tailwindlabs/tailwindcss/pull/8091)) +- Require matching prefix when detecting negatives ([#8121](https://github.com/tailwindlabs/tailwindcss/pull/8121)) +- Handle duplicate At Rules without children ([#8122](https://github.com/tailwindlabs/tailwindcss/pull/8122)) +- Allow arbitrary values with commas in `@apply` ([#8125](https://github.com/tailwindlabs/tailwindcss/pull/8125)) +- Fix intellisense for plugins with multiple `@apply` rules ([#8213](https://github.com/tailwindlabs/tailwindcss/pull/8213)) +- Improve type detection for arbitrary color values ([#8201](https://github.com/tailwindlabs/tailwindcss/pull/8201)) +- Support PostCSS config options in config file in CLI ([#8226](https://github.com/tailwindlabs/tailwindcss/pull/8226)) +- Remove default `[hidden]` style in preflight ([#8248](https://github.com/tailwindlabs/tailwindcss/pull/8248)) +- Only check selectors containing base apply candidates for circular dependencies ([#8222](https://github.com/tailwindlabs/tailwindcss/pull/8222)) +- Rewrite default class extractor ([#8204](https://github.com/tailwindlabs/tailwindcss/pull/8204)) +- Move `important` selector to the front when `@apply`-ing selector-modifying variants in custom utilities ([#8313](https://github.com/tailwindlabs/tailwindcss/pull/8313)) +- Error when registering an invalid custom variant ([#8345](https://github.com/tailwindlabs/tailwindcss/pull/8345)) +- Create tailwind.config.cjs file in ESM package when running init ([#8363](https://github.com/tailwindlabs/tailwindcss/pull/8363)) +- Fix `matchVariants` that use at-rules and placeholders ([#8392](https://github.com/tailwindlabs/tailwindcss/pull/8392)) +- Improve types of the `tailwindcss/plugin` ([#8400](https://github.com/tailwindlabs/tailwindcss/pull/8400)) +- Allow returning parallel variants from `addVariant` or `matchVariant` callback functions ([#8455](https://github.com/tailwindlabs/tailwindcss/pull/8455)) +- Try using local `postcss` installation first in the CLI ([#8270](https://github.com/tailwindlabs/tailwindcss/pull/8270)) +- Allow default ring color to be a function ([#7587](https://github.com/tailwindlabs/tailwindcss/pull/7587)) +- Don't inherit `to` value from parent gradients ([#8489](https://github.com/tailwindlabs/tailwindcss/pull/8489)) +- Remove process dependency from log functions ([#8530](https://github.com/tailwindlabs/tailwindcss/pull/8530)) +- Ensure we can use `@import 'tailwindcss/...'` without node_modules ([#8537](https://github.com/tailwindlabs/tailwindcss/pull/8537)) + +### Changed + +- Only apply hover styles when supported (future) ([#8394](https://github.com/tailwindlabs/tailwindcss/pull/8394)) +- Respect default ring color opacity (future) ([#8448](https://github.com/tailwindlabs/tailwindcss/pull/8448), [3f4005e](https://github.com/tailwindlabs/tailwindcss/commit/3f4005e833445f7549219eb5ae89728cbb3a2630)) + +### Added + +- Support PostCSS `Document` nodes ([#7291](https://github.com/tailwindlabs/tailwindcss/pull/7291)) +- Add `text-start` and `text-end` utilities ([#6656](https://github.com/tailwindlabs/tailwindcss/pull/6656)) +- Support customizing class name when using `darkMode: 'class'` ([#5800](https://github.com/tailwindlabs/tailwindcss/pull/5800)) +- Add `--poll` option to the CLI ([#7725](https://github.com/tailwindlabs/tailwindcss/pull/7725)) +- Add new `border-spacing` utilities ([#7102](https://github.com/tailwindlabs/tailwindcss/pull/7102)) +- Add `enabled` variant ([#7905](https://github.com/tailwindlabs/tailwindcss/pull/7905)) +- Add TypeScript types for the `tailwind.config.js` file ([#7891](https://github.com/tailwindlabs/tailwindcss/pull/7891)) +- Add `backdrop` variant ([#7924](https://github.com/tailwindlabs/tailwindcss/pull/7924), [#8526](https://github.com/tailwindlabs/tailwindcss/pull/8526)) +- Add `grid-flow-dense` utility ([#8193](https://github.com/tailwindlabs/tailwindcss/pull/8193)) +- Add `mix-blend-plus-lighter` utility ([#8288](https://github.com/tailwindlabs/tailwindcss/pull/8288)) +- Add arbitrary variants ([#8299](https://github.com/tailwindlabs/tailwindcss/pull/8299)) +- Add experimental `matchVariant` API ([#8310](https://github.com/tailwindlabs/tailwindcss/pull/8310), [34fd0fb8](https://github.com/tailwindlabs/tailwindcss/commit/34fd0fb82aa574cddc5c7aa3ad7d1af5e3735e5d)) +- Add `prefers-contrast` media query variants ([#8410](https://github.com/tailwindlabs/tailwindcss/pull/8410)) +- Add opacity support when referencing colors with `theme` function ([#8416](https://github.com/tailwindlabs/tailwindcss/pull/8416)) +- Add `postcss-import` support to the CLI ([#8437](https://github.com/tailwindlabs/tailwindcss/pull/8437)) +- Add `optional` variant ([#8486](https://github.com/tailwindlabs/tailwindcss/pull/8486)) +- Add `` placeholder support for custom colors ([#8501](https://github.com/tailwindlabs/tailwindcss/pull/8501)) + +## [3.0.24] - 2022-04-12 + +### Fixed + +- Prevent nesting plugin from breaking other plugins ([#7563](https://github.com/tailwindlabs/tailwindcss/pull/7563)) +- Recursively collapse adjacent rules ([#7565](https://github.com/tailwindlabs/tailwindcss/pull/7565)) +- Preserve source maps for generated CSS ([#7588](https://github.com/tailwindlabs/tailwindcss/pull/7588)) +- Split box shadows on top-level commas only ([#7479](https://github.com/tailwindlabs/tailwindcss/pull/7479)) +- Use local user CSS cache for `@apply` ([#7524](https://github.com/tailwindlabs/tailwindcss/pull/7524)) +- Invalidate context when main CSS changes ([#7626](https://github.com/tailwindlabs/tailwindcss/pull/7626)) +- Only add `!` to selector class matching template candidate when using important modifier with mutli-class selectors ([#7664](https://github.com/tailwindlabs/tailwindcss/pull/7664)) +- Correctly parse and prefix animation names with dots ([#7163](https://github.com/tailwindlabs/tailwindcss/pull/7163)) +- Fix extraction from template literal/function with array ([#7481](https://github.com/tailwindlabs/tailwindcss/pull/7481)) +- Don't output unparsable arbitrary values ([#7789](https://github.com/tailwindlabs/tailwindcss/pull/7789)) +- Fix generation of `div:not(.foo)` if `.foo` is never defined ([#7815](https://github.com/tailwindlabs/tailwindcss/pull/7815)) +- Allow for custom properties in `rgb`, `rgba`, `hsl` and `hsla` colors ([#7933](https://github.com/tailwindlabs/tailwindcss/pull/7933)) +- Remove autoprefixer as explicit peer-dependency to avoid invalid warnings in situations where it isn't actually needed ([#7949](https://github.com/tailwindlabs/tailwindcss/pull/7949)) +- Ensure the `percentage` data type is validated correctly ([#8015](https://github.com/tailwindlabs/tailwindcss/pull/8015)) +- Make sure `font-weight` is inherited by form controls in all browsers ([#8078](https://github.com/tailwindlabs/tailwindcss/pull/8078)) + +### Changed + +- Replace `chalk` with `picocolors` ([#6039](https://github.com/tailwindlabs/tailwindcss/pull/6039)) +- Replace `cosmiconfig` with `lilconfig` ([#6039](https://github.com/tailwindlabs/tailwindcss/pull/6038)) +- Update `cssnano` to avoid removing empty variables when minifying ([#7818](https://github.com/tailwindlabs/tailwindcss/pull/7818)) + +## [3.0.23] - 2022-02-16 + +### Fixed + +- Remove opacity variables from `:visited` pseudo class ([#7458](https://github.com/tailwindlabs/tailwindcss/pull/7458)) +- Support arbitrary values + calc + theme with quotes ([#7462](https://github.com/tailwindlabs/tailwindcss/pull/7462)) +- Don't duplicate layer output when scanning content with variants + wildcards ([#7478](https://github.com/tailwindlabs/tailwindcss/pull/7478)) +- Implement `getClassOrder` instead of `sortClassList` ([#7459](https://github.com/tailwindlabs/tailwindcss/pull/7459)) + +## [3.0.22] - 2022-02-11 + +### Fixed + +- Temporarily move `postcss` to dependencies ([#7424](https://github.com/tailwindlabs/tailwindcss/pull/7424)) + +## [3.0.21] - 2022-02-10 + +### Fixed + +- Move prettier plugin to dev dependencies ([#7418](https://github.com/tailwindlabs/tailwindcss/pull/7418)) + +## [3.0.20] - 2022-02-10 + +### Added + +- Expose `context.sortClassList(classes)` ([#7412](https://github.com/tailwindlabs/tailwindcss/pull/7412)) + +## [3.0.19] - 2022-02-07 + +### Fixed + +- Fix preflight border color fallback ([#7288](https://github.com/tailwindlabs/tailwindcss/pull/7288)) +- Correctly parse shadow lengths without a leading zero ([#7289](https://github.com/tailwindlabs/tailwindcss/pull/7289)) +- Don't crash when scanning extremely long class candidates ([#7331](https://github.com/tailwindlabs/tailwindcss/pull/7331)) +- Use less hacky fix for URLs detected as custom properties ([#7275](https://github.com/tailwindlabs/tailwindcss/pull/7275)) +- Correctly generate negative utilities when dash is before the prefix ([#7295](https://github.com/tailwindlabs/tailwindcss/pull/7295)) +- Detect prefixed negative utilities in the safelist ([#7295](https://github.com/tailwindlabs/tailwindcss/pull/7295)) + +## [3.0.18] - 2022-01-28 + +### Fixed + +- Fix `@apply` order regression (in `addComponents`, `addUtilities`, ...) ([#7232](https://github.com/tailwindlabs/tailwindcss/pull/7232)) +- Quick fix for incorrect arbitrary properties when using URLs ([#7252](https://github.com/tailwindlabs/tailwindcss/pull/7252)) + +## [3.0.17] - 2022-01-26 + +### Fixed + +- Remove false positive warning in CLI when using the `--content` option ([#7220](https://github.com/tailwindlabs/tailwindcss/pull/7220)) + +## [3.0.16] - 2022-01-24 + +### Fixed + +- Ensure to transpile the PostCSS Nesting plugin (tailwindcss/nesting) ([#7080](https://github.com/tailwindlabs/tailwindcss/pull/7080)) +- Improve various warnings ([#7118](https://github.com/tailwindlabs/tailwindcss/pull/7118)) +- Fix grammatical mistake ([cca5a38](https://github.com/tailwindlabs/tailwindcss/commit/cca5a3804e1d3ee0214491921e1aec35bf62a813)) + +## [3.0.15] - 2022-01-15 + +### Fixed + +- Temporarily remove optional chaining in nesting plugin ([#7077](https://github.com/tailwindlabs/tailwindcss/pull/7077)) + +## [3.0.14] - 2022-01-14 + +### Added + +- Show warnings for invalid content config ([#7065](https://github.com/tailwindlabs/tailwindcss/pull/7065)) + +### Fixed + +- Only emit utility/component variants when those layers exist ([#7066](https://github.com/tailwindlabs/tailwindcss/pull/7066)) +- Ensure nesting plugins can receive options ([#7016](https://github.com/tailwindlabs/tailwindcss/pull/7016)) + +## [3.0.13] - 2022-01-11 + +### Fixed + +- Fix consecutive builds with at apply producing different CSS ([#6999](https://github.com/tailwindlabs/tailwindcss/pull/6999)) + +## [3.0.12] - 2022-01-07 + +### Fixed + +- Allow use of falsy values in theme config ([#6917](https://github.com/tailwindlabs/tailwindcss/pull/6917)) +- Ensure we can apply classes that are grouped with non-class selectors ([#6922](https://github.com/tailwindlabs/tailwindcss/pull/6922)) +- Improve standalone CLI compatibility on Linux by switching to the `linuxstatic` build target ([#6914](https://github.com/tailwindlabs/tailwindcss/pull/6914)) +- Ensure `@apply` works consistently with or without `@layer` ([#6938](https://github.com/tailwindlabs/tailwindcss/pull/6938)) +- Only emit defaults when using base layer ([#6926](https://github.com/tailwindlabs/tailwindcss/pull/6926)) +- Emit plugin defaults regardless of usage ([#6926](https://github.com/tailwindlabs/tailwindcss/pull/6926)) +- Move default border color back to preflight ([#6926](https://github.com/tailwindlabs/tailwindcss/pull/6926)) +- Change `experimental.optimizeUniversalDefaults` to only work with `@tailwind base` ([#6926](https://github.com/tailwindlabs/tailwindcss/pull/6926)) + +## [3.0.11] - 2022-01-05 + +### Fixed + +- Preserve casing of CSS variables added by plugins ([#6888](https://github.com/tailwindlabs/tailwindcss/pull/6888)) +- Ignore content paths that are passed in but don't actually exist ([#6901](https://github.com/tailwindlabs/tailwindcss/pull/6901)) +- Revert change that applies Tailwind's defaults in isolated environments like CSS modules ([9fdc391](https://github.com/tailwindlabs/tailwindcss/commit/9fdc391d4ff93e7e350f5ce439060176b1f0162f)) + +## [3.0.10] - 2022-01-04 + +### Fixed + +- Fix `@apply` in files without `@tailwind` directives ([#6580](https://github.com/tailwindlabs/tailwindcss/pull/6580), [#6875](https://github.com/tailwindlabs/tailwindcss/pull/6875)) +- CLI: avoid unnecessary writes to output files ([#6550](https://github.com/tailwindlabs/tailwindcss/pull/6550)) + +### Added + +- Allow piping data into the CLI ([#6876](https://github.com/tailwindlabs/tailwindcss/pull/6876)) + +## [3.0.9] - 2022-01-03 + +### Fixed + +- Improve `DEBUG` flag ([#6797](https://github.com/tailwindlabs/tailwindcss/pull/6797), [#6804](https://github.com/tailwindlabs/tailwindcss/pull/6804)) +- Ensure we can use `<` and `>` characters in modifiers ([#6851](https://github.com/tailwindlabs/tailwindcss/pull/6851)) +- Validate `theme()` works in arbitrary values ([#6852](https://github.com/tailwindlabs/tailwindcss/pull/6852)) +- Properly detect `theme()` value usage in arbitrary properties ([#6854](https://github.com/tailwindlabs/tailwindcss/pull/6854)) +- Improve collapsing of duplicate declarations ([#6856](https://github.com/tailwindlabs/tailwindcss/pull/6856)) +- Remove support for `TAILWIND_MODE=watch` ([#6858](https://github.com/tailwindlabs/tailwindcss/pull/6858)) + +## [3.0.8] - 2021-12-28 + +### Fixed + +- Reduce specificity of `abbr` rule in preflight ([#6671](https://github.com/tailwindlabs/tailwindcss/pull/6671)) +- Support HSL with hue units in arbitrary values ([#6726](https://github.com/tailwindlabs/tailwindcss/pull/6726)) +- Add `node16-linux-arm64` target for standalone CLI ([#6693](https://github.com/tailwindlabs/tailwindcss/pull/6693)) + +## [3.0.7] - 2021-12-17 + +### Fixed + +- Don't mutate custom color palette when overriding per-plugin colors ([#6546](https://github.com/tailwindlabs/tailwindcss/pull/6546)) +- Improve circular dependency detection when using `@apply` ([#6588](https://github.com/tailwindlabs/tailwindcss/pull/6588)) +- Only generate variants for non-`user` layers ([#6589](https://github.com/tailwindlabs/tailwindcss/pull/6589)) +- Properly extract classes with arbitrary values in arrays and classes followed by escaped quotes ([#6590](https://github.com/tailwindlabs/tailwindcss/pull/6590)) +- Improve jsx interpolation candidate matching ([#6593](https://github.com/tailwindlabs/tailwindcss/pull/6593)) +- Ensure `@apply` of a rule inside an AtRule works ([#6594](https://github.com/tailwindlabs/tailwindcss/pull/6594)) + +## [3.0.6] - 2021-12-16 + +### Fixed + +- Support square bracket notation in paths ([#6519](https://github.com/tailwindlabs/tailwindcss/pull/6519)) +- Ensure all plugins are executed for a given candidate ([#6540](https://github.com/tailwindlabs/tailwindcss/pull/6540)) + +## [3.0.5] - 2021-12-15 + +### Fixed + +- Revert: add `li` to list-style reset ([9777562d](https://github.com/tailwindlabs/tailwindcss/commit/9777562da37ee631bbf77374c0d14825f09ef9af)) + +## [3.0.4] - 2021-12-15 + +### Fixed + +- Insert always-on defaults layer in correct spot ([#6526](https://github.com/tailwindlabs/tailwindcss/pull/6526)) + +## [3.0.3] - 2021-12-15 + +### Added + +- Warn about invalid globs in `content` ([#6449](https://github.com/tailwindlabs/tailwindcss/pull/6449)) +- Add standalone tailwindcss CLI ([#6506](https://github.com/tailwindlabs/tailwindcss/pull/6506)) +- Add `li` to list-style reset ([00f60e6](https://github.com/tailwindlabs/tailwindcss/commit/00f60e61013c6e4e3419e4b699371a13eb30b75d)) + +### Fixed + +- Don't output unparsable values ([#6469](https://github.com/tailwindlabs/tailwindcss/pull/6469)) +- Fix text decoration utilities from overriding the new text decoration color/style/thickness utilities when used with a modifier ([#6378](https://github.com/tailwindlabs/tailwindcss/pull/6378)) +- Move defaults to their own always-on layer ([#6500](https://github.com/tailwindlabs/tailwindcss/pull/6500)) +- Support negative values in safelist patterns ([#6480](https://github.com/tailwindlabs/tailwindcss/pull/6480)) + +## [3.0.2] - 2021-12-13 + +### Fixed + +- Temporarily disable optimize universal defaults, fixes issue with transforms/filters/rings not being `@apply`-able in CSS modules/Svelte components/Vue components ([#6461](https://github.com/tailwindlabs/tailwindcss/pull/6461)) + +## [3.0.1] - 2021-12-10 + +### Fixed + +- Ensure complex variants with multiple classes work ([#6311](https://github.com/tailwindlabs/tailwindcss/pull/6311)) +- Re-add `default` interop to public available functions ([#6348](https://github.com/tailwindlabs/tailwindcss/pull/6348)) +- Detect circular dependencies when using `@apply` ([#6365](https://github.com/tailwindlabs/tailwindcss/pull/6365)) +- Fix defaults optimization when vendor prefixes are involved ([#6369](https://github.com/tailwindlabs/tailwindcss/pull/6369)) + +## [3.0.0] - 2021-12-09 + +### Fixed + +- Enforce the order of some variants (like `before` and `after`) ([#6018](https://github.com/tailwindlabs/tailwindcss/pull/6018)) + +### Added + +- Add `placeholder` variant ([#6106](https://github.com/tailwindlabs/tailwindcss/pull/6106)) +- Add composable `touch-action` utilities ([#6115](https://github.com/tailwindlabs/tailwindcss/pull/6115)) +- Add support for "arbitrary properties" ([#6161](https://github.com/tailwindlabs/tailwindcss/pull/6161)) +- Add `portrait` and `landscape` variants ([#6046](https://github.com/tailwindlabs/tailwindcss/pull/6046)) +- Add `text-decoration-style`, `text-decoration-thickness`, and `text-underline-offset` utilities ([#6004](https://github.com/tailwindlabs/tailwindcss/pull/6004)) +- Add `menu` reset to preflight ([#6213](https://github.com/tailwindlabs/tailwindcss/pull/6213)) +- Allow `0` as a valid `length` value ([#6233](https://github.com/tailwindlabs/tailwindcss/pull/6233), [#6259](https://github.com/tailwindlabs/tailwindcss/pull/6259)) +- Add CSS functions to data types ([#6258](https://github.com/tailwindlabs/tailwindcss/pull/6258)) +- Support negative values for `scale-*` utilities ([c48e629](https://github.com/tailwindlabs/tailwindcss/commit/c48e629955585ad18dadba9f470fda59cc448ab7)) +- Improve `length` data type, by validating each value individually ([#6283](https://github.com/tailwindlabs/tailwindcss/pull/6283)) + +### Changed + +- Deprecate `decoration-slice` and `decoration-break` in favor `box-decoration-slice` and `box-decoration-break` _(non-breaking)_ ([#6004](https://github.com/tailwindlabs/tailwindcss/pull/6004)) + +## [3.0.0-alpha.2] - 2021-11-08 + +### Changed + +- Don't use pointer cursor on disabled buttons by default ([#5772](https://github.com/tailwindlabs/tailwindcss/pull/5772)) +- Set default content value in preflight instead of within each before/after utility ([#5820](https://github.com/tailwindlabs/tailwindcss/pull/5820)) +- Remove `prefix` as a function ([#5829](https://github.com/tailwindlabs/tailwindcss/pull/5829)) + +### Added + +- Add `flex-basis` utilities ([#5671](https://github.com/tailwindlabs/tailwindcss/pull/5671)) +- Make negative values a first-class feature ([#5709](https://github.com/tailwindlabs/tailwindcss/pull/5709)) +- Add `fit-content` values for `min/max-width/height` utilities ([#5638](https://github.com/tailwindlabs/tailwindcss/pull/5638)) +- Add `min/max-content` values for `min/max-height` utilities ([#5729](https://github.com/tailwindlabs/tailwindcss/pull/5729)) +- Add all standard `cursor-*` values by default ([#5734](https://github.com/tailwindlabs/tailwindcss/pull/5734)) +- Add `grow-*` and `shrink-*` utilities, deprecate `flex-grow-*` and `flex-shrink-*` ([#5733](https://github.com/tailwindlabs/tailwindcss/pull/5733)) +- Add `text-decoration-color` utilities ([#5760](https://github.com/tailwindlabs/tailwindcss/pull/5760)) +- Add new declarative `addVariant` API ([#5809](https://github.com/tailwindlabs/tailwindcss/pull/5809)) +- Add first-class `print` variant for targeting printed media ([#5885](https://github.com/tailwindlabs/tailwindcss/pull/5885)) +- Add `outline-style`, `outline-color`, `outline-width` and `outline-offset` utilities ([#5887](https://github.com/tailwindlabs/tailwindcss/pull/5887)) +- Add full color palette for `fill-*` and `stroke-*` utilities (#5933[](https://github.com/tailwindlabs/tailwindcss/pull/5933)) +- Add composable API for colored box shadows ([#5979](https://github.com/tailwindlabs/tailwindcss/pull/5979)) + +### Fixed + +- Configure chokidar's `awaitWriteFinish` setting to avoid occasional stale builds on Windows ([#5774](https://github.com/tailwindlabs/tailwindcss/pull/5774)) +- Fix CLI `--content` option ([#5775](https://github.com/tailwindlabs/tailwindcss/pull/5775)) +- Fix before/after utilities overriding custom content values at larger breakpoints ([#5820](https://github.com/tailwindlabs/tailwindcss/pull/5820)) +- Cleanup duplicate properties ([#5830](https://github.com/tailwindlabs/tailwindcss/pull/5830)) +- Allow `_` inside `url()` when using arbitrary values ([#5853](https://github.com/tailwindlabs/tailwindcss/pull/5853)) +- Prevent crashes when using comments in `@layer` AtRules ([#5854](https://github.com/tailwindlabs/tailwindcss/pull/5854)) +- Handle color transformations properly with `theme(...)` for all relevant plugins ([#4533](https://github.com/tailwindlabs/tailwindcss/pull/4533), [#5871](https://github.com/tailwindlabs/tailwindcss/pull/5871)) +- Ensure `@apply`-ing a utility with multiple definitions works ([#5870](https://github.com/tailwindlabs/tailwindcss/pull/5870)) + +## [3.0.0-alpha.1] - 2021-10-01 + +### Changed + +- Remove AOT engine, make JIT the default ([#5340](https://github.com/tailwindlabs/tailwindcss/pull/5340)) +- Throw when trying to `@apply` the `group` class ([#4666](https://github.com/tailwindlabs/tailwindcss/pull/4666)) +- Remove dependency on `modern-normalize`, inline and consolidate with Preflight ([#5358](https://github.com/tailwindlabs/tailwindcss/pull/5358)) +- Enable extended color palette by default with updated color names ([#5384](https://github.com/tailwindlabs/tailwindcss/pull/5384)) +- Move `vertical-align` values to config file instead of hard-coding ([#5487](https://github.com/tailwindlabs/tailwindcss/pull/5487)) +- Rename `overflow-clip` to `text-clip` and `overflow-ellipsis` to `text-ellipsis` ([#5630](https://github.com/tailwindlabs/tailwindcss/pull/5630)) + +### Added + +- Add native `aspect-ratio` utilities ([#5359](https://github.com/tailwindlabs/tailwindcss/pull/5359)) +- Unify config callback helpers into single object ([#5382](https://github.com/tailwindlabs/tailwindcss/pull/5382)) +- Preserve original color format when adding opacity whenever possible ([#5154](https://github.com/tailwindlabs/tailwindcss/pull/5154)) +- Add `accent-color` utilities ([#5387](https://github.com/tailwindlabs/tailwindcss/pull/5387)) +- Add `scroll-behavior` utilities ([#5388](https://github.com/tailwindlabs/tailwindcss/pull/5388)) +- Add `will-change` utilities ([#5448](https://github.com/tailwindlabs/tailwindcss/pull/5448)) +- Add `text-indent` utilities ([#5449](https://github.com/tailwindlabs/tailwindcss/pull/5449)) +- Add `column` utilities ([#5457](https://github.com/tailwindlabs/tailwindcss/pull/5457)) +- Add `border-hidden` utility ([#5485](https://github.com/tailwindlabs/tailwindcss/pull/5485)) +- Add `align-sub` and `align-super` utilities by default ([#5486](https://github.com/tailwindlabs/tailwindcss/pull/5486)) +- Add `break-before`, `break-inside` and `break-after` utilities ([#5530](https://github.com/tailwindlabs/tailwindcss/pull/5530)) +- Add `file` variant for `::file-selector-button` pseudo element ([#4936](https://github.com/tailwindlabs/tailwindcss/pull/4936)) +- Add comprehensive arbitrary value support ([#5568](https://github.com/tailwindlabs/tailwindcss/pull/5568)) +- Add `touch-action` utilities ([#5603](https://github.com/tailwindlabs/tailwindcss/pull/5603)) +- Add `inherit` to default color palette ([#5597](https://github.com/tailwindlabs/tailwindcss/pull/5597)) +- Add `overflow-clip`, `overflow-x-clip` and `overflow-y-clip` utilities ([#5630](https://github.com/tailwindlabs/tailwindcss/pull/5630)) +- Add `[open]` variant ([#5627](https://github.com/tailwindlabs/tailwindcss/pull/5627)) +- Add `scroll-snap` utilities ([#5637](https://github.com/tailwindlabs/tailwindcss/pull/5637)) +- Add `border-x` and `border-y` width and color utilities ([#5639](https://github.com/tailwindlabs/tailwindcss/pull/5639)) + +### Fixed + +- Fix defining colors as functions when color opacity plugins are disabled ([#5470](https://github.com/tailwindlabs/tailwindcss/pull/5470)) +- Fix using negated `content` globs ([#5625](https://github.com/tailwindlabs/tailwindcss/pull/5625)) +- Fix using backslashes in `content` globs ([#5628](https://github.com/tailwindlabs/tailwindcss/pull/5628)) + +## [2.2.19] - 2021-10-29 + +### Fixed + +- Ensure `corePlugins` order is consisent in AOT mode ([#5928](https://github.com/tailwindlabs/tailwindcss/pull/5928)) + +## [2.2.18] - 2021-10-29 + +### Fixed + +- Bump versions for security vulnerabilities ([#5924](https://github.com/tailwindlabs/tailwindcss/pull/5924)) + +## [2.2.17] - 2021-10-13 + +### Fixed + +- Configure chokidar's `awaitWriteFinish` setting to avoid occasional stale builds on Windows ([#5758](https://github.com/tailwindlabs/tailwindcss/pull/5758)) + +## [2.2.16] - 2021-09-26 + +### Fixed + +- JIT: Properly handle animations that use CSS custom properties ([#5602](https://github.com/tailwindlabs/tailwindcss/pull/5602)) + +## [2.2.15] - 2021-09-10 + +### Fixed + +- Ensure using CLI without `-i` for input file continues to work even though deprecated ([#5464](https://github.com/tailwindlabs/tailwindcss/pull/5464)) + +## [2.2.14] - 2021-09-08 + +### Fixed + +- Only use `@defaults` in JIT, switch back to `clean-css` in case there's any meaningful differences in the output ([bf248cb](https://github.com/tailwindlabs/tailwindcss/commit/bf248cb0de889d48854fbdd26536f4a492556efd)) + +## [2.2.13] - 2021-09-08 + +### Fixed + +- Replace `clean-css` with `cssnano` for CDN builds to fix minified builds ([75cc3ca](https://github.com/tailwindlabs/tailwindcss/commit/75cc3ca305aedddc8a85f3df1a420fefad3fb5c4)) + +## [2.2.12] - 2021-09-08 + +### Fixed + +- Ensure that divide utilities inject a default border color ([#5438](https://github.com/tailwindlabs/tailwindcss/pull/5438)) + +## [2.2.11] - 2021-09-07 + +### Fixed + +- Rebundle to fix missing CLI peer dependencies + +## [2.2.10] - 2021-09-06 + +### Fixed + +- Fix build error when using `presets: []` in config file ([#4903](https://github.com/tailwindlabs/tailwindcss/pull/4903)) + +### Added + +- Reintroduce universal selector optimizations under experimental `optimizeUniversalDefaults` flag ([a9e160c](https://github.com/tailwindlabs/tailwindcss/commit/a9e160cf9acb75a2bbac34f8864568b12940f89a)) + +## [2.2.9] - 2021-08-30 + +### Fixed + +- JIT: Fix `@apply`ing utilities that contain variants + the important modifier ([#4854](https://github.com/tailwindlabs/tailwindcss/pull/4854)) +- JIT: Don't strip "null" when parsing tracked file paths ([#5008](https://github.com/tailwindlabs/tailwindcss/pull/5008)) +- Pin `clean-css` to v5.1.4 to fix empty CSS variables in CDN builds ([#5338](https://github.com/tailwindlabs/tailwindcss/pull/5338)) + +## [2.2.8] - 2021-08-27 + +### Fixed + +- Improve accessibility of default link focus styles in Firefox ([#5082](https://github.com/tailwindlabs/tailwindcss/pull/5082)) +- JIT: Fix animation variants corrupting keyframes rules ([#5223](https://github.com/tailwindlabs/tailwindcss/pull/5223)) +- JIT: Ignore escaped commas when splitting selectors to apply prefixes ([#5239](https://github.com/tailwindlabs/tailwindcss/pull/5239/)) +- Nesting: Maintain PostCSS node sources when handling `@apply` ([#5249](https://github.com/tailwindlabs/tailwindcss/pull/5249)) +- JIT: Fix support for animation lists ([#5252](https://github.com/tailwindlabs/tailwindcss/pull/5252)) +- JIT: Fix arbitrary value support for `object-position` utilities ([#5245](https://github.com/tailwindlabs/tailwindcss/pull/5245)) +- CLI: Abort watcher if stdin is closed to avoid zombie processes ([#4997](https://github.com/tailwindlabs/tailwindcss/pull/4997)) +- JIT: Ignore arbitrary values with unbalanced brackets ([#5293](https://github.com/tailwindlabs/tailwindcss/pull/5293)) + +## [2.2.7] - 2021-07-23 + +### Fixed + +- Temporarily revert runtime performance optimizations introduced in v2.2.5, use universal selector again ([#5060](https://github.com/tailwindlabs/tailwindcss/pull/5060)) + +## [2.2.6] - 2021-07-21 + +### Fixed + +- Fix issue where base styles not generated for translate transforms in JIT ([#5038](https://github.com/tailwindlabs/tailwindcss/pull/5038)) + +## [2.2.5] - 2021-07-21 + +### Added + +- Added `self-baseline` utility (I know this is a patch release, no one's going to die relax) ([#5000](https://github.com/tailwindlabs/tailwindcss/pull/5000)) + +### Changed + +- JIT: Optimize universal selector usage by inlining only the relevant selectors ([#4850](https://github.com/tailwindlabs/tailwindcss/pull/4850))) + + This provides a very significant performance boost on pages with a huge number of DOM nodes, but there's a chance it could be a breaking change in very rare edge cases we haven't thought of. Please open an issue if anything related to shadows, rings, transforms, filters, or backdrop-filters seems to be behaving differently after upgrading. + +### Fixed + +- Fix support for `step-start` and `step-end` in animation utilities ([#4795](https://github.com/tailwindlabs/tailwindcss/pull/4795))) +- JIT: Prevent presence of `!*` in templates from ruining everything ([#4816](https://github.com/tailwindlabs/tailwindcss/pull/4816))) +- JIT: Improve support for quotes in arbitrary values ([#4817](https://github.com/tailwindlabs/tailwindcss/pull/4817))) +- Fix filter/backdrop-filter/transform utilities being inserted into the wrong position if not all core plugins are enabled ([#4852](https://github.com/tailwindlabs/tailwindcss/pull/4852))) +- JIT: Fix `@layer` rules being mistakenly inserted during incremental rebuilds ([#4853](https://github.com/tailwindlabs/tailwindcss/pull/4853))) +- Improve build performance for projects with many small non-Tailwind stylesheets ([#4644](https://github.com/tailwindlabs/tailwindcss/pull/4644)) +- Ensure `[hidden]` works as expected on elements where we override the default `display` value in Preflight ([#4873](https://github.com/tailwindlabs/tailwindcss/pull/4873)) +- Fix variant configuration not being applied to `backdropOpacity` utilities ([#4892](https://github.com/tailwindlabs/tailwindcss/pull/4892)) + +## [2.2.4] - 2021-06-23 + +### Fixed + +- Remove `postinstall` script that was preventing people from installing the library ([1eacfb9](https://github.com/tailwindlabs/tailwindcss/commit/1eacfb98849c0d4737e0af3595ddec8c73addaac)) + +## [2.2.3] - 2021-06-23 + +### Added + +- Pass extended color palette to theme closures so it can be used without installing Tailwind when using `npx tailwindcss` ([359252c](https://github.com/tailwindlabs/tailwindcss/commit/359252c9b429e81217c28eb3ca7bab73d8f81e6d)) + +### Fixed + +- JIT: Explicitly error when `-` is used as a custom separator ([#4704](https://github.com/tailwindlabs/tailwindcss/pull/4704)) +- JIT: Don't add multiple `~` when stacking `peer-*` variants ([#4757](https://github.com/tailwindlabs/tailwindcss/pull/4757)) +- Remove outdated focus style fix in Preflight ([#4780](https://github.com/tailwindlabs/tailwindcss/pull/4780)) +- Enable `purge` if provided on the CLI ([#4772](https://github.com/tailwindlabs/tailwindcss/pull/4772)) +- JIT: Fix error when not using a config file with postcss-cli ([#4773](https://github.com/tailwindlabs/tailwindcss/pull/4773)) +- Fix issue with `resolveConfig` not being importable in Next.js pags ([#4725](https://github.com/tailwindlabs/tailwindcss/pull/4725)) + +## [2.2.2] - 2021-06-18 + +### Fixed + +- JIT: Reintroduce `transform`, `filter`, and `backdrop-filter` classes purely to create stacking contexts to minimize the impact of the breaking change ([#4700](https://github.com/tailwindlabs/tailwindcss/pull/4700)) + +## [2.2.1] - 2021-06-18 + +### Fixed + +- Recover from errors gracefully in CLI watch mode ([#4693](https://github.com/tailwindlabs/tailwindcss/pull/4693)) +- Fix issue with media queries not being generated properly when using PostCSS 7 ([#4695](https://github.com/tailwindlabs/tailwindcss/pull/4695)) + +## [2.2.0] - 2021-06-17 + +### Changed + +- JIT: Use "tracking" context by default instead of "watching" context for improved reliability with most bundlers ([#4514](https://github.com/tailwindlabs/tailwindcss/pull/4514)) + + Depending on which tooling you use, you may need to explicitly set `TAILWIND_MODE=watch` until your build runner has been updated to support PostCSS's `dir-dependency` message type. + +### Added + +- Add `background-origin` utilities ([#4117](https://github.com/tailwindlabs/tailwindcss/pull/4117)) +- Improve `@apply` performance in projects that process many CSS sources ([#3178](https://github.com/tailwindlabs/tailwindcss/pull/3718)) +- JIT: Don't use CSS variables for color utilities if color opacity utilities are disabled ([#3984](https://github.com/tailwindlabs/tailwindcss/pull/3984)) +- JIT: Redesign `matchUtilities` API to make it more suitable for third-party use ([#4232](https://github.com/tailwindlabs/tailwindcss/pull/4232)) +- JIT: Support applying important utility variants ([#4260](https://github.com/tailwindlabs/tailwindcss/pull/4260)) +- JIT: Support coercing arbitrary values when the type isn't detectable ([#4263](https://github.com/tailwindlabs/tailwindcss/pull/4263)) +- JIT: Support for `raw` syntax in `purge` config ([#4272](https://github.com/tailwindlabs/tailwindcss/pull/4272)) +- Add `empty` variant ([#3298](https://github.com/tailwindlabs/tailwindcss/pull/3298)) +- Update `modern-normalize` to v1.1 ([#4287](https://github.com/tailwindlabs/tailwindcss/pull/4287)) +- Implement `theme` function internally, remove `postcss-functions` dependency ([#4317](https://github.com/tailwindlabs/tailwindcss/pull/4317)) +- Add `screen` function to improve nesting plugin compatibility ([#4318](https://github.com/tailwindlabs/tailwindcss/pull/4318)) +- JIT: Add universal shorthand color opacity syntax ([#4348](https://github.com/tailwindlabs/tailwindcss/pull/4348)) +- JIT: Add `@tailwind variants` directive to replace `@tailwind screens` ([#4356](https://github.com/tailwindlabs/tailwindcss/pull/4356)) +- JIT: Add support for PostCSS `dir-dependency` messages in `TAILWIND_DISABLE_TOUCH` mode ([#4388](https://github.com/tailwindlabs/tailwindcss/pull/4388)) +- JIT: Add per-side border color utilities ([#4404](https://github.com/tailwindlabs/tailwindcss/pull/4404)) +- JIT: Add support for `before` and `after` pseudo-element variants and `content` utilities ([#4461](https://github.com/tailwindlabs/tailwindcss/pull/4461)) +- Add new `transform` and `extract` APIs to simplify PurgeCSS/JIT customization ([#4469](https://github.com/tailwindlabs/tailwindcss/pull/4469)) +- JIT: Add exhaustive pseudo-class and pseudo-element variant support ([#4482](https://github.com/tailwindlabs/tailwindcss/pull/4482)) +- JIT: Add `caret-color` utilities ([#4499](https://github.com/tailwindlabs/tailwindcss/pull/4499)) +- Rename `lightBlue` to `sky`, emit console warning when using deprecated name ([#4513](https://github.com/tailwindlabs/tailwindcss/pull/4513)) +- New CLI with improved JIT support, `--watch` mode, and more ([#4526](https://github.com/tailwindlabs/tailwindcss/pull/4526), [4558](https://github.com/tailwindlabs/tailwindcss/pull/4558)) +- JIT: Add new `peer-*` variants for styling based on sibling state ([#4556](https://github.com/tailwindlabs/tailwindcss/pull/4556)) +- Expose `safelist` as a top-level option under `purge` for both JIT and classic engines ([#4580](https://github.com/tailwindlabs/tailwindcss/pull/4580)) +- JIT: Remove need for `transform` class when using classes like `scale-*`, `rotate-*`, etc. ([#4604](https://github.com/tailwindlabs/tailwindcss/pull/4604)) +- JIT: Remove need for `filter` and `backdrop-filter` classes when using classes like `contrast-*`, `backdrop-blur-*`, etc. ([#4614](https://github.com/tailwindlabs/tailwindcss/pull/4614)) +- Support passing a custom path for your PostCSS configuration in the Tailwind CLI ([#4607](https://github.com/tailwindlabs/tailwindcss/pull/4607)) +- Add `blur-none` by default with intent to deprecate `blur-0` ([#4614](https://github.com/tailwindlabs/tailwindcss/pull/4614)) + +### Fixed + +- JIT: Improve support for Svelte class bindings ([#4187](https://github.com/tailwindlabs/tailwindcss/pull/4187)) +- JIT: Improve support for `calc` and `var` in arbitrary values ([#4147](https://github.com/tailwindlabs/tailwindcss/pull/4147)) +- Convert `hsl` colors to `hsla` when transforming for opacity support instead of `rgba` ([#3850](https://github.com/tailwindlabs/tailwindcss/pull/3850)) +- Fix `backdropBlur` variants not being generated ([#4188](https://github.com/tailwindlabs/tailwindcss/pull/4188)) +- Improve animation value parsing ([#4250](https://github.com/tailwindlabs/tailwindcss/pull/4250)) +- Ignore unknown object types when hashing config ([82f4eaa](https://github.com/tailwindlabs/tailwindcss/commit/82f4eaa6832ef8a4e3fd90869e7068efdf6e34f2)) +- Ensure variants are grouped properly for plugins with order-dependent utilities ([#4273](https://github.com/tailwindlabs/tailwindcss/pull/4273)) +- JIT: Fix temp file storage when node temp directories are kept on a different drive than the project itself ([#4044](https://github.com/tailwindlabs/tailwindcss/pull/4044)) +- Support border-opacity utilities alongside default `border` utility ([#4277](https://github.com/tailwindlabs/tailwindcss/pull/4277)) +- JIT: Fix source maps for expanded `@tailwind` directives ([2f15411](https://github.com/tailwindlabs/tailwindcss/commit/2f1541123dea29d8a2ab0f1411bf60c79eeb96b4)) +- JIT: Ignore whitespace when collapsing adjacent rules ([15642fb](https://github.com/tailwindlabs/tailwindcss/commit/15642fbcc885eba9cc50b7678a922b09c90d6b51)) +- JIT: Generate group parent classes correctly when using custom separator ([#4508](https://github.com/tailwindlabs/tailwindcss/pull/4508)) +- JIT: Fix incorrect stacking of multiple `group` variants ([#4551](https://github.com/tailwindlabs/tailwindcss/pull/4551)) +- JIT: Fix memory leak due to holding on to unused contexts ([#4571](https://github.com/tailwindlabs/tailwindcss/pull/4571)) + +### Internals + +- Add integration tests for popular build runners ([#4354](https://github.com/tailwindlabs/tailwindcss/pull/4354)) + +## [2.1.4] - 2021-06-02 + +### Fixed + +- Skip `raw` PurgeCSS sources when registering template dependencies ([#4542](https://github.com/tailwindlabs/tailwindcss/pull/4542)) + +## [2.1.3] - 2021-06-01 + +### Fixed + +- Register PurgeCSS paths as PostCSS dependencies to guarantee proper cache-busting in webpack 5 ([#4530](https://github.com/tailwindlabs/tailwindcss/pull/4530)) + +## [2.1.2] - 2021-04-23 + +### Fixed + +- Fix issue where JIT engine would generate the wrong CSS when using PostCSS 7 ([#4078](https://github.com/tailwindlabs/tailwindcss/pull/4078)) + +## [2.1.1] - 2021-04-05 + +### Fixed + +- Fix issue where JIT engine would fail to compile when a source path isn't provided by the build runner for the current input file ([#3978](https://github.com/tailwindlabs/tailwindcss/pull/3978)) + +## [2.1.0] - 2021-04-05 + +### Added + +- Add alternate JIT engine (in preview) ([#3905](https://github.com/tailwindlabs/tailwindcss/pull/3905)) +- Add new `mix-blend-mode` and `background-blend-mode` utilities ([#3920](https://github.com/tailwindlabs/tailwindcss/pull/3920)) +- Add new `box-decoration-break` utilities ([#3911](https://github.com/tailwindlabs/tailwindcss/pull/3911)) +- Add new `isolation` utilities ([#3914](https://github.com/tailwindlabs/tailwindcss/pull/3914)) +- Add `inline-table` display utility ([#3563](https://github.com/tailwindlabs/tailwindcss/pull/3563)) +- Add `list-item` display utility ([#3929](https://github.com/tailwindlabs/tailwindcss/pull/3929)) +- Add new `filter` and `backdrop-filter` utilities ([#3923](https://github.com/tailwindlabs/tailwindcss/pull/3923)) + +## [2.0.4] - 2021-03-17 + +### Fixed + +- Pass full `var(--bg-opacity)` value as `opacityValue` when defining colors as functions + +## [2.0.3] - 2021-02-07 + +### Fixed + +- Ensure sourcemap input is deterministic when using `@apply` in Vue components ([#3356](https://github.com/tailwindlabs/tailwindcss/pull/3356)) +- Ensure placeholder opacity is consistent across browsers ([#3308](https://github.com/tailwindlabs/tailwindcss/pull/3308)) +- Fix issue where `theme()` didn't work with colors defined as functions ([#2919](https://github.com/tailwindlabs/tailwindcss/pull/2919)) +- Enable `dark` variants by default for color opacity utilities ([#2975](https://github.com/tailwindlabs/tailwindcss/pull/2975)) + +### Added + +- Add support for a `tailwind.config.cjs` file in Node ESM projects ([#3181](https://github.com/tailwindlabs/tailwindcss/pull/3181)) +- Add version comment to Preflight ([#3255](https://github.com/tailwindlabs/tailwindcss/pull/3255)) +- Add `cursor-help` by default ([#3199](https://github.com/tailwindlabs/tailwindcss/pull/3199)) + +## [2.0.2] - 2020-12-11 + +### Fixed + +- Fix issue with `@apply` not working as expected with `!important` inside an atrule ([#2824](https://github.com/tailwindlabs/tailwindcss/pull/2824)) +- Fix issue with `@apply` not working as expected with defined classes ([#2832](https://github.com/tailwindlabs/tailwindcss/pull/2832)) +- Fix memory leak, and broken `@apply` when splitting up files ([#3032](https://github.com/tailwindlabs/tailwindcss/pull/3032)) + +### Added + +- Add default values for the `ring` utility ([#2951](https://github.com/tailwindlabs/tailwindcss/pull/2951)) + +## [2.0.1] - 2020-11-18 + +- Nothing, just the only thing I could do when I found out npm won't let me publish the same version under two tags. + +## [2.0.0] - 2020-11-18 + +### Added + +- Add redesigned color palette ([#2623](https://github.com/tailwindlabs/tailwindcss/pull/2623), [700866c](https://github.com/tailwindlabs/tailwindcss/commit/700866ce5e0c0b8d140be161c4d07fc6f31242bc), [#2633](https://github.com/tailwindlabs/tailwindcss/pull/2633)) +- Add dark mode support ([#2279](https://github.com/tailwindlabs/tailwindcss/pull/2279), [#2631](https://github.com/tailwindlabs/tailwindcss/pull/2631)) +- Add `overflow-ellipsis` and `overflow-clip` utilities ([#1289](https://github.com/tailwindlabs/tailwindcss/pull/1289)) +- Add `transform-gpu` to force hardware acceleration on transforms when desired ([#1380](https://github.com/tailwindlabs/tailwindcss/pull/1380)) +- Extend default spacing scale ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630), [7f05204](https://github.com/tailwindlabs/tailwindcss/commit/7f05204ce7a5581b6845591448265c3c21afde86)) +- Add spacing scale to `inset` plugin ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630)) +- Add percentage sizes to `translate`, `inset`, and `height` plugins ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630), [5259560](https://github.com/tailwindlabs/tailwindcss/commit/525956065272dc53e8f8395f55f9ad13077a38d1)) +- Extend default font size scale ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609), [#2619](https://github.com/tailwindlabs/tailwindcss/pull/2619)) +- Support using `@apply` with complex classes, including variants like `lg:hover:bg-blue-500` ([#2159](https://github.com/tailwindlabs/tailwindcss/pull/2159)) +- Add new `2xl` breakpoint at 1536px by default ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609)) +- Add default line-height values for font-size utilities ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609)) +- Support defining theme values using arrays for CSS properties that support comma separated values ([e13f083c4](https://github.com/tailwindlabs/tailwindcss/commit/e13f083c4bc48bf9870d27c966136a9584943127)) +- Enable `group-hover` for color plugins, `boxShadow`, and `textDecoration` by default ([28985b6](https://github.com/tailwindlabs/tailwindcss/commit/28985b6cd592e72d4849fdb9ce97eb045744e09c), [f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Enable `focus` for z-index utilities by default ([ae5b3d3](https://github.com/tailwindlabs/tailwindcss/commit/ae5b3d312d5000ae9c2065001f3df7add72dc365)) +- Support `extend` in `variants` configuration ([#2651](https://github.com/tailwindlabs/tailwindcss/pull/2651)) +- Add `max-w-prose` class by default ([#2574](https://github.com/tailwindlabs/tailwindcss/pull/2574)) +- Support flattening deeply nested color objects ([#2148](https://github.com/tailwindlabs/tailwindcss/pull/2148)) +- Support defining presets as functions ([#2680](https://github.com/tailwindlabs/tailwindcss/pull/2680)) +- Support deep merging of objects under `extend` ([#2679](https://github.com/tailwindlabs/tailwindcss/pull/2679), [#2700](https://github.com/tailwindlabs/tailwindcss/pull/2700)) +- Enable `focus-within` for all plugins that have `focus` enabled by default ([1a21f072](https://github.com/tailwindlabs/tailwindcss/commit/1a21f0721c7368d61fa3feef33d616de3f78c7d7), [f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Added new `ring` utilities for creating outline/focus rings using box shadows ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747), [879f088](https://github.com/tailwindlabs/tailwindcss/commit/879f088), [e0788ef](https://github.com/tailwindlabs/tailwindcss/commit/879f088)) +- Added `5` and `95` to opacity scale ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747)) +- Add support for default duration and timing function values whenever enabling transitions ([#2755](https://github.com/tailwindlabs/tailwindcss/pull/2755)) + +### Changed + +- Completely redesign color palette ([#2623](https://github.com/tailwindlabs/tailwindcss/pull/2623), [700866c](https://github.com/tailwindlabs/tailwindcss/commit/700866ce5e0c0b8d140be161c4d07fc6f31242bc), [#2633](https://github.com/tailwindlabs/tailwindcss/pull/2633)) +- Drop support for Node 8 and 10 ([#2582](https://github.com/tailwindlabs/tailwindcss/pull/2582)) +- Removed `target` feature and dropped any compatibility with IE 11 ([#2571](https://github.com/tailwindlabs/tailwindcss/pull/2571)) +- Upgrade to PostCSS 8 (but include PostCSS 7 compatibility build) ([729b400](https://github.com/tailwindlabs/tailwindcss/commit/729b400a685973f46af73c8a68b364f20f7c5e1e), [1d8679d](https://github.com/tailwindlabs/tailwindcss/commit/1d8679d37e0eb1ba8281b2076bade5fc754f47dd), [c238ed1](https://github.com/tailwindlabs/tailwindcss/commit/c238ed15b5c02ff51978965511312018f2bc2cae)) +- Removed `shadow-outline`, `shadow-solid`, and `shadow-xs` by default in favor of new `ring` API ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747)) +- Switch `normalize.css` to `modern-normalize` ([#2572](https://github.com/tailwindlabs/tailwindcss/pull/2572)) +- Rename `whitespace-no-wrap` to `whitespace-nowrap` ([#2664](https://github.com/tailwindlabs/tailwindcss/pull/2664)) +- Rename `flex-no-wrap` to `flex-nowrap` ([#2676](https://github.com/tailwindlabs/tailwindcss/pull/2676)) +- Remove `clearfix` utility, recommend `flow-root` instead ([#2766](https://github.com/tailwindlabs/tailwindcss/pull/2766)) +- Disable `hover` and `focus` for `fontWeight` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Remove `grid-gap` fallbacks needed for old versions of Safari ([5ec45fa](https://github.com/tailwindlabs/tailwindcss/commit/5ec45fa)) +- Change special use of 'default' in config to 'DEFAULT' ([#2580](https://github.com/tailwindlabs/tailwindcss/pull/2580)) +- New `@apply` implementation, slight backwards incompatibilities with previous behavior ([#2159](https://github.com/tailwindlabs/tailwindcss/pull/2159)) +- Make `theme` retrieve the expected resolved value when theme value is complex ([e13f083c4](https://github.com/tailwindlabs/tailwindcss/commit/e13f083c4bc48bf9870d27c966136a9584943127)) +- Move `truncate` class to `textOverflow` core plugin ([#2562](https://github.com/tailwindlabs/tailwindcss/pull/2562)) +- Remove `scrolling-touch` and `scrolling-auto` utilities ([#2573](https://github.com/tailwindlabs/tailwindcss/pull/2573)) +- Modernize default system font stacks ([#1711](https://github.com/tailwindlabs/tailwindcss/pull/1711)) +- Upgrade to PurgeCSS 3.0 ([8e4e0a0](https://github.com/tailwindlabs/tailwindcss/commit/8e4e0a0eb8dcbf84347c7562988b4f9afd344081)) +- Change default `text-6xl` font-size to 3.75rem instead of 4rem ([#2619](https://github.com/tailwindlabs/tailwindcss/pull/2619)) +- Ignore `[hidden]` elements within `space` and `divide` utilities instead of `template` elements ([#2642](https://github.com/tailwindlabs/tailwindcss/pull/2642)) +- Automatically prefix keyframes and animation names when a prefix is configured ([#2621](https://github.com/tailwindlabs/tailwindcss/pull/2621), [#2641](https://github.com/tailwindlabs/tailwindcss/pull/2641)) +- Merge `extend` objects deeply by default ([#2679](https://github.com/tailwindlabs/tailwindcss/pull/2679)) +- Respect `preserveHtmlElements` option even when using custom PurgeCSS extractor ([#2704](https://github.com/tailwindlabs/tailwindcss/pull/2704)) +- Namespace all internal custom properties under `tw-` to avoid collisions with end-user custom properties ([#2771](https://github.com/tailwindlabs/tailwindcss/pull/2771)) + +## [2.0.0-alpha.25] - 2020-11-17 + +### Fixed + +- Fix issue where `ring-offset-0` didn't work due to unitless `0` in `calc` function ([3de0c48](https://github.com/tailwindlabs/tailwindcss/commit/3de0c48)) + +## [2.0.0-alpha.24] - 2020-11-16 + +### Changed + +- Don't override ring color when overriding ring width with a variant ([e40079a](https://github.com/tailwindlabs/tailwindcss/commit/e40079a)) + +### Fixed + +- Prevent shadow/ring styles from cascading to children ([e40079a](https://github.com/tailwindlabs/tailwindcss/commit/e40079a)) +- Ensure rings have a default color even if `colors.blue.500` is not present in config ([e40079a](https://github.com/tailwindlabs/tailwindcss/commit/e40079a)) + +## [2.0.0-alpha.23] - 2020-11-16 + +### Added + +- Add scripts for generating a PostCSS 7 compatible build alongside PostCSS 8 version ([#2773](https://github.com/tailwindlabs/tailwindcss/pull/2773)) + +### Changed + +- All custom properties have been internally namespaced under `tw-` to avoid collisions with end-user custom properties ([#2771](https://github.com/tailwindlabs/tailwindcss/pull/2771)) + +## [2.0.0-alpha.22] - 2020-11-16 + +### Changed + +- ~~All custom properties have been internally namespaced under `tw-` to avoid collisions with end-user custom properties ([#2771](https://github.com/tailwindlabs/tailwindcss/pull/2771))~~ I made a git boo-boo, check alpha.23 instead + +## [2.0.0-alpha.21] - 2020-11-15 + +### Changed + +- Upgrade to PostCSS 8, Autoprefixer 10, move `postcss` and `autoprefixer` to peerDependencies ([729b400](https://github.com/tailwindlabs/tailwindcss/commit/729b400)) + +## [2.0.0-alpha.20] - 2020-11-13 + +### Changed + +- Remove `clearfix` utility, recommend `flow-root` instead ([#2766](https://github.com/tailwindlabs/tailwindcss/pull/2766)) + +## [2.0.0-alpha.19] - 2020-11-13 + +### Fixed + +- Don't crash when color palette is empty ([278c203](https://github.com/tailwindlabs/tailwindcss/commit/278c203)) + +## [2.0.0-alpha.18] - 2020-11-13 + +### Changed + +- `black` and `white` have been added to `colors.js` ([b3ed724](https://github.com/tailwindlabs/tailwindcss/commit/b3ed724)) + +### Fixed + +- Add support for colors as closures to `ringColor` and `ringOffsetColor`, previously would crash build ([62a47f9](https://github.com/tailwindlabs/tailwindcss/commit/62a47f9)) + +## [2.0.0-alpha.17] - 2020-11-13 + +### Changed + +- Remove `grid-gap` fallbacks needed for old versions of Safari ([5ec45fa](https://github.com/tailwindlabs/tailwindcss/commit/5ec45fa)) + +## [2.0.0-alpha.16] - 2020-11-12 + +### Added + +- Enable `focus`, `focus-within`, and `dark` variants (when enabled) for all ring utilities by default ([e0788ef](https://github.com/tailwindlabs/tailwindcss/commit/879f088)) + +## [2.0.0-alpha.15] - 2020-11-11 + +### Added + +- Added `ring-inset` utility for rendering rings as inset shadows ([879f088](https://github.com/tailwindlabs/tailwindcss/commit/879f088)) + +### Changed + +- `ringWidth` utilities always reset ring styles to ensure no accidental variable inheritance through the cascade ([879f088](https://github.com/tailwindlabs/tailwindcss/commit/879f088)) + +## [2.0.0-alpha.14] - 2020-11-11 + +### Added + +- Enable `focus-within` for `outline` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Enable `focus-within` for `ringWidth` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Enable `group-hover` for `boxShadow` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) +- Enable `group-hover` and `focus-within` for `textDecoration` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) + +### Changed + +- Disable `hover` and `focus` for `fontWeight` utilities by default ([f6923b1](https://github.com/tailwindlabs/tailwindcss/commit/f6923b1)) + +## [2.0.0-alpha.13] - 2020-11-11 + +### Added + +- Add support for default duration and timing function values whenever enabling transitions ([#2755](https://github.com/tailwindlabs/tailwindcss/pull/2755)) + +## [2.0.0-alpha.12] - 2020-11-10 + +### Fixed + +- Prevent `boxShadow` utilities from overriding ring shadows added by components like in the custom forms plugin ([c3dd3b6](https://github.com/tailwindlabs/tailwindcss/commit/c3dd3b68454ad418833a9edf7f3409cad66fb5b0)) + +## [2.0.0-alpha.11] - 2020-11-09 + +### Fixed + +- Convert `none` to `0 0 #0000` when used for shadows to ensure compatibility with `ring` utilities ([4eecc27](https://github.com/tailwindlabs/tailwindcss/commit/4eecc2751ca0c461e8da5bd5772ae650197a2e5d)) + +## [2.0.0-alpha.10] - 2020-11-09 + +### Added + +- Added new `ring` utilities ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747)) +- Added `5` and `95` to opacity scale ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747)) + +### Changed + +- Removed `shadow-outline`, `shadow-solid`, and `shadow-xs` in favor of new `ring` API ([#2747](https://github.com/tailwindlabs/tailwindcss/pull/2747)) + +## [2.0.0-alpha.9] - 2020-11-07 + +### Added + +- Added `shadow-solid` utility, a 2px solid shadow that uses the current text color ([369cfae](https://github.com/tailwindlabs/tailwindcss/commit/369cfae2905a577033529c46a5e8ca58c69f5623)) +- Enable `focus-within` where useful by default ([1a21f072](https://github.com/tailwindlabs/tailwindcss/commit/1a21f0721c7368d61fa3feef33d616de3f78c7d7)) + +### Changed + +- Update `shadow-outline` to use the new blue ([b078238](https://github.com/tailwindlabs/tailwindcss/commit/b0782385c9832d35a10929b38b4fcaf27e055d6b)) + +## [2.0.0-alpha.8] - 2020-11-06 + +### Added + +- Add `11` to spacing scale ([7f05204](https://github.com/tailwindlabs/tailwindcss/commit/7f05204ce7a5581b6845591448265c3c21afde86)) +- Add percentage-based height values ([5259560](https://github.com/tailwindlabs/tailwindcss/commit/525956065272dc53e8f8395f55f9ad13077a38d1)) +- Add indigo to the color palette by default ([700866c](https://github.com/tailwindlabs/tailwindcss/commit/700866ce5e0c0b8d140be161c4d07fc6f31242bc)) + +### Changed + +- Use `coolGray` as the default gray ([700866c](https://github.com/tailwindlabs/tailwindcss/commit/700866ce5e0c0b8d140be161c4d07fc6f31242bc)) + +## [2.0.0-alpha.7] - 2020-11-05 + +### Changed + +- Revert upgrading to PostCSS 8 lol + +## [2.0.0-alpha.6] - 2020-11-04 + +### Changed + +- Respect `preserveHtmlElements` option even when using custom PurgeCSS extractor ([#2704](https://github.com/tailwindlabs/tailwindcss/pull/2704)) +- Set font-family and line-height to `inherit` on `body` to behave more like v1.x ([#2729](https://github.com/tailwindlabs/tailwindcss/pull/2729)) + +## [2.0.0-alpha.5] - 2020-10-30 + +### Changed + +- Upgrade to PostCSS 8 ([59aa484](https://github.com/tailwindlabs/tailwindcss/commit/59aa484dfea0607d96bff6ef41b1150c78576c37)) + +## [2.0.0-alpha.4] - 2020-10-29 + +### Added + +- Support deep merging of arrays of objects under `extend` ([#2700](https://github.com/tailwindlabs/tailwindcss/pull/2700)) + +## [2.0.0-alpha.3] - 2020-10-27 + +### Added + +- Support flattening deeply nested color objects ([#2148](https://github.com/tailwindlabs/tailwindcss/pull/2148)) +- Support defining presets as functions ([#2680](https://github.com/tailwindlabs/tailwindcss/pull/2680)) + +### Changed + +- Merge `extend` objects deeply by default ([#2679](https://github.com/tailwindlabs/tailwindcss/pull/2679)) +- Rename `flex-no-wrap` to `flex-nowrap` ([#2676](https://github.com/tailwindlabs/tailwindcss/pull/2676)) + +## [2.0.0-alpha.2] - 2020-10-25 + +### Added + +- Support `extend` in `variants` configuration ([#2651](https://github.com/tailwindlabs/tailwindcss/pull/2651)) +- Add `max-w-prose` class by default ([#2574](https://github.com/tailwindlabs/tailwindcss/pull/2574)) + +### Changed + +- Revert use of logical properties for `space` and `divide` utilities ([#2644](https://github.com/tailwindlabs/tailwindcss/pull/2644)) +- `space` and `divide` utilities ignore elements with `[hidden]` now instead of only ignoring `template` elements ([#2642](https://github.com/tailwindlabs/tailwindcss/pull/2642)) +- Set default font on `body`, not just `html` ([#2643](https://github.com/tailwindlabs/tailwindcss/pull/2643)) +- Automatically prefix keyframes and animation names when a prefix is configured ([#2621](https://github.com/tailwindlabs/tailwindcss/pull/2621), [#2641](https://github.com/tailwindlabs/tailwindcss/pull/2641)) +- Rename `whitespace-no-wrap` to `whitespace-nowrap` ([#2664](https://github.com/tailwindlabs/tailwindcss/pull/2664)) + +## [1.9.6] - 2020-10-23 + +### Changed + +- The `presets` feature had unexpected behavior where a preset config without its own `presets` key would not extend the default config. ([#2662](https://github.com/tailwindlabs/tailwindcss/pull/2662)) + + If you were depending on this unexpected behavior, just add `presets: []` to your own preset to exclude the default configuration. + +## [2.0.0-alpha.1] - 2020-10-20 + +### Added + +- Added dark mode support ([#2279](https://github.com/tailwindlabs/tailwindcss/pull/2279), [#2631](https://github.com/tailwindlabs/tailwindcss/pull/2631)) +- Added `overflow-ellipsis` and `overflow-clip` utilities ([#1289](https://github.com/tailwindlabs/tailwindcss/pull/1289)) +- Add `transform-gpu` to force hardware acceleration on transforms when beneficial ([#1380](https://github.com/tailwindlabs/tailwindcss/pull/1380)) +- Extended spacing scale ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630)) +- Add spacing scale to `inset` plugin ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630)) +- Enable useful relative sizes for more plugins ([#2630](https://github.com/tailwindlabs/tailwindcss/pull/2630)) +- Extend font size scale ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609), [#2619](https://github.com/tailwindlabs/tailwindcss/pull/2619)) +- Support using `@apply` with complex classes ([#2159](https://github.com/tailwindlabs/tailwindcss/pull/2159)) +- Add new `2xl` breakpoint ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609)) +- Add default line-height values for font-size utilities ([#2609](https://github.com/tailwindlabs/tailwindcss/pull/2609)) +- Support defining theme values using arrays wherever it makes sense (box-shadow, transition-property, etc.) ([e13f083c4](https://github.com/tailwindlabs/tailwindcss/commit/e13f083c4bc48bf9870d27c966136a9584943127)) +- Enable `group-hover` for color utilities by default ([28985b6](https://github.com/tailwindlabs/tailwindcss/commit/28985b6cd592e72d4849fdb9ce97eb045744e09c)) +- Enable `focus` for z-index utilities by default ([ae5b3d3](https://github.com/tailwindlabs/tailwindcss/commit/ae5b3d312d5000ae9c2065001f3df7add72dc365)) + +### Changed + +- New `@apply` implementation, slight backwards incompatibilities with previous behavior ([#2159](https://github.com/tailwindlabs/tailwindcss/pull/2159)) +- Move `truncate` class to `textOverflow` core plugin ([#2562](https://github.com/tailwindlabs/tailwindcss/pull/2562)) +- Removed `target` feature and dropped any compatibility with IE 11 ([#2571](https://github.com/tailwindlabs/tailwindcss/pull/2571)) +- Switch `normalize.css` to `modern-normalize` ([#2572](https://github.com/tailwindlabs/tailwindcss/pull/2572)) +- Remove `scrolling-touch` and `scrolling-auto` utilities ([#2573](https://github.com/tailwindlabs/tailwindcss/pull/2573)) +- Change special use of 'default' in config to 'DEFAULT' ([#2580](https://github.com/tailwindlabs/tailwindcss/pull/2580)) +- Drop support for Node 8 and 10 ([#2582](https://github.com/tailwindlabs/tailwindcss/pull/2582)) +- Modernize default system font stacks ([#1711](https://github.com/tailwindlabs/tailwindcss/pull/1711)) +- Upgrade to PurgeCSS 3.0 +- ~~Upgrade to PostCSS 8.0~~ Reverted for now +- Use logical properties for `space` and `divide` utilities ([#1883](https://github.com/tailwindlabs/tailwindcss/pull/1883)) +- Make `theme` retrieve the expected resolved value when theme value is complex ([e13f083c4](https://github.com/tailwindlabs/tailwindcss/commit/e13f083c4bc48bf9870d27c966136a9584943127)) +- Adjust default font-size scale to include 60px instead of 64px ([#2619](https://github.com/tailwindlabs/tailwindcss/pull/2619)) +- Update default colors in Preflight to match new color palette ([#2633](https://github.com/tailwindlabs/tailwindcss/pull/2633)) + +## [1.9.5] - 2020-10-19 + +### Fixed + +- Fix issue where using `theme` with default line-heights did not resolve correctly + +## [1.9.4] - 2020-10-17 + +### Fixed + +- Fix issue changing plugins defined using the `withOptions` API would not trigger rebuilds in watch processes + +## [1.9.3] - 2020-10-16 + +### Fixed + +- Fix issue where `tailwindcss init --full` scaffolded a corrupt config file (https://github.com/tailwindlabs/tailwindcss/issues/2556) + +### Changed + +- Remove console warnings about upcoming breaking changes + +## [1.9.2] - 2020-10-14 + +### Fixed + +- Merge plugins when merging config with preset ([#2561](https://github.com/tailwindlabs/tailwindcss/pulls/#2561) +- Use `word-wrap` and `overflow-wrap` together, not one or the other since `word-wrap` is IE-only + +## [1.9.1] - 2020-10-14 + +### Fixed + +- Don't import `corePlugins` in `resolveConfig` to avoid bundling browser-incompatible code ([#2548](https://github.com/tailwindlabs/tailwindcss/pull/2548)) + +## [1.9.0] - 2020-10-12 + +### Added + +- Add new `presets` config option ([#2474](https://github.com/tailwindlabs/tailwindcss/pull/2474)) +- Scaffold new `tailwind.config.js` files with available `future` flags commented out ([#2379](https://github.com/tailwindlabs/tailwindcss/pull/2379)) +- Add `col-span-full` and `row-span-full` ([#2471](https://github.com/tailwindlabs/tailwindcss/pull/2471)) +- Make `outline` configurable, `outline-none` more accessible by default, and add `outline-black` and `outline-white` ([#2460](https://github.com/tailwindlabs/tailwindcss/pull/2460)) +- Add additional small `rotate` and `skew` values ([#2528](https://github.com/tailwindlabs/tailwindcss/pull/2528)) +- Add `xl`, `2xl`, and `3xl` border radius values ([#2529](https://github.com/tailwindlabs/tailwindcss/pull/2529)) +- Add new utilities for `grid-auto-columns` and `grid-auto-rows` ([#2531](https://github.com/tailwindlabs/tailwindcss/pull/2531)) +- Promote `defaultLineHeights` and `standardFontWeights` from experimental to future + +### Fixed + +- Don't escape keyframe values ([#2432](https://github.com/tailwindlabs/tailwindcss/pull/2432)) +- Use `word-wrap` instead of `overflow-wrap` in `ie11` target mode ([#2391](https://github.com/tailwindlabs/tailwindcss/pull/2391)) + +### Experimental + +- Add experimental `2xl` breakpoint ([#2468](https://github.com/tailwindlabs/tailwindcss/pull/2468)) +- Rename `{u}-max-content` and `{u}-min-content` utilities to `{u}-max` and `{u}-min` in experimental extended spacing scale ([#2532](https://github.com/tailwindlabs/tailwindcss/pull/2532)) +- Support disabling dark mode variants globally ([#2530](https://github.com/tailwindlabs/tailwindcss/pull/2530)) + +## [1.8.13] - 2020-10-09 + +### Fixed + +- Support defining colors as closures even when opacity variables are not supported ([#2536](https://github.com/tailwindlabs/tailwindcss/pull/2515)) + +## [1.8.12] - 2020-10-07 + +### Fixed + +- Reset color opacity variable in utilities generated using closure colors ([#2515](https://github.com/tailwindlabs/tailwindcss/pull/2515)) + +## [1.8.11] - 2020-10-06 + +- Make `tailwindcss.plugin` work in ESM environments for reasons + +## [1.8.10] - 2020-09-14 + +### Fixed + +- Prevent new `dark` experiment from causing third-party `dark` variants to inherit stacking behavior ([#2382](https://github.com/tailwindlabs/tailwindcss/pull/2382)) + +## [1.8.9] - 2020-09-13 + +### Fixed + +- Add negative spacing values to inset plugin in the `extendedSpacingScale` experiment ([#2358](https://github.com/tailwindlabs/tailwindcss/pull/2358)) +- Fix issue where `!important` was stripped from declarations within rules that used `@apply` with `applyComplexClasses` ([#2376](https://github.com/tailwindlabs/tailwindcss/pull/2376)) + +### Changed + +- Add `future` section to config stubs ([#2372](https://github.com/tailwindlabs/tailwindcss/pull/2372), [3090b98](https://github.com/tailwindlabs/tailwindcss/commit/3090b98ece766b1046abe5bbaa94204e811f7fac)) + +## [1.8.8] - 2020-09-11 + +### Fixed + +- Register dark mode plugin outside of `resolveConfig` code path ([#2368](https://github.com/tailwindlabs/tailwindcss/pull/2368)) + +## [1.8.7] - 2020-09-10 + +### Fixed + +- Fix issue where classes in escaped strings (like `class=\"block\"`) weren't extracted properly for purging ([#2364](https://github.com/tailwindlabs/tailwindcss/pull/2364)) + +## [1.8.6] - 2020-09-09 + +### Fixed + +- Fix issue where container padding not applied when using object syntax ([#2353](https://github.com/tailwindlabs/tailwindcss/pull/2353)) + +## [1.8.5] - 2020-09-07 + +### Fixed + +- Fix issue where `resolveConfig` didn't take into account configs added by feature flags ([#2347](https://github.com/tailwindlabs/tailwindcss/pull/2347)) + +## [1.8.4] - 2020-09-06 + +### Fixed + +- Fix [issue](https://github.com/tailwindlabs/tailwindcss/issues/2258) where inserting extra PurgeCSS control comments could break integrated PurgeCSS support +- Fix issue where dark variant in 'class' mode was incompatible with 'group-hover' variant ([#2337](https://github.com/tailwindlabs/tailwindcss/pull/2337)) +- Support basic nesting structure with `@apply` when using the `applyComplexClasses` experiment ([#2271](https://github.com/tailwindlabs/tailwindcss/pull/2271)) + +### Changed + +- Rename `font-hairline` and `font-thin` to `font-thin` and `font-extralight` behind `standardFontWeights` flag (experimental until v1.9.0) ([#2333](https://github.com/tailwindlabs/tailwindcss/pull/2333)) + +## [1.8.3] - 2020-09-05 + +### Fixed + +- Fix issue where `font-variant-numeric` utilities would break in combination with most CSS minifier configurations ([f3660ce](https://github.com/tailwindlabs/tailwindcss/commit/f3660ceed391cfc9390ca4ea1a729a955e64b895)) +- Only warn about `conservative` purge mode being deprecated once per process ([58781b5](https://github.com/tailwindlabs/tailwindcss/commit/58781b517daffbaf80fc5c0791d311f53b2d67d8)) + +## [1.8.2] - 2020-09-04 + +### Fixed + +- Fix bug where dark mode variants would cause an error if you had a `plugins` array in your config ([#2322](https://github.com/tailwindlabs/tailwindcss/pull/2322)) + +## [1.8.1] - 2020-09-04 + +### Fixed + +- Fix bug in the new font-variant-numeric utilities which broke the whole rule ([#2318](https://github.com/tailwindlabs/tailwindcss/pull/2318)) +- Fix bug while purging ([#2320](https://github.com/tailwindlabs/tailwindcss/pull/2320)) + +## [1.8.0] - 2020-09-04 + +### Added + +- Dark mode variant (experimental) ([#2279](https://github.com/tailwindlabs/tailwindcss/pull/2279)) +- New `preserveHtmlElements` option for `purge` ([#2283](https://github.com/tailwindlabs/tailwindcss/pull/2283)) +- New `layers` mode for `purge` ([#2288](https://github.com/tailwindlabs/tailwindcss/pull/2288)) +- New `font-variant-numeric` utilities ([#2305](https://github.com/tailwindlabs/tailwindcss/pull/2305)) +- New `place-items`, `place-content`, `place-self`, `justify-items`, and `justify-self` utilities ([#2306](https://github.com/tailwindlabs/tailwindcss/pull/2306)) +- Support configuring variants as functions ([#2309](https://github.com/tailwindlabs/tailwindcss/pull/2309)) + +### Changed + +- CSS within `@layer` at-rules are now grouped with the corresponding `@tailwind` at-rule ([#2312](https://github.com/tailwindlabs/tailwindcss/pull/2312)) + +### Deprecated + +- `conservative` purge mode, deprecated in favor of `layers` + +## [1.7.6] - 2020-08-29 + +### Fixed + +- Fix bug where the new experimental `@apply` implementation broke when applying a variant class with the important option globally enabled + +## [1.7.5] - 2020-08-28 + +### Changed + +- Update lodash to latest to silence security warnings + +## [1.7.4] - 2020-08-26 + +### Added + +- Add new -p flag to CLI to quickly scaffold a `postcss.config.js` file + +### Changed + +- Make `@apply` insensitive to whitespace in the new `applyComplexClasses` experiment + +### Fixed + +- Fix bug where the new `applyComplexClasses` experiment didn't behave as expected with rules with multiple selectors, like `.foo, .bar { color: red }` + +## [1.7.3] - 2020-08-20 + +### Changed + +- Log feature flag notices to stderr instead of stdout to preserve compatibility with pipe-based build systems +- Add missing bg-none utility for disabling background images + +### Fixed + +- Fix bug that prevented defining colors as closures when the `gradientColorStops` plugin was enabled + +## [1.7.2] - 2020-08-19 + +### Added + +- Reuse generated CSS as much as possible in long-running processes instead of needlessly recalculating + +## [1.7.1] - 2020-08-28 + +### Changed + +- Don't issue duplicate flag notices in long-running build processes + +## [1.7.0] - 2020-08-28 + +### Added + +- Gradients +- New background-clip utilities +- New `contents` display utility +- Default letter-spacing per font-size +- Divide border styles +- Access entire config object from plugins +- Define colors as closures +- Use `@apply` with variants and other complex classes (experimental) +- New additional color-palette (experimental) +- Extended spacing scale (experimental) +- Default line-heights per font-size by default (experimental) +- Extended font size scale (experimental) + +### Deprecated + +- Deprecated gap utilities + +## [1.6.3] - 2020-08-18 + +### Fixed + +- Fixes issue where motion-safe and motion-reduce variants didn't stack correctly with group-hover variants + +## [1.6.2] - 2020-08-03 + +### Fixed + +- Fixes issue where `@keyframes` respecting the important option would break animations in Chrome + +## [1.6.1] - 2020-08-02 + +### Fixed + +- Fixes an issue where animation keyframes weren't included in the build without @tailwind base (#2108) + +## [1.6.0] - 2020-07-28 + +### Added + +- Animation support +- New `prefers-reduced-motion` variants +- New `overscroll-behaviour` utilities +- Generate CSS without an input file + +## [1.5.2] - 2020-07-21 + +### Fixed + +- Fixes issue where you could no longer use `@apply` with unprefixed class names if you had configured a prefix + +## [1.5.1] - 2020-07-15 + +### Fixed + +- Fixes accidental breaking change where adding component variants using the old manual syntax (as recommended in the docs) stopped working + +## [1.5.0] - 2020-07-15 + +### Added + +- Component `variants` support +- Responsive `container` variants +- New `focus-visible` variant +- New `checked` variant + +## v0.0.0-658250a96 - 2020-07-12 [YANKED] + +No release notes + +## [1.4.6] - 2020-05-08 + +### Changed + +- Explicitly error when using a class as the important config option instead of just generating the wrong CSS + +## [1.4.5] - 2020-05-06 + +### Fixed + +- Fix bug where the `divideColor` plugin was using the wrong '' in IE11 target mode + +## [1.4.4] - 2020-05-01 + +### Fixed + +- Fix bug where target: 'browserslist' didn't work, only `target: ['browserslist', {...}]` did + +## [1.4.3] - 2020-05-01 + +### Changed + +- Don't generate unnecessary CSS in color plugins when color opacity utilities are disabled + +## [1.4.2] - 2020-05-01 + +### Fixed + +- Fix issue where `purge: { enabled: false }` was ignored, add `purge: false` shorthand + +## [1.4.1] - 2020-04-30 + +### Changed + +- Improve built-in PurgeCSS extractor to better support Haml and Slim templates + +## [1.4.0] - 2020-04-29 + +### Added + +- New color opacity utilities +- Built-in PurgeCSS +- IE 11 target mode (experimental) + +## [1.3.5] - 2020-04-23 + +### Removed + +- Drop `fs-extra` dependency to `^8.0.0` to preserve Node 8 compatibility until Tailwind 2.0 + +### Fixed + +- Fix missing unit in calc bug in space plugin (`space-x-0` didn't work for example) + +## [1.3.4] - 2020-04-21 + +### Fixed + +- Fix bug where `divide-{x/y}-0` utilities didn't work due to missing unit in `calc` call + +## [1.3.3] - 2020-04-21 + +### Added + +- Add forgotten responsive variants for `space`, `divideWidth`, and `divideColor` utilities + +## [1.3.1] - 2020-04-21 + +### Fixed + +- Fix bug where the `space-x` utilities were not being applied correctly due to referencing `--space-y-reverse` instead of `--space-x-reverse` + +## [1.3.0] - 2020-04-21 + +### Added + +- New `space` and `divide` layout utilities +- New `transition-delay` utilities +- New `group-focus` variant +- Support for specifying a default line-height for each font-size utility +- Support for breakpoint-specific padding for `container` class +- Added `current` to the default color palette +- New `inline-grid` utility +- New `flow-root` display utility +- New `clear-none` utility + +## [1.2.0] - 2020-02-05 + +### Added + +- CSS Transition support +- CSS Transform support +- CSS Grid support +- Added `max-w-{screen}` utilities +- Added `max-w-none` utility +- Added `rounded-md` utility +- Added `shadow-sm` utility +- Added `shadow-xs` utility +- Added `stroke-width` utilities +- Added fixed line-height utilities +- Added additional display utilities for table elements +- Added box-sizing utilities +- Added clear utilities +- Config file dependencies are now watchable +- Added new `plugin` and `plugin.withOptions` APIs + +### Changed + +- Allow plugins to extend the user's config + +## [1.2.0-canary.8] - 2020-02-05 + +### Added + +- Add additional fixed-size line-height utilities + +## [1.2.0-canary.7] - 2020-02-04 + +### Removed + +- Remove Inter from font-sans, plan to add later under new class + +## [1.2.0-canary.6] - 2020-02-03 + +### Added + +- Add system-ui to default font stack +- Add shadow-xs, increase shadow-sm alpha to 0.05 +- Support import syntax even without postcss-import +- Alias tailwind bin to tailwindcss +- Add fill/stroke to transition-colors +- Add transition-shadow, add box-shadow to default transition +- Combine gap/columnGap/rowGap +- Add grid row utilities +- Add skew utilities + +### Changed + +- Use font-sans as default font + +## [1.2.0-canary.5] - 2020-01-08 + +### Added + +- Adds missing dependency `resolve` which is required for making config dependencies watchable + +## [1.2.0-canary.4] - 2020-01-08 + +### Added + +- CSS Transition support +- CSS Transform support +- CSS Grid support +- New `max-w-{screen}` utilities +- Added `max-w-none` utility +- Added "Inter" to the default sans-serif font stack +- Add `rounded-md` utility +- Add `shadow-sm` utility +- Added stroke-width utilities +- Added additional display utilities for table elements +- Added box-sizing utilities +- Added clear utilities +- Config file dependencies are now watchable +- Allow plugins to extend the user's config +- Add new `plugin` and `plugin.withOptions` APIs + +## [v1.2.0-canary.3] - 2020-01-08 [YANKED] + +No release notes + +## [1.1.4] - 2019-11-25 + +### Changed + +- Note: Although this is a bugfix it could affect your site if you were working around the bug in your own code by not prefixing the `.group` class. I'm sorry 😞 + +### Fixed + +- Fixes a bug where the `.group` class was not receiving the user's configured prefix when using the `prefix` option + +## [1.2.0-canary.1] - 2019-10-22 + +### Changed + +- Don't watch `node_modules` files for changes + +### Fixed + +- Fixes significant build performance regression in `v1.2.0-canary.0` + +## [1.1.3] - 2019-10-22 + +### Fixed + +- Fixes an issue where in some cases function properties in the user's `theme` config didn't receive the second utils argument + +## [1.2.0-canary.0] - 2019-10-14 + +### Added + +- Automatically watch all config file dependencies (plugins, design tokens imported from other files, etc.) for changes when build watcher is running +- Add `justify-evenly` utility + +### Changed + +- Allow plugins to add their own config file to be resolved with the user's custom config + +## [1.1.2] - 2019-08-14 + +### Fixed + +- Fixes a bug with horizontal rules where they were displayed with a 2px border instead of a 1px border +- Fixes a bug with horizontal rules where they were rendered with default top/bottom margin + +## [1.1.1] - 2019-08-09 + +### Fixed + +- Fixes issue where values like `auto` would fail to make it through the default negative margin config + +## [1.1.0] - 2019-08-06 + +### Added + +- Added utilities for screenreader visibility +- Added utilities for placeholder color +- First, last, even, and odd child variants +- Disabled variant +- Visited variant +- Increase utility specificity using a scope instead of !important +- Add hover/focus variants for opacity by default +- Added `border-double` utility +- Support negative prefix for boxShadow and letterSpacing plugins +- Support passing config path via object + +### Fixed + +- Placeholders no longer have a default opacity +- Make horizontal rules visible by default +- Generate correct negative margins when using calc + +## [1.0.6] - 2019-08-01 + +### Fixed + +- Fixes issue where modifiers would mutate nested rules + +## [1.0.5] - 2019-07-11 + +### Added + +- Support built-in variants for utilities that include pseudo-elements + +### Changed + +- Update several dependencies, including postcss-js which fixes an issue with using `!important` directly in Tailwind utility plugins + +## [1.0.4] - 2019-06-11 + +### Changed + +- Increase precision of percentage width values to avoid 1px rounding issues in grid layouts + +## [1.0.3] - 2019-06-01 + +### Changed + +- Throws an error when someone tries to use `@tailwind preflight` instead of `@tailwind base`, this is the source of many support requests + +## [1.0.2] - 2019-05-27 + +### Fixed + +- Fixes a bug where `@screen` rules weren't bubbled properly when nested in plugins + +## [1.0.1] - 2019-05-13 + +### Fixed + +- Fixes a bug where global variants weren't properly merged + +## [1.0.0] - 2019-05-13 + +No release notes + +## [1.0.0-beta.10] - 2019-05-12 + +### Changed + +- Use `9999` and `-9999` for `order-last` and `order-first` utilities respectively + +## [1.0.0-beta.9] - 2019-05-12 + +### Added + +- Add `bg-repeat-round` and `bg-repeat-space` utilities +- Add `select-all` and `select-auto` utilities + +### Changed + +- Make all utilities responsive by default + +## [1.0.0-beta.8] - 2019-04-28 + +### Added + +- Adds `responsive` variants for the new order utilities by default, should have been there all along + +## [1.0.0-beta.7] - 2019-04-27 + +### Fixed + +- Fixes a bug where you couldn't extend the margin config + +## [1.0.0-beta.6] - 2019-04-27 + +### Added + +- Added support for negative inset (`-top-6`, `-right-4`) and z-index (`-z-10`) utilities, using the same negative key syntax supported by the margin plugin +- Add missing fractions as well as x/12 fractions to width scale +- Add `order` utilities +- Add `cursor-text` class by default + +### Changed + +- Make it possible to access your fully merged config file in JS + +### Removed + +- Removed `negativeMargin` plugin, now the regular `margin` plugin supports generating negative classes (like `-mx-6`) by using negative keys in the config, like `-6` + +## [1.0.0-beta.5] - 2019-04-18 + +### Changed + +- Make it possible to disable all core plugins using `corePlugins: false` +- Make it possible to configure a single list of variants that applies to all utility plugins +- Make it possible to whitelist which core plugins should be enabled + +### Fixed + +- Fix a bug where stroke and fill plugins didn't properly handle the next object syntax for color definitions +- Fix a bug where you couldn't have comments near `@apply` directives + +## [1.0.0-beta.4] - 2019-03-29 + +### Added + +- Add the `container` key to the scaffolded config file when generated with `--full` + +### Changed + +- Bumps node dependency to 8.9.0 so we can keep our default config file clean, 6.9.0 is EOL next month anyways + +### Removed + +- Removes `SFMono-Regular` from the beginning of the default monospace font stack, it has no italic support and Menlo looks better anyways + +### Fixed + +- Fixes an issue where the user's config object was being mutated during processing (only affects @bradlc 😅) +- Fixes an issue where you couldn't use a closure to define theme sections under `extend` + +## [1.0.0-beta.3] - 2019-03-18 + +### Added + +- Support lazy evaluation in `theme.extend` + +### Changed + +- Use lighter default border color +- Revert #745 and use `bolder` for strong tags by default instead of `fontWeight.bold` + +## [1.0.0-beta.2] - 2019-03-17 + +### Changed + +- Closures in the `theme` section of the config file are now passed a `theme` function instead of an object + +### Fixed + +- Fix issue where `@screen` didn't work at all 🙃 + +## [1.0.0-beta.1] - 2019-03-17 + +### Added + +- New config file structure +- New expanded default color palette +- New default `maxWidth` scale +- Added utilities for `list-style-type` and `list-style-position` +- Added `break-all` utility + +### Changed + +- `object-position` utilities are now customizable under `theme.objectPosition` +- `cursor` utilities are now customizable under `theme.cursors` +- `flex-grow/shrink` utilities are now customizable under `theme.flexGrow/flexShrink` +- Default variant output position can be customized +- Extended default line-height scale +- Extended default letter-spacing scale + +## [0.7.4] - 2019-01-23 + +### Changed + +- Update our PostCSS related dependencies + +### Fixed + +- Fix bug where class names containing a `.`character had the responsive prefix added in the wrong place + +## [0.7.3] - 2018-12-03 + +### Changed + +- Update Normalize to v8.0.1 + +## [0.7.2] - 2018-11-05 + +### Added + +- Add `--no-autoprefixer` option to CLI `build` command + +## [0.7.1] - 2018-11-05 + +### Changed + +- Update autoprefixer dependency + +## [0.7.0] - 2018-10-31 + +### Added + +- Registering new variants from plugins +- Variant order can be customized per module +- Added focus-within variant +- Fancy CLI updates +- Option to generate config without comments +- Make configured prefix optional when using @apply +- Improve Flexbox behavior in IE 10/11 + +### Changed + +- Variant order in modules is now significant +- Normalize.css updated to v8.0.0 +- Removed CSS fix for Chrome 62 button border radius change + +## [0.6.6] - 2018-09-21 + +### Changed + +- Promote `shadowLookup` from experiment to official feature + +## [0.6.5] - 2018-08-18 + +### Fixed + +- Fixes an issue where units were stripped from zero value properties + +## [0.6.4] - 2018-07-16 + +### Fixed + +- Fixes an issue where changes to your configuration file were ignored when using `webpack --watch` + +## [0.6.3] - 2018-07-11 + +### Fixed + +- Fixes an issue where `@tailwind utilities` generated no output + +## [0.6.2] - 2018-03-11 + +### Added + +- Added table layout utilities for styling tables +- Configuration can now be passed as an object +- Registering new variants from plugins (experimental) +- Allow `@apply`-ing classes that aren't defined but would be generated (experimental) + +### Changed + +- Default config file changes + +## [0.6.1] - 2018-06-22 + +### Fixed + +- Fix incorrect box-shadow syntax for the `.shadow-outline` utility 🤦‍♂️ + +## [0.6.0] - 2018-06-21 + +### Added + +- Added border collapse utilities for styling tables +- Added more axis-specific overflow utilities +- Added `.outline-none` utility for suppressing focus styles +- Added `.shadow-outline` utility as an alternative to default browser focus styles +- Extended default padding, margin, negative margin, width, and height scales +- Enable focus and hover variants for more modules by default + +### Changed + +- Removed default `outline: none !important` styles from focusable but keyboard-inaccessible elements +- Moved screen prefix for responsive `group-hover` variants +- Default config file changes + +## [0.5.3] - 2018-05-07 + +### Changed + +- Improve sourcemaps for replaced styles like `preflight` + +### Fixed + +- Fix bug where informational messages were being logged to stdout during build, preventing the ability to use Tailwind's output in Unix pipelines + +## [0.5.2] - 2018-03-29 + +### Fixed + +- Fixes an issue with a dependency that had a security vulnerability + +## [0.5.1] - 2018-03-13 + +### Removed + +- Reverts a change that renamed the `.roman` class to `.not-italic` due to the fact that it breaks compatibility with cssnext: [postcss/postcss-selector-not#10](https://github.com/postcss/postcss-selector-not/issues/10). We'll stick with `.roman` for now with a plan to switch to `.not-italic` in another breaking version should that issue get resolved in postcss-selector-not. + +## [0.5.0] - 2018-03-13 + +### Added + +- Plugin system +- Added `.sticky position` utility +- Added `.cursor-wait` and `.cursor-move` utilities +- Added `.bg-auto` background size utility +- Background sizes are now customizable +- Support for active variants +- Better postcss-import support +- Configuration options for the `.container` component + +### Changed + +- The `.container` component is now a built-in plugin +- State variant precedence changes +- New config file keys +- `.overflow-x/y-scroll` now set `overflow: scroll` instead of `overflow: auto` +- `.roman` renamed to `.not-italic` + +## [0.4.3] - 2018-03-13 + +### Changed + +- Use `global.Object` to avoid issues with polyfills when importing the Tailwind config into other JS + +## [0.4.2] - 2018-03-01 + +### Added + +- Add support for using a function to define class prefixes in addition to a simple string + +### Changed + +- Improve the performance of @apply by using a lookup table instead of searching + +### Fixed + +- Fix an issue where borders couldn't be applied to `img` tags without specifying a border style + +## [0.4.1] - 2018-01-22 + +### Changed + +- Make default sans-serif font stack more future proof and safe to use with CSS `font` shorthand +- Replace stylefmt with Perfectionist to avoid weird stylelint conflicts + +## [0.4.0] - 2017-12-15 + +### Added + +- `@apply`'d classes can now be made `!important` explicitly + +### Changed + +- `@apply` now strips `!important` from any mixed in classes +- Default color palette tweaks + +## [0.3.0] - 2017-12-01 + +### Added + +- Enable/disable modules and control which variants are generated for each +- Focus variants +- Group hover variants +- New `@variants` at-rule +- Customize the separator character +- Missing config keys now fallback to their default values +- New utilities + +### Changed + +- Lists now have no margins by default +- `.pin` no longer sets width and height to 100% +- SVG `fill` no longer defaults to currentColor + +## [0.2.2] - 2017-11-19 + +### Fixed + +- Fix issue with dist files not being published due to bug in latest npm + +## [0.2.1] - 2017-11-18 + +### Fixed + +- Fix overly specific border-radius reset for Chrome 62 button styles + +## [0.2.0] - 2017-11-17 + +### Added + +- Add a custom prefix to all utilities +- Optionally make all utilities `!important` +- Round element corners independently +- Cascading border colors and styles + +### Changed + +- `auto` is no longer a hard-coded margin value +- The `defaultConfig` function is now a separate module +- Rounded utilities now combine position and radius size +- Border width utilities no longer affect border color/style +- `@apply` is now very strict about what classes can be applied +- Add `options` key to your config +- Spacing, radius, and border width utility declaration order changes + +## [0.1.6] - 2017-11-09 + +### Fixed + +- Fix CDN files not being published to npm + +## [0.1.5] - 2017-11-08 + +### Changed + +- Apply the same default placeholder styling that's applied to inputs to textareas + +### Fixed + +- Fix CLI tool not loading config files properly + +## [0.1.4] - 2017-11-06 + +### Added + +- Autoprefix dist assets for quick hacking and prototyping +- Add `my-auto`, `mt-auto`, and `mb-auto` margin utilities +- Add `sans-serif` to end of default `sans` font stack + +### Changed + +- If using Webpack, it will now watch your config file changes +- When running `tailwind init [filename]`, automatically append `.js` to filename if not present +- Support default fallback value in `config(...)` function, ie. `config('colors.blue', #0000ff)` +- Don't output empty media queries if Tailwind processes a file that doesn't use Tailwind + +### Fixed + +- Move list utilities earlier in stylesheet to allow overriding with spacing utilities + +## [0.1.3] - 2017-11-02 + +### Added + +- Add new `.scrolling-touch` and `.scrolling-auto` utilities for controlling inertial scroll behavior on WebKit touch devices +- Generate separate dist files for preflight, utilities, and tailwind for CDN usage + +## [0.1.2] - 2017-11-01 + +### Changed + +- Target Node 6.9.0 explicitly (instead of 8.6 implicitly) to support more users + +### Fixed + +- Fix issue with config option not being respected in `tailwind build` + +## [0.1.1] - 2017-11-01 + +### Fixed + +- Fix `tailwind build` CLI command not writing output files + +## [0.1.0] - 2017-11-01 + +### Added + +- Everything! + +[unreleased]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.4...HEAD +[3.1.4]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.3...v3.1.4 +[3.1.3]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.2...v3.1.3 +[3.1.2]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.1...v3.1.2 +[3.1.1]: https://github.com/tailwindlabs/tailwindcss/compare/v3.1.0...v3.1.1 +[3.1.0]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.24...v3.1.0 +[3.0.24]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.23...v3.0.24 +[3.0.23]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.22...v3.0.23 +[3.0.22]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.21...v3.0.22 +[3.0.21]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.20...v3.0.21 +[3.0.20]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.19...v3.0.20 +[3.0.19]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.18...v3.0.19 +[3.0.18]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.17...v3.0.18 +[3.0.17]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.16...v3.0.17 +[3.0.16]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.15...v3.0.16 +[3.0.15]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.14...v3.0.15 +[3.0.14]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.13...v3.0.14 +[3.0.13]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.12...v3.0.13 +[3.0.12]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.11...v3.0.12 +[3.0.11]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.10...v3.0.11 +[3.0.10]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.9...v3.0.10 +[3.0.9]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.8...v3.0.9 +[3.0.8]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.7...v3.0.8 +[3.0.7]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.6...v3.0.7 +[3.0.6]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.5...v3.0.6 +[3.0.5]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.4...v3.0.5 +[3.0.4]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.3...v3.0.4 +[3.0.3]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.2...v3.0.3 +[3.0.2]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.1...v3.0.2 +[3.0.1]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.0...v3.0.1 +[3.0.0]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.0-alpha.2...v3.0.0 +[3.0.0-alpha.2]: https://github.com/tailwindlabs/tailwindcss/compare/v3.0.0-alpha.1...v3.0.0-alpha.2 +[3.0.0-alpha.1]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.19...v3.0.0-alpha.1 +[2.2.19]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.18...v2.2.19 +[2.2.18]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.17...v2.2.18 +[2.2.17]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.16...v2.2.17 +[2.2.16]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.15...v2.2.16 +[2.2.15]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.14...v2.2.15 +[2.2.14]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.13...v2.2.14 +[2.2.13]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.12...v2.2.13 +[2.2.12]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.11...v2.2.12 +[2.2.11]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.10...v2.2.11 +[2.2.10]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.9...v2.2.10 +[2.2.9]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.8...v2.2.9 +[2.2.8]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.7...v2.2.8 +[2.2.7]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.6...v2.2.7 +[2.2.6]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.5...v2.2.6 +[2.2.5]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.4...v2.2.5 +[2.2.4]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.3...v2.2.4 +[2.2.3]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.2...v2.2.3 +[2.2.2]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.1...v2.2.2 +[2.2.1]: https://github.com/tailwindlabs/tailwindcss/compare/v2.2.0...v2.2.1 +[2.2.0]: https://github.com/tailwindlabs/tailwindcss/compare/v2.1.4...v2.2.0 +[2.1.4]: https://github.com/tailwindlabs/tailwindcss/compare/v2.1.3...v2.1.4 +[2.1.3]: https://github.com/tailwindlabs/tailwindcss/compare/v2.1.2...v2.1.3 +[2.1.2]: https://github.com/tailwindlabs/tailwindcss/compare/v2.1.1...v2.1.2 +[2.1.1]: https://github.com/tailwindlabs/tailwindcss/compare/v2.1.0...v2.1.1 +[2.1.0]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.4...v2.1.0 +[2.0.4]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.3...v2.0.4 +[2.0.3]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.2...v2.0.3 +[2.0.2]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.1...v2.0.2 +[2.0.1]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0...v2.0.1 +[2.0.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.6...v2.0.0 +[2.0.0-alpha.25]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.24...v2.0.0-alpha.25 +[2.0.0-alpha.24]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.23...v2.0.0-alpha.24 +[2.0.0-alpha.23]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.22...v2.0.0-alpha.23 +[2.0.0-alpha.22]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.21...v2.0.0-alpha.22 +[2.0.0-alpha.21]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.20...v2.0.0-alpha.21 +[2.0.0-alpha.20]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.19...v2.0.0-alpha.20 +[2.0.0-alpha.19]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.18...v2.0.0-alpha.19 +[2.0.0-alpha.18]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.17...v2.0.0-alpha.18 +[2.0.0-alpha.17]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.16...v2.0.0-alpha.17 +[2.0.0-alpha.16]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.15...v2.0.0-alpha.16 +[2.0.0-alpha.15]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.14...v2.0.0-alpha.15 +[2.0.0-alpha.14]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.13...v2.0.0-alpha.14 +[2.0.0-alpha.13]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.12...v2.0.0-alpha.13 +[2.0.0-alpha.12]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.11...v2.0.0-alpha.12 +[2.0.0-alpha.11]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.10...v2.0.0-alpha.11 +[2.0.0-alpha.10]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.9...v2.0.0-alpha.10 +[2.0.0-alpha.9]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.8...v2.0.0-alpha.9 +[2.0.0-alpha.8]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.7...v2.0.0-alpha.8 +[2.0.0-alpha.7]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.6...v2.0.0-alpha.7 +[2.0.0-alpha.6]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.5...v2.0.0-alpha.6 +[2.0.0-alpha.5]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.4...v2.0.0-alpha.5 +[2.0.0-alpha.4]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.3...v2.0.0-alpha.4 +[2.0.0-alpha.3]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.2...v2.0.0-alpha.3 +[2.0.0-alpha.2]: https://github.com/tailwindlabs/tailwindcss/compare/v2.0.0-alpha.1...v2.0.0-alpha.2 +[1.9.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.5...v1.9.6 +[2.0.0-alpha.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.5...v2.0.0-alpha.1 +[1.9.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.4...v1.9.5 +[1.9.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.3...v1.9.4 +[1.9.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.3 +[1.9.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.1...v1.9.2 +[1.9.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.9.0...v1.9.1 +[1.9.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.13...v1.9.0 +[1.8.13]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.12...v1.8.13 +[1.8.12]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.11...v1.8.12 +[1.8.11]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.10...v1.8.11 +[1.8.10]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.9...v1.8.10 +[1.8.9]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.8...v1.8.9 +[1.8.8]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.7...v1.8.8 +[1.8.7]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.6...v1.8.7 +[1.8.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.5...v1.8.6 +[1.8.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.4...v1.8.5 +[1.8.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.3...v1.8.4 +[1.8.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.2...v1.8.3 +[1.8.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.1...v1.8.2 +[1.8.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.8.0...v1.8.1 +[1.8.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.6...v1.8.0 +[1.7.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.5...v1.7.6 +[1.7.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.4...v1.7.5 +[1.7.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.3...v1.7.4 +[1.7.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.2...v1.7.3 +[1.7.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.1...v1.7.2 +[1.7.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.7.0...v1.7.1 +[1.7.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.6.3...v1.7.0 +[1.6.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.6.2...v1.6.3 +[1.6.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.6.1...v1.6.2 +[1.6.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.6.0...v1.6.1 +[1.6.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.5.2...v1.6.0 +[1.5.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.5.1...v1.5.2 +[1.5.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.5.0...v1.5.1 +[1.5.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.6...v1.5.0 +[1.4.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.5...v1.4.6 +[1.4.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.4...v1.4.5 +[1.4.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.3...v1.4.4 +[1.4.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.2...v1.4.3 +[1.4.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.1...v1.4.2 +[1.4.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.4.0...v1.4.1 +[1.4.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.3.5...v1.4.0 +[1.3.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.3.4...v1.3.5 +[1.3.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.3.3...v1.3.4 +[1.3.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.3.1...v1.3.3 +[1.3.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.3.0...v1.3.1 +[1.3.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0...v1.3.0 +[1.2.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.4...v1.2.0 +[1.2.0-canary.8]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.7...v1.2.0-canary.8 +[1.2.0-canary.7]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.6...v1.2.0-canary.7 +[1.2.0-canary.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.5...v1.2.0-canary.6 +[1.2.0-canary.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.4...v1.2.0-canary.5 +[1.2.0-canary.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.3...v1.2.0-canary.4 +[1.1.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.3...v1.1.4 +[1.2.0-canary.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.2.0-canary.0...v1.2.0-canary.1 +[1.1.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.2...v1.1.3 +[1.2.0-canary.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.2...v1.2.0-canary.0 +[1.1.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.1...v1.1.2 +[1.1.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.1.0...v1.1.1 +[1.1.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.6...v1.1.0 +[1.0.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.5...v1.0.6 +[1.0.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.4...v1.0.5 +[1.0.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.3...v1.0.4 +[1.0.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.2...v1.0.3 +[1.0.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.1...v1.0.2 +[1.0.1]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0...v1.0.1 +[1.0.0]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.10...v1.0.0 +[1.0.0-beta.10]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.9...v1.0.0-beta.10 +[1.0.0-beta.9]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.8...v1.0.0-beta.9 +[1.0.0-beta.8]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.7...v1.0.0-beta.8 +[1.0.0-beta.7]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.6...v1.0.0-beta.7 +[1.0.0-beta.6]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.5...v1.0.0-beta.6 +[1.0.0-beta.5]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.4...v1.0.0-beta.5 +[1.0.0-beta.4]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.3...v1.0.0-beta.4 +[1.0.0-beta.3]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.2...v1.0.0-beta.3 +[1.0.0-beta.2]: https://github.com/tailwindlabs/tailwindcss/compare/v1.0.0-beta.1...v1.0.0-beta.2 +[1.0.0-beta.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.7.4...v1.0.0-beta.1 +[0.7.4]: https://github.com/tailwindlabs/tailwindcss/compare/v0.7.3...v0.7.4 +[0.7.3]: https://github.com/tailwindlabs/tailwindcss/compare/v0.7.2...v0.7.3 +[0.7.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.7.1...v0.7.2 +[0.7.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.7.0...v0.7.1 +[0.7.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.6...v0.7.0 +[0.6.6]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.5...v0.6.6 +[0.6.5]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.4...v0.6.5 +[0.6.4]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.3...v0.6.4 +[0.6.3]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.2...v0.6.3 +[0.6.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.1...v0.6.2 +[0.6.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.6.0...v0.6.1 +[0.6.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.5.3...v0.6.0 +[0.5.3]: https://github.com/tailwindlabs/tailwindcss/compare/v0.5.2...v0.5.3 +[0.5.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.5.1...v0.5.2 +[0.5.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.5.0...v0.5.1 +[0.5.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.4.3...v0.5.0 +[0.4.3]: https://github.com/tailwindlabs/tailwindcss/compare/v0.4.2...v0.4.3 +[0.4.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.4.1...v0.4.2 +[0.4.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.4.0...v0.4.1 +[0.4.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.3.0...v0.4.0 +[0.3.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.2.2...v0.3.0 +[0.2.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.2.1...v0.2.2 +[0.2.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.2.0...v0.2.1 +[0.2.0]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.6...v0.2.0 +[0.1.6]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.5...v0.1.6 +[0.1.5]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.4...v0.1.5 +[0.1.4]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.3...v0.1.4 +[0.1.3]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.2...v0.1.3 +[0.1.2]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.1...v0.1.2 +[0.1.1]: https://github.com/tailwindlabs/tailwindcss/compare/v0.1.0...v0.1.1 +[0.1.0]: https://github.com/tailwindlabs/tailwindcss/releases/tag/v0.1.0 diff --git a/node_modules/tailwindcss/LICENSE b/node_modules/tailwindcss/LICENSE new file mode 100644 index 0000000..d6a8229 --- /dev/null +++ b/node_modules/tailwindcss/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) Tailwind Labs, Inc. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/tailwindcss/README.md b/node_modules/tailwindcss/README.md new file mode 100644 index 0000000..2ffaaf8 --- /dev/null +++ b/node_modules/tailwindcss/README.md @@ -0,0 +1,37 @@ +

      + + Tailwind CSS + + + Tailwind CSS + +

      + +A utility-first CSS framework for rapidly building custom user interfaces. + +

      + Build Status + Total Downloads + Latest Release + License +

      + +------ + +## Documentation + +For full documentation, visit [tailwindcss.com](https://tailwindcss.com/). + +## Community + +For help, discussion about best practices, or any other conversation that would benefit from being searchable: + +[Discuss Tailwind CSS on GitHub](https://github.com/tailwindcss/tailwindcss/discussions) + +For casual chit-chat with others using the framework: + +[Join the Tailwind CSS Discord Server](https://discord.gg/7NF8GNe) + +## Contributing + +If you're interested in contributing to Tailwind CSS, please read our [contributing docs](https://github.com/tailwindcss/tailwindcss/blob/master/.github/CONTRIBUTING.md) **before submitting a pull request**. diff --git a/node_modules/tailwindcss/base.css b/node_modules/tailwindcss/base.css new file mode 100644 index 0000000..2f02db5 --- /dev/null +++ b/node_modules/tailwindcss/base.css @@ -0,0 +1 @@ +@tailwind base; diff --git a/node_modules/tailwindcss/colors.d.ts b/node_modules/tailwindcss/colors.d.ts new file mode 100644 index 0000000..d85ab86 --- /dev/null +++ b/node_modules/tailwindcss/colors.d.ts @@ -0,0 +1,3 @@ +import type { DefaultColors } from './types/generated/colors' +declare const colors: DefaultColors +export = colors diff --git a/node_modules/tailwindcss/colors.js b/node_modules/tailwindcss/colors.js new file mode 100644 index 0000000..c6f9149 --- /dev/null +++ b/node_modules/tailwindcss/colors.js @@ -0,0 +1,2 @@ +let colors = require('./lib/public/colors') +module.exports = (colors.__esModule ? colors : { default: colors }).default diff --git a/node_modules/tailwindcss/components.css b/node_modules/tailwindcss/components.css new file mode 100644 index 0000000..020aaba --- /dev/null +++ b/node_modules/tailwindcss/components.css @@ -0,0 +1 @@ +@tailwind components; diff --git a/node_modules/tailwindcss/defaultConfig.d.ts b/node_modules/tailwindcss/defaultConfig.d.ts new file mode 100644 index 0000000..2c2bccf --- /dev/null +++ b/node_modules/tailwindcss/defaultConfig.d.ts @@ -0,0 +1,3 @@ +import type { Config } from './types/config' +declare const config: Config +export = config diff --git a/node_modules/tailwindcss/defaultConfig.js b/node_modules/tailwindcss/defaultConfig.js new file mode 100644 index 0000000..7b63587 --- /dev/null +++ b/node_modules/tailwindcss/defaultConfig.js @@ -0,0 +1,2 @@ +let defaultConfig = require('./lib/public/default-config') +module.exports = (defaultConfig.__esModule ? defaultConfig : { default: defaultConfig }).default diff --git a/node_modules/tailwindcss/defaultTheme.d.ts b/node_modules/tailwindcss/defaultTheme.d.ts new file mode 100644 index 0000000..9172051 --- /dev/null +++ b/node_modules/tailwindcss/defaultTheme.d.ts @@ -0,0 +1,3 @@ +import type { Config } from './types/config' +declare const theme: Config['theme'] +export = theme diff --git a/node_modules/tailwindcss/defaultTheme.js b/node_modules/tailwindcss/defaultTheme.js new file mode 100644 index 0000000..991526d --- /dev/null +++ b/node_modules/tailwindcss/defaultTheme.js @@ -0,0 +1,2 @@ +let defaultTheme = require('./lib/public/default-theme') +module.exports = (defaultTheme.__esModule ? defaultTheme : { default: defaultTheme }).default diff --git a/node_modules/tailwindcss/lib/cli-peer-dependencies.js b/node_modules/tailwindcss/lib/cli-peer-dependencies.js new file mode 100644 index 0000000..d4b19ff --- /dev/null +++ b/node_modules/tailwindcss/lib/cli-peer-dependencies.js @@ -0,0 +1,20 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.lazyPostcss = lazyPostcss; +exports.lazyPostcssImport = lazyPostcssImport; +exports.lazyAutoprefixer = lazyAutoprefixer; +exports.lazyCssnano = lazyCssnano; +function lazyPostcss() { + return require("postcss"); +} +function lazyPostcssImport() { + return require("postcss-import"); +} +function lazyAutoprefixer() { + return require("autoprefixer"); +} +function lazyCssnano() { + return require("cssnano"); +} diff --git a/node_modules/tailwindcss/lib/cli.js b/node_modules/tailwindcss/lib/cli.js new file mode 100755 index 0000000..ee81eb8 --- /dev/null +++ b/node_modules/tailwindcss/lib/cli.js @@ -0,0 +1,805 @@ +#!/usr/bin/env node +"use strict"; +var _indexJs = require("../peers/index.js"); +var _chokidar = _interopRequireDefault(require("chokidar")); +var _path = _interopRequireDefault(require("path")); +var _arg = _interopRequireDefault(require("arg")); +var _fs = _interopRequireDefault(require("fs")); +var _postcssLoadConfig = _interopRequireDefault(require("postcss-load-config")); +var _lilconfig = require("lilconfig"); +var _plugins // Little bit scary, looking at private/internal API + = _interopRequireDefault(require("postcss-load-config/src/plugins")); +var _options // Little bit scary, looking at private/internal API + = _interopRequireDefault(require("postcss-load-config/src/options")); +var _processTailwindFeatures = _interopRequireDefault(require("./processTailwindFeatures")); +var _resolveConfig = _interopRequireDefault(require("../resolveConfig")); +var _fastGlob = _interopRequireDefault(require("fast-glob")); +var _getModuleDependencies = _interopRequireDefault(require("./lib/getModuleDependencies")); +var _log = _interopRequireDefault(require("./util/log")); +var _packageJson = _interopRequireDefault(require("../package.json")); +var _normalizePath = _interopRequireDefault(require("normalize-path")); +var _validateConfigJs = require("./util/validateConfig.js"); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +let env = { + DEBUG: process.env.DEBUG !== undefined && process.env.DEBUG !== "0" +}; +function isESM() { + const pkgPath = _path.default.resolve("./package.json"); + try { + let pkg = JSON.parse(_fs.default.readFileSync(pkgPath, "utf8")); + return pkg.type && pkg.type === "module"; + } catch (err) { + return false; + } +} +let configs = isESM() ? { + tailwind: "tailwind.config.cjs", + postcss: "postcss.config.cjs" +} : { + tailwind: "tailwind.config.js", + postcss: "postcss.config.js" +}; +// --- +function indentRecursive(node, indent = 0) { + node.each && node.each((child, i)=>{ + if (!child.raws.before || !child.raws.before.trim() || child.raws.before.includes("\n")) { + child.raws.before = `\n${node.type !== "rule" && i > 0 ? "\n" : ""}${" ".repeat(indent)}`; + } + child.raws.after = `\n${" ".repeat(indent)}`; + indentRecursive(child, indent + 1); + }); +} +function formatNodes(root) { + indentRecursive(root); + if (root.first) { + root.first.raws.before = ""; + } +} +async function outputFile(file, contents) { + if (_fs.default.existsSync(file) && await _fs.default.promises.readFile(file, "utf8") === contents) { + return; // Skip writing the file + } + // Write the file + await _fs.default.promises.writeFile(file, contents, "utf8"); +} +function drainStdin() { + return new Promise((resolve, reject)=>{ + let result = ""; + process.stdin.on("data", (chunk)=>{ + result += chunk; + }); + process.stdin.on("end", ()=>resolve(result)); + process.stdin.on("error", (err)=>reject(err)); + }); +} +function help({ message , usage , commands: commands1 , options }) { + let indent = 2; + // Render header + console.log(); + console.log(`${_packageJson.default.name} v${_packageJson.default.version}`); + // Render message + if (message) { + console.log(); + for (let msg of message.split("\n")){ + console.log(msg); + } + } + // Render usage + if (usage && usage.length > 0) { + console.log(); + console.log("Usage:"); + for (let example of usage){ + console.log(" ".repeat(indent), example); + } + } + // Render commands + if (commands1 && commands1.length > 0) { + console.log(); + console.log("Commands:"); + for (let command1 of commands1){ + console.log(" ".repeat(indent), command1); + } + } + // Render options + if (options) { + let groupedOptions = {}; + for (let [key, value] of Object.entries(options)){ + if (typeof value === "object") { + groupedOptions[key] = { + ...value, + flags: [ + key + ] + }; + } else { + groupedOptions[value].flags.push(key); + } + } + console.log(); + console.log("Options:"); + for (let { flags: flags1 , description , deprecated } of Object.values(groupedOptions)){ + if (deprecated) continue; + if (flags1.length === 1) { + console.log(" ".repeat(indent + 4 /* 4 = "-i, ".length */ ), flags1.slice().reverse().join(", ").padEnd(20, " "), description); + } else { + console.log(" ".repeat(indent), flags1.slice().reverse().join(", ").padEnd(24, " "), description); + } + } + } + console.log(); +} +function oneOf(...options) { + return Object.assign((value = true)=>{ + for (let option of options){ + let parsed = option(value); + if (parsed === value) { + return parsed; + } + } + throw new Error("..."); + }, { + manualParsing: true + }); +} +function loadPostcss() { + // Try to load a local `postcss` version first + try { + return require("postcss"); + } catch {} + return (0, _indexJs).lazyPostcss(); +} +let commands = { + init: { + run: init, + args: { + "--full": { + type: Boolean, + description: `Initialize a full \`${configs.tailwind}\` file` + }, + "--postcss": { + type: Boolean, + description: `Initialize a \`${configs.postcss}\` file` + }, + "-f": "--full", + "-p": "--postcss" + } + }, + build: { + run: build, + args: { + "--input": { + type: String, + description: "Input file" + }, + "--output": { + type: String, + description: "Output file" + }, + "--watch": { + type: Boolean, + description: "Watch for changes and rebuild as needed" + }, + "--poll": { + type: Boolean, + description: "Use polling instead of filesystem events when watching" + }, + "--content": { + type: String, + description: "Content paths to use for removing unused classes" + }, + "--purge": { + type: String, + deprecated: true + }, + "--postcss": { + type: oneOf(String, Boolean), + description: "Load custom PostCSS configuration" + }, + "--minify": { + type: Boolean, + description: "Minify the output" + }, + "--config": { + type: String, + description: "Path to a custom config file" + }, + "--no-autoprefixer": { + type: Boolean, + description: "Disable autoprefixer" + }, + "-c": "--config", + "-i": "--input", + "-o": "--output", + "-m": "--minify", + "-w": "--watch", + "-p": "--poll" + } + } +}; +let sharedFlags = { + "--help": { + type: Boolean, + description: "Display usage information" + }, + "-h": "--help" +}; +if (process.stdout.isTTY /* Detect redirecting output to a file */ && (process.argv[2] === undefined || process.argv.slice(2).every((flag)=>sharedFlags[flag] !== undefined))) { + help({ + usage: [ + "tailwindcss [--input input.css] [--output output.css] [--watch] [options...]", + "tailwindcss init [--full] [--postcss] [options...]", + ], + commands: Object.keys(commands).filter((command2)=>command2 !== "build").map((command3)=>`${command3} [options]`), + options: { + ...commands.build.args, + ...sharedFlags + } + }); + process.exit(0); +} +let command = ((arg = "")=>arg.startsWith("-") ? undefined : arg)(process.argv[2]) || "build"; +if (commands[command] === undefined) { + if (_fs.default.existsSync(_path.default.resolve(command))) { + // TODO: Deprecate this in future versions + // Check if non-existing command, might be a file. + command = "build"; + } else { + help({ + message: `Invalid command: ${command}`, + usage: [ + "tailwindcss [options]" + ], + commands: Object.keys(commands).filter((command4)=>command4 !== "build").map((command5)=>`${command5} [options]`), + options: sharedFlags + }); + process.exit(1); + } +} +// Execute command +let { args: flags , run } = commands[command]; +let args = (()=>{ + try { + let result = (0, _arg).default(Object.fromEntries(Object.entries({ + ...flags, + ...sharedFlags + }).filter(([_key, value])=>{ + var ref; + return !(value === null || value === void 0 ? void 0 : (ref = value.type) === null || ref === void 0 ? void 0 : ref.manualParsing); + }).map(([key, value])=>[ + key, + typeof value === "object" ? value.type : value + ])), { + permissive: true + }); + // Manual parsing of flags to allow for special flags like oneOf(Boolean, String) + for(let i = result["_"].length - 1; i >= 0; --i){ + let flag = result["_"][i]; + if (!flag.startsWith("-")) continue; + let flagName = flag; + let handler = flags[flag]; + // Resolve flagName & handler + while(typeof handler === "string"){ + flagName = handler; + handler = flags[handler]; + } + if (!handler) continue; + let args1 = []; + let offset = i + 1; + // Parse args for current flag + while(result["_"][offset] && !result["_"][offset].startsWith("-")){ + args1.push(result["_"][offset++]); + } + // Cleanup manually parsed flags + args + result["_"].splice(i, 1 + args1.length); + // Set the resolved value in the `result` object + result[flagName] = handler.type(args1.length === 0 ? undefined : args1.length === 1 ? args1[0] : args1, flagName); + } + // Ensure that the `command` is always the first argument in the `args`. + // This is important so that we don't have to check if a default command + // (build) was used or not from within each plugin. + // + // E.g.: tailwindcss input.css -> _: ['build', 'input.css'] + // E.g.: tailwindcss build input.css -> _: ['build', 'input.css'] + if (result["_"][0] !== command) { + result["_"].unshift(command); + } + return result; + } catch (err) { + if (err.code === "ARG_UNKNOWN_OPTION") { + help({ + message: err.message, + usage: [ + "tailwindcss [options]" + ], + options: sharedFlags + }); + process.exit(1); + } + throw err; + } +})(); +if (args["--help"]) { + help({ + options: { + ...flags, + ...sharedFlags + }, + usage: [ + `tailwindcss ${command} [options]` + ] + }); + process.exit(0); +} +run(); +// --- +function init() { + let messages = []; + var ref; + let tailwindConfigLocation = _path.default.resolve((ref = args["_"][1]) !== null && ref !== void 0 ? ref : `./${configs.tailwind}`); + if (_fs.default.existsSync(tailwindConfigLocation)) { + messages.push(`${_path.default.basename(tailwindConfigLocation)} already exists.`); + } else { + let stubFile = _fs.default.readFileSync(args["--full"] ? _path.default.resolve(__dirname, "../stubs/defaultConfig.stub.js") : _path.default.resolve(__dirname, "../stubs/simpleConfig.stub.js"), "utf8"); + // Change colors import + stubFile = stubFile.replace("../colors", "tailwindcss/colors"); + _fs.default.writeFileSync(tailwindConfigLocation, stubFile, "utf8"); + messages.push(`Created Tailwind CSS config file: ${_path.default.basename(tailwindConfigLocation)}`); + } + if (args["--postcss"]) { + let postcssConfigLocation = _path.default.resolve(`./${configs.postcss}`); + if (_fs.default.existsSync(postcssConfigLocation)) { + messages.push(`${_path.default.basename(postcssConfigLocation)} already exists.`); + } else { + let stubFile = _fs.default.readFileSync(_path.default.resolve(__dirname, "../stubs/defaultPostCssConfig.stub.js"), "utf8"); + _fs.default.writeFileSync(postcssConfigLocation, stubFile, "utf8"); + messages.push(`Created PostCSS config file: ${_path.default.basename(postcssConfigLocation)}`); + } + } + if (messages.length > 0) { + console.log(); + for (let message of messages){ + console.log(message); + } + } +} +async function build() { + let input = args["--input"]; + let output = args["--output"]; + let shouldWatch = args["--watch"]; + let shouldPoll = args["--poll"]; + let shouldCoalesceWriteEvents = shouldPoll || process.platform === "win32"; + let includePostCss = args["--postcss"]; + // Polling interval in milliseconds + // Used only when polling or coalescing add/change events on Windows + let pollInterval = 10; + // TODO: Deprecate this in future versions + if (!input && args["_"][1]) { + console.error("[deprecation] Running tailwindcss without -i, please provide an input file."); + input = args["--input"] = args["_"][1]; + } + if (input && input !== "-" && !_fs.default.existsSync(input = _path.default.resolve(input))) { + console.error(`Specified input file ${args["--input"]} does not exist.`); + process.exit(9); + } + if (args["--config"] && !_fs.default.existsSync(args["--config"] = _path.default.resolve(args["--config"]))) { + console.error(`Specified config file ${args["--config"]} does not exist.`); + process.exit(9); + } + let configPath = args["--config"] ? args["--config"] : ((defaultPath)=>_fs.default.existsSync(defaultPath) ? defaultPath : null)(_path.default.resolve(`./${configs.tailwind}`)); + async function loadPostCssPlugins() { + let customPostCssPath = typeof args["--postcss"] === "string" ? args["--postcss"] : undefined; + let config1 = customPostCssPath ? await (async ()=>{ + let file = _path.default.resolve(customPostCssPath); + // Implementation, see: https://unpkg.com/browse/postcss-load-config@3.1.0/src/index.js + let { config ={} } = await (0, _lilconfig).lilconfig("postcss").load(file); + if (typeof config === "function") { + config = config(); + } else { + config = Object.assign({}, config); + } + if (!config.plugins) { + config.plugins = []; + } + return { + file, + plugins: (0, _plugins).default(config, file), + options: (0, _options).default(config, file) + }; + })() : await (0, _postcssLoadConfig).default(); + let configPlugins = config1.plugins; + let configPluginTailwindIdx = configPlugins.findIndex((plugin)=>{ + if (typeof plugin === "function" && plugin.name === "tailwindcss") { + return true; + } + if (typeof plugin === "object" && plugin !== null && plugin.postcssPlugin === "tailwindcss") { + return true; + } + return false; + }); + let beforePlugins = configPluginTailwindIdx === -1 ? [] : configPlugins.slice(0, configPluginTailwindIdx); + let afterPlugins = configPluginTailwindIdx === -1 ? configPlugins : configPlugins.slice(configPluginTailwindIdx + 1); + return [ + beforePlugins, + afterPlugins, + config1.options + ]; + } + function loadBuiltinPostcssPlugins() { + let postcss = loadPostcss(); + let IMPORT_COMMENT = "__TAILWIND_RESTORE_IMPORT__: "; + return [ + [ + (root)=>{ + root.walkAtRules("import", (rule)=>{ + if (rule.params.slice(1).startsWith("tailwindcss/")) { + rule.after(postcss.comment({ + text: IMPORT_COMMENT + rule.params + })); + rule.remove(); + } + }); + }, + (()=>{ + try { + return require("postcss-import"); + } catch {} + return (0, _indexJs).lazyPostcssImport(); + })(), + (root)=>{ + root.walkComments((rule)=>{ + if (rule.text.startsWith(IMPORT_COMMENT)) { + rule.after(postcss.atRule({ + name: "import", + params: rule.text.replace(IMPORT_COMMENT, "") + })); + rule.remove(); + } + }); + }, + ], + [], + {}, + ]; + } + function resolveConfig() { + let config = configPath ? require(configPath) : {}; + if (args["--purge"]) { + _log.default.warn("purge-flag-deprecated", [ + "The `--purge` flag has been deprecated.", + "Please use `--content` instead.", + ]); + if (!args["--content"]) { + args["--content"] = args["--purge"]; + } + } + if (args["--content"]) { + let files = args["--content"].split(/(?{ + // Strings in this case are files / globs. If it is something else, + // like an object it's probably a raw content object. But this object + // is not watchable, so let's remove it. + return typeof file === "string"; + }).map((glob)=>(0, _normalizePath).default(glob)); + } + function extractRawContent(config) { + return config.content.files.filter((file)=>{ + return typeof file === "object" && file !== null; + }); + } + function getChangedContent(config) { + let changedContent = []; + // Resolve globs from the content config + let globs = extractFileGlobs(config); + let files = _fastGlob.default.sync(globs); + for (let file of files){ + changedContent.push({ + content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"), + extension: _path.default.extname(file).slice(1) + }); + } + // Resolve raw content in the tailwind config + for (let { raw: content , extension ="html" } of extractRawContent(config)){ + changedContent.push({ + content, + extension + }); + } + return changedContent; + } + async function buildOnce() { + let config = resolveConfig(); + let changedContent = getChangedContent(config); + let tailwindPlugin = ()=>{ + return { + postcssPlugin: "tailwindcss", + Once (root, { result }) { + (0, _processTailwindFeatures).default(({ createContext })=>{ + return ()=>{ + return createContext(config, changedContent); + }; + })(root, result); + } + }; + }; + tailwindPlugin.postcss = true; + let [beforePlugins, afterPlugins, postcssOptions] = includePostCss ? await loadPostCssPlugins() : loadBuiltinPostcssPlugins(); + let plugins = [ + ...beforePlugins, + tailwindPlugin, + !args["--minify"] && formatNodes, + ...afterPlugins, + !args["--no-autoprefixer"] && (()=>{ + // Try to load a local `autoprefixer` version first + try { + return require("autoprefixer"); + } catch {} + return (0, _indexJs).lazyAutoprefixer(); + })(), + args["--minify"] && (()=>{ + let options = { + preset: [ + "default", + { + cssDeclarationSorter: false + } + ] + }; + // Try to load a local `cssnano` version first + try { + return require("cssnano"); + } catch {} + return (0, _indexJs).lazyCssnano()(options); + })(), + ].filter(Boolean); + let postcss = loadPostcss(); + let processor = postcss(plugins); + function processCSS(css) { + let start = process.hrtime.bigint(); + return Promise.resolve().then(()=>output ? _fs.default.promises.mkdir(_path.default.dirname(output), { + recursive: true + }) : null).then(()=>processor.process(css, { + ...postcssOptions, + from: input, + to: output + })).then((result)=>{ + if (!output) { + return process.stdout.write(result.css); + } + return Promise.all([ + outputFile(output, result.css), + result.map && outputFile(output + ".map", result.map.toString()), + ].filter(Boolean)); + }).then(()=>{ + let end = process.hrtime.bigint(); + console.error(); + console.error("Done in", (end - start) / BigInt(1e6) + "ms."); + }); + } + let css1 = await (()=>{ + // Piping in data, let's drain the stdin + if (input === "-") { + return drainStdin(); + } + // Input file has been provided + if (input) { + return _fs.default.readFileSync(_path.default.resolve(input), "utf8"); + } + // No input file provided, fallback to default atrules + return "@tailwind base; @tailwind components; @tailwind utilities"; + })(); + return processCSS(css1); + } + let context = null; + async function startWatcher() { + let changedContent = []; + let configDependencies = []; + let contextDependencies = new Set(); + let watcher = null; + function refreshConfig() { + env.DEBUG && console.time("Module dependencies"); + for (let file1 of configDependencies){ + delete require.cache[require.resolve(file1)]; + } + if (configPath) { + configDependencies = (0, _getModuleDependencies).default(configPath).map(({ file })=>file); + for (let dependency of configDependencies){ + contextDependencies.add(dependency); + } + } + env.DEBUG && console.timeEnd("Module dependencies"); + return resolveConfig(); + } + let [beforePlugins, afterPlugins] = includePostCss ? await loadPostCssPlugins() : loadBuiltinPostcssPlugins(); + let plugins = [ + ...beforePlugins, + "__TAILWIND_PLUGIN_POSITION__", + !args["--minify"] && formatNodes, + ...afterPlugins, + !args["--no-autoprefixer"] && (()=>{ + // Try to load a local `autoprefixer` version first + try { + return require("autoprefixer"); + } catch {} + return (0, _indexJs).lazyAutoprefixer(); + })(), + args["--minify"] && (()=>{ + let options = { + preset: [ + "default", + { + cssDeclarationSorter: false + } + ] + }; + // Try to load a local `cssnano` version first + try { + return require("cssnano"); + } catch {} + return (0, _indexJs).lazyCssnano()(options); + })(), + ].filter(Boolean); + async function rebuild(config) { + env.DEBUG && console.time("Finished in"); + let tailwindPlugin = ()=>{ + return { + postcssPlugin: "tailwindcss", + Once (root, { result }) { + env.DEBUG && console.time("Compiling CSS"); + (0, _processTailwindFeatures).default(({ createContext })=>{ + console.error(); + console.error("Rebuilding..."); + return ()=>{ + if (context !== null) { + context.changedContent = changedContent.splice(0); + return context; + } + env.DEBUG && console.time("Creating context"); + context = createContext(config, changedContent.splice(0)); + env.DEBUG && console.timeEnd("Creating context"); + return context; + }; + })(root, result); + env.DEBUG && console.timeEnd("Compiling CSS"); + } + }; + }; + tailwindPlugin.postcss = true; + let tailwindPluginIdx = plugins.indexOf("__TAILWIND_PLUGIN_POSITION__"); + let copy = plugins.slice(); + copy.splice(tailwindPluginIdx, 1, tailwindPlugin); + let postcss = loadPostcss(); + let processor = postcss(copy); + function processCSS(css) { + let start = process.hrtime.bigint(); + return Promise.resolve().then(()=>output ? _fs.default.promises.mkdir(_path.default.dirname(output), { + recursive: true + }) : null).then(()=>processor.process(css, { + from: input, + to: output + })).then(async (result)=>{ + for (let message of result.messages){ + if (message.type === "dependency") { + contextDependencies.add(message.file); + } + } + watcher.add([ + ...contextDependencies + ]); + if (!output) { + return process.stdout.write(result.css); + } + return Promise.all([ + outputFile(output, result.css), + result.map && outputFile(output + ".map", result.map.toString()), + ].filter(Boolean)); + }).then(()=>{ + let end = process.hrtime.bigint(); + console.error("Done in", (end - start) / BigInt(1e6) + "ms."); + }).catch((err)=>{ + if (err.name === "CssSyntaxError") { + console.error(err.toString()); + } else { + console.error(err); + } + }); + } + let css2 = await (()=>{ + // Piping in data, let's drain the stdin + if (input === "-") { + return drainStdin(); + } + // Input file has been provided + if (input) { + return _fs.default.readFileSync(_path.default.resolve(input), "utf8"); + } + // No input file provided, fallback to default atrules + return "@tailwind base; @tailwind components; @tailwind utilities"; + })(); + let result1 = await processCSS(css2); + env.DEBUG && console.timeEnd("Finished in"); + return result1; + } + let config2 = refreshConfig(configPath); + if (input) { + contextDependencies.add(_path.default.resolve(input)); + } + watcher = _chokidar.default.watch([ + ...contextDependencies, + ...extractFileGlobs(config2) + ], { + usePolling: shouldPoll, + interval: shouldPoll ? pollInterval : undefined, + ignoreInitial: true, + awaitWriteFinish: shouldCoalesceWriteEvents ? { + stabilityThreshold: 50, + pollInterval: pollInterval + } : false + }); + let chain = Promise.resolve(); + watcher.on("change", async (file)=>{ + if (contextDependencies.has(file)) { + env.DEBUG && console.time("Resolve config"); + context = null; + config2 = refreshConfig(configPath); + env.DEBUG && console.timeEnd("Resolve config"); + env.DEBUG && console.time("Watch new files"); + let globs = extractFileGlobs(config2); + watcher.add(configDependencies); + watcher.add(globs); + env.DEBUG && console.timeEnd("Watch new files"); + chain = chain.then(async ()=>{ + changedContent.push(...getChangedContent(config2)); + await rebuild(config2); + }); + } else { + chain = chain.then(async ()=>{ + changedContent.push({ + content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"), + extension: _path.default.extname(file).slice(1) + }); + await rebuild(config2); + }); + } + }); + watcher.on("add", async (file)=>{ + chain = chain.then(async ()=>{ + changedContent.push({ + content: _fs.default.readFileSync(_path.default.resolve(file), "utf8"), + extension: _path.default.extname(file).slice(1) + }); + await rebuild(config2); + }); + }); + chain = chain.then(()=>{ + changedContent.push(...getChangedContent(config2)); + return rebuild(config2); + }); + } + if (shouldWatch) { + /* Abort the watcher if stdin is closed to avoid zombie processes */ if (process.stdin.isTTY) { + process.stdin.on("end", ()=>process.exit(0)); + process.stdin.resume(); + } + startWatcher(); + } else { + buildOnce(); + } +} diff --git a/node_modules/tailwindcss/lib/constants.js b/node_modules/tailwindcss/lib/constants.js new file mode 100644 index 0000000..6cbf3c8 --- /dev/null +++ b/node_modules/tailwindcss/lib/constants.js @@ -0,0 +1,37 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.defaultPostCssConfigStubFile = exports.simpleConfigStubFile = exports.defaultConfigStubFile = exports.supportedPostCssConfigFile = exports.supportedConfigFiles = exports.cjsPostCssConfigFile = exports.cjsConfigFile = exports.defaultPostCssConfigFile = exports.defaultConfigFile = exports.cli = void 0; +var _path = _interopRequireDefault(require("path")); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +const cli = "tailwind"; +exports.cli = cli; +const defaultConfigFile = "./tailwind.config.js"; +exports.defaultConfigFile = defaultConfigFile; +const defaultPostCssConfigFile = "./postcss.config.js"; +exports.defaultPostCssConfigFile = defaultPostCssConfigFile; +const cjsConfigFile = "./tailwind.config.cjs"; +exports.cjsConfigFile = cjsConfigFile; +const cjsPostCssConfigFile = "./postcss.config.cjs"; +exports.cjsPostCssConfigFile = cjsPostCssConfigFile; +const supportedConfigFiles = [ + cjsConfigFile, + defaultConfigFile +]; +exports.supportedConfigFiles = supportedConfigFiles; +const supportedPostCssConfigFile = [ + cjsPostCssConfigFile, + defaultPostCssConfigFile +]; +exports.supportedPostCssConfigFile = supportedPostCssConfigFile; +const defaultConfigStubFile = _path.default.resolve(__dirname, "../stubs/defaultConfig.stub.js"); +exports.defaultConfigStubFile = defaultConfigStubFile; +const simpleConfigStubFile = _path.default.resolve(__dirname, "../stubs/simpleConfig.stub.js"); +exports.simpleConfigStubFile = simpleConfigStubFile; +const defaultPostCssConfigStubFile = _path.default.resolve(__dirname, "../stubs/defaultPostCssConfig.stub.js"); +exports.defaultPostCssConfigStubFile = defaultPostCssConfigStubFile; diff --git a/node_modules/tailwindcss/lib/corePluginList.js b/node_modules/tailwindcss/lib/corePluginList.js new file mode 100644 index 0000000..660fb22 --- /dev/null +++ b/node_modules/tailwindcss/lib/corePluginList.js @@ -0,0 +1,179 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = void 0; +var _default = [ + "preflight", + "container", + "accessibility", + "pointerEvents", + "visibility", + "position", + "inset", + "isolation", + "zIndex", + "order", + "gridColumn", + "gridColumnStart", + "gridColumnEnd", + "gridRow", + "gridRowStart", + "gridRowEnd", + "float", + "clear", + "margin", + "boxSizing", + "display", + "aspectRatio", + "height", + "maxHeight", + "minHeight", + "width", + "minWidth", + "maxWidth", + "flex", + "flexShrink", + "flexGrow", + "flexBasis", + "tableLayout", + "borderCollapse", + "borderSpacing", + "transformOrigin", + "translate", + "rotate", + "skew", + "scale", + "transform", + "animation", + "cursor", + "touchAction", + "userSelect", + "resize", + "scrollSnapType", + "scrollSnapAlign", + "scrollSnapStop", + "scrollMargin", + "scrollPadding", + "listStylePosition", + "listStyleType", + "appearance", + "columns", + "breakBefore", + "breakInside", + "breakAfter", + "gridAutoColumns", + "gridAutoFlow", + "gridAutoRows", + "gridTemplateColumns", + "gridTemplateRows", + "flexDirection", + "flexWrap", + "placeContent", + "placeItems", + "alignContent", + "alignItems", + "justifyContent", + "justifyItems", + "gap", + "space", + "divideWidth", + "divideStyle", + "divideColor", + "divideOpacity", + "placeSelf", + "alignSelf", + "justifySelf", + "overflow", + "overscrollBehavior", + "scrollBehavior", + "textOverflow", + "whitespace", + "wordBreak", + "borderRadius", + "borderWidth", + "borderStyle", + "borderColor", + "borderOpacity", + "backgroundColor", + "backgroundOpacity", + "backgroundImage", + "gradientColorStops", + "boxDecorationBreak", + "backgroundSize", + "backgroundAttachment", + "backgroundClip", + "backgroundPosition", + "backgroundRepeat", + "backgroundOrigin", + "fill", + "stroke", + "strokeWidth", + "objectFit", + "objectPosition", + "padding", + "textAlign", + "textIndent", + "verticalAlign", + "fontFamily", + "fontSize", + "fontWeight", + "textTransform", + "fontStyle", + "fontVariantNumeric", + "lineHeight", + "letterSpacing", + "textColor", + "textOpacity", + "textDecoration", + "textDecorationColor", + "textDecorationStyle", + "textDecorationThickness", + "textUnderlineOffset", + "fontSmoothing", + "placeholderColor", + "placeholderOpacity", + "caretColor", + "accentColor", + "opacity", + "backgroundBlendMode", + "mixBlendMode", + "boxShadow", + "boxShadowColor", + "outlineStyle", + "outlineWidth", + "outlineOffset", + "outlineColor", + "ringWidth", + "ringColor", + "ringOpacity", + "ringOffsetWidth", + "ringOffsetColor", + "blur", + "brightness", + "contrast", + "dropShadow", + "grayscale", + "hueRotate", + "invert", + "saturate", + "sepia", + "filter", + "backdropBlur", + "backdropBrightness", + "backdropContrast", + "backdropGrayscale", + "backdropHueRotate", + "backdropInvert", + "backdropOpacity", + "backdropSaturate", + "backdropSepia", + "backdropFilter", + "transitionProperty", + "transitionDelay", + "transitionDuration", + "transitionTimingFunction", + "willChange", + "content" +]; +exports.default = _default; diff --git a/node_modules/tailwindcss/lib/corePlugins.js b/node_modules/tailwindcss/lib/corePlugins.js new file mode 100644 index 0000000..115b48d --- /dev/null +++ b/node_modules/tailwindcss/lib/corePlugins.js @@ -0,0 +1,3659 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.corePlugins = exports.variantPlugins = void 0; +var _fs = _interopRequireDefault(require("fs")); +var path = _interopRequireWildcard(require("path")); +var _postcss = _interopRequireDefault(require("postcss")); +var _createUtilityPlugin = _interopRequireDefault(require("./util/createUtilityPlugin")); +var _buildMediaQuery = _interopRequireDefault(require("./util/buildMediaQuery")); +var _escapeClassName = _interopRequireDefault(require("./util/escapeClassName")); +var _parseAnimationValue = _interopRequireDefault(require("./util/parseAnimationValue")); +var _flattenColorPalette = _interopRequireDefault(require("./util/flattenColorPalette")); +var _withAlphaVariable = _interopRequireWildcard(require("./util/withAlphaVariable")); +var _toColorValue = _interopRequireDefault(require("./util/toColorValue")); +var _isPlainObject = _interopRequireDefault(require("./util/isPlainObject")); +var _transformThemeValue = _interopRequireDefault(require("./util/transformThemeValue")); +var _packageJson = require("../package.json"); +var _log = _interopRequireDefault(require("./util/log")); +var _normalizeScreens = require("./util/normalizeScreens"); +var _parseBoxShadowValue = require("./util/parseBoxShadowValue"); +var _removeAlphaVariables = require("./util/removeAlphaVariables"); +var _featureFlags = require("./featureFlags"); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +function _getRequireWildcardCache() { + if (typeof WeakMap !== "function") return null; + var cache = new WeakMap(); + _getRequireWildcardCache = function() { + return cache; + }; + return cache; +} +function _interopRequireWildcard(obj) { + if (obj && obj.__esModule) { + return obj; + } + if (obj === null || typeof obj !== "object" && typeof obj !== "function") { + return { + default: obj + }; + } + var cache = _getRequireWildcardCache(); + if (cache && cache.has(obj)) { + return cache.get(obj); + } + var newObj = {}; + var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; + for(var key in obj){ + if (Object.prototype.hasOwnProperty.call(obj, key)) { + var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; + if (desc && (desc.get || desc.set)) { + Object.defineProperty(newObj, key, desc); + } else { + newObj[key] = obj[key]; + } + } + } + newObj.default = obj; + if (cache) { + cache.set(obj, newObj); + } + return newObj; +} +let variantPlugins = { + pseudoElementVariants: ({ addVariant })=>{ + addVariant("first-letter", "&::first-letter"); + addVariant("first-line", "&::first-line"); + addVariant("marker", [ + ({ container })=>{ + (0, _removeAlphaVariables).removeAlphaVariables(container, [ + "--tw-text-opacity" + ]); + return "& *::marker"; + }, + ({ container })=>{ + (0, _removeAlphaVariables).removeAlphaVariables(container, [ + "--tw-text-opacity" + ]); + return "&::marker"; + }, + ]); + addVariant("selection", [ + "& *::selection", + "&::selection" + ]); + addVariant("file", "&::file-selector-button"); + addVariant("placeholder", "&::placeholder"); + addVariant("backdrop", "&::backdrop"); + addVariant("before", ({ container })=>{ + container.walkRules((rule)=>{ + let foundContent = false; + rule.walkDecls("content", ()=>{ + foundContent = true; + }); + if (!foundContent) { + rule.prepend(_postcss.default.decl({ + prop: "content", + value: "var(--tw-content)" + })); + } + }); + return "&::before"; + }); + addVariant("after", ({ container })=>{ + container.walkRules((rule)=>{ + let foundContent = false; + rule.walkDecls("content", ()=>{ + foundContent = true; + }); + if (!foundContent) { + rule.prepend(_postcss.default.decl({ + prop: "content", + value: "var(--tw-content)" + })); + } + }); + return "&::after"; + }); + }, + pseudoClassVariants: ({ addVariant , config })=>{ + let pseudoVariants = [ + // Positional + [ + "first", + "&:first-child" + ], + [ + "last", + "&:last-child" + ], + [ + "only", + "&:only-child" + ], + [ + "odd", + "&:nth-child(odd)" + ], + [ + "even", + "&:nth-child(even)" + ], + "first-of-type", + "last-of-type", + "only-of-type", + // State + [ + "visited", + ({ container })=>{ + (0, _removeAlphaVariables).removeAlphaVariables(container, [ + "--tw-text-opacity", + "--tw-border-opacity", + "--tw-bg-opacity", + ]); + return "&:visited"; + }, + ], + "target", + [ + "open", + "&[open]" + ], + // Forms + "default", + "checked", + "indeterminate", + "placeholder-shown", + "autofill", + "optional", + "required", + "valid", + "invalid", + "in-range", + "out-of-range", + "read-only", + // Content + "empty", + // Interactive + "focus-within", + [ + "hover", + !(0, _featureFlags).flagEnabled(config(), "hoverOnlyWhenSupported") ? "&:hover" : "@media (hover: hover) and (pointer: fine) { &:hover }", + ], + "focus", + "focus-visible", + "active", + "enabled", + "disabled", + ].map((variant)=>Array.isArray(variant) ? variant : [ + variant, + `&:${variant}` + ]); + for (let [variantName, state] of pseudoVariants){ + addVariant(variantName, (ctx)=>{ + let result = typeof state === "function" ? state(ctx) : state; + return result; + }); + } + for (let [variantName1, state1] of pseudoVariants){ + addVariant(`group-${variantName1}`, (ctx)=>{ + let result = typeof state1 === "function" ? state1(ctx) : state1; + return result.replace(/&(\S+)/, ":merge(.group)$1 &"); + }); + } + for (let [variantName2, state2] of pseudoVariants){ + addVariant(`peer-${variantName2}`, (ctx)=>{ + let result = typeof state2 === "function" ? state2(ctx) : state2; + return result.replace(/&(\S+)/, ":merge(.peer)$1 ~ &"); + }); + } + }, + directionVariants: ({ addVariant })=>{ + addVariant("ltr", ()=>{ + _log.default.warn("rtl-experimental", [ + "The RTL features in Tailwind CSS are currently in preview.", + "Preview features are not covered by semver, and may be improved in breaking ways at any time.", + ]); + return '[dir="ltr"] &'; + }); + addVariant("rtl", ()=>{ + _log.default.warn("rtl-experimental", [ + "The RTL features in Tailwind CSS are currently in preview.", + "Preview features are not covered by semver, and may be improved in breaking ways at any time.", + ]); + return '[dir="rtl"] &'; + }); + }, + reducedMotionVariants: ({ addVariant })=>{ + addVariant("motion-safe", "@media (prefers-reduced-motion: no-preference)"); + addVariant("motion-reduce", "@media (prefers-reduced-motion: reduce)"); + }, + darkVariants: ({ config , addVariant })=>{ + let [mode, className = ".dark"] = [].concat(config("darkMode", "media")); + if (mode === false) { + mode = "media"; + _log.default.warn("darkmode-false", [ + "The `darkMode` option in your Tailwind CSS configuration is set to `false`, which now behaves the same as `media`.", + "Change `darkMode` to `media` or remove it entirely.", + "https://tailwindcss.com/docs/upgrade-guide#remove-dark-mode-configuration", + ]); + } + if (mode === "class") { + addVariant("dark", `${className} &`); + } else if (mode === "media") { + addVariant("dark", "@media (prefers-color-scheme: dark)"); + } + }, + printVariant: ({ addVariant })=>{ + addVariant("print", "@media print"); + }, + screenVariants: ({ theme , addVariant })=>{ + for (let screen of (0, _normalizeScreens).normalizeScreens(theme("screens"))){ + let query = (0, _buildMediaQuery).default(screen); + addVariant(screen.name, `@media ${query}`); + } + }, + orientationVariants: ({ addVariant })=>{ + addVariant("portrait", "@media (orientation: portrait)"); + addVariant("landscape", "@media (orientation: landscape)"); + }, + prefersContrastVariants: ({ addVariant })=>{ + addVariant("contrast-more", "@media (prefers-contrast: more)"); + addVariant("contrast-less", "@media (prefers-contrast: less)"); + } +}; +exports.variantPlugins = variantPlugins; +let cssTransformValue = [ + "translate(var(--tw-translate-x), var(--tw-translate-y))", + "rotate(var(--tw-rotate))", + "skewX(var(--tw-skew-x))", + "skewY(var(--tw-skew-y))", + "scaleX(var(--tw-scale-x))", + "scaleY(var(--tw-scale-y))", +].join(" "); +let cssFilterValue = [ + "var(--tw-blur)", + "var(--tw-brightness)", + "var(--tw-contrast)", + "var(--tw-grayscale)", + "var(--tw-hue-rotate)", + "var(--tw-invert)", + "var(--tw-saturate)", + "var(--tw-sepia)", + "var(--tw-drop-shadow)", +].join(" "); +let cssBackdropFilterValue = [ + "var(--tw-backdrop-blur)", + "var(--tw-backdrop-brightness)", + "var(--tw-backdrop-contrast)", + "var(--tw-backdrop-grayscale)", + "var(--tw-backdrop-hue-rotate)", + "var(--tw-backdrop-invert)", + "var(--tw-backdrop-opacity)", + "var(--tw-backdrop-saturate)", + "var(--tw-backdrop-sepia)", +].join(" "); +let corePlugins = { + preflight: ({ addBase })=>{ + let preflightStyles = _postcss.default.parse(_fs.default.readFileSync(path.join(__dirname, "./css/preflight.css"), "utf8")); + addBase([ + _postcss.default.comment({ + text: `! tailwindcss v${_packageJson.version} | MIT License | https://tailwindcss.com` + }), + ...preflightStyles.nodes, + ]); + }, + container: (()=>{ + function extractMinWidths(breakpoints = []) { + return breakpoints.flatMap((breakpoint1)=>breakpoint1.values.map((breakpoint)=>breakpoint.min)).filter((v)=>v !== undefined); + } + function mapMinWidthsToPadding(minWidths, screens, paddings) { + if (typeof paddings === "undefined") { + return []; + } + if (!(typeof paddings === "object" && paddings !== null)) { + return [ + { + screen: "DEFAULT", + minWidth: 0, + padding: paddings + }, + ]; + } + let mapping = []; + if (paddings.DEFAULT) { + mapping.push({ + screen: "DEFAULT", + minWidth: 0, + padding: paddings.DEFAULT + }); + } + for (let minWidth of minWidths){ + for (let screen of screens){ + for (let { min } of screen.values){ + if (min === minWidth) { + mapping.push({ + minWidth, + padding: paddings[screen.name] + }); + } + } + } + } + return mapping; + } + return function({ addComponents , theme }) { + let screens = (0, _normalizeScreens).normalizeScreens(theme("container.screens", theme("screens"))); + let minWidths = extractMinWidths(screens); + let paddings = mapMinWidthsToPadding(minWidths, screens, theme("container.padding")); + let generatePaddingFor = (minWidth)=>{ + let paddingConfig = paddings.find((padding)=>padding.minWidth === minWidth); + if (!paddingConfig) { + return {}; + } + return { + paddingRight: paddingConfig.padding, + paddingLeft: paddingConfig.padding + }; + }; + let atRules = Array.from(new Set(minWidths.slice().sort((a, z)=>parseInt(a) - parseInt(z)))).map((minWidth)=>({ + [`@media (min-width: ${minWidth})`]: { + ".container": { + "max-width": minWidth, + ...generatePaddingFor(minWidth) + } + } + })); + addComponents([ + { + ".container": Object.assign({ + width: "100%" + }, theme("container.center", false) ? { + marginRight: "auto", + marginLeft: "auto" + } : {}, generatePaddingFor(0)) + }, + ...atRules, + ]); + }; + })(), + accessibility: ({ addUtilities })=>{ + addUtilities({ + ".sr-only": { + position: "absolute", + width: "1px", + height: "1px", + padding: "0", + margin: "-1px", + overflow: "hidden", + clip: "rect(0, 0, 0, 0)", + whiteSpace: "nowrap", + borderWidth: "0" + }, + ".not-sr-only": { + position: "static", + width: "auto", + height: "auto", + padding: "0", + margin: "0", + overflow: "visible", + clip: "auto", + whiteSpace: "normal" + } + }); + }, + pointerEvents: ({ addUtilities })=>{ + addUtilities({ + ".pointer-events-none": { + "pointer-events": "none" + }, + ".pointer-events-auto": { + "pointer-events": "auto" + } + }); + }, + visibility: ({ addUtilities })=>{ + addUtilities({ + ".visible": { + visibility: "visible" + }, + ".invisible": { + visibility: "hidden" + } + }); + }, + position: ({ addUtilities })=>{ + addUtilities({ + ".static": { + position: "static" + }, + ".fixed": { + position: "fixed" + }, + ".absolute": { + position: "absolute" + }, + ".relative": { + position: "relative" + }, + ".sticky": { + position: "sticky" + } + }); + }, + inset: (0, _createUtilityPlugin).default("inset", [ + [ + "inset", + [ + "top", + "right", + "bottom", + "left" + ] + ], + [ + [ + "inset-x", + [ + "left", + "right" + ] + ], + [ + "inset-y", + [ + "top", + "bottom" + ] + ], + ], + [ + [ + "top", + [ + "top" + ] + ], + [ + "right", + [ + "right" + ] + ], + [ + "bottom", + [ + "bottom" + ] + ], + [ + "left", + [ + "left" + ] + ], + ], + ], { + supportsNegativeValues: true + }), + isolation: ({ addUtilities })=>{ + addUtilities({ + ".isolate": { + isolation: "isolate" + }, + ".isolation-auto": { + isolation: "auto" + } + }); + }, + zIndex: (0, _createUtilityPlugin).default("zIndex", [ + [ + "z", + [ + "zIndex" + ] + ] + ], { + supportsNegativeValues: true + }), + order: (0, _createUtilityPlugin).default("order", undefined, { + supportsNegativeValues: true + }), + gridColumn: (0, _createUtilityPlugin).default("gridColumn", [ + [ + "col", + [ + "gridColumn" + ] + ] + ]), + gridColumnStart: (0, _createUtilityPlugin).default("gridColumnStart", [ + [ + "col-start", + [ + "gridColumnStart" + ] + ] + ]), + gridColumnEnd: (0, _createUtilityPlugin).default("gridColumnEnd", [ + [ + "col-end", + [ + "gridColumnEnd" + ] + ] + ]), + gridRow: (0, _createUtilityPlugin).default("gridRow", [ + [ + "row", + [ + "gridRow" + ] + ] + ]), + gridRowStart: (0, _createUtilityPlugin).default("gridRowStart", [ + [ + "row-start", + [ + "gridRowStart" + ] + ] + ]), + gridRowEnd: (0, _createUtilityPlugin).default("gridRowEnd", [ + [ + "row-end", + [ + "gridRowEnd" + ] + ] + ]), + float: ({ addUtilities })=>{ + addUtilities({ + ".float-right": { + float: "right" + }, + ".float-left": { + float: "left" + }, + ".float-none": { + float: "none" + } + }); + }, + clear: ({ addUtilities })=>{ + addUtilities({ + ".clear-left": { + clear: "left" + }, + ".clear-right": { + clear: "right" + }, + ".clear-both": { + clear: "both" + }, + ".clear-none": { + clear: "none" + } + }); + }, + margin: (0, _createUtilityPlugin).default("margin", [ + [ + "m", + [ + "margin" + ] + ], + [ + [ + "mx", + [ + "margin-left", + "margin-right" + ] + ], + [ + "my", + [ + "margin-top", + "margin-bottom" + ] + ], + ], + [ + [ + "mt", + [ + "margin-top" + ] + ], + [ + "mr", + [ + "margin-right" + ] + ], + [ + "mb", + [ + "margin-bottom" + ] + ], + [ + "ml", + [ + "margin-left" + ] + ], + ], + ], { + supportsNegativeValues: true + }), + boxSizing: ({ addUtilities })=>{ + addUtilities({ + ".box-border": { + "box-sizing": "border-box" + }, + ".box-content": { + "box-sizing": "content-box" + } + }); + }, + display: ({ addUtilities })=>{ + addUtilities({ + ".block": { + display: "block" + }, + ".inline-block": { + display: "inline-block" + }, + ".inline": { + display: "inline" + }, + ".flex": { + display: "flex" + }, + ".inline-flex": { + display: "inline-flex" + }, + ".table": { + display: "table" + }, + ".inline-table": { + display: "inline-table" + }, + ".table-caption": { + display: "table-caption" + }, + ".table-cell": { + display: "table-cell" + }, + ".table-column": { + display: "table-column" + }, + ".table-column-group": { + display: "table-column-group" + }, + ".table-footer-group": { + display: "table-footer-group" + }, + ".table-header-group": { + display: "table-header-group" + }, + ".table-row-group": { + display: "table-row-group" + }, + ".table-row": { + display: "table-row" + }, + ".flow-root": { + display: "flow-root" + }, + ".grid": { + display: "grid" + }, + ".inline-grid": { + display: "inline-grid" + }, + ".contents": { + display: "contents" + }, + ".list-item": { + display: "list-item" + }, + ".hidden": { + display: "none" + } + }); + }, + aspectRatio: (0, _createUtilityPlugin).default("aspectRatio", [ + [ + "aspect", + [ + "aspect-ratio" + ] + ] + ]), + height: (0, _createUtilityPlugin).default("height", [ + [ + "h", + [ + "height" + ] + ] + ]), + maxHeight: (0, _createUtilityPlugin).default("maxHeight", [ + [ + "max-h", + [ + "maxHeight" + ] + ] + ]), + minHeight: (0, _createUtilityPlugin).default("minHeight", [ + [ + "min-h", + [ + "minHeight" + ] + ] + ]), + width: (0, _createUtilityPlugin).default("width", [ + [ + "w", + [ + "width" + ] + ] + ]), + minWidth: (0, _createUtilityPlugin).default("minWidth", [ + [ + "min-w", + [ + "minWidth" + ] + ] + ]), + maxWidth: (0, _createUtilityPlugin).default("maxWidth", [ + [ + "max-w", + [ + "maxWidth" + ] + ] + ]), + flex: (0, _createUtilityPlugin).default("flex"), + flexShrink: (0, _createUtilityPlugin).default("flexShrink", [ + [ + "flex-shrink", + [ + "flex-shrink" + ] + ], + [ + "shrink", + [ + "flex-shrink" + ] + ], + ]), + flexGrow: (0, _createUtilityPlugin).default("flexGrow", [ + [ + "flex-grow", + [ + "flex-grow" + ] + ], + [ + "grow", + [ + "flex-grow" + ] + ], + ]), + flexBasis: (0, _createUtilityPlugin).default("flexBasis", [ + [ + "basis", + [ + "flex-basis" + ] + ] + ]), + tableLayout: ({ addUtilities })=>{ + addUtilities({ + ".table-auto": { + "table-layout": "auto" + }, + ".table-fixed": { + "table-layout": "fixed" + } + }); + }, + borderCollapse: ({ addUtilities })=>{ + addUtilities({ + ".border-collapse": { + "border-collapse": "collapse" + }, + ".border-separate": { + "border-collapse": "separate" + } + }); + }, + borderSpacing: ({ addDefaults , matchUtilities , theme })=>{ + addDefaults("border-spacing", { + "--tw-border-spacing-x": 0, + "--tw-border-spacing-y": 0 + }); + matchUtilities({ + "border-spacing": (value)=>{ + return { + "--tw-border-spacing-x": value, + "--tw-border-spacing-y": value, + "@defaults border-spacing": {}, + "border-spacing": "var(--tw-border-spacing-x) var(--tw-border-spacing-y)" + }; + }, + "border-spacing-x": (value)=>{ + return { + "--tw-border-spacing-x": value, + "@defaults border-spacing": {}, + "border-spacing": "var(--tw-border-spacing-x) var(--tw-border-spacing-y)" + }; + }, + "border-spacing-y": (value)=>{ + return { + "--tw-border-spacing-y": value, + "@defaults border-spacing": {}, + "border-spacing": "var(--tw-border-spacing-x) var(--tw-border-spacing-y)" + }; + } + }, { + values: theme("borderSpacing") + }); + }, + transformOrigin: (0, _createUtilityPlugin).default("transformOrigin", [ + [ + "origin", + [ + "transformOrigin" + ] + ] + ]), + translate: (0, _createUtilityPlugin).default("translate", [ + [ + [ + "translate-x", + [ + [ + "@defaults transform", + {} + ], + "--tw-translate-x", + [ + "transform", + cssTransformValue + ] + ], + ], + [ + "translate-y", + [ + [ + "@defaults transform", + {} + ], + "--tw-translate-y", + [ + "transform", + cssTransformValue + ] + ], + ], + ], + ], { + supportsNegativeValues: true + }), + rotate: (0, _createUtilityPlugin).default("rotate", [ + [ + "rotate", + [ + [ + "@defaults transform", + {} + ], + "--tw-rotate", + [ + "transform", + cssTransformValue + ] + ] + ] + ], { + supportsNegativeValues: true + }), + skew: (0, _createUtilityPlugin).default("skew", [ + [ + [ + "skew-x", + [ + [ + "@defaults transform", + {} + ], + "--tw-skew-x", + [ + "transform", + cssTransformValue + ] + ] + ], + [ + "skew-y", + [ + [ + "@defaults transform", + {} + ], + "--tw-skew-y", + [ + "transform", + cssTransformValue + ] + ] + ], + ], + ], { + supportsNegativeValues: true + }), + scale: (0, _createUtilityPlugin).default("scale", [ + [ + "scale", + [ + [ + "@defaults transform", + {} + ], + "--tw-scale-x", + "--tw-scale-y", + [ + "transform", + cssTransformValue + ], + ], + ], + [ + [ + "scale-x", + [ + [ + "@defaults transform", + {} + ], + "--tw-scale-x", + [ + "transform", + cssTransformValue + ] + ], + ], + [ + "scale-y", + [ + [ + "@defaults transform", + {} + ], + "--tw-scale-y", + [ + "transform", + cssTransformValue + ] + ], + ], + ], + ], { + supportsNegativeValues: true + }), + transform: ({ addDefaults , addUtilities })=>{ + addDefaults("transform", { + "--tw-translate-x": "0", + "--tw-translate-y": "0", + "--tw-rotate": "0", + "--tw-skew-x": "0", + "--tw-skew-y": "0", + "--tw-scale-x": "1", + "--tw-scale-y": "1" + }); + addUtilities({ + ".transform": { + "@defaults transform": {}, + transform: cssTransformValue + }, + ".transform-cpu": { + transform: cssTransformValue + }, + ".transform-gpu": { + transform: cssTransformValue.replace("translate(var(--tw-translate-x), var(--tw-translate-y))", "translate3d(var(--tw-translate-x), var(--tw-translate-y), 0)") + }, + ".transform-none": { + transform: "none" + } + }); + }, + animation: ({ matchUtilities , theme , config })=>{ + let prefixName = (name)=>`${config("prefix")}${(0, _escapeClassName).default(name)}`; + var ref; + let keyframes = Object.fromEntries(Object.entries((ref = theme("keyframes")) !== null && ref !== void 0 ? ref : {}).map(([key, value])=>{ + return [ + key, + { + [`@keyframes ${prefixName(key)}`]: value + } + ]; + })); + matchUtilities({ + animate: (value1)=>{ + let animations = (0, _parseAnimationValue).default(value1); + return [ + ...animations.flatMap((animation)=>keyframes[animation.name]), + { + animation: animations.map(({ name , value })=>{ + if (name === undefined || keyframes[name] === undefined) { + return value; + } + return value.replace(name, prefixName(name)); + }).join(", ") + }, + ]; + } + }, { + values: theme("animation") + }); + }, + cursor: (0, _createUtilityPlugin).default("cursor"), + touchAction: ({ addDefaults , addUtilities })=>{ + addDefaults("touch-action", { + "--tw-pan-x": " ", + "--tw-pan-y": " ", + "--tw-pinch-zoom": " " + }); + let cssTouchActionValue = "var(--tw-pan-x) var(--tw-pan-y) var(--tw-pinch-zoom)"; + addUtilities({ + ".touch-auto": { + "touch-action": "auto" + }, + ".touch-none": { + "touch-action": "none" + }, + ".touch-pan-x": { + "@defaults touch-action": {}, + "--tw-pan-x": "pan-x", + "touch-action": cssTouchActionValue + }, + ".touch-pan-left": { + "@defaults touch-action": {}, + "--tw-pan-x": "pan-left", + "touch-action": cssTouchActionValue + }, + ".touch-pan-right": { + "@defaults touch-action": {}, + "--tw-pan-x": "pan-right", + "touch-action": cssTouchActionValue + }, + ".touch-pan-y": { + "@defaults touch-action": {}, + "--tw-pan-y": "pan-y", + "touch-action": cssTouchActionValue + }, + ".touch-pan-up": { + "@defaults touch-action": {}, + "--tw-pan-y": "pan-up", + "touch-action": cssTouchActionValue + }, + ".touch-pan-down": { + "@defaults touch-action": {}, + "--tw-pan-y": "pan-down", + "touch-action": cssTouchActionValue + }, + ".touch-pinch-zoom": { + "@defaults touch-action": {}, + "--tw-pinch-zoom": "pinch-zoom", + "touch-action": cssTouchActionValue + }, + ".touch-manipulation": { + "touch-action": "manipulation" + } + }); + }, + userSelect: ({ addUtilities })=>{ + addUtilities({ + ".select-none": { + "user-select": "none" + }, + ".select-text": { + "user-select": "text" + }, + ".select-all": { + "user-select": "all" + }, + ".select-auto": { + "user-select": "auto" + } + }); + }, + resize: ({ addUtilities })=>{ + addUtilities({ + ".resize-none": { + resize: "none" + }, + ".resize-y": { + resize: "vertical" + }, + ".resize-x": { + resize: "horizontal" + }, + ".resize": { + resize: "both" + } + }); + }, + scrollSnapType: ({ addDefaults , addUtilities })=>{ + addDefaults("scroll-snap-type", { + "--tw-scroll-snap-strictness": "proximity" + }); + addUtilities({ + ".snap-none": { + "scroll-snap-type": "none" + }, + ".snap-x": { + "@defaults scroll-snap-type": {}, + "scroll-snap-type": "x var(--tw-scroll-snap-strictness)" + }, + ".snap-y": { + "@defaults scroll-snap-type": {}, + "scroll-snap-type": "y var(--tw-scroll-snap-strictness)" + }, + ".snap-both": { + "@defaults scroll-snap-type": {}, + "scroll-snap-type": "both var(--tw-scroll-snap-strictness)" + }, + ".snap-mandatory": { + "--tw-scroll-snap-strictness": "mandatory" + }, + ".snap-proximity": { + "--tw-scroll-snap-strictness": "proximity" + } + }); + }, + scrollSnapAlign: ({ addUtilities })=>{ + addUtilities({ + ".snap-start": { + "scroll-snap-align": "start" + }, + ".snap-end": { + "scroll-snap-align": "end" + }, + ".snap-center": { + "scroll-snap-align": "center" + }, + ".snap-align-none": { + "scroll-snap-align": "none" + } + }); + }, + scrollSnapStop: ({ addUtilities })=>{ + addUtilities({ + ".snap-normal": { + "scroll-snap-stop": "normal" + }, + ".snap-always": { + "scroll-snap-stop": "always" + } + }); + }, + scrollMargin: (0, _createUtilityPlugin).default("scrollMargin", [ + [ + "scroll-m", + [ + "scroll-margin" + ] + ], + [ + [ + "scroll-mx", + [ + "scroll-margin-left", + "scroll-margin-right" + ] + ], + [ + "scroll-my", + [ + "scroll-margin-top", + "scroll-margin-bottom" + ] + ], + ], + [ + [ + "scroll-mt", + [ + "scroll-margin-top" + ] + ], + [ + "scroll-mr", + [ + "scroll-margin-right" + ] + ], + [ + "scroll-mb", + [ + "scroll-margin-bottom" + ] + ], + [ + "scroll-ml", + [ + "scroll-margin-left" + ] + ], + ], + ], { + supportsNegativeValues: true + }), + scrollPadding: (0, _createUtilityPlugin).default("scrollPadding", [ + [ + "scroll-p", + [ + "scroll-padding" + ] + ], + [ + [ + "scroll-px", + [ + "scroll-padding-left", + "scroll-padding-right" + ] + ], + [ + "scroll-py", + [ + "scroll-padding-top", + "scroll-padding-bottom" + ] + ], + ], + [ + [ + "scroll-pt", + [ + "scroll-padding-top" + ] + ], + [ + "scroll-pr", + [ + "scroll-padding-right" + ] + ], + [ + "scroll-pb", + [ + "scroll-padding-bottom" + ] + ], + [ + "scroll-pl", + [ + "scroll-padding-left" + ] + ], + ], + ]), + listStylePosition: ({ addUtilities })=>{ + addUtilities({ + ".list-inside": { + "list-style-position": "inside" + }, + ".list-outside": { + "list-style-position": "outside" + } + }); + }, + listStyleType: (0, _createUtilityPlugin).default("listStyleType", [ + [ + "list", + [ + "listStyleType" + ] + ] + ]), + appearance: ({ addUtilities })=>{ + addUtilities({ + ".appearance-none": { + appearance: "none" + } + }); + }, + columns: (0, _createUtilityPlugin).default("columns", [ + [ + "columns", + [ + "columns" + ] + ] + ]), + breakBefore: ({ addUtilities })=>{ + addUtilities({ + ".break-before-auto": { + "break-before": "auto" + }, + ".break-before-avoid": { + "break-before": "avoid" + }, + ".break-before-all": { + "break-before": "all" + }, + ".break-before-avoid-page": { + "break-before": "avoid-page" + }, + ".break-before-page": { + "break-before": "page" + }, + ".break-before-left": { + "break-before": "left" + }, + ".break-before-right": { + "break-before": "right" + }, + ".break-before-column": { + "break-before": "column" + } + }); + }, + breakInside: ({ addUtilities })=>{ + addUtilities({ + ".break-inside-auto": { + "break-inside": "auto" + }, + ".break-inside-avoid": { + "break-inside": "avoid" + }, + ".break-inside-avoid-page": { + "break-inside": "avoid-page" + }, + ".break-inside-avoid-column": { + "break-inside": "avoid-column" + } + }); + }, + breakAfter: ({ addUtilities })=>{ + addUtilities({ + ".break-after-auto": { + "break-after": "auto" + }, + ".break-after-avoid": { + "break-after": "avoid" + }, + ".break-after-all": { + "break-after": "all" + }, + ".break-after-avoid-page": { + "break-after": "avoid-page" + }, + ".break-after-page": { + "break-after": "page" + }, + ".break-after-left": { + "break-after": "left" + }, + ".break-after-right": { + "break-after": "right" + }, + ".break-after-column": { + "break-after": "column" + } + }); + }, + gridAutoColumns: (0, _createUtilityPlugin).default("gridAutoColumns", [ + [ + "auto-cols", + [ + "gridAutoColumns" + ] + ] + ]), + gridAutoFlow: ({ addUtilities })=>{ + addUtilities({ + ".grid-flow-row": { + gridAutoFlow: "row" + }, + ".grid-flow-col": { + gridAutoFlow: "column" + }, + ".grid-flow-dense": { + gridAutoFlow: "dense" + }, + ".grid-flow-row-dense": { + gridAutoFlow: "row dense" + }, + ".grid-flow-col-dense": { + gridAutoFlow: "column dense" + } + }); + }, + gridAutoRows: (0, _createUtilityPlugin).default("gridAutoRows", [ + [ + "auto-rows", + [ + "gridAutoRows" + ] + ] + ]), + gridTemplateColumns: (0, _createUtilityPlugin).default("gridTemplateColumns", [ + [ + "grid-cols", + [ + "gridTemplateColumns" + ] + ], + ]), + gridTemplateRows: (0, _createUtilityPlugin).default("gridTemplateRows", [ + [ + "grid-rows", + [ + "gridTemplateRows" + ] + ] + ]), + flexDirection: ({ addUtilities })=>{ + addUtilities({ + ".flex-row": { + "flex-direction": "row" + }, + ".flex-row-reverse": { + "flex-direction": "row-reverse" + }, + ".flex-col": { + "flex-direction": "column" + }, + ".flex-col-reverse": { + "flex-direction": "column-reverse" + } + }); + }, + flexWrap: ({ addUtilities })=>{ + addUtilities({ + ".flex-wrap": { + "flex-wrap": "wrap" + }, + ".flex-wrap-reverse": { + "flex-wrap": "wrap-reverse" + }, + ".flex-nowrap": { + "flex-wrap": "nowrap" + } + }); + }, + placeContent: ({ addUtilities })=>{ + addUtilities({ + ".place-content-center": { + "place-content": "center" + }, + ".place-content-start": { + "place-content": "start" + }, + ".place-content-end": { + "place-content": "end" + }, + ".place-content-between": { + "place-content": "space-between" + }, + ".place-content-around": { + "place-content": "space-around" + }, + ".place-content-evenly": { + "place-content": "space-evenly" + }, + ".place-content-stretch": { + "place-content": "stretch" + } + }); + }, + placeItems: ({ addUtilities })=>{ + addUtilities({ + ".place-items-start": { + "place-items": "start" + }, + ".place-items-end": { + "place-items": "end" + }, + ".place-items-center": { + "place-items": "center" + }, + ".place-items-stretch": { + "place-items": "stretch" + } + }); + }, + alignContent: ({ addUtilities })=>{ + addUtilities({ + ".content-center": { + "align-content": "center" + }, + ".content-start": { + "align-content": "flex-start" + }, + ".content-end": { + "align-content": "flex-end" + }, + ".content-between": { + "align-content": "space-between" + }, + ".content-around": { + "align-content": "space-around" + }, + ".content-evenly": { + "align-content": "space-evenly" + } + }); + }, + alignItems: ({ addUtilities })=>{ + addUtilities({ + ".items-start": { + "align-items": "flex-start" + }, + ".items-end": { + "align-items": "flex-end" + }, + ".items-center": { + "align-items": "center" + }, + ".items-baseline": { + "align-items": "baseline" + }, + ".items-stretch": { + "align-items": "stretch" + } + }); + }, + justifyContent: ({ addUtilities })=>{ + addUtilities({ + ".justify-start": { + "justify-content": "flex-start" + }, + ".justify-end": { + "justify-content": "flex-end" + }, + ".justify-center": { + "justify-content": "center" + }, + ".justify-between": { + "justify-content": "space-between" + }, + ".justify-around": { + "justify-content": "space-around" + }, + ".justify-evenly": { + "justify-content": "space-evenly" + } + }); + }, + justifyItems: ({ addUtilities })=>{ + addUtilities({ + ".justify-items-start": { + "justify-items": "start" + }, + ".justify-items-end": { + "justify-items": "end" + }, + ".justify-items-center": { + "justify-items": "center" + }, + ".justify-items-stretch": { + "justify-items": "stretch" + } + }); + }, + gap: (0, _createUtilityPlugin).default("gap", [ + [ + "gap", + [ + "gap" + ] + ], + [ + [ + "gap-x", + [ + "columnGap" + ] + ], + [ + "gap-y", + [ + "rowGap" + ] + ], + ], + ]), + space: ({ matchUtilities , addUtilities , theme })=>{ + matchUtilities({ + "space-x": (value)=>{ + value = value === "0" ? "0px" : value; + return { + "& > :not([hidden]) ~ :not([hidden])": { + "--tw-space-x-reverse": "0", + "margin-right": `calc(${value} * var(--tw-space-x-reverse))`, + "margin-left": `calc(${value} * calc(1 - var(--tw-space-x-reverse)))` + } + }; + }, + "space-y": (value)=>{ + value = value === "0" ? "0px" : value; + return { + "& > :not([hidden]) ~ :not([hidden])": { + "--tw-space-y-reverse": "0", + "margin-top": `calc(${value} * calc(1 - var(--tw-space-y-reverse)))`, + "margin-bottom": `calc(${value} * var(--tw-space-y-reverse))` + } + }; + } + }, { + values: theme("space"), + supportsNegativeValues: true + }); + addUtilities({ + ".space-y-reverse > :not([hidden]) ~ :not([hidden])": { + "--tw-space-y-reverse": "1" + }, + ".space-x-reverse > :not([hidden]) ~ :not([hidden])": { + "--tw-space-x-reverse": "1" + } + }); + }, + divideWidth: ({ matchUtilities , addUtilities , theme })=>{ + matchUtilities({ + "divide-x": (value)=>{ + value = value === "0" ? "0px" : value; + return { + "& > :not([hidden]) ~ :not([hidden])": { + "@defaults border-width": {}, + "--tw-divide-x-reverse": "0", + "border-right-width": `calc(${value} * var(--tw-divide-x-reverse))`, + "border-left-width": `calc(${value} * calc(1 - var(--tw-divide-x-reverse)))` + } + }; + }, + "divide-y": (value)=>{ + value = value === "0" ? "0px" : value; + return { + "& > :not([hidden]) ~ :not([hidden])": { + "@defaults border-width": {}, + "--tw-divide-y-reverse": "0", + "border-top-width": `calc(${value} * calc(1 - var(--tw-divide-y-reverse)))`, + "border-bottom-width": `calc(${value} * var(--tw-divide-y-reverse))` + } + }; + } + }, { + values: theme("divideWidth"), + type: [ + "line-width", + "length" + ] + }); + addUtilities({ + ".divide-y-reverse > :not([hidden]) ~ :not([hidden])": { + "@defaults border-width": {}, + "--tw-divide-y-reverse": "1" + }, + ".divide-x-reverse > :not([hidden]) ~ :not([hidden])": { + "@defaults border-width": {}, + "--tw-divide-x-reverse": "1" + } + }); + }, + divideStyle: ({ addUtilities })=>{ + addUtilities({ + ".divide-solid > :not([hidden]) ~ :not([hidden])": { + "border-style": "solid" + }, + ".divide-dashed > :not([hidden]) ~ :not([hidden])": { + "border-style": "dashed" + }, + ".divide-dotted > :not([hidden]) ~ :not([hidden])": { + "border-style": "dotted" + }, + ".divide-double > :not([hidden]) ~ :not([hidden])": { + "border-style": "double" + }, + ".divide-none > :not([hidden]) ~ :not([hidden])": { + "border-style": "none" + } + }); + }, + divideColor: ({ matchUtilities , theme , corePlugins: corePlugins1 })=>{ + matchUtilities({ + divide: (value)=>{ + if (!corePlugins1("divideOpacity")) { + return { + ["& > :not([hidden]) ~ :not([hidden])"]: { + "border-color": (0, _toColorValue).default(value) + } + }; + } + return { + ["& > :not([hidden]) ~ :not([hidden])"]: (0, _withAlphaVariable).default({ + color: value, + property: "border-color", + variable: "--tw-divide-opacity" + }) + }; + } + }, { + values: (({ DEFAULT: _ , ...colors })=>colors)((0, _flattenColorPalette).default(theme("divideColor"))), + type: "color" + }); + }, + divideOpacity: ({ matchUtilities , theme })=>{ + matchUtilities({ + "divide-opacity": (value)=>{ + return { + [`& > :not([hidden]) ~ :not([hidden])`]: { + "--tw-divide-opacity": value + } + }; + } + }, { + values: theme("divideOpacity") + }); + }, + placeSelf: ({ addUtilities })=>{ + addUtilities({ + ".place-self-auto": { + "place-self": "auto" + }, + ".place-self-start": { + "place-self": "start" + }, + ".place-self-end": { + "place-self": "end" + }, + ".place-self-center": { + "place-self": "center" + }, + ".place-self-stretch": { + "place-self": "stretch" + } + }); + }, + alignSelf: ({ addUtilities })=>{ + addUtilities({ + ".self-auto": { + "align-self": "auto" + }, + ".self-start": { + "align-self": "flex-start" + }, + ".self-end": { + "align-self": "flex-end" + }, + ".self-center": { + "align-self": "center" + }, + ".self-stretch": { + "align-self": "stretch" + }, + ".self-baseline": { + "align-self": "baseline" + } + }); + }, + justifySelf: ({ addUtilities })=>{ + addUtilities({ + ".justify-self-auto": { + "justify-self": "auto" + }, + ".justify-self-start": { + "justify-self": "start" + }, + ".justify-self-end": { + "justify-self": "end" + }, + ".justify-self-center": { + "justify-self": "center" + }, + ".justify-self-stretch": { + "justify-self": "stretch" + } + }); + }, + overflow: ({ addUtilities })=>{ + addUtilities({ + ".overflow-auto": { + overflow: "auto" + }, + ".overflow-hidden": { + overflow: "hidden" + }, + ".overflow-clip": { + overflow: "clip" + }, + ".overflow-visible": { + overflow: "visible" + }, + ".overflow-scroll": { + overflow: "scroll" + }, + ".overflow-x-auto": { + "overflow-x": "auto" + }, + ".overflow-y-auto": { + "overflow-y": "auto" + }, + ".overflow-x-hidden": { + "overflow-x": "hidden" + }, + ".overflow-y-hidden": { + "overflow-y": "hidden" + }, + ".overflow-x-clip": { + "overflow-x": "clip" + }, + ".overflow-y-clip": { + "overflow-y": "clip" + }, + ".overflow-x-visible": { + "overflow-x": "visible" + }, + ".overflow-y-visible": { + "overflow-y": "visible" + }, + ".overflow-x-scroll": { + "overflow-x": "scroll" + }, + ".overflow-y-scroll": { + "overflow-y": "scroll" + } + }); + }, + overscrollBehavior: ({ addUtilities })=>{ + addUtilities({ + ".overscroll-auto": { + "overscroll-behavior": "auto" + }, + ".overscroll-contain": { + "overscroll-behavior": "contain" + }, + ".overscroll-none": { + "overscroll-behavior": "none" + }, + ".overscroll-y-auto": { + "overscroll-behavior-y": "auto" + }, + ".overscroll-y-contain": { + "overscroll-behavior-y": "contain" + }, + ".overscroll-y-none": { + "overscroll-behavior-y": "none" + }, + ".overscroll-x-auto": { + "overscroll-behavior-x": "auto" + }, + ".overscroll-x-contain": { + "overscroll-behavior-x": "contain" + }, + ".overscroll-x-none": { + "overscroll-behavior-x": "none" + } + }); + }, + scrollBehavior: ({ addUtilities })=>{ + addUtilities({ + ".scroll-auto": { + "scroll-behavior": "auto" + }, + ".scroll-smooth": { + "scroll-behavior": "smooth" + } + }); + }, + textOverflow: ({ addUtilities })=>{ + addUtilities({ + ".truncate": { + overflow: "hidden", + "text-overflow": "ellipsis", + "white-space": "nowrap" + }, + ".overflow-ellipsis": { + "text-overflow": "ellipsis" + }, + ".text-ellipsis": { + "text-overflow": "ellipsis" + }, + ".text-clip": { + "text-overflow": "clip" + } + }); + }, + whitespace: ({ addUtilities })=>{ + addUtilities({ + ".whitespace-normal": { + "white-space": "normal" + }, + ".whitespace-nowrap": { + "white-space": "nowrap" + }, + ".whitespace-pre": { + "white-space": "pre" + }, + ".whitespace-pre-line": { + "white-space": "pre-line" + }, + ".whitespace-pre-wrap": { + "white-space": "pre-wrap" + } + }); + }, + wordBreak: ({ addUtilities })=>{ + addUtilities({ + ".break-normal": { + "overflow-wrap": "normal", + "word-break": "normal" + }, + ".break-words": { + "overflow-wrap": "break-word" + }, + ".break-all": { + "word-break": "break-all" + } + }); + }, + borderRadius: (0, _createUtilityPlugin).default("borderRadius", [ + [ + "rounded", + [ + "border-radius" + ] + ], + [ + [ + "rounded-t", + [ + "border-top-left-radius", + "border-top-right-radius" + ] + ], + [ + "rounded-r", + [ + "border-top-right-radius", + "border-bottom-right-radius" + ] + ], + [ + "rounded-b", + [ + "border-bottom-right-radius", + "border-bottom-left-radius" + ] + ], + [ + "rounded-l", + [ + "border-top-left-radius", + "border-bottom-left-radius" + ] + ], + ], + [ + [ + "rounded-tl", + [ + "border-top-left-radius" + ] + ], + [ + "rounded-tr", + [ + "border-top-right-radius" + ] + ], + [ + "rounded-br", + [ + "border-bottom-right-radius" + ] + ], + [ + "rounded-bl", + [ + "border-bottom-left-radius" + ] + ], + ], + ]), + borderWidth: (0, _createUtilityPlugin).default("borderWidth", [ + [ + "border", + [ + [ + "@defaults border-width", + {} + ], + "border-width" + ] + ], + [ + [ + "border-x", + [ + [ + "@defaults border-width", + {} + ], + "border-left-width", + "border-right-width" + ] + ], + [ + "border-y", + [ + [ + "@defaults border-width", + {} + ], + "border-top-width", + "border-bottom-width" + ] + ], + ], + [ + [ + "border-t", + [ + [ + "@defaults border-width", + {} + ], + "border-top-width" + ] + ], + [ + "border-r", + [ + [ + "@defaults border-width", + {} + ], + "border-right-width" + ] + ], + [ + "border-b", + [ + [ + "@defaults border-width", + {} + ], + "border-bottom-width" + ] + ], + [ + "border-l", + [ + [ + "@defaults border-width", + {} + ], + "border-left-width" + ] + ], + ], + ], { + type: [ + "line-width", + "length" + ] + }), + borderStyle: ({ addUtilities })=>{ + addUtilities({ + ".border-solid": { + "border-style": "solid" + }, + ".border-dashed": { + "border-style": "dashed" + }, + ".border-dotted": { + "border-style": "dotted" + }, + ".border-double": { + "border-style": "double" + }, + ".border-hidden": { + "border-style": "hidden" + }, + ".border-none": { + "border-style": "none" + } + }); + }, + borderColor: ({ matchUtilities , theme , corePlugins: corePlugins2 })=>{ + matchUtilities({ + border: (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "border-color", + variable: "--tw-border-opacity" + }); + } + }, { + values: (({ DEFAULT: _ , ...colors })=>colors)((0, _flattenColorPalette).default(theme("borderColor"))), + type: [ + "color" + ] + }); + matchUtilities({ + "border-x": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-left-color": (0, _toColorValue).default(value), + "border-right-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: [ + "border-left-color", + "border-right-color" + ], + variable: "--tw-border-opacity" + }); + }, + "border-y": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-top-color": (0, _toColorValue).default(value), + "border-bottom-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: [ + "border-top-color", + "border-bottom-color" + ], + variable: "--tw-border-opacity" + }); + } + }, { + values: (({ DEFAULT: _ , ...colors })=>colors)((0, _flattenColorPalette).default(theme("borderColor"))), + type: "color" + }); + matchUtilities({ + "border-t": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-top-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "border-top-color", + variable: "--tw-border-opacity" + }); + }, + "border-r": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-right-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "border-right-color", + variable: "--tw-border-opacity" + }); + }, + "border-b": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-bottom-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "border-bottom-color", + variable: "--tw-border-opacity" + }); + }, + "border-l": (value)=>{ + if (!corePlugins2("borderOpacity")) { + return { + "border-left-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "border-left-color", + variable: "--tw-border-opacity" + }); + } + }, { + values: (({ DEFAULT: _ , ...colors })=>colors)((0, _flattenColorPalette).default(theme("borderColor"))), + type: "color" + }); + }, + borderOpacity: (0, _createUtilityPlugin).default("borderOpacity", [ + [ + "border-opacity", + [ + "--tw-border-opacity" + ] + ], + ]), + backgroundColor: ({ matchUtilities , theme , corePlugins: corePlugins3 })=>{ + matchUtilities({ + bg: (value)=>{ + if (!corePlugins3("backgroundOpacity")) { + return { + "background-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "background-color", + variable: "--tw-bg-opacity" + }); + } + }, { + values: (0, _flattenColorPalette).default(theme("backgroundColor")), + type: "color" + }); + }, + backgroundOpacity: (0, _createUtilityPlugin).default("backgroundOpacity", [ + [ + "bg-opacity", + [ + "--tw-bg-opacity" + ] + ], + ]), + backgroundImage: (0, _createUtilityPlugin).default("backgroundImage", [ + [ + "bg", + [ + "background-image" + ] + ] + ], { + type: [ + "lookup", + "image", + "url" + ] + }), + gradientColorStops: (()=>{ + function transparentTo(value) { + return (0, _withAlphaVariable).withAlphaValue(value, 0, "rgb(255 255 255 / 0)"); + } + return function({ matchUtilities , theme }) { + let options = { + values: (0, _flattenColorPalette).default(theme("gradientColorStops")), + type: [ + "color", + "any" + ] + }; + matchUtilities({ + from: (value)=>{ + let transparentToValue = transparentTo(value); + return { + "--tw-gradient-from": (0, _toColorValue).default(value, "from"), + "--tw-gradient-to": transparentToValue, + "--tw-gradient-stops": `var(--tw-gradient-from), var(--tw-gradient-to)` + }; + } + }, options); + matchUtilities({ + via: (value)=>{ + let transparentToValue = transparentTo(value); + return { + "--tw-gradient-to": transparentToValue, + "--tw-gradient-stops": `var(--tw-gradient-from), ${(0, _toColorValue).default(value, "via")}, var(--tw-gradient-to)` + }; + } + }, options); + matchUtilities({ + to: (value)=>({ + "--tw-gradient-to": (0, _toColorValue).default(value, "to") + }) + }, options); + }; + })(), + boxDecorationBreak: ({ addUtilities })=>{ + addUtilities({ + ".decoration-slice": { + "box-decoration-break": "slice" + }, + ".decoration-clone": { + "box-decoration-break": "clone" + }, + ".box-decoration-slice": { + "box-decoration-break": "slice" + }, + ".box-decoration-clone": { + "box-decoration-break": "clone" + } + }); + }, + backgroundSize: (0, _createUtilityPlugin).default("backgroundSize", [ + [ + "bg", + [ + "background-size" + ] + ] + ], { + type: [ + "lookup", + "length", + "percentage" + ] + }), + backgroundAttachment: ({ addUtilities })=>{ + addUtilities({ + ".bg-fixed": { + "background-attachment": "fixed" + }, + ".bg-local": { + "background-attachment": "local" + }, + ".bg-scroll": { + "background-attachment": "scroll" + } + }); + }, + backgroundClip: ({ addUtilities })=>{ + addUtilities({ + ".bg-clip-border": { + "background-clip": "border-box" + }, + ".bg-clip-padding": { + "background-clip": "padding-box" + }, + ".bg-clip-content": { + "background-clip": "content-box" + }, + ".bg-clip-text": { + "background-clip": "text" + } + }); + }, + backgroundPosition: (0, _createUtilityPlugin).default("backgroundPosition", [ + [ + "bg", + [ + "background-position" + ] + ] + ], { + type: [ + "lookup", + "position" + ] + }), + backgroundRepeat: ({ addUtilities })=>{ + addUtilities({ + ".bg-repeat": { + "background-repeat": "repeat" + }, + ".bg-no-repeat": { + "background-repeat": "no-repeat" + }, + ".bg-repeat-x": { + "background-repeat": "repeat-x" + }, + ".bg-repeat-y": { + "background-repeat": "repeat-y" + }, + ".bg-repeat-round": { + "background-repeat": "round" + }, + ".bg-repeat-space": { + "background-repeat": "space" + } + }); + }, + backgroundOrigin: ({ addUtilities })=>{ + addUtilities({ + ".bg-origin-border": { + "background-origin": "border-box" + }, + ".bg-origin-padding": { + "background-origin": "padding-box" + }, + ".bg-origin-content": { + "background-origin": "content-box" + } + }); + }, + fill: ({ matchUtilities , theme })=>{ + matchUtilities({ + fill: (value)=>{ + return { + fill: (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("fill")), + type: [ + "color", + "any" + ] + }); + }, + stroke: ({ matchUtilities , theme })=>{ + matchUtilities({ + stroke: (value)=>{ + return { + stroke: (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("stroke")), + type: [ + "color", + "url" + ] + }); + }, + strokeWidth: (0, _createUtilityPlugin).default("strokeWidth", [ + [ + "stroke", + [ + "stroke-width" + ] + ] + ], { + type: [ + "length", + "number", + "percentage" + ] + }), + objectFit: ({ addUtilities })=>{ + addUtilities({ + ".object-contain": { + "object-fit": "contain" + }, + ".object-cover": { + "object-fit": "cover" + }, + ".object-fill": { + "object-fit": "fill" + }, + ".object-none": { + "object-fit": "none" + }, + ".object-scale-down": { + "object-fit": "scale-down" + } + }); + }, + objectPosition: (0, _createUtilityPlugin).default("objectPosition", [ + [ + "object", + [ + "object-position" + ] + ] + ]), + padding: (0, _createUtilityPlugin).default("padding", [ + [ + "p", + [ + "padding" + ] + ], + [ + [ + "px", + [ + "padding-left", + "padding-right" + ] + ], + [ + "py", + [ + "padding-top", + "padding-bottom" + ] + ], + ], + [ + [ + "pt", + [ + "padding-top" + ] + ], + [ + "pr", + [ + "padding-right" + ] + ], + [ + "pb", + [ + "padding-bottom" + ] + ], + [ + "pl", + [ + "padding-left" + ] + ], + ], + ]), + textAlign: ({ addUtilities })=>{ + addUtilities({ + ".text-left": { + "text-align": "left" + }, + ".text-center": { + "text-align": "center" + }, + ".text-right": { + "text-align": "right" + }, + ".text-justify": { + "text-align": "justify" + }, + ".text-start": { + "text-align": "start" + }, + ".text-end": { + "text-align": "end" + } + }); + }, + textIndent: (0, _createUtilityPlugin).default("textIndent", [ + [ + "indent", + [ + "text-indent" + ] + ] + ], { + supportsNegativeValues: true + }), + verticalAlign: ({ addUtilities , matchUtilities })=>{ + addUtilities({ + ".align-baseline": { + "vertical-align": "baseline" + }, + ".align-top": { + "vertical-align": "top" + }, + ".align-middle": { + "vertical-align": "middle" + }, + ".align-bottom": { + "vertical-align": "bottom" + }, + ".align-text-top": { + "vertical-align": "text-top" + }, + ".align-text-bottom": { + "vertical-align": "text-bottom" + }, + ".align-sub": { + "vertical-align": "sub" + }, + ".align-super": { + "vertical-align": "super" + } + }); + matchUtilities({ + align: (value)=>({ + "vertical-align": value + }) + }); + }, + fontFamily: (0, _createUtilityPlugin).default("fontFamily", [ + [ + "font", + [ + "fontFamily" + ] + ] + ], { + type: [ + "lookup", + "generic-name", + "family-name" + ] + }), + fontSize: ({ matchUtilities , theme })=>{ + matchUtilities({ + text: (value)=>{ + let [fontSize, options] = Array.isArray(value) ? value : [ + value + ]; + let { lineHeight , letterSpacing } = (0, _isPlainObject).default(options) ? options : { + lineHeight: options + }; + return { + "font-size": fontSize, + ...lineHeight === undefined ? {} : { + "line-height": lineHeight + }, + ...letterSpacing === undefined ? {} : { + "letter-spacing": letterSpacing + } + }; + } + }, { + values: theme("fontSize"), + type: [ + "absolute-size", + "relative-size", + "length", + "percentage" + ] + }); + }, + fontWeight: (0, _createUtilityPlugin).default("fontWeight", [ + [ + "font", + [ + "fontWeight" + ] + ] + ], { + type: [ + "lookup", + "number" + ] + }), + textTransform: ({ addUtilities })=>{ + addUtilities({ + ".uppercase": { + "text-transform": "uppercase" + }, + ".lowercase": { + "text-transform": "lowercase" + }, + ".capitalize": { + "text-transform": "capitalize" + }, + ".normal-case": { + "text-transform": "none" + } + }); + }, + fontStyle: ({ addUtilities })=>{ + addUtilities({ + ".italic": { + "font-style": "italic" + }, + ".not-italic": { + "font-style": "normal" + } + }); + }, + fontVariantNumeric: ({ addDefaults , addUtilities })=>{ + let cssFontVariantNumericValue = "var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)"; + addDefaults("font-variant-numeric", { + "--tw-ordinal": " ", + "--tw-slashed-zero": " ", + "--tw-numeric-figure": " ", + "--tw-numeric-spacing": " ", + "--tw-numeric-fraction": " " + }); + addUtilities({ + ".normal-nums": { + "font-variant-numeric": "normal" + }, + ".ordinal": { + "@defaults font-variant-numeric": {}, + "--tw-ordinal": "ordinal", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".slashed-zero": { + "@defaults font-variant-numeric": {}, + "--tw-slashed-zero": "slashed-zero", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".lining-nums": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-figure": "lining-nums", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".oldstyle-nums": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-figure": "oldstyle-nums", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".proportional-nums": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-spacing": "proportional-nums", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".tabular-nums": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-spacing": "tabular-nums", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".diagonal-fractions": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-fraction": "diagonal-fractions", + "font-variant-numeric": cssFontVariantNumericValue + }, + ".stacked-fractions": { + "@defaults font-variant-numeric": {}, + "--tw-numeric-fraction": "stacked-fractions", + "font-variant-numeric": cssFontVariantNumericValue + } + }); + }, + lineHeight: (0, _createUtilityPlugin).default("lineHeight", [ + [ + "leading", + [ + "lineHeight" + ] + ] + ]), + letterSpacing: (0, _createUtilityPlugin).default("letterSpacing", [ + [ + "tracking", + [ + "letterSpacing" + ] + ] + ], { + supportsNegativeValues: true + }), + textColor: ({ matchUtilities , theme , corePlugins: corePlugins4 })=>{ + matchUtilities({ + text: (value)=>{ + if (!corePlugins4("textOpacity")) { + return { + color: (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "color", + variable: "--tw-text-opacity" + }); + } + }, { + values: (0, _flattenColorPalette).default(theme("textColor")), + type: "color" + }); + }, + textOpacity: (0, _createUtilityPlugin).default("textOpacity", [ + [ + "text-opacity", + [ + "--tw-text-opacity" + ] + ] + ]), + textDecoration: ({ addUtilities })=>{ + addUtilities({ + ".underline": { + "text-decoration-line": "underline" + }, + ".overline": { + "text-decoration-line": "overline" + }, + ".line-through": { + "text-decoration-line": "line-through" + }, + ".no-underline": { + "text-decoration-line": "none" + } + }); + }, + textDecorationColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + decoration: (value)=>{ + return { + "text-decoration-color": (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("textDecorationColor")), + type: [ + "color" + ] + }); + }, + textDecorationStyle: ({ addUtilities })=>{ + addUtilities({ + ".decoration-solid": { + "text-decoration-style": "solid" + }, + ".decoration-double": { + "text-decoration-style": "double" + }, + ".decoration-dotted": { + "text-decoration-style": "dotted" + }, + ".decoration-dashed": { + "text-decoration-style": "dashed" + }, + ".decoration-wavy": { + "text-decoration-style": "wavy" + } + }); + }, + textDecorationThickness: (0, _createUtilityPlugin).default("textDecorationThickness", [ + [ + "decoration", + [ + "text-decoration-thickness" + ] + ] + ], { + type: [ + "length", + "percentage" + ] + }), + textUnderlineOffset: (0, _createUtilityPlugin).default("textUnderlineOffset", [ + [ + "underline-offset", + [ + "text-underline-offset" + ] + ] + ], { + type: [ + "length", + "percentage" + ] + }), + fontSmoothing: ({ addUtilities })=>{ + addUtilities({ + ".antialiased": { + "-webkit-font-smoothing": "antialiased", + "-moz-osx-font-smoothing": "grayscale" + }, + ".subpixel-antialiased": { + "-webkit-font-smoothing": "auto", + "-moz-osx-font-smoothing": "auto" + } + }); + }, + placeholderColor: ({ matchUtilities , theme , corePlugins: corePlugins5 })=>{ + matchUtilities({ + placeholder: (value)=>{ + if (!corePlugins5("placeholderOpacity")) { + return { + "&::placeholder": { + color: (0, _toColorValue).default(value) + } + }; + } + return { + "&::placeholder": (0, _withAlphaVariable).default({ + color: value, + property: "color", + variable: "--tw-placeholder-opacity" + }) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("placeholderColor")), + type: [ + "color", + "any" + ] + }); + }, + placeholderOpacity: ({ matchUtilities , theme })=>{ + matchUtilities({ + "placeholder-opacity": (value)=>{ + return { + ["&::placeholder"]: { + "--tw-placeholder-opacity": value + } + }; + } + }, { + values: theme("placeholderOpacity") + }); + }, + caretColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + caret: (value)=>{ + return { + "caret-color": (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("caretColor")), + type: [ + "color", + "any" + ] + }); + }, + accentColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + accent: (value)=>{ + return { + "accent-color": (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("accentColor")), + type: [ + "color", + "any" + ] + }); + }, + opacity: (0, _createUtilityPlugin).default("opacity", [ + [ + "opacity", + [ + "opacity" + ] + ] + ]), + backgroundBlendMode: ({ addUtilities })=>{ + addUtilities({ + ".bg-blend-normal": { + "background-blend-mode": "normal" + }, + ".bg-blend-multiply": { + "background-blend-mode": "multiply" + }, + ".bg-blend-screen": { + "background-blend-mode": "screen" + }, + ".bg-blend-overlay": { + "background-blend-mode": "overlay" + }, + ".bg-blend-darken": { + "background-blend-mode": "darken" + }, + ".bg-blend-lighten": { + "background-blend-mode": "lighten" + }, + ".bg-blend-color-dodge": { + "background-blend-mode": "color-dodge" + }, + ".bg-blend-color-burn": { + "background-blend-mode": "color-burn" + }, + ".bg-blend-hard-light": { + "background-blend-mode": "hard-light" + }, + ".bg-blend-soft-light": { + "background-blend-mode": "soft-light" + }, + ".bg-blend-difference": { + "background-blend-mode": "difference" + }, + ".bg-blend-exclusion": { + "background-blend-mode": "exclusion" + }, + ".bg-blend-hue": { + "background-blend-mode": "hue" + }, + ".bg-blend-saturation": { + "background-blend-mode": "saturation" + }, + ".bg-blend-color": { + "background-blend-mode": "color" + }, + ".bg-blend-luminosity": { + "background-blend-mode": "luminosity" + } + }); + }, + mixBlendMode: ({ addUtilities })=>{ + addUtilities({ + ".mix-blend-normal": { + "mix-blend-mode": "normal" + }, + ".mix-blend-multiply": { + "mix-blend-mode": "multiply" + }, + ".mix-blend-screen": { + "mix-blend-mode": "screen" + }, + ".mix-blend-overlay": { + "mix-blend-mode": "overlay" + }, + ".mix-blend-darken": { + "mix-blend-mode": "darken" + }, + ".mix-blend-lighten": { + "mix-blend-mode": "lighten" + }, + ".mix-blend-color-dodge": { + "mix-blend-mode": "color-dodge" + }, + ".mix-blend-color-burn": { + "mix-blend-mode": "color-burn" + }, + ".mix-blend-hard-light": { + "mix-blend-mode": "hard-light" + }, + ".mix-blend-soft-light": { + "mix-blend-mode": "soft-light" + }, + ".mix-blend-difference": { + "mix-blend-mode": "difference" + }, + ".mix-blend-exclusion": { + "mix-blend-mode": "exclusion" + }, + ".mix-blend-hue": { + "mix-blend-mode": "hue" + }, + ".mix-blend-saturation": { + "mix-blend-mode": "saturation" + }, + ".mix-blend-color": { + "mix-blend-mode": "color" + }, + ".mix-blend-luminosity": { + "mix-blend-mode": "luminosity" + }, + ".mix-blend-plus-lighter": { + "mix-blend-mode": "plus-lighter" + } + }); + }, + boxShadow: (()=>{ + let transformValue = (0, _transformThemeValue).default("boxShadow"); + let defaultBoxShadow = [ + `var(--tw-ring-offset-shadow, 0 0 #0000)`, + `var(--tw-ring-shadow, 0 0 #0000)`, + `var(--tw-shadow)`, + ].join(", "); + return function({ matchUtilities , addDefaults , theme }) { + addDefaults(" box-shadow", { + "--tw-ring-offset-shadow": "0 0 #0000", + "--tw-ring-shadow": "0 0 #0000", + "--tw-shadow": "0 0 #0000", + "--tw-shadow-colored": "0 0 #0000" + }); + matchUtilities({ + shadow: (value)=>{ + value = transformValue(value); + let ast = (0, _parseBoxShadowValue).parseBoxShadowValue(value); + for (let shadow of ast){ + // Don't override color if the whole shadow is a variable + if (!shadow.valid) { + continue; + } + shadow.color = "var(--tw-shadow-color)"; + } + return { + "@defaults box-shadow": {}, + "--tw-shadow": value === "none" ? "0 0 #0000" : value, + "--tw-shadow-colored": value === "none" ? "0 0 #0000" : (0, _parseBoxShadowValue).formatBoxShadowValue(ast), + "box-shadow": defaultBoxShadow + }; + } + }, { + values: theme("boxShadow"), + type: [ + "shadow" + ] + }); + }; + })(), + boxShadowColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + shadow: (value)=>{ + return { + "--tw-shadow-color": (0, _toColorValue).default(value), + "--tw-shadow": "var(--tw-shadow-colored)" + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("boxShadowColor")), + type: [ + "color" + ] + }); + }, + outlineStyle: ({ addUtilities })=>{ + addUtilities({ + ".outline-none": { + outline: "2px solid transparent", + "outline-offset": "2px" + }, + ".outline": { + "outline-style": "solid" + }, + ".outline-dashed": { + "outline-style": "dashed" + }, + ".outline-dotted": { + "outline-style": "dotted" + }, + ".outline-double": { + "outline-style": "double" + }, + ".outline-hidden": { + "outline-style": "hidden" + } + }); + }, + outlineWidth: (0, _createUtilityPlugin).default("outlineWidth", [ + [ + "outline", + [ + "outline-width" + ] + ] + ], { + type: [ + "length", + "number", + "percentage" + ] + }), + outlineOffset: (0, _createUtilityPlugin).default("outlineOffset", [ + [ + "outline-offset", + [ + "outline-offset" + ] + ] + ], { + type: [ + "length", + "number", + "percentage" + ] + }), + outlineColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + outline: (value)=>{ + return { + "outline-color": (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("outlineColor")), + type: [ + "color" + ] + }); + }, + ringWidth: ({ matchUtilities , addDefaults , addUtilities , theme , config })=>{ + let ringColorDefault = (()=>{ + var ref, ref1; + if ((0, _featureFlags).flagEnabled(config(), "respectDefaultRingColorOpacity")) { + return theme("ringColor.DEFAULT"); + } + let ringOpacityDefault = theme("ringOpacity.DEFAULT", "0.5"); + if (!((ref = theme("ringColor")) === null || ref === void 0 ? void 0 : ref.DEFAULT)) { + return `rgb(147 197 253 / ${ringOpacityDefault})`; + } + return (0, _withAlphaVariable).withAlphaValue((ref1 = theme("ringColor")) === null || ref1 === void 0 ? void 0 : ref1.DEFAULT, ringOpacityDefault, `rgb(147 197 253 / ${ringOpacityDefault})`); + })(); + addDefaults("ring-width", { + "--tw-ring-inset": " ", + "--tw-ring-offset-width": theme("ringOffsetWidth.DEFAULT", "0px"), + "--tw-ring-offset-color": theme("ringOffsetColor.DEFAULT", "#fff"), + "--tw-ring-color": ringColorDefault, + "--tw-ring-offset-shadow": "0 0 #0000", + "--tw-ring-shadow": "0 0 #0000", + "--tw-shadow": "0 0 #0000", + "--tw-shadow-colored": "0 0 #0000" + }); + matchUtilities({ + ring: (value)=>{ + return { + "@defaults ring-width": {}, + "--tw-ring-offset-shadow": `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`, + "--tw-ring-shadow": `var(--tw-ring-inset) 0 0 0 calc(${value} + var(--tw-ring-offset-width)) var(--tw-ring-color)`, + "box-shadow": [ + `var(--tw-ring-offset-shadow)`, + `var(--tw-ring-shadow)`, + `var(--tw-shadow, 0 0 #0000)`, + ].join(", ") + }; + } + }, { + values: theme("ringWidth"), + type: "length" + }); + addUtilities({ + ".ring-inset": { + "@defaults ring-width": {}, + "--tw-ring-inset": "inset" + } + }); + }, + ringColor: ({ matchUtilities , theme , corePlugins: corePlugins6 })=>{ + matchUtilities({ + ring: (value)=>{ + if (!corePlugins6("ringOpacity")) { + return { + "--tw-ring-color": (0, _toColorValue).default(value) + }; + } + return (0, _withAlphaVariable).default({ + color: value, + property: "--tw-ring-color", + variable: "--tw-ring-opacity" + }); + } + }, { + values: Object.fromEntries(Object.entries((0, _flattenColorPalette).default(theme("ringColor"))).filter(([modifier])=>modifier !== "DEFAULT")), + type: "color" + }); + }, + ringOpacity: (helpers)=>{ + let { config } = helpers; + return (0, _createUtilityPlugin).default("ringOpacity", [ + [ + "ring-opacity", + [ + "--tw-ring-opacity" + ] + ] + ], { + filterDefault: !(0, _featureFlags).flagEnabled(config(), "respectDefaultRingColorOpacity") + })(helpers); + }, + ringOffsetWidth: (0, _createUtilityPlugin).default("ringOffsetWidth", [ + [ + "ring-offset", + [ + "--tw-ring-offset-width" + ] + ] + ], { + type: "length" + }), + ringOffsetColor: ({ matchUtilities , theme })=>{ + matchUtilities({ + "ring-offset": (value)=>{ + return { + "--tw-ring-offset-color": (0, _toColorValue).default(value) + }; + } + }, { + values: (0, _flattenColorPalette).default(theme("ringOffsetColor")), + type: "color" + }); + }, + blur: ({ matchUtilities , theme })=>{ + matchUtilities({ + blur: (value)=>{ + return { + "--tw-blur": `blur(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("blur") + }); + }, + brightness: ({ matchUtilities , theme })=>{ + matchUtilities({ + brightness: (value)=>{ + return { + "--tw-brightness": `brightness(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("brightness") + }); + }, + contrast: ({ matchUtilities , theme })=>{ + matchUtilities({ + contrast: (value)=>{ + return { + "--tw-contrast": `contrast(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("contrast") + }); + }, + dropShadow: ({ matchUtilities , theme })=>{ + matchUtilities({ + "drop-shadow": (value)=>{ + return { + "--tw-drop-shadow": Array.isArray(value) ? value.map((v)=>`drop-shadow(${v})`).join(" ") : `drop-shadow(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("dropShadow") + }); + }, + grayscale: ({ matchUtilities , theme })=>{ + matchUtilities({ + grayscale: (value)=>{ + return { + "--tw-grayscale": `grayscale(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("grayscale") + }); + }, + hueRotate: ({ matchUtilities , theme })=>{ + matchUtilities({ + "hue-rotate": (value)=>{ + return { + "--tw-hue-rotate": `hue-rotate(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("hueRotate"), + supportsNegativeValues: true + }); + }, + invert: ({ matchUtilities , theme })=>{ + matchUtilities({ + invert: (value)=>{ + return { + "--tw-invert": `invert(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("invert") + }); + }, + saturate: ({ matchUtilities , theme })=>{ + matchUtilities({ + saturate: (value)=>{ + return { + "--tw-saturate": `saturate(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("saturate") + }); + }, + sepia: ({ matchUtilities , theme })=>{ + matchUtilities({ + sepia: (value)=>{ + return { + "--tw-sepia": `sepia(${value})`, + "@defaults filter": {}, + filter: cssFilterValue + }; + } + }, { + values: theme("sepia") + }); + }, + filter: ({ addDefaults , addUtilities })=>{ + addDefaults("filter", { + "--tw-blur": " ", + "--tw-brightness": " ", + "--tw-contrast": " ", + "--tw-grayscale": " ", + "--tw-hue-rotate": " ", + "--tw-invert": " ", + "--tw-saturate": " ", + "--tw-sepia": " ", + "--tw-drop-shadow": " " + }); + addUtilities({ + ".filter": { + "@defaults filter": {}, + filter: cssFilterValue + }, + ".filter-none": { + filter: "none" + } + }); + }, + backdropBlur: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-blur": (value)=>{ + return { + "--tw-backdrop-blur": `blur(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropBlur") + }); + }, + backdropBrightness: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-brightness": (value)=>{ + return { + "--tw-backdrop-brightness": `brightness(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropBrightness") + }); + }, + backdropContrast: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-contrast": (value)=>{ + return { + "--tw-backdrop-contrast": `contrast(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropContrast") + }); + }, + backdropGrayscale: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-grayscale": (value)=>{ + return { + "--tw-backdrop-grayscale": `grayscale(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropGrayscale") + }); + }, + backdropHueRotate: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-hue-rotate": (value)=>{ + return { + "--tw-backdrop-hue-rotate": `hue-rotate(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropHueRotate"), + supportsNegativeValues: true + }); + }, + backdropInvert: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-invert": (value)=>{ + return { + "--tw-backdrop-invert": `invert(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropInvert") + }); + }, + backdropOpacity: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-opacity": (value)=>{ + return { + "--tw-backdrop-opacity": `opacity(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropOpacity") + }); + }, + backdropSaturate: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-saturate": (value)=>{ + return { + "--tw-backdrop-saturate": `saturate(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropSaturate") + }); + }, + backdropSepia: ({ matchUtilities , theme })=>{ + matchUtilities({ + "backdrop-sepia": (value)=>{ + return { + "--tw-backdrop-sepia": `sepia(${value})`, + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }; + } + }, { + values: theme("backdropSepia") + }); + }, + backdropFilter: ({ addDefaults , addUtilities })=>{ + addDefaults("backdrop-filter", { + "--tw-backdrop-blur": " ", + "--tw-backdrop-brightness": " ", + "--tw-backdrop-contrast": " ", + "--tw-backdrop-grayscale": " ", + "--tw-backdrop-hue-rotate": " ", + "--tw-backdrop-invert": " ", + "--tw-backdrop-opacity": " ", + "--tw-backdrop-saturate": " ", + "--tw-backdrop-sepia": " " + }); + addUtilities({ + ".backdrop-filter": { + "@defaults backdrop-filter": {}, + "backdrop-filter": cssBackdropFilterValue + }, + ".backdrop-filter-none": { + "backdrop-filter": "none" + } + }); + }, + transitionProperty: ({ matchUtilities , theme })=>{ + let defaultTimingFunction = theme("transitionTimingFunction.DEFAULT"); + let defaultDuration = theme("transitionDuration.DEFAULT"); + matchUtilities({ + transition: (value)=>{ + return { + "transition-property": value, + ...value === "none" ? {} : { + "transition-timing-function": defaultTimingFunction, + "transition-duration": defaultDuration + } + }; + } + }, { + values: theme("transitionProperty") + }); + }, + transitionDelay: (0, _createUtilityPlugin).default("transitionDelay", [ + [ + "delay", + [ + "transitionDelay" + ] + ] + ]), + transitionDuration: (0, _createUtilityPlugin).default("transitionDuration", [ + [ + "duration", + [ + "transitionDuration" + ] + ] + ], { + filterDefault: true + }), + transitionTimingFunction: (0, _createUtilityPlugin).default("transitionTimingFunction", [ + [ + "ease", + [ + "transitionTimingFunction" + ] + ] + ], { + filterDefault: true + }), + willChange: (0, _createUtilityPlugin).default("willChange", [ + [ + "will-change", + [ + "will-change" + ] + ] + ]), + content: (0, _createUtilityPlugin).default("content", [ + [ + "content", + [ + "--tw-content", + [ + "content", + "var(--tw-content)" + ] + ] + ], + ]) +}; +exports.corePlugins = corePlugins; diff --git a/node_modules/tailwindcss/lib/css/LICENSE b/node_modules/tailwindcss/lib/css/LICENSE new file mode 100644 index 0000000..a1fb039 --- /dev/null +++ b/node_modules/tailwindcss/lib/css/LICENSE @@ -0,0 +1,25 @@ +MIT License + +Copyright (c) Nicolas Gallagher +Copyright (c) Jonathan Neal +Copyright (c) Sindre Sorhus (sindresorhus.com) +Copyright (c) Adam Wathan +Copyright (c) Jonathan Reinink + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/node_modules/tailwindcss/lib/css/preflight.css b/node_modules/tailwindcss/lib/css/preflight.css new file mode 100644 index 0000000..bf36495 --- /dev/null +++ b/node_modules/tailwindcss/lib/css/preflight.css @@ -0,0 +1,360 @@ +/* +1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4) +2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116) +*/ + +*, +::before, +::after { + box-sizing: border-box; /* 1 */ + border-width: 0; /* 2 */ + border-style: solid; /* 2 */ + border-color: theme('borderColor.DEFAULT', currentColor); /* 2 */ +} + +::before, +::after { + --tw-content: ''; +} + +/* +1. Use a consistent sensible line-height in all browsers. +2. Prevent adjustments of font size after orientation changes in iOS. +3. Use a more readable tab size. +4. Use the user's configured `sans` font-family by default. +*/ + +html { + line-height: 1.5; /* 1 */ + -webkit-text-size-adjust: 100%; /* 2 */ + -moz-tab-size: 4; /* 3 */ + tab-size: 4; /* 3 */ + font-family: theme('fontFamily.sans', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"); /* 4 */ +} + +/* +1. Remove the margin in all browsers. +2. Inherit line-height from `html` so users can set them as a class directly on the `html` element. +*/ + +body { + margin: 0; /* 1 */ + line-height: inherit; /* 2 */ +} + +/* +1. Add the correct height in Firefox. +2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655) +3. Ensure horizontal rules are visible by default. +*/ + +hr { + height: 0; /* 1 */ + color: inherit; /* 2 */ + border-top-width: 1px; /* 3 */ +} + +/* +Add the correct text decoration in Chrome, Edge, and Safari. +*/ + +abbr:where([title]) { + text-decoration: underline dotted; +} + +/* +Remove the default font size and weight for headings. +*/ + +h1, +h2, +h3, +h4, +h5, +h6 { + font-size: inherit; + font-weight: inherit; +} + +/* +Reset links to optimize for opt-in styling instead of opt-out. +*/ + +a { + color: inherit; + text-decoration: inherit; +} + +/* +Add the correct font weight in Edge and Safari. +*/ + +b, +strong { + font-weight: bolder; +} + +/* +1. Use the user's configured `mono` font family by default. +2. Correct the odd `em` font sizing in all browsers. +*/ + +code, +kbd, +samp, +pre { + font-family: theme('fontFamily.mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace); /* 1 */ + font-size: 1em; /* 2 */ +} + +/* +Add the correct font size in all browsers. +*/ + +small { + font-size: 80%; +} + +/* +Prevent `sub` and `sup` elements from affecting the line height in all browsers. +*/ + +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} + +sub { + bottom: -0.25em; +} + +sup { + top: -0.5em; +} + +/* +1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297) +2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016) +3. Remove gaps between table borders by default. +*/ + +table { + text-indent: 0; /* 1 */ + border-color: inherit; /* 2 */ + border-collapse: collapse; /* 3 */ +} + +/* +1. Change the font styles in all browsers. +2. Remove the margin in Firefox and Safari. +3. Remove default padding in all browsers. +*/ + +button, +input, +optgroup, +select, +textarea { + font-family: inherit; /* 1 */ + font-size: 100%; /* 1 */ + font-weight: inherit; /* 1 */ + line-height: inherit; /* 1 */ + color: inherit; /* 1 */ + margin: 0; /* 2 */ + padding: 0; /* 3 */ +} + +/* +Remove the inheritance of text transform in Edge and Firefox. +*/ + +button, +select { + text-transform: none; +} + +/* +1. Correct the inability to style clickable types in iOS and Safari. +2. Remove default button styles. +*/ + +button, +[type='button'], +[type='reset'], +[type='submit'] { + -webkit-appearance: button; /* 1 */ + background-color: transparent; /* 2 */ + background-image: none; /* 2 */ +} + +/* +Use the modern Firefox focus style for all focusable elements. +*/ + +:-moz-focusring { + outline: auto; +} + +/* +Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737) +*/ + +:-moz-ui-invalid { + box-shadow: none; +} + +/* +Add the correct vertical alignment in Chrome and Firefox. +*/ + +progress { + vertical-align: baseline; +} + +/* +Correct the cursor style of increment and decrement buttons in Safari. +*/ + +::-webkit-inner-spin-button, +::-webkit-outer-spin-button { + height: auto; +} + +/* +1. Correct the odd appearance in Chrome and Safari. +2. Correct the outline style in Safari. +*/ + +[type='search'] { + -webkit-appearance: textfield; /* 1 */ + outline-offset: -2px; /* 2 */ +} + +/* +Remove the inner padding in Chrome and Safari on macOS. +*/ + +::-webkit-search-decoration { + -webkit-appearance: none; +} + +/* +1. Correct the inability to style clickable types in iOS and Safari. +2. Change font properties to `inherit` in Safari. +*/ + +::-webkit-file-upload-button { + -webkit-appearance: button; /* 1 */ + font: inherit; /* 2 */ +} + +/* +Add the correct display in Chrome and Safari. +*/ + +summary { + display: list-item; +} + +/* +Removes the default spacing and border for appropriate elements. +*/ + +blockquote, +dl, +dd, +h1, +h2, +h3, +h4, +h5, +h6, +hr, +figure, +p, +pre { + margin: 0; +} + +fieldset { + margin: 0; + padding: 0; +} + +legend { + padding: 0; +} + +ol, +ul, +menu { + list-style: none; + margin: 0; + padding: 0; +} + +/* +Prevent resizing textareas horizontally by default. +*/ + +textarea { + resize: vertical; +} + +/* +1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300) +2. Set the default placeholder color to the user's configured gray 400 color. +*/ + +input::placeholder, +textarea::placeholder { + opacity: 1; /* 1 */ + color: theme('colors.gray.400', #9ca3af); /* 2 */ +} + +/* +Set the default cursor for buttons. +*/ + +button, +[role="button"] { + cursor: pointer; +} + +/* +Make sure disabled buttons don't get the pointer cursor. +*/ +:disabled { + cursor: default; +} + +/* +1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14) +2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210) + This can trigger a poorly considered lint error in some tools but is included by design. +*/ + +img, +svg, +video, +canvas, +audio, +iframe, +embed, +object { + display: block; /* 1 */ + vertical-align: middle; /* 2 */ +} + +/* +Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14) +*/ + +img, +video { + max-width: 100%; + height: auto; +} diff --git a/node_modules/tailwindcss/lib/featureFlags.js b/node_modules/tailwindcss/lib/featureFlags.js new file mode 100644 index 0000000..9e1fa98 --- /dev/null +++ b/node_modules/tailwindcss/lib/featureFlags.js @@ -0,0 +1,61 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.flagEnabled = flagEnabled; +exports.issueFlagNotices = issueFlagNotices; +exports.default = void 0; +var _picocolors = _interopRequireDefault(require("picocolors")); +var _log = _interopRequireDefault(require("./util/log")); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +let defaults = { + optimizeUniversalDefaults: false +}; +let featureFlags = { + future: [ + "hoverOnlyWhenSupported", + "respectDefaultRingColorOpacity" + ], + experimental: [ + "optimizeUniversalDefaults", + "matchVariant" /* , 'variantGrouping' */ + ] +}; +function flagEnabled(config, flag) { + if (featureFlags.future.includes(flag)) { + var ref; + var ref1, ref2; + return config.future === "all" || ((ref2 = (ref1 = config === null || config === void 0 ? void 0 : (ref = config.future) === null || ref === void 0 ? void 0 : ref[flag]) !== null && ref1 !== void 0 ? ref1 : defaults[flag]) !== null && ref2 !== void 0 ? ref2 : false); + } + if (featureFlags.experimental.includes(flag)) { + var ref3; + var ref4, ref5; + return config.experimental === "all" || ((ref5 = (ref4 = config === null || config === void 0 ? void 0 : (ref3 = config.experimental) === null || ref3 === void 0 ? void 0 : ref3[flag]) !== null && ref4 !== void 0 ? ref4 : defaults[flag]) !== null && ref5 !== void 0 ? ref5 : false); + } + return false; +} +function experimentalFlagsEnabled(config) { + if (config.experimental === "all") { + return featureFlags.experimental; + } + var ref; + return Object.keys((ref = config === null || config === void 0 ? void 0 : config.experimental) !== null && ref !== void 0 ? ref : {}).filter((flag)=>featureFlags.experimental.includes(flag) && config.experimental[flag]); +} +function issueFlagNotices(config) { + if (process.env.JEST_WORKER_ID !== undefined) { + return; + } + if (experimentalFlagsEnabled(config).length > 0) { + let changes = experimentalFlagsEnabled(config).map((s)=>_picocolors.default.yellow(s)).join(", "); + _log.default.warn("experimental-flags-enabled", [ + `You have enabled experimental features: ${changes}`, + "Experimental features in Tailwind CSS are not covered by semver, may introduce breaking changes, and can change at any time.", + ]); + } +} +var _default = featureFlags; +exports.default = _default; diff --git a/node_modules/tailwindcss/lib/index.js b/node_modules/tailwindcss/lib/index.js new file mode 100644 index 0000000..12e67ba --- /dev/null +++ b/node_modules/tailwindcss/lib/index.js @@ -0,0 +1,40 @@ +"use strict"; +var _setupTrackingContext = _interopRequireDefault(require("./lib/setupTrackingContext")); +var _processTailwindFeatures = _interopRequireDefault(require("./processTailwindFeatures")); +var _sharedState = require("./lib/sharedState"); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +module.exports = function tailwindcss(configOrPath) { + return { + postcssPlugin: "tailwindcss", + plugins: [ + _sharedState.env.DEBUG && function(root) { + console.log("\n"); + console.time("JIT TOTAL"); + return root; + }, + function(root, result) { + let context = (0, _setupTrackingContext).default(configOrPath); + if (root.type === "document") { + let roots = root.nodes.filter((node)=>node.type === "root"); + for (const root1 of roots){ + if (root1.type === "root") { + (0, _processTailwindFeatures).default(context)(root1, result); + } + } + return; + } + (0, _processTailwindFeatures).default(context)(root, result); + }, + _sharedState.env.DEBUG && function(root) { + console.timeEnd("JIT TOTAL"); + console.log("\n"); + return root; + }, + ].filter(Boolean) + }; +}; +module.exports.postcss = true; diff --git a/node_modules/tailwindcss/lib/lib/cacheInvalidation.js b/node_modules/tailwindcss/lib/lib/cacheInvalidation.js new file mode 100644 index 0000000..5244a59 --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/cacheInvalidation.js @@ -0,0 +1,87 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.hasContentChanged = hasContentChanged; +var _crypto = _interopRequireDefault(require("crypto")); +var sharedState = _interopRequireWildcard(require("./sharedState")); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +function _getRequireWildcardCache() { + if (typeof WeakMap !== "function") return null; + var cache = new WeakMap(); + _getRequireWildcardCache = function() { + return cache; + }; + return cache; +} +function _interopRequireWildcard(obj) { + if (obj && obj.__esModule) { + return obj; + } + if (obj === null || typeof obj !== "object" && typeof obj !== "function") { + return { + default: obj + }; + } + var cache = _getRequireWildcardCache(); + if (cache && cache.has(obj)) { + return cache.get(obj); + } + var newObj = {}; + var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; + for(var key in obj){ + if (Object.prototype.hasOwnProperty.call(obj, key)) { + var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; + if (desc && (desc.get || desc.set)) { + Object.defineProperty(newObj, key, desc); + } else { + newObj[key] = obj[key]; + } + } + } + newObj.default = obj; + if (cache) { + cache.set(obj, newObj); + } + return newObj; +} +/** + * Calculate the hash of a string. + * + * This doesn't need to be cryptographically secure or + * anything like that since it's used only to detect + * when the CSS changes to invalidate the context. + * + * This is wrapped in a try/catch because it's really dependent + * on how Node itself is build and the environment and OpenSSL + * version / build that is installed on the user's machine. + * + * Based on the environment this can just outright fail. + * + * See https://github.com/nodejs/node/issues/40455 + * + * @param {string} str + */ function getHash(str) { + try { + return _crypto.default.createHash("md5").update(str, "utf-8").digest("binary"); + } catch (err) { + return ""; + } +} +function hasContentChanged(sourcePath, root) { + let css = root.toString(); + // We only care about files with @tailwind directives + // Other files use an existing context + if (!css.includes("@tailwind")) { + return false; + } + let existingHash = sharedState.sourceHashMap.get(sourcePath); + let rootHash = getHash(css); + let didChange = existingHash !== rootHash; + sharedState.sourceHashMap.set(sourcePath, rootHash); + return didChange; +} diff --git a/node_modules/tailwindcss/lib/lib/collapseAdjacentRules.js b/node_modules/tailwindcss/lib/lib/collapseAdjacentRules.js new file mode 100644 index 0000000..af2ab2d --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/collapseAdjacentRules.js @@ -0,0 +1,56 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = collapseAdjacentRules; +function collapseAdjacentRules() { + function collapseRulesIn(root) { + let currentRule = null; + root.each((node)=>{ + if (!types.has(node.type)) { + currentRule = null; + return; + } + if (currentRule === null) { + currentRule = node; + return; + } + let properties = comparisonMap[node.type]; + var _property, _property1; + if (node.type === "atrule" && node.name === "font-face") { + currentRule = node; + } else if (properties.every((property)=>((_property = node[property]) !== null && _property !== void 0 ? _property : "").replace(/\s+/g, " ") === ((_property1 = currentRule[property]) !== null && _property1 !== void 0 ? _property1 : "").replace(/\s+/g, " "))) { + // An AtRule may not have children (for example if we encounter duplicate @import url(…) rules) + if (node.nodes) { + currentRule.append(node.nodes); + } + node.remove(); + } else { + currentRule = node; + } + }); + // After we've collapsed adjacent rules & at-rules, we need to collapse + // adjacent rules & at-rules that are children of at-rules. + // We do not care about nesting rules because Tailwind CSS + // explicitly does not handle rule nesting on its own as + // the user is expected to use a nesting plugin + root.each((node)=>{ + if (node.type === "atrule") { + collapseRulesIn(node); + } + }); + } + return (root)=>{ + collapseRulesIn(root); + }; +} +let comparisonMap = { + atrule: [ + "name", + "params" + ], + rule: [ + "selector" + ] +}; +let types = new Set(Object.keys(comparisonMap)); diff --git a/node_modules/tailwindcss/lib/lib/collapseDuplicateDeclarations.js b/node_modules/tailwindcss/lib/lib/collapseDuplicateDeclarations.js new file mode 100644 index 0000000..e21f660 --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/collapseDuplicateDeclarations.js @@ -0,0 +1,80 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = collapseDuplicateDeclarations; +function collapseDuplicateDeclarations() { + return (root)=>{ + root.walkRules((node)=>{ + let seen = new Map(); + let droppable = new Set([]); + let byProperty = new Map(); + node.walkDecls((decl)=>{ + // This could happen if we have nested selectors. In that case the + // parent will loop over all its declarations but also the declarations + // of nested rules. With this we ensure that we are shallowly checking + // declarations. + if (decl.parent !== node) { + return; + } + if (seen.has(decl.prop)) { + // Exact same value as what we have seen so far + if (seen.get(decl.prop).value === decl.value) { + // Keep the last one, drop the one we've seen so far + droppable.add(seen.get(decl.prop)); + // Override the existing one with the new value. This is necessary + // so that if we happen to have more than one declaration with the + // same value, that we keep removing the previous one. Otherwise we + // will only remove the *first* one. + seen.set(decl.prop, decl); + return; + } + // Not the same value, so we need to check if we can merge it so + // let's collect it first. + if (!byProperty.has(decl.prop)) { + byProperty.set(decl.prop, new Set()); + } + byProperty.get(decl.prop).add(seen.get(decl.prop)); + byProperty.get(decl.prop).add(decl); + } + seen.set(decl.prop, decl); + }); + // Drop all the duplicate declarations with the exact same value we've + // already seen so far. + for (let decl1 of droppable){ + decl1.remove(); + } + // Analyze the declarations based on its unit, drop all the declarations + // with the same unit but the last one in the list. + for (let declarations of byProperty.values()){ + let byUnit = new Map(); + for (let decl of declarations){ + let unit = resolveUnit(decl.value); + if (unit === null) { + continue; + } + if (!byUnit.has(unit)) { + byUnit.set(unit, new Set()); + } + byUnit.get(unit).add(decl); + } + for (let declarations1 of byUnit.values()){ + // Get all but the last one + let removableDeclarations = Array.from(declarations1).slice(0, -1); + for (let decl of removableDeclarations){ + decl.remove(); + } + } + } + }); + }; +} +let UNITLESS_NUMBER = Symbol("unitless-number"); +function resolveUnit(input) { + let result = /^-?\d*.?\d+([\w%]+)?$/g.exec(input); + if (result) { + var ref; + return (ref = result[1]) !== null && ref !== void 0 ? ref : UNITLESS_NUMBER; + } + return null; +} diff --git a/node_modules/tailwindcss/lib/lib/defaultExtractor.js b/node_modules/tailwindcss/lib/lib/defaultExtractor.js new file mode 100644 index 0000000..ce2d68b --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/defaultExtractor.js @@ -0,0 +1,223 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.defaultExtractor = defaultExtractor; +var _featureFlagsJs = require("../featureFlags.js"); +var regex = _interopRequireWildcard(require("./regex")); +function _getRequireWildcardCache() { + if (typeof WeakMap !== "function") return null; + var cache = new WeakMap(); + _getRequireWildcardCache = function() { + return cache; + }; + return cache; +} +function _interopRequireWildcard(obj) { + if (obj && obj.__esModule) { + return obj; + } + if (obj === null || typeof obj !== "object" && typeof obj !== "function") { + return { + default: obj + }; + } + var cache = _getRequireWildcardCache(); + if (cache && cache.has(obj)) { + return cache.get(obj); + } + var newObj = {}; + var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; + for(var key in obj){ + if (Object.prototype.hasOwnProperty.call(obj, key)) { + var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; + if (desc && (desc.get || desc.set)) { + Object.defineProperty(newObj, key, desc); + } else { + newObj[key] = obj[key]; + } + } + } + newObj.default = obj; + if (cache) { + cache.set(obj, newObj); + } + return newObj; +} +function defaultExtractor(context) { + let patterns = Array.from(buildRegExps(context)); + /** + * @param {string} content + */ return (content)=>{ + /** @type {(string|string)[]} */ let results = []; + for (let pattern of patterns){ + var ref; + results = [ + ...results, + ...(ref = content.match(pattern)) !== null && ref !== void 0 ? ref : [] + ]; + } + return results.filter((v)=>v !== undefined).map(clipAtBalancedParens); + }; +} +function* buildRegExps(context) { + let separator = context.tailwindConfig.separator; + let variantGroupingEnabled = (0, _featureFlagsJs).flagEnabled(context.tailwindConfig, "variantGrouping"); + let utility = regex.any([ + // Arbitrary properties + /\[[^\s:'"`]+:[^\s\]]+\]/, + // Utilities + regex.pattern([ + // Utility Name / Group Name + /-?(?:\w+)/, + // Normal/Arbitrary values + regex.optional(regex.any([ + regex.pattern([ + // Arbitrary values + /-(?:\w+-)*\[[^\s:]+\]/, + // Not immediately followed by an `{[(` + /(?![{([]])/, + // optionally followed by an opacity modifier + /(?:\/[^\s'"`\\><$]*)?/, + ]), + regex.pattern([ + // Arbitrary values + /-(?:\w+-)*\[[^\s]+\]/, + // Not immediately followed by an `{[(` + /(?![{([]])/, + // optionally followed by an opacity modifier + /(?:\/[^\s'"`\\$]*)?/, + ]), + // Normal values w/o quotes — may include an opacity modifier + /[-\/][^\s'"`\\$={><]*/, + ])), + ]), + ]); + let variantPatterns = [ + // Without quotes + regex.any([ + regex.pattern([ + /([^\s"'`\[\\]+-)?\[[^\s"'`]+\]/, + separator + ]), + regex.pattern([ + /[^\s"'`\[\\]+/, + separator + ]), + ]), + // With quotes allowed + regex.any([ + regex.pattern([ + /([^\s"'`\[\\]+-)?\[[^\s`]+\]/, + separator + ]), + regex.pattern([ + /[^\s`\[\\]+/, + separator + ]), + ]), + ]; + for (const variantPattern of variantPatterns){ + yield regex.pattern([ + // Variants + "((?=((", + variantPattern, + ")+))\\2)?", + // Important (optional) + /!?/, + variantGroupingEnabled ? regex.any([ + // Or any of those things but grouped separated by commas + regex.pattern([ + /\(/, + utility, + regex.zeroOrMore([ + /,/, + utility + ]), + /\)/ + ]), + // Arbitrary properties, constrained utilities, arbitrary values, etc… + utility, + ]) : utility, + ]); + } + // 5. Inner matches + yield /[^<>"'`\s.(){}[\]#=%$]*[^<>"'`\s.(){}[\]#=%:$]/g; +} +// We want to capture any "special" characters +// AND the characters immediately following them (if there is one) +let SPECIALS = /([\[\]'"`])([^\[\]'"`])?/g; +let ALLOWED_CLASS_CHARACTERS = /[^"'`\s<>\]]+/; +/** + * Clips a string ensuring that parentheses, quotes, etc… are balanced + * Used for arbitrary values only + * + * We will go past the end of the balanced parens until we find a non-class character + * + * Depth matching behavior: + * w-[calc(100%-theme('spacing[some_key][1.5]'))]'] + * ┬ ┬ ┬┬ ┬ ┬┬ ┬┬┬┬┬┬┬ + * 1 2 3 4 34 3 210 END + * ╰────┴──────────┴────────┴────────┴┴───┴─┴┴┴ + * + * @param {string} input + */ function clipAtBalancedParens(input) { + // We are care about this for arbitrary values + if (!input.includes("-[")) { + return input; + } + let depth = 0; + let openStringTypes = []; + // Find all parens, brackets, quotes, etc + // Stop when we end at a balanced pair + // This is naive and will treat mismatched parens as balanced + // This shouldn't be a problem in practice though + let matches = input.matchAll(SPECIALS); + // We can't use lookbehind assertions because we have to support Safari + // So, instead, we've emulated it using capture groups and we'll re-work the matches to accommodate + matches = Array.from(matches).flatMap((match)=>{ + const [, ...groups] = match; + return groups.map((group, idx)=>Object.assign([], match, { + index: match.index + idx, + 0: group + })); + }); + for (let match1 of matches){ + let char = match1[0]; + let inStringType = openStringTypes[openStringTypes.length - 1]; + if (char === inStringType) { + openStringTypes.pop(); + } else if (char === "'" || char === '"' || char === "`") { + openStringTypes.push(char); + } + if (inStringType) { + continue; + } else if (char === "[") { + depth++; + continue; + } else if (char === "]") { + depth--; + continue; + } + // We've gone one character past the point where we should stop + // This means that there was an extra closing `]` + // We'll clip to just before it + if (depth < 0) { + return input.substring(0, match1.index); + } + // We've finished balancing the brackets but there still may be characters that can be included + // For example in the class `text-[#336699]/[.35]` + // The depth goes to `0` at the closing `]` but goes up again at the `[` + // If we're at zero and encounter a non-class character then we clip the class there + if (depth === 0 && !ALLOWED_CLASS_CHARACTERS.test(char)) { + return input.substring(0, match1.index); + } + } + return input; +} // Regular utilities + // {{modifier}:}*{namespace}{-{suffix}}*{/{opacityModifier}}? + // Arbitrary values + // {{modifier}:}*{namespace}-[{arbitraryValue}]{/{opacityModifier}}? + // arbitraryValue: no whitespace, balanced quotes unless within quotes, balanced brackets unless within quotes + // Arbitrary properties + // {{modifier}:}*[{validCssPropertyName}:{arbitraryValue}] diff --git a/node_modules/tailwindcss/lib/lib/detectNesting.js b/node_modules/tailwindcss/lib/lib/detectNesting.js new file mode 100644 index 0000000..0602b08 --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/detectNesting.js @@ -0,0 +1,34 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _default; +function _default(_context) { + return (root, result)=>{ + let found = false; + root.walkAtRules("tailwind", (node)=>{ + if (found) return false; + if (node.parent && node.parent.type !== "root") { + found = true; + node.warn(result, [ + "Nested @tailwind rules were detected, but are not supported.", + "Consider using a prefix to scope Tailwind's classes: https://tailwindcss.com/docs/configuration#prefix", + "Alternatively, use the important selector strategy: https://tailwindcss.com/docs/configuration#selector-strategy", + ].join("\n")); + return false; + } + }); + root.walkRules((rule)=>{ + if (found) return false; + rule.walkRules((nestedRule)=>{ + found = true; + nestedRule.warn(result, [ + "Nested CSS was detected, but CSS nesting has not been configured correctly.", + "Please enable a CSS nesting plugin *before* Tailwind in your configuration.", + "See how here: https://tailwindcss.com/docs/using-with-preprocessors#nesting", + ].join("\n")); + return false; + }); + }); + }; +} diff --git a/node_modules/tailwindcss/lib/lib/evaluateTailwindFunctions.js b/node_modules/tailwindcss/lib/lib/evaluateTailwindFunctions.js new file mode 100644 index 0000000..86d80d7 --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/evaluateTailwindFunctions.js @@ -0,0 +1,187 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = _default; +var _dlv = _interopRequireDefault(require("dlv")); +var _didyoumean = _interopRequireDefault(require("didyoumean")); +var _transformThemeValue = _interopRequireDefault(require("../util/transformThemeValue")); +var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser")); +var _normalizeScreens = require("../util/normalizeScreens"); +var _buildMediaQuery = _interopRequireDefault(require("../util/buildMediaQuery")); +var _toPath = require("../util/toPath"); +var _withAlphaVariable = require("../util/withAlphaVariable"); +var _pluginUtils = require("../util/pluginUtils"); +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +function isObject(input) { + return typeof input === "object" && input !== null; +} +function findClosestExistingPath(theme, path) { + let parts = (0, _toPath).toPath(path); + do { + parts.pop(); + if ((0, _dlv).default(theme, parts) !== undefined) break; + }while (parts.length); + return parts.length ? parts : undefined; +} +function pathToString(path) { + if (typeof path === "string") return path; + return path.reduce((acc, cur, i)=>{ + if (cur.includes(".")) return `${acc}[${cur}]`; + return i === 0 ? cur : `${acc}.${cur}`; + }, ""); +} +function list(items) { + return items.map((key)=>`'${key}'`).join(", "); +} +function listKeys(obj) { + return list(Object.keys(obj)); +} +function validatePath(config, path, defaultValue, themeOpts = {}) { + const pathString = Array.isArray(path) ? pathToString(path) : path.replace(/^['"]+|['"]+$/g, ""); + const pathSegments = Array.isArray(path) ? path : (0, _toPath).toPath(pathString); + const value = (0, _dlv).default(config.theme, pathSegments, defaultValue); + if (value === undefined) { + let error = `'${pathString}' does not exist in your theme config.`; + const parentSegments = pathSegments.slice(0, -1); + const parentValue = (0, _dlv).default(config.theme, parentSegments); + if (isObject(parentValue)) { + const validKeys = Object.keys(parentValue).filter((key)=>validatePath(config, [ + ...parentSegments, + key + ]).isValid); + const suggestion = (0, _didyoumean).default(pathSegments[pathSegments.length - 1], validKeys); + if (suggestion) { + error += ` Did you mean '${pathToString([ + ...parentSegments, + suggestion + ])}'?`; + } else if (validKeys.length > 0) { + error += ` '${pathToString(parentSegments)}' has the following valid keys: ${list(validKeys)}`; + } + } else { + const closestPath = findClosestExistingPath(config.theme, pathString); + if (closestPath) { + const closestValue = (0, _dlv).default(config.theme, closestPath); + if (isObject(closestValue)) { + error += ` '${pathToString(closestPath)}' has the following keys: ${listKeys(closestValue)}`; + } else { + error += ` '${pathToString(closestPath)}' is not an object.`; + } + } else { + error += ` Your theme has the following top-level keys: ${listKeys(config.theme)}`; + } + } + return { + isValid: false, + error + }; + } + if (!(typeof value === "string" || typeof value === "number" || typeof value === "function" || value instanceof String || value instanceof Number || Array.isArray(value))) { + let error = `'${pathString}' was found but does not resolve to a string.`; + if (isObject(value)) { + let validKeys = Object.keys(value).filter((key)=>validatePath(config, [ + ...pathSegments, + key + ]).isValid); + if (validKeys.length) { + error += ` Did you mean something like '${pathToString([ + ...pathSegments, + validKeys[0] + ])}'?`; + } + } + return { + isValid: false, + error + }; + } + const [themeSection] = pathSegments; + return { + isValid: true, + value: (0, _transformThemeValue).default(themeSection)(value, themeOpts) + }; +} +function extractArgs(node, vNodes, functions) { + vNodes = vNodes.map((vNode)=>resolveVNode(node, vNode, functions)); + let args = [ + "" + ]; + for (let vNode1 of vNodes){ + if (vNode1.type === "div" && vNode1.value === ",") { + args.push(""); + } else { + args[args.length - 1] += _postcssValueParser.default.stringify(vNode1); + } + } + return args; +} +function resolveVNode(node, vNode, functions) { + if (vNode.type === "function" && functions[vNode.value] !== undefined) { + let args = extractArgs(node, vNode.nodes, functions); + vNode.type = "word"; + vNode.value = functions[vNode.value](node, ...args); + } + return vNode; +} +function resolveFunctions(node, input, functions) { + return (0, _postcssValueParser).default(input).walk((vNode)=>{ + resolveVNode(node, vNode, functions); + }).toString(); +} +let nodeTypePropertyMap = { + atrule: "params", + decl: "value" +}; +function _default({ tailwindConfig: config }) { + let functions = { + theme: (node, path, ...defaultValue)=>{ + // Strip quotes from beginning and end of string + // This allows the alpha value to be present inside of quotes + path = path.replace(/^['"]+|['"]+$/g, ""); + let matches = path.match(/^([^\s]+)(?![^\[]*\])(?:\s*\/\s*([^\/\s]+))$/); + let alpha = undefined; + if (matches) { + path = matches[1]; + alpha = matches[2]; + } + let { isValid , value , error } = validatePath(config, path, defaultValue.length ? defaultValue : undefined, { + opacityValue: alpha + }); + if (!isValid) { + throw node.error(error); + } + let maybeColor = (0, _pluginUtils).parseColorFormat(value); + let isColorFunction = maybeColor !== undefined && typeof maybeColor === "function"; + if (alpha !== undefined || isColorFunction) { + if (alpha === undefined) { + alpha = 1.0; + } + value = (0, _withAlphaVariable).withAlphaValue(maybeColor, alpha, maybeColor); + } + return value; + }, + screen: (node, screen)=>{ + screen = screen.replace(/^['"]+/g, "").replace(/['"]+$/g, ""); + let screens = (0, _normalizeScreens).normalizeScreens(config.theme.screens); + let screenDefinition = screens.find(({ name })=>name === screen); + if (!screenDefinition) { + throw node.error(`The '${screen}' screen does not exist in your theme.`); + } + return (0, _buildMediaQuery).default(screenDefinition); + } + }; + return (root)=>{ + root.walk((node)=>{ + let property = nodeTypePropertyMap[node.type]; + if (property === undefined) { + return; + } + node[property] = resolveFunctions(node, node[property], functions); + }); + }; +} diff --git a/node_modules/tailwindcss/lib/lib/expandApplyAtRules.js b/node_modules/tailwindcss/lib/lib/expandApplyAtRules.js new file mode 100644 index 0000000..6f6df8b --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/expandApplyAtRules.js @@ -0,0 +1,470 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = expandApplyAtRules; +var _postcss = _interopRequireDefault(require("postcss")); +var _postcssSelectorParser = _interopRequireDefault(require("postcss-selector-parser")); +var _generateRules = require("./generateRules"); +var _bigSign = _interopRequireDefault(require("../util/bigSign")); +var _escapeClassName = _interopRequireDefault(require("../util/escapeClassName")); +function expandApplyAtRules(context) { + return (root)=>{ + // Build a cache of the user's CSS so we can use it to resolve classes used by @apply + let localCache = lazyCache(()=>buildLocalApplyCache(root, context)); + processApply(root, context, localCache); + }; +} +function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { + default: obj + }; +} +/** @typedef {Map} ApplyCache */ function extractClasses(node) { + /** @type {Map>} */ let groups = new Map(); + let container = _postcss.default.root({ + nodes: [ + node.clone() + ] + }); + container.walkRules((rule)=>{ + (0, _postcssSelectorParser).default((selectors)=>{ + selectors.walkClasses((classSelector)=>{ + let parentSelector = classSelector.parent.toString(); + let classes = groups.get(parentSelector); + if (!classes) { + groups.set(parentSelector, classes = new Set()); + } + classes.add(classSelector.value); + }); + }).processSync(rule.selector); + }); + let normalizedGroups = Array.from(groups.values(), (classes)=>Array.from(classes)); + let classes1 = normalizedGroups.flat(); + return Object.assign(classes1, { + groups: normalizedGroups + }); +} +let selectorExtractor = (0, _postcssSelectorParser).default((root)=>root.nodes.map((node)=>node.toString())); +/** + * @param {string} ruleSelectors + */ function extractSelectors(ruleSelectors) { + return selectorExtractor.transformSync(ruleSelectors); +} +function extractBaseCandidates(candidates, separator) { + let baseClasses = new Set(); + for (let candidate of candidates){ + baseClasses.add(candidate.split(separator).pop()); + } + return Array.from(baseClasses); +} +function prefix(context, selector) { + let prefix1 = context.tailwindConfig.prefix; + return typeof prefix1 === "function" ? prefix1(selector) : prefix1 + selector; +} +function* pathToRoot(node) { + yield node; + while(node.parent){ + yield node.parent; + node = node.parent; + } +} +/** + * Only clone the node itself and not its children + * + * @param {*} node + * @param {*} overrides + * @returns + */ function shallowClone(node, overrides = {}) { + let children = node.nodes; + node.nodes = []; + let tmp = node.clone(overrides); + node.nodes = children; + return tmp; +} +/** + * Clone just the nodes all the way to the top that are required to represent + * this singular rule in the tree. + * + * For example, if we have CSS like this: + * ```css + * @media (min-width: 768px) { + * @supports (display: grid) { + * .foo { + * display: grid; + * grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); + * } + * } + * + * @supports (backdrop-filter: blur(1px)) { + * .bar { + * backdrop-filter: blur(1px); + * } + * } + * + * .baz { + * color: orange; + * } + * } + * ``` + * + * And we're cloning `.bar` it'll return a cloned version of what's required for just that single node: + * + * ```css + * @media (min-width: 768px) { + * @supports (backdrop-filter: blur(1px)) { + * .bar { + * backdrop-filter: blur(1px); + * } + * } + * } + * ``` + * + * @param {import('postcss').Node} node + */ function nestedClone(node) { + for (let parent of pathToRoot(node)){ + if (node === parent) { + continue; + } + if (parent.type === "root") { + break; + } + node = shallowClone(parent, { + nodes: [ + node + ] + }); + } + return node; +} +/** + * @param {import('postcss').Root} root + */ function buildLocalApplyCache(root, context) { + /** @type {ApplyCache} */ let cache = new Map(); + let highestOffset = context.layerOrder.user >> 4n; + root.walkRules((rule, idx)=>{ + // Ignore rules generated by Tailwind + for (let node of pathToRoot(rule)){ + var ref; + if (((ref = node.raws.tailwind) === null || ref === void 0 ? void 0 : ref.layer) !== undefined) { + return; + } + } + // Clone what's required to represent this singular rule in the tree + let container = nestedClone(rule); + for (let className of extractClasses(rule)){ + let list = cache.get(className) || []; + cache.set(className, list); + list.push([ + { + layer: "user", + sort: BigInt(idx) + highestOffset, + important: false + }, + container, + ]); + } + }); + return cache; +} +/** + * @returns {ApplyCache} + */ function buildApplyCache(applyCandidates, context) { + for (let candidate of applyCandidates){ + if (context.notClassCache.has(candidate) || context.applyClassCache.has(candidate)) { + continue; + } + if (context.classCache.has(candidate)) { + context.applyClassCache.set(candidate, context.classCache.get(candidate).map(([meta, rule])=>[ + meta, + rule.clone() + ])); + continue; + } + let matches = Array.from((0, _generateRules).resolveMatches(candidate, context)); + if (matches.length === 0) { + context.notClassCache.add(candidate); + continue; + } + context.applyClassCache.set(candidate, matches); + } + return context.applyClassCache; +} +/** + * Build a cache only when it's first used + * + * @param {() => ApplyCache} buildCacheFn + * @returns {ApplyCache} + */ function lazyCache(buildCacheFn) { + let cache = null; + return { + get: (name)=>{ + cache = cache || buildCacheFn(); + return cache.get(name); + }, + has: (name)=>{ + cache = cache || buildCacheFn(); + return cache.has(name); + } + }; +} +/** + * Take a series of multiple caches and merge + * them so they act like one large cache + * + * @param {ApplyCache[]} caches + * @returns {ApplyCache} + */ function combineCaches(caches) { + return { + get: (name)=>caches.flatMap((cache)=>cache.get(name) || []), + has: (name)=>caches.some((cache)=>cache.has(name)) + }; +} +function extractApplyCandidates(params) { + let candidates = params.split(/[\s\t\n]+/g); + if (candidates[candidates.length - 1] === "!important") { + return [ + candidates.slice(0, -1), + true + ]; + } + return [ + candidates, + false + ]; +} +function processApply(root, context, localCache) { + let applyCandidates = new Set(); + // Collect all @apply rules and candidates + let applies = []; + root.walkAtRules("apply", (rule)=>{ + let [candidates] = extractApplyCandidates(rule.params); + for (let util of candidates){ + applyCandidates.add(util); + } + applies.push(rule); + }); + // Start the @apply process if we have rules with @apply in them + if (applies.length === 0) { + return; + } + // Fill up some caches! + let applyClassCache = combineCaches([ + localCache, + buildApplyCache(applyCandidates, context) + ]); + /** + * When we have an apply like this: + * + * .abc { + * @apply hover:font-bold; + * } + * + * What we essentially will do is resolve to this: + * + * .abc { + * @apply .hover\:font-bold:hover { + * font-weight: 500; + * } + * } + * + * Notice that the to-be-applied class is `.hover\:font-bold:hover` and that the utility candidate was `hover:font-bold`. + * What happens in this function is that we prepend a `.` and escape the candidate. + * This will result in `.hover\:font-bold` + * Which means that we can replace `.hover\:font-bold` with `.abc` in `.hover\:font-bold:hover` resulting in `.abc:hover` + */ // TODO: Should we use postcss-selector-parser for this instead? + function replaceSelector(selector, utilitySelectors, candidate) { + let needle1 = `.${(0, _escapeClassName).default(candidate)}`; + let needles = [ + ...new Set([ + needle1, + needle1.replace(/\\2c /g, "\\,") + ]) + ]; + let utilitySelectorsList = extractSelectors(utilitySelectors); + return extractSelectors(selector).map((s)=>{ + let replaced = []; + for (let utilitySelector of utilitySelectorsList){ + let replacedSelector = utilitySelector; + for (const needle of needles){ + replacedSelector = replacedSelector.replace(needle, s); + } + if (replacedSelector === utilitySelector) { + continue; + } + replaced.push(replacedSelector); + } + return replaced.join(", "); + }).join(", "); + } + let perParentApplies = new Map(); + // Collect all apply candidates and their rules + for (let apply of applies){ + let [candidates] = perParentApplies.get(apply.parent) || [ + [], + apply.source + ]; + perParentApplies.set(apply.parent, [ + candidates, + apply.source + ]); + let [applyCandidates, important] = extractApplyCandidates(apply.params); + if (apply.parent.type === "atrule") { + if (apply.parent.name === "screen") { + const screenType = apply.parent.params; + throw apply.error(`@apply is not supported within nested at-rules like @screen. We suggest you write this as @apply ${applyCandidates.map((c)=>`${screenType}:${c}`).join(" ")} instead.`); + } + throw apply.error(`@apply is not supported within nested at-rules like @${apply.parent.name}. You can fix this by un-nesting @${apply.parent.name}.`); + } + for (let applyCandidate of applyCandidates){ + if ([ + prefix(context, "group"), + prefix(context, "peer") + ].includes(applyCandidate)) { + // TODO: Link to specific documentation page with error code. + throw apply.error(`@apply should not be used with the '${applyCandidate}' utility`); + } + if (!applyClassCache.has(applyCandidate)) { + throw apply.error(`The \`${applyCandidate}\` class does not exist. If \`${applyCandidate}\` is a custom class, make sure it is defined within a \`@layer\` directive.`); + } + let rules = applyClassCache.get(applyCandidate); + candidates.push([ + applyCandidate, + important, + rules + ]); + } + } + for (const [parent, [candidates1, atApplySource]] of perParentApplies){ + let siblings = []; + for (let [applyCandidate, important, rules] of candidates1){ + let potentialApplyCandidates = [ + applyCandidate, + ...extractBaseCandidates([ + applyCandidate + ], context.tailwindConfig.separator), + ]; + for (let [meta, node1] of rules){ + let parentClasses = extractClasses(parent); + let nodeClasses = extractClasses(node1); + // When we encounter a rule like `.dark .a, .b { … }` we only want to be left with `[.dark, .a]` if the base applyCandidate is `.a` or with `[.b]` if the base applyCandidate is `.b` + // So we've split them into groups + nodeClasses = nodeClasses.groups.filter((classList)=>classList.some((className)=>potentialApplyCandidates.includes(className))).flat(); + // Add base utility classes from the @apply node to the list of + // classes to check whether it intersects and therefore results in a + // circular dependency or not. + // + // E.g.: + // .foo { + // @apply hover:a; // This applies "a" but with a modifier + // } + // + // We only have to do that with base classes of the `node`, not of the `parent` + // E.g.: + // .hover\:foo { + // @apply bar; + // } + // .bar { + // @apply foo; + // } + // + // This should not result in a circular dependency because we are + // just applying `.foo` and the rule above is `.hover\:foo` which is + // unrelated. However, if we were to apply `hover:foo` then we _did_ + // have to include this one. + nodeClasses = nodeClasses.concat(extractBaseCandidates(nodeClasses, context.tailwindConfig.separator)); + let intersects = parentClasses.some((selector)=>nodeClasses.includes(selector)); + if (intersects) { + throw node1.error(`You cannot \`@apply\` the \`${applyCandidate}\` utility here because it creates a circular dependency.`); + } + let root = _postcss.default.root({ + nodes: [ + node1.clone() + ] + }); + // Make sure every node in the entire tree points back at the @apply rule that generated it + root.walk((node)=>{ + node.source = atApplySource; + }); + let canRewriteSelector = node1.type !== "atrule" || node1.type === "atrule" && node1.name !== "keyframes"; + if (canRewriteSelector) { + root.walkRules((rule)=>{ + // Let's imagine you have the following structure: + // + // .foo { + // @apply bar; + // } + // + // @supports (a: b) { + // .bar { + // color: blue + // } + // + // .something-unrelated {} + // } + // + // In this case we want to apply `.bar` but it happens to be in + // an atrule node. We clone that node instead of the nested one + // because we still want that @supports rule to be there once we + // applied everything. + // + // However it happens to be that the `.something-unrelated` is + // also in that same shared @supports atrule. This is not good, + // and this should not be there. The good part is that this is + // a clone already and it can be safely removed. The question is + // how do we know we can remove it. Basically what we can do is + // match it against the applyCandidate that you want to apply. If + // it doesn't match the we can safely delete it. + // + // If we didn't do this, then the `replaceSelector` function + // would have replaced this with something that didn't exist and + // therefore it removed the selector altogether. In this specific + // case it would result in `{}` instead of `.something-unrelated {}` + if (!extractClasses(rule).some((candidate)=>candidate === applyCandidate)) { + rule.remove(); + return; + } + // Strip the important selector from the parent selector if at the beginning + let importantSelector = typeof context.tailwindConfig.important === "string" ? context.tailwindConfig.important : null; + // We only want to move the "important" selector if this is a Tailwind-generated utility + // We do *not* want to do this for user CSS that happens to be structured the same + let isGenerated = parent.raws.tailwind !== undefined; + let parentSelector = isGenerated && importantSelector && parent.selector.indexOf(importantSelector) === 0 ? parent.selector.slice(importantSelector.length) : parent.selector; + rule.selector = replaceSelector(parentSelector, rule.selector, applyCandidate); + // And then re-add it if it was removed + if (importantSelector && parentSelector !== parent.selector) { + rule.selector = `${importantSelector} ${rule.selector}`; + } + rule.walkDecls((d)=>{ + d.important = meta.important || important; + }); + }); + } + // Insert it + siblings.push([ + // Ensure that when we are sorting, that we take the layer order into account + { + ...meta, + sort: meta.sort | context.layerOrder[meta.layer] + }, + root.nodes[0], + ]); + } + } + // Inject the rules, sorted, correctly + let nodes = siblings.sort(([a], [z])=>(0, _bigSign).default(a.sort - z.sort)).map((s)=>s[1]); + // `parent` refers to the node at `.abc` in: .abc { @apply mt-2 } + parent.after(nodes); + } + for (let apply1 of applies){ + // If there are left-over declarations, just remove the @apply + if (apply1.parent.nodes.length > 1) { + apply1.remove(); + } else { + // The node is empty, drop the full node + apply1.parent.remove(); + } + } + // Do it again, in case we have other `@apply` rules + processApply(root, context, localCache); +} diff --git a/node_modules/tailwindcss/lib/lib/expandTailwindAtRules.js b/node_modules/tailwindcss/lib/lib/expandTailwindAtRules.js new file mode 100644 index 0000000..fcf1077 --- /dev/null +++ b/node_modules/tailwindcss/lib/lib/expandTailwindAtRules.js @@ -0,0 +1,276 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.default = expandTailwindAtRules; +var _quickLru = _interopRequireDefault(require("quick-lru")); +var sharedState = _interopRequireWildcard(require("./sharedState")); +var _generateRules = require("./generateRules"); +var _bigSign = _interopRequireDefault(require("../util/bigSign")); +var _log = _interopRequireDefault(require("../util/log")); +var _cloneNodes = _interopRequireDefault(require("../util/cloneNodes")); +var _defaultExtractor = require("./defaultExtractor"); +function expandTailwindAtRules(context) { + return (root)=>{ + let layerNodes = { + base: null, + components: null, + utilities: null, + variants: null + }; + root.walkAtRules((rule)=>{ + // Make sure this file contains Tailwind directives. If not, we can save + // a lot of work and bail early. Also we don't have to register our touch + // file as a dependency since the output of this CSS does not depend on + // the source of any templates. Think Vue

      #UtC0~bm^t7aUy<8kdeGtbzHckjV^3JI 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

    ^F|q`pz8bT3gyc6wNdtQUfjQ7m1FvN=Y)XcN516 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 z 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 literal 0 HcmV?d00001 diff --git a/images/experiences.png b/images/experiences.png new file mode 100644 index 0000000000000000000000000000000000000000..36ad304ac747826c0d0c01e2529b9475060e0efc GIT binary patch literal 97780 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

  • 9{LvHqTMoF+iI-g`HYD00dB})8}#f!YMYXH$PYW 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