@makeswift/runtime 0.0.22 → 0.1.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Box.cjs.js +502 -0
- package/dist/Box.cjs.js.map +1 -0
- package/dist/Box.es.js +496 -0
- package/dist/Box.es.js.map +1 -0
- package/dist/Button.cjs.js +308 -0
- package/dist/Button.cjs.js.map +1 -0
- package/dist/Button.es.js +301 -0
- package/dist/Button.es.js.map +1 -0
- package/dist/Carousel.cjs.js +487 -0
- package/dist/Carousel.cjs.js.map +1 -0
- package/dist/Carousel.es.js +481 -0
- package/dist/Carousel.es.js.map +1 -0
- package/dist/Countdown.cjs.js +340 -0
- package/dist/Countdown.cjs.js.map +1 -0
- package/dist/Countdown.es.js +334 -0
- package/dist/Countdown.es.js.map +1 -0
- package/dist/Divider.cjs.js +115 -0
- package/dist/Divider.cjs.js.map +1 -0
- package/dist/Divider.es.js +109 -0
- package/dist/Divider.es.js.map +1 -0
- package/dist/Embed.cjs.js +129 -0
- package/dist/Embed.cjs.js.map +1 -0
- package/dist/Embed.es.js +123 -0
- package/dist/Embed.es.js.map +1 -0
- package/dist/Form.cjs.js +1705 -0
- package/dist/Form.cjs.js.map +1 -0
- package/dist/Form.es.js +1677 -0
- package/dist/Form.es.js.map +1 -0
- package/dist/Image.cjs2.js +148 -0
- package/dist/Image.cjs2.js.map +1 -0
- package/dist/Image.es2.js +141 -0
- package/dist/Image.es2.js.map +1 -0
- package/dist/Navigation.cjs.js +736 -0
- package/dist/Navigation.cjs.js.map +1 -0
- package/dist/Navigation.es.js +710 -0
- package/dist/Navigation.es.js.map +1 -0
- package/dist/Root.cjs.js +143 -0
- package/dist/Root.cjs.js.map +1 -0
- package/dist/Root.es.js +137 -0
- package/dist/Root.es.js.map +1 -0
- package/dist/SocialLinks.cjs.js +900 -0
- package/dist/SocialLinks.cjs.js.map +1 -0
- package/dist/SocialLinks.es.js +874 -0
- package/dist/SocialLinks.es.js.map +1 -0
- package/dist/Text.cjs.js +475 -0
- package/dist/Text.cjs.js.map +1 -0
- package/dist/Text.es.js +467 -0
- package/dist/Text.es.js.map +1 -0
- package/dist/Video.cjs.js +121 -0
- package/dist/Video.cjs.js.map +1 -0
- package/dist/Video.es.js +114 -0
- package/dist/Video.es.js.map +1 -0
- package/dist/components.cjs.js +80 -58
- package/dist/components.cjs.js.map +1 -1
- package/dist/components.es.js +41 -18
- package/dist/components.es.js.map +1 -1
- package/dist/cssMediaRules.cjs.js +222 -0
- package/dist/cssMediaRules.cjs.js.map +1 -0
- package/dist/cssMediaRules.es.js +213 -0
- package/dist/cssMediaRules.es.js.map +1 -0
- package/dist/descriptors.es.js +1 -1
- package/dist/index.cjs.js +1410 -7741
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.cjs2.js +522 -0
- package/dist/index.cjs2.js.map +1 -0
- package/dist/index.cjs3.js +141 -0
- package/dist/index.cjs3.js.map +1 -0
- package/dist/index.cjs4.js +18 -0
- package/dist/index.cjs4.js.map +1 -0
- package/dist/index.es.js +1341 -7697
- package/dist/index.es.js.map +1 -1
- package/dist/index.es2.js +514 -0
- package/dist/index.es2.js.map +1 -0
- package/dist/index.es3.js +134 -0
- package/dist/index.es3.js.map +1 -0
- package/dist/index.es4.js +13 -0
- package/dist/index.es4.js.map +1 -0
- package/dist/next.cjs.js +19 -201
- package/dist/next.cjs.js.map +1 -1
- package/dist/next.es.js +12 -192
- package/dist/next.es.js.map +1 -1
- package/dist/placeholders.cjs.js +13 -0
- package/dist/placeholders.cjs.js.map +1 -0
- package/dist/placeholders.es.js +12 -0
- package/dist/placeholders.es.js.map +1 -0
- package/dist/react-builder-preview.cjs.js +23 -33
- package/dist/react-builder-preview.cjs.js.map +1 -1
- package/dist/react-builder-preview.es.js +13 -23
- package/dist/react-builder-preview.es.js.map +1 -1
- package/dist/react-page.es.js +1 -1
- package/dist/react.cjs.js +16 -28
- package/dist/react.cjs.js.map +1 -1
- package/dist/react.es.js +8 -20
- package/dist/react.es.js.map +1 -1
- package/dist/types/components/builtin/Box/Box.d.ts +1 -4
- package/dist/types/components/builtin/Box/Box.d.ts.map +1 -1
- package/dist/types/components/builtin/Box/animations.d.ts +1 -8
- package/dist/types/components/builtin/Box/animations.d.ts.map +1 -1
- package/dist/types/components/builtin/Box/constants.d.ts +9 -0
- package/dist/types/components/builtin/Box/constants.d.ts.map +1 -0
- package/dist/types/components/builtin/Box/contants.d.ts +9 -0
- package/dist/types/components/builtin/Box/contants.d.ts.map +1 -0
- package/dist/types/components/builtin/Box/index.d.ts +2 -2
- package/dist/types/components/builtin/Box/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Box/register.d.ts +3 -0
- package/dist/types/components/builtin/Box/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Button/Button.d.ts +1 -4
- package/dist/types/components/builtin/Button/Button.d.ts.map +1 -1
- package/dist/types/components/builtin/Button/constants.d.ts +2 -0
- package/dist/types/components/builtin/Button/constants.d.ts.map +1 -0
- package/dist/types/components/builtin/Button/contants.d.ts +2 -0
- package/dist/types/components/builtin/Button/contants.d.ts.map +1 -0
- package/dist/types/components/builtin/Button/index.d.ts +1 -1
- package/dist/types/components/builtin/Button/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Button/register.d.ts +3 -0
- package/dist/types/components/builtin/Button/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Carousel/Carousel.d.ts +0 -3
- package/dist/types/components/builtin/Carousel/Carousel.d.ts.map +1 -1
- package/dist/types/components/builtin/Carousel/index.d.ts +1 -1
- package/dist/types/components/builtin/Carousel/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Carousel/register.d.ts +3 -0
- package/dist/types/components/builtin/Carousel/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Countdown/Countdown.d.ts +0 -3
- package/dist/types/components/builtin/Countdown/Countdown.d.ts.map +1 -1
- package/dist/types/components/builtin/Countdown/index.d.ts +1 -1
- package/dist/types/components/builtin/Countdown/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Countdown/register.d.ts +3 -0
- package/dist/types/components/builtin/Countdown/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Divider/Divider.d.ts +0 -3
- package/dist/types/components/builtin/Divider/Divider.d.ts.map +1 -1
- package/dist/types/components/builtin/Divider/index.d.ts +1 -1
- package/dist/types/components/builtin/Divider/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Divider/register.d.ts +3 -0
- package/dist/types/components/builtin/Divider/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Embed/Embed.d.ts +0 -3
- package/dist/types/components/builtin/Embed/Embed.d.ts.map +1 -1
- package/dist/types/components/builtin/Embed/index.d.ts +1 -1
- package/dist/types/components/builtin/Embed/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Embed/register.d.ts +3 -0
- package/dist/types/components/builtin/Embed/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Form/Form.d.ts +1 -10
- package/dist/types/components/builtin/Form/Form.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/constants.d.ts +1 -0
- package/dist/types/components/builtin/Form/constants.d.ts.map +1 -0
- package/dist/types/components/builtin/Form/context/FormContext.d.ts +6 -0
- package/dist/types/components/builtin/Form/context/FormContext.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/index.d.ts +1 -1
- package/dist/types/components/builtin/Form/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/register.d.ts +3 -0
- package/dist/types/components/builtin/Form/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Image/Image.d.ts +0 -3
- package/dist/types/components/builtin/Image/Image.d.ts.map +1 -1
- package/dist/types/components/builtin/Image/index.d.ts +1 -1
- package/dist/types/components/builtin/Image/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Image/register.d.ts +3 -0
- package/dist/types/components/builtin/Image/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Navigation/Navigation.d.ts +0 -3
- package/dist/types/components/builtin/Navigation/Navigation.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/index.d.ts +1 -1
- package/dist/types/components/builtin/Navigation/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/register.d.ts +3 -0
- package/dist/types/components/builtin/Navigation/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Root/Root.d.ts +0 -2
- package/dist/types/components/builtin/Root/Root.d.ts.map +1 -1
- package/dist/types/components/builtin/Root/index.d.ts +1 -1
- package/dist/types/components/builtin/Root/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Root/register.d.ts +3 -0
- package/dist/types/components/builtin/Root/register.d.ts.map +1 -0
- package/dist/types/components/builtin/SocialLinks/SocialLinks.d.ts +0 -3
- package/dist/types/components/builtin/SocialLinks/SocialLinks.d.ts.map +1 -1
- package/dist/types/components/builtin/SocialLinks/index.d.ts +1 -1
- package/dist/types/components/builtin/SocialLinks/index.d.ts.map +1 -1
- package/dist/types/components/builtin/SocialLinks/register.d.ts +3 -0
- package/dist/types/components/builtin/SocialLinks/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Text/Text.d.ts +0 -3
- package/dist/types/components/builtin/Text/Text.d.ts.map +1 -1
- package/dist/types/components/builtin/Text/index.d.ts +1 -1
- package/dist/types/components/builtin/Text/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Text/register.d.ts +3 -0
- package/dist/types/components/builtin/Text/register.d.ts.map +1 -0
- package/dist/types/components/builtin/Video/Video.d.ts +0 -3
- package/dist/types/components/builtin/Video/Video.d.ts.map +1 -1
- package/dist/types/components/builtin/Video/index.d.ts +1 -1
- package/dist/types/components/builtin/Video/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Video/register.d.ts +3 -0
- package/dist/types/components/builtin/Video/register.d.ts.map +1 -0
- package/dist/types/components/builtin/index.d.ts +1 -2
- package/dist/types/components/builtin/index.d.ts.map +1 -1
- package/dist/types/components/builtin/register.d.ts +3 -0
- package/dist/types/components/builtin/register.d.ts.map +1 -0
- package/dist/types/dynamic.d.ts +2 -0
- package/dist/types/dynamic.d.ts.map +1 -0
- package/dist/types/next/plugin.d.ts +3 -0
- package/dist/types/next/plugin.d.ts.map +1 -0
- package/dist/types/next.d.ts +12 -2
- package/dist/types/next.d.ts.map +1 -1
- package/dist/useBackgrounds.cjs.js +124 -0
- package/dist/useBackgrounds.cjs.js.map +1 -0
- package/dist/useBackgrounds.es.js +123 -0
- package/dist/useBackgrounds.es.js.map +1 -0
- package/dist/useBoxShadow.cjs.js +78 -0
- package/dist/useBoxShadow.cjs.js.map +1 -0
- package/dist/useBoxShadow.es.js +77 -0
- package/dist/useBoxShadow.es.js.map +1 -0
- package/dist/useMediaQuery.cjs.js +26 -0
- package/dist/useMediaQuery.cjs.js.map +1 -0
- package/dist/useMediaQuery.es.js +25 -0
- package/dist/useMediaQuery.es.js.map +1 -0
- package/dist/usePage.cjs.js +14 -0
- package/dist/usePage.cjs.js.map +1 -0
- package/dist/usePage.es.js +13 -0
- package/dist/usePage.es.js.map +1 -0
- package/dist/useTable.cjs.js +10 -0
- package/dist/useTable.cjs.js.map +1 -0
- package/dist/useTable.es.js +9 -0
- package/dist/useTable.es.js.map +1 -0
- package/next/plugin.js +1 -0
- package/package.json +4 -1
|
@@ -0,0 +1,481 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
import { forwardRef, useState, useRef, useCallback, useEffect } from "react";
|
|
21
|
+
import styled, { css } from "styled-components";
|
|
22
|
+
import { motion, useAnimation } from "framer-motion";
|
|
23
|
+
import { useGesture } from "react-use-gesture";
|
|
24
|
+
import { wrap } from "@popmotion/popcorn";
|
|
25
|
+
import { cx } from "@emotion/css";
|
|
26
|
+
import { b as cssMargin, c as cssMediaRules } from "./cssMediaRules.es.js";
|
|
27
|
+
import { o as colorToString } from "./index.es.js";
|
|
28
|
+
import { u as useMediaQuery } from "./useMediaQuery.es.js";
|
|
29
|
+
import ImageComponent from "./Image.es2.js";
|
|
30
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
31
|
+
import "use-sync-external-store/shim/with-selector";
|
|
32
|
+
import "./react-page.es.js";
|
|
33
|
+
import "redux";
|
|
34
|
+
import "redux-thunk";
|
|
35
|
+
import "./actions.es.js";
|
|
36
|
+
import "./descriptors.es.js";
|
|
37
|
+
import "./style.es.js";
|
|
38
|
+
import "./color.es.js";
|
|
39
|
+
import "./image.es.js";
|
|
40
|
+
import "next/dynamic";
|
|
41
|
+
import "next/document";
|
|
42
|
+
import "slate";
|
|
43
|
+
import "@emotion/server/create-instance";
|
|
44
|
+
import "@apollo/client";
|
|
45
|
+
import "@apollo/client/link/batch-http";
|
|
46
|
+
import "./graphql.es.js";
|
|
47
|
+
import "./text-input.es.js";
|
|
48
|
+
import "./shape.es.js";
|
|
49
|
+
import "color";
|
|
50
|
+
import "react-dom";
|
|
51
|
+
import "html-react-parser";
|
|
52
|
+
import "next/head";
|
|
53
|
+
import "uuid/v4";
|
|
54
|
+
import "corporate-ipsum";
|
|
55
|
+
import "next/image";
|
|
56
|
+
import "./useBoxShadow.es.js";
|
|
57
|
+
import "./placeholders.es.js";
|
|
58
|
+
import "./index.es3.js";
|
|
59
|
+
import "scroll-into-view-if-needed";
|
|
60
|
+
import "next/link";
|
|
61
|
+
const LeftChevron = () => /* @__PURE__ */ jsx("svg", {
|
|
62
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
63
|
+
width: "10",
|
|
64
|
+
height: "14",
|
|
65
|
+
viewBox: "0 0 10 14",
|
|
66
|
+
children: /* @__PURE__ */ jsx("path", {
|
|
67
|
+
d: "M7,13,1,7,7,1",
|
|
68
|
+
fill: "none",
|
|
69
|
+
strokeLinecap: "round",
|
|
70
|
+
strokeLinejoin: "round",
|
|
71
|
+
strokeWidth: "2"
|
|
72
|
+
})
|
|
73
|
+
});
|
|
74
|
+
const RightChevron = () => /* @__PURE__ */ jsx("svg", {
|
|
75
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
76
|
+
width: "10",
|
|
77
|
+
height: "14",
|
|
78
|
+
viewBox: "0 0 10 14",
|
|
79
|
+
children: /* @__PURE__ */ jsx("path", {
|
|
80
|
+
d: "M3,1,9,7,3,13",
|
|
81
|
+
fill: "none",
|
|
82
|
+
strokeLinecap: "round",
|
|
83
|
+
strokeLinejoin: "round",
|
|
84
|
+
strokeWidth: "2"
|
|
85
|
+
})
|
|
86
|
+
});
|
|
87
|
+
const Container = styled.div`
|
|
88
|
+
position: relative;
|
|
89
|
+
height: 100%;
|
|
90
|
+
`;
|
|
91
|
+
const Wrapper = styled.div.withConfig({
|
|
92
|
+
shouldForwardProp: (prop) => !["margin"].includes(prop)
|
|
93
|
+
})`
|
|
94
|
+
position: relative;
|
|
95
|
+
display: flex;
|
|
96
|
+
flex-direction: column;
|
|
97
|
+
${cssMargin()}
|
|
98
|
+
|
|
99
|
+
&:focus {
|
|
100
|
+
outline: 0;
|
|
101
|
+
}
|
|
102
|
+
`;
|
|
103
|
+
const Arrow = styled.div.withConfig({
|
|
104
|
+
shouldForwardProp: (prop) => !["background"].includes(prop)
|
|
105
|
+
})`
|
|
106
|
+
padding: 10px;
|
|
107
|
+
border-radius: 50%;
|
|
108
|
+
outline: 0;
|
|
109
|
+
border: 0;
|
|
110
|
+
width: 40px;
|
|
111
|
+
height: 40px;
|
|
112
|
+
display: flex;
|
|
113
|
+
align-items: center;
|
|
114
|
+
justify-content: center;
|
|
115
|
+
cursor: pointer;
|
|
116
|
+
user-select: none;
|
|
117
|
+
${(p) => cssMediaRules([p.background], ([background = {
|
|
118
|
+
swatch: {
|
|
119
|
+
hue: 0,
|
|
120
|
+
saturation: 0,
|
|
121
|
+
lightness: 100
|
|
122
|
+
},
|
|
123
|
+
alpha: 1
|
|
124
|
+
}]) => css`
|
|
125
|
+
background: ${colorToString(background)};
|
|
126
|
+
`)}
|
|
127
|
+
|
|
128
|
+
svg {
|
|
129
|
+
transition: transform 0.15s;
|
|
130
|
+
stroke: currentColor;
|
|
131
|
+
}
|
|
132
|
+
`;
|
|
133
|
+
const Slop = styled.div.withConfig({
|
|
134
|
+
shouldForwardProp: (prop) => !["color"].includes(prop)
|
|
135
|
+
})`
|
|
136
|
+
position: absolute;
|
|
137
|
+
top: 0;
|
|
138
|
+
bottom: 0;
|
|
139
|
+
display: ${(props) => props.hidden ? "none" : "flex"};
|
|
140
|
+
align-items: center;
|
|
141
|
+
cursor: pointer;
|
|
142
|
+
z-index: 2;
|
|
143
|
+
${(p) => cssMediaRules([p.color], ([color = {
|
|
144
|
+
swatch: {
|
|
145
|
+
hue: 0,
|
|
146
|
+
saturation: 0,
|
|
147
|
+
lightness: 0
|
|
148
|
+
},
|
|
149
|
+
alpha: 1
|
|
150
|
+
}]) => css`
|
|
151
|
+
color: ${colorToString(color)};
|
|
152
|
+
`)}
|
|
153
|
+
`;
|
|
154
|
+
const Slide = styled(motion.div).withConfig({
|
|
155
|
+
shouldForwardProp: (prop) => !["pageSize", "alignItems"].includes(prop)
|
|
156
|
+
})`
|
|
157
|
+
display: flex;
|
|
158
|
+
${(p) => cssMediaRules([p.pageSize], ([pageSize = 1]) => css`
|
|
159
|
+
flex-basis: ${100 / pageSize}%;
|
|
160
|
+
max-width: ${100 / pageSize}%;
|
|
161
|
+
min-width: ${100 / pageSize}%;
|
|
162
|
+
`)}
|
|
163
|
+
|
|
164
|
+
${(p) => cssMediaRules([p.alignItems], ([alignItems = "center"]) => ({
|
|
165
|
+
alignItems
|
|
166
|
+
}))}
|
|
167
|
+
`;
|
|
168
|
+
const Reel = styled(motion.div).withConfig({
|
|
169
|
+
shouldForwardProp: (prop) => !["gap"].includes(prop)
|
|
170
|
+
})`
|
|
171
|
+
display: flex;
|
|
172
|
+
position: relative;
|
|
173
|
+
flex-wrap: nowrap;
|
|
174
|
+
${(p) => cssMediaRules([p.gap], ([gap = {
|
|
175
|
+
value: 0,
|
|
176
|
+
unit: "px"
|
|
177
|
+
}]) => css`
|
|
178
|
+
margin: 0 ${`${-gap.value / 2}${gap.unit}`};
|
|
179
|
+
|
|
180
|
+
& > ${Slide} {
|
|
181
|
+
padding: 0 ${`${gap.value / 2}${gap.unit}`};
|
|
182
|
+
}
|
|
183
|
+
`)}
|
|
184
|
+
`;
|
|
185
|
+
const Page = styled(motion.div)`
|
|
186
|
+
position: relative;
|
|
187
|
+
width: 100%;
|
|
188
|
+
`;
|
|
189
|
+
const LeftSlop = styled(Slop).withConfig({
|
|
190
|
+
shouldForwardProp: (prop) => !["position"].includes(prop)
|
|
191
|
+
})`
|
|
192
|
+
${(p) => cssMediaRules([p.position], ([position = "inside"]) => {
|
|
193
|
+
switch (position) {
|
|
194
|
+
case "inside":
|
|
195
|
+
return css`
|
|
196
|
+
transform: translateX(8px);
|
|
197
|
+
`;
|
|
198
|
+
case "outside":
|
|
199
|
+
return css`
|
|
200
|
+
transform: translateX(calc(-100% - 8px));
|
|
201
|
+
`;
|
|
202
|
+
default:
|
|
203
|
+
return css`
|
|
204
|
+
transform: translateX(calc(-50%));
|
|
205
|
+
`;
|
|
206
|
+
}
|
|
207
|
+
})}
|
|
208
|
+
left: 0;
|
|
209
|
+
|
|
210
|
+
&:hover > ${Arrow} {
|
|
211
|
+
& > svg {
|
|
212
|
+
transform: translateX(-2px);
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
`;
|
|
216
|
+
const RightSlop = styled(Slop).withConfig({
|
|
217
|
+
shouldForwardProp: (prop) => !["position"].includes(prop)
|
|
218
|
+
})`
|
|
219
|
+
${(p) => cssMediaRules([p.position], ([position = "inside"]) => {
|
|
220
|
+
switch (position) {
|
|
221
|
+
case "inside":
|
|
222
|
+
return css`
|
|
223
|
+
transform: translateX(-8px);
|
|
224
|
+
`;
|
|
225
|
+
case "outside":
|
|
226
|
+
return css`
|
|
227
|
+
transform: translateX(calc(100% + 8px));
|
|
228
|
+
`;
|
|
229
|
+
default:
|
|
230
|
+
return css`
|
|
231
|
+
transform: translateX(calc(50%));
|
|
232
|
+
`;
|
|
233
|
+
}
|
|
234
|
+
})}
|
|
235
|
+
right: 0;
|
|
236
|
+
|
|
237
|
+
&:hover > ${Arrow} {
|
|
238
|
+
& > svg {
|
|
239
|
+
transform: translateX(2px);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
`;
|
|
243
|
+
const ClipMask = styled.div`
|
|
244
|
+
overflow: hidden;
|
|
245
|
+
`;
|
|
246
|
+
const Dots = styled.div.withConfig({
|
|
247
|
+
shouldForwardProp: (prop) => !["color"].includes(prop)
|
|
248
|
+
})`
|
|
249
|
+
display: ${(props) => props.hidden ? "none" : "flex"};
|
|
250
|
+
justify-content: center;
|
|
251
|
+
margin-top: 20px;
|
|
252
|
+
${(p) => cssMediaRules([p.color], ([color = {
|
|
253
|
+
swatch: {
|
|
254
|
+
hue: 0,
|
|
255
|
+
saturation: 0,
|
|
256
|
+
lightness: 0
|
|
257
|
+
},
|
|
258
|
+
alpha: 1
|
|
259
|
+
}]) => css`
|
|
260
|
+
color: ${colorToString(color)};
|
|
261
|
+
`)}
|
|
262
|
+
`;
|
|
263
|
+
const Dot = styled.div.withConfig({
|
|
264
|
+
shouldForwardProp: (prop) => !["active"].includes(prop)
|
|
265
|
+
})`
|
|
266
|
+
position: relative;
|
|
267
|
+
margin: 0 6px;
|
|
268
|
+
border-radius: 50%;
|
|
269
|
+
cursor: pointer;
|
|
270
|
+
width: 16px;
|
|
271
|
+
height: 16px;
|
|
272
|
+
|
|
273
|
+
&::before,
|
|
274
|
+
&::after {
|
|
275
|
+
content: '';
|
|
276
|
+
position: absolute;
|
|
277
|
+
top: 50%;
|
|
278
|
+
left: 50%;
|
|
279
|
+
display: block;
|
|
280
|
+
border-radius: 50%;
|
|
281
|
+
transition: all 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
&::before {
|
|
285
|
+
box-shadow: 0 0 0 2px currentColor;
|
|
286
|
+
transform: translate3d(-50%, -50%, 0);
|
|
287
|
+
width: ${(props) => props.active ? 16 : 10}px;
|
|
288
|
+
height: ${(props) => props.active ? 16 : 10}px;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
&::after {
|
|
292
|
+
background: currentColor;
|
|
293
|
+
transform: translate3d(-50%, -50%, 0) scale(${(props) => props.active ? 1 : 0});
|
|
294
|
+
width: 10px;
|
|
295
|
+
height: 10px;
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
&:hover::after {
|
|
299
|
+
transform: translate3d(-50%, -50%, 0) scale(${(props) => props.active ? 1 : 0.5});
|
|
300
|
+
}
|
|
301
|
+
`;
|
|
302
|
+
const SWIPE_THRESHOLD = 20;
|
|
303
|
+
const swipePower = (dx, velocity) => dx * (1 + velocity);
|
|
304
|
+
const Carousel = forwardRef(function Carousel2({
|
|
305
|
+
images = [],
|
|
306
|
+
width,
|
|
307
|
+
margin,
|
|
308
|
+
pageSize: responsivePageSize,
|
|
309
|
+
step: responsiveStep,
|
|
310
|
+
gap,
|
|
311
|
+
slideAlignment,
|
|
312
|
+
showDots,
|
|
313
|
+
showArrows,
|
|
314
|
+
arrowPosition,
|
|
315
|
+
arrowColor,
|
|
316
|
+
arrowBackground,
|
|
317
|
+
dotColor,
|
|
318
|
+
autoplay = false,
|
|
319
|
+
delay = 5,
|
|
320
|
+
slideBorder,
|
|
321
|
+
slideBorderRadius
|
|
322
|
+
}, ref) {
|
|
323
|
+
const [index, setIndex] = useState(0);
|
|
324
|
+
const swipe = useRef(0);
|
|
325
|
+
const startIndex = wrap(0, images.length, index);
|
|
326
|
+
const pageSize = useMediaQuery(responsivePageSize) || 1;
|
|
327
|
+
const step = useMediaQuery(responsiveStep) || 1;
|
|
328
|
+
const endIndex = startIndex + pageSize;
|
|
329
|
+
const pageCount = Math.ceil((images.length - pageSize) / step + 1);
|
|
330
|
+
const pageIndex = Math.ceil(startIndex / step);
|
|
331
|
+
const isFirstPage = pageIndex === 0;
|
|
332
|
+
const isLastPage = pageIndex === pageCount - 1;
|
|
333
|
+
const paginate = useCallback((pageDistance) => {
|
|
334
|
+
if (pageDistance === 0)
|
|
335
|
+
return;
|
|
336
|
+
const direction = pageDistance / Math.abs(pageDistance);
|
|
337
|
+
const remaining = direction > 0 ? images.slice(endIndex) : images.slice(0, startIndex);
|
|
338
|
+
const distance = direction * Math.min(remaining.length, step * Math.abs(pageDistance));
|
|
339
|
+
setIndex(index + distance);
|
|
340
|
+
}, [images, index, startIndex, endIndex, step]);
|
|
341
|
+
const animation = useAnimation({
|
|
342
|
+
x: 0,
|
|
343
|
+
transition: {
|
|
344
|
+
type: "spring",
|
|
345
|
+
stiffness: 100
|
|
346
|
+
}
|
|
347
|
+
});
|
|
348
|
+
const bindPage = useGesture({
|
|
349
|
+
onDrag: ({
|
|
350
|
+
movement: [mx],
|
|
351
|
+
delta: [dx],
|
|
352
|
+
velocity
|
|
353
|
+
}) => {
|
|
354
|
+
animation.start({
|
|
355
|
+
x: mx
|
|
356
|
+
});
|
|
357
|
+
swipe.current = swipePower(dx, velocity);
|
|
358
|
+
},
|
|
359
|
+
onDragEnd: () => {
|
|
360
|
+
animation.start({
|
|
361
|
+
x: 0
|
|
362
|
+
});
|
|
363
|
+
if (swipe.current > SWIPE_THRESHOLD)
|
|
364
|
+
paginate(1);
|
|
365
|
+
else if (swipe.current < -SWIPE_THRESHOLD)
|
|
366
|
+
paginate(-1);
|
|
367
|
+
}
|
|
368
|
+
}, {
|
|
369
|
+
drag: {
|
|
370
|
+
axis: "x",
|
|
371
|
+
bounds: {
|
|
372
|
+
left: 0,
|
|
373
|
+
right: 0
|
|
374
|
+
},
|
|
375
|
+
rubberband: true
|
|
376
|
+
}
|
|
377
|
+
});
|
|
378
|
+
useEffect(() => {
|
|
379
|
+
if (!autoplay || pageSize !== 0)
|
|
380
|
+
setIndex(0);
|
|
381
|
+
}, [autoplay, pageSize]);
|
|
382
|
+
useEffect(() => {
|
|
383
|
+
if (!autoplay)
|
|
384
|
+
return () => {
|
|
385
|
+
};
|
|
386
|
+
const intervalId = setInterval(() => isLastPage ? setIndex(0) : paginate(1), delay * 1e3);
|
|
387
|
+
return () => clearInterval(intervalId);
|
|
388
|
+
}, [autoplay, delay, paginate, isLastPage]);
|
|
389
|
+
return /* @__PURE__ */ jsxs(Wrapper, {
|
|
390
|
+
ref,
|
|
391
|
+
className: cx(width),
|
|
392
|
+
margin,
|
|
393
|
+
tabIndex: -1,
|
|
394
|
+
onKeyDown: (e) => {
|
|
395
|
+
switch (e.key) {
|
|
396
|
+
case "ArrowRight":
|
|
397
|
+
paginate(1);
|
|
398
|
+
break;
|
|
399
|
+
case "ArrowLeft":
|
|
400
|
+
paginate(-1);
|
|
401
|
+
break;
|
|
402
|
+
}
|
|
403
|
+
},
|
|
404
|
+
children: [/* @__PURE__ */ jsxs(Container, {
|
|
405
|
+
children: [/* @__PURE__ */ jsx(ClipMask, {
|
|
406
|
+
children: /* @__PURE__ */ jsx(Page, __spreadProps(__spreadValues({}, bindPage()), {
|
|
407
|
+
animate: animation,
|
|
408
|
+
children: /* @__PURE__ */ jsx(Reel, {
|
|
409
|
+
gap,
|
|
410
|
+
animate: {
|
|
411
|
+
x: `${-(100 / pageSize) * startIndex}%`
|
|
412
|
+
},
|
|
413
|
+
transition: {
|
|
414
|
+
x: {
|
|
415
|
+
type: "tween",
|
|
416
|
+
ease: [0.165, 0.84, 0.44, 1],
|
|
417
|
+
duration: 0.5
|
|
418
|
+
}
|
|
419
|
+
},
|
|
420
|
+
children: images.map(({
|
|
421
|
+
props: imageProps,
|
|
422
|
+
key
|
|
423
|
+
}) => /* @__PURE__ */ jsx(Slide, {
|
|
424
|
+
id: key,
|
|
425
|
+
pageSize: responsivePageSize,
|
|
426
|
+
alignItems: slideAlignment,
|
|
427
|
+
onMouseDown: (e) => e.preventDefault(),
|
|
428
|
+
onClick: (e) => {
|
|
429
|
+
if (swipe.current !== 0)
|
|
430
|
+
e.preventDefault();
|
|
431
|
+
},
|
|
432
|
+
children: /* @__PURE__ */ jsx(ImageComponent, {
|
|
433
|
+
width: [{
|
|
434
|
+
deviceId: "desktop",
|
|
435
|
+
value: {
|
|
436
|
+
value: 100,
|
|
437
|
+
unit: "%"
|
|
438
|
+
}
|
|
439
|
+
}],
|
|
440
|
+
file: imageProps.file,
|
|
441
|
+
altText: imageProps.altText,
|
|
442
|
+
link: imageProps.link,
|
|
443
|
+
border: slideBorder,
|
|
444
|
+
borderRadius: slideBorderRadius
|
|
445
|
+
})
|
|
446
|
+
}, key))
|
|
447
|
+
})
|
|
448
|
+
}))
|
|
449
|
+
}), /* @__PURE__ */ jsx(LeftSlop, {
|
|
450
|
+
onClick: () => paginate(-1),
|
|
451
|
+
position: arrowPosition,
|
|
452
|
+
color: arrowColor,
|
|
453
|
+
hidden: !showArrows || isFirstPage,
|
|
454
|
+
children: /* @__PURE__ */ jsx(Arrow, {
|
|
455
|
+
background: arrowBackground,
|
|
456
|
+
children: /* @__PURE__ */ jsx(LeftChevron, {})
|
|
457
|
+
})
|
|
458
|
+
}), /* @__PURE__ */ jsx(RightSlop, {
|
|
459
|
+
onClick: () => paginate(1),
|
|
460
|
+
position: arrowPosition,
|
|
461
|
+
color: arrowColor,
|
|
462
|
+
hidden: !showArrows || isLastPage,
|
|
463
|
+
children: /* @__PURE__ */ jsx(Arrow, {
|
|
464
|
+
background: arrowBackground,
|
|
465
|
+
children: /* @__PURE__ */ jsx(RightChevron, {})
|
|
466
|
+
})
|
|
467
|
+
})]
|
|
468
|
+
}), /* @__PURE__ */ jsx(Dots, {
|
|
469
|
+
color: dotColor,
|
|
470
|
+
hidden: !showDots,
|
|
471
|
+
children: Array.from({
|
|
472
|
+
length: pageCount
|
|
473
|
+
}).map((_, i) => /* @__PURE__ */ jsx(Dot, {
|
|
474
|
+
active: i === pageIndex,
|
|
475
|
+
onClick: () => paginate(i - pageIndex)
|
|
476
|
+
}, i))
|
|
477
|
+
})]
|
|
478
|
+
});
|
|
479
|
+
});
|
|
480
|
+
export { Carousel as default };
|
|
481
|
+
//# sourceMappingURL=Carousel.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Carousel.es.js","sources":["../src/components/builtin/Carousel/Carousel.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useCallback, forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { motion, useAnimation } from 'framer-motion'\nimport { useGesture } from 'react-use-gesture'\nimport { wrap } from '@popmotion/popcorn'\nimport { cx } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { useMediaQuery } from '../../hooks'\n\nimport Image from '../Image'\nimport {\n ResponsiveValue,\n ElementIDValue,\n ImagesValue,\n MarginValue,\n ResponsiveNumberValue,\n ResponsiveIconRadioGroupValue,\n GapXValue,\n CheckboxValue,\n NumberValue,\n BorderValue,\n BorderRadiusValue,\n} from '../../../prop-controllers/descriptors'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\nconst LeftChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M7,13,1,7,7,1\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\nconst RightChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M3,1,9,7,3,13\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\n// NOTE: We set height to 100% here to fix an issue on IE11 where the child height of a flex column extends too far\nconst Container = styled.div`\n position: relative;\n height: 100%;\n`\n\ntype Props = {\n id?: ElementIDValue\n images?: ImagesValue\n width?: string\n margin?: MarginValue\n pageSize?: ResponsiveNumberValue\n step?: ResponsiveNumberValue\n slideAlignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gap?: GapXValue\n autoplay?: CheckboxValue\n delay?: NumberValue\n showArrows?: CheckboxValue\n arrowPosition?: ResponsiveIconRadioGroupValue<'inside' | 'center' | 'outside'>\n arrowColor?: ResponsiveColor | null\n arrowBackground?: ResponsiveColor | null\n showDots?: CheckboxValue\n dotColor?: ResponsiveColor | null\n slideBorder?: BorderValue\n slideBorderRadius?: BorderRadiusValue\n}\n\nconst Wrapper = styled.div.withConfig({\n shouldForwardProp: prop => !['margin'].includes(prop),\n})<{ margin: Props['margin'] }>`\n position: relative;\n display: flex;\n flex-direction: column;\n ${cssMargin()}\n\n &:focus {\n outline: 0;\n }\n`\n\nconst Arrow = styled.div.withConfig({\n shouldForwardProp: prop => !['background'].includes(prop),\n})<{ background?: ResponsiveValue<Color> | null }>`\n padding: 10px;\n border-radius: 50%;\n outline: 0;\n border: 0;\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n user-select: none;\n ${p =>\n cssMediaRules(\n [p.background] as const,\n ([background = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 }]) => css`\n background: ${colorToString(background)};\n `,\n )}\n\n svg {\n transition: transform 0.15s;\n stroke: currentColor;\n }\n`\n\nconst Slop = styled.div.withConfig({\n shouldForwardProp: prop => !['color'].includes(prop),\n})<{\n color?: ResponsiveValue<Color> | null\n}>`\n position: absolute;\n top: 0;\n bottom: 0;\n display: ${props => (props.hidden ? 'none' : 'flex')};\n align-items: center;\n cursor: pointer;\n z-index: 2;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Slide = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['pageSize', 'alignItems'].includes(prop),\n})<{\n pageSize: Props['pageSize']\n alignItems: Props['slideAlignment']\n}>`\n display: flex;\n ${p =>\n cssMediaRules(\n [p.pageSize],\n ([pageSize = 1]) => css`\n flex-basis: ${100 / pageSize}%;\n max-width: ${100 / pageSize}%;\n min-width: ${100 / pageSize}%;\n `,\n )}\n\n ${p => cssMediaRules([p.alignItems], ([alignItems = 'center']) => ({ alignItems }))}\n`\n\nconst Reel = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['gap'].includes(prop),\n})<{ gap: Props['gap'] }>`\n display: flex;\n position: relative;\n flex-wrap: nowrap;\n ${p =>\n cssMediaRules(\n [p.gap] as const,\n ([gap = { value: 0, unit: 'px' }]) => css`\n margin: 0 ${`${-gap.value / 2}${gap.unit}`};\n\n & > ${Slide} {\n padding: 0 ${`${gap.value / 2}${gap.unit}`};\n }\n `,\n )}\n`\n\nconst Page = styled(motion.div)`\n position: relative;\n width: 100%;\n`\n\nconst LeftSlop = styled(Slop).withConfig({\n shouldForwardProp: prop => !['position'].includes(prop),\n})<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(-100% - 8px));\n `\n default:\n return css`\n transform: translateX(calc(-50%));\n `\n }\n })}\n left: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(-2px);\n }\n }\n`\n\nconst RightSlop = styled(Slop).withConfig({\n shouldForwardProp: prop => !['position'].includes(prop),\n})<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(-8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(100% + 8px));\n `\n default:\n return css`\n transform: translateX(calc(50%));\n `\n }\n })}\n right: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(2px);\n }\n }\n`\n\nconst ClipMask = styled.div`\n overflow: hidden;\n`\n\nconst Dots = styled.div.withConfig({\n shouldForwardProp: prop => !['color'].includes(prop),\n})<{ color?: ResponsiveValue<Color> | null }>`\n display: ${props => (props.hidden ? 'none' : 'flex')};\n justify-content: center;\n margin-top: 20px;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Dot = styled.div.withConfig({\n shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active: boolean }>`\n position: relative;\n margin: 0 6px;\n border-radius: 50%;\n cursor: pointer;\n width: 16px;\n height: 16px;\n\n &::before,\n &::after {\n content: '';\n position: absolute;\n top: 50%;\n left: 50%;\n display: block;\n border-radius: 50%;\n transition: all 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);\n }\n\n &::before {\n box-shadow: 0 0 0 2px currentColor;\n transform: translate3d(-50%, -50%, 0);\n width: ${props => (props.active ? 16 : 10)}px;\n height: ${props => (props.active ? 16 : 10)}px;\n }\n\n &::after {\n background: currentColor;\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0)});\n width: 10px;\n height: 10px;\n }\n\n &:hover::after {\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0.5)});\n }\n`\n\nconst SWIPE_THRESHOLD = 20\nconst swipePower = (dx: number, velocity: number) => dx * (1 + velocity)\n\nconst Carousel = forwardRef(function Carousel(\n {\n images = [],\n width,\n margin,\n pageSize: responsivePageSize,\n step: responsiveStep,\n gap,\n slideAlignment,\n showDots,\n showArrows,\n arrowPosition,\n arrowColor,\n arrowBackground,\n dotColor,\n autoplay = false,\n delay = 5,\n slideBorder,\n slideBorderRadius,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const [index, setIndex] = useState(0)\n const swipe = useRef(0)\n const startIndex = wrap(0, images.length, index)\n const pageSize = useMediaQuery(responsivePageSize) || 1\n const step = useMediaQuery(responsiveStep) || 1\n const endIndex = startIndex + pageSize\n const pageCount = Math.ceil((images.length - pageSize) / step + 1)\n const pageIndex = Math.ceil(startIndex / step)\n const isFirstPage = pageIndex === 0\n const isLastPage = pageIndex === pageCount - 1\n const paginate = useCallback(\n pageDistance => {\n if (pageDistance === 0) return\n\n const direction = pageDistance / Math.abs(pageDistance)\n const remaining = direction > 0 ? images.slice(endIndex) : images.slice(0, startIndex)\n const distance = direction * Math.min(remaining.length, step * Math.abs(pageDistance))\n\n setIndex(index + distance)\n },\n [images, index, startIndex, endIndex, step],\n )\n // @ts-expect-error: `useAnimation` types expect no arguments.\n const animation = useAnimation({ x: 0, transition: { type: 'spring', stiffness: 100 } })\n const bindPage = useGesture(\n {\n onDrag: ({ movement: [mx], delta: [dx], velocity }) => {\n animation.start({ x: mx })\n swipe.current = swipePower(dx, velocity)\n },\n onDragEnd: () => {\n animation.start({ x: 0 })\n\n if (swipe.current > SWIPE_THRESHOLD) paginate(1)\n else if (swipe.current < -SWIPE_THRESHOLD) paginate(-1)\n },\n },\n {\n drag: {\n axis: 'x',\n bounds: { left: 0, right: 0 },\n rubberband: true,\n },\n },\n )\n\n useEffect(() => {\n if (!autoplay || pageSize !== 0) setIndex(0)\n }, [autoplay, pageSize])\n\n useEffect(() => {\n if (!autoplay) return () => {}\n\n const intervalId = setInterval(() => (isLastPage ? setIndex(0) : paginate(1)), delay * 1000)\n\n return () => clearInterval(intervalId)\n }, [autoplay, delay, paginate, isLastPage])\n\n return (\n <Wrapper\n ref={ref}\n className={cx(width)}\n margin={margin}\n tabIndex={-1}\n onKeyDown={e => {\n switch (e.key) {\n case 'ArrowRight':\n paginate(1)\n break\n case 'ArrowLeft':\n paginate(-1)\n break\n default:\n }\n }}\n >\n <Container>\n <ClipMask>\n <Page {...bindPage()} animate={animation}>\n <Reel\n gap={gap}\n animate={{ x: `${-(100 / pageSize) * startIndex}%` }}\n transition={{\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n duration: 0.5,\n },\n }}\n >\n {images.map(({ props: imageProps, key }) => (\n <Slide\n id={key}\n key={key}\n pageSize={responsivePageSize}\n alignItems={slideAlignment}\n onMouseDown={e => e.preventDefault()}\n onClick={e => {\n if (swipe.current !== 0) e.preventDefault()\n }}\n >\n <Image\n width={[{ deviceId: 'desktop', value: { value: 100, unit: '%' } }]}\n file={imageProps.file}\n altText={imageProps.altText}\n link={imageProps.link}\n border={slideBorder}\n borderRadius={slideBorderRadius}\n />\n </Slide>\n ))}\n </Reel>\n </Page>\n </ClipMask>\n <LeftSlop\n onClick={() => paginate(-1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isFirstPage}\n >\n <Arrow background={arrowBackground}>\n <LeftChevron />\n </Arrow>\n </LeftSlop>\n <RightSlop\n onClick={() => paginate(1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isLastPage}\n >\n <Arrow background={arrowBackground}>\n <RightChevron />\n </Arrow>\n </RightSlop>\n </Container>\n {/* @ts-expect-error: HTMLDivElement attributes conflicts with `color` prop */}\n <Dots color={dotColor} hidden={!showDots}>\n {Array.from({ length: pageCount }).map((_, i) => (\n <Dot key={i} active={i === pageIndex} onClick={() => paginate(i - pageIndex)} />\n ))}\n </Dots>\n </Wrapper>\n )\n})\n\nexport default Carousel\n"],"names":["LeftChevron","_jsx","RightChevron","Container","styled","div","Wrapper","withConfig","shouldForwardProp","prop","includes","cssMargin","Arrow","p","cssMediaRules","background","swatch","hue","saturation","lightness","alpha","css","colorToString","Slop","props","hidden","color","Slide","motion","pageSize","alignItems","Reel","gap","value","unit","Page","LeftSlop","position","RightSlop","ClipMask","Dots","Dot","active","SWIPE_THRESHOLD","swipePower","dx","velocity","Carousel","forwardRef","images","width","margin","responsivePageSize","step","responsiveStep","slideAlignment","showDots","showArrows","arrowPosition","arrowColor","arrowBackground","dotColor","autoplay","delay","slideBorder","slideBorderRadius","ref","index","setIndex","useState","swipe","useRef","startIndex","wrap","length","useMediaQuery","endIndex","pageCount","Math","ceil","pageIndex","isFirstPage","isLastPage","paginate","useCallback","pageDistance","direction","abs","remaining","slice","distance","min","animation","useAnimation","x","transition","type","stiffness","bindPage","useGesture","onDrag","movement","mx","delta","start","current","onDragEnd","drag","axis","bounds","left","right","rubberband","useEffect","intervalId","setInterval","clearInterval","cx","e","key","_jsxs","ease","duration","map","imageProps","preventDefault","Image","deviceId","file","altText","link","Array","from","_","i"],"mappings":"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"}
|