framer-motion 7.3.5 → 7.4.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/index.d.ts CHANGED
@@ -3099,259 +3099,7 @@ interface Props<V> {
3099
3099
  }
3100
3100
 
3101
3101
  declare const Reorder: {
3102
- Group: React$1.ForwardRefExoticComponent<Props<unknown> & {
3103
- color?: string | undefined;
3104
- translate?: "no" | "yes" | undefined;
3105
- hidden?: boolean | undefined;
3106
- onPlay?: React$1.ReactEventHandler<any> | undefined;
3107
- className?: string | undefined;
3108
- id?: string | undefined;
3109
- lang?: string | undefined;
3110
- role?: React$1.AriaRole | undefined;
3111
- tabIndex?: number | undefined;
3112
- "aria-activedescendant"?: string | undefined;
3113
- "aria-atomic"?: (boolean | "false" | "true") | undefined;
3114
- "aria-autocomplete"?: "none" | "inline" | "both" | "list" | undefined;
3115
- "aria-busy"?: (boolean | "false" | "true") | undefined;
3116
- "aria-checked"?: boolean | "mixed" | "false" | "true" | undefined;
3117
- "aria-colcount"?: number | undefined;
3118
- "aria-colindex"?: number | undefined;
3119
- "aria-colspan"?: number | undefined;
3120
- "aria-controls"?: string | undefined;
3121
- "aria-current"?: boolean | "page" | "false" | "true" | "step" | "location" | "date" | "time" | undefined;
3122
- "aria-describedby"?: string | undefined;
3123
- "aria-details"?: string | undefined;
3124
- "aria-disabled"?: (boolean | "false" | "true") | undefined;
3125
- "aria-dropeffect"?: "none" | "copy" | "move" | "link" | "execute" | "popup" | undefined;
3126
- "aria-errormessage"?: string | undefined;
3127
- "aria-expanded"?: (boolean | "false" | "true") | undefined;
3128
- "aria-flowto"?: string | undefined;
3129
- "aria-grabbed"?: (boolean | "false" | "true") | undefined;
3130
- "aria-haspopup"?: boolean | "grid" | "listbox" | "menu" | "false" | "true" | "dialog" | "tree" | undefined;
3131
- "aria-hidden"?: (boolean | "false" | "true") | undefined;
3132
- "aria-invalid"?: boolean | "false" | "true" | "grammar" | "spelling" | undefined;
3133
- "aria-keyshortcuts"?: string | undefined;
3134
- "aria-label"?: string | undefined;
3135
- "aria-labelledby"?: string | undefined;
3136
- "aria-level"?: number | undefined;
3137
- "aria-live"?: "off" | "assertive" | "polite" | undefined;
3138
- "aria-modal"?: (boolean | "false" | "true") | undefined;
3139
- "aria-multiline"?: (boolean | "false" | "true") | undefined;
3140
- "aria-multiselectable"?: (boolean | "false" | "true") | undefined;
3141
- "aria-orientation"?: "horizontal" | "vertical" | undefined;
3142
- "aria-owns"?: string | undefined;
3143
- "aria-placeholder"?: string | undefined;
3144
- "aria-posinset"?: number | undefined;
3145
- "aria-pressed"?: boolean | "mixed" | "false" | "true" | undefined;
3146
- "aria-readonly"?: (boolean | "false" | "true") | undefined;
3147
- "aria-relevant"?: "all" | "text" | "additions" | "additions removals" | "additions text" | "removals" | "removals additions" | "removals text" | "text additions" | "text removals" | undefined;
3148
- "aria-required"?: (boolean | "false" | "true") | undefined;
3149
- "aria-roledescription"?: string | undefined;
3150
- "aria-rowcount"?: number | undefined;
3151
- "aria-rowindex"?: number | undefined;
3152
- "aria-rowspan"?: number | undefined;
3153
- "aria-selected"?: (boolean | "false" | "true") | undefined;
3154
- "aria-setsize"?: number | undefined;
3155
- "aria-sort"?: "none" | "ascending" | "descending" | "other" | undefined;
3156
- "aria-valuemax"?: number | undefined;
3157
- "aria-valuemin"?: number | undefined;
3158
- "aria-valuenow"?: number | undefined;
3159
- "aria-valuetext"?: string | undefined;
3160
- children?: React$1.ReactNode;
3161
- dangerouslySetInnerHTML?: {
3162
- __html: string;
3163
- } | undefined;
3164
- onCopy?: React$1.ClipboardEventHandler<any> | undefined;
3165
- onCopyCapture?: React$1.ClipboardEventHandler<any> | undefined;
3166
- onCut?: React$1.ClipboardEventHandler<any> | undefined;
3167
- onCutCapture?: React$1.ClipboardEventHandler<any> | undefined;
3168
- onPaste?: React$1.ClipboardEventHandler<any> | undefined;
3169
- onPasteCapture?: React$1.ClipboardEventHandler<any> | undefined;
3170
- onCompositionEnd?: React$1.CompositionEventHandler<any> | undefined;
3171
- onCompositionEndCapture?: React$1.CompositionEventHandler<any> | undefined;
3172
- onCompositionStart?: React$1.CompositionEventHandler<any> | undefined;
3173
- onCompositionStartCapture?: React$1.CompositionEventHandler<any> | undefined;
3174
- onCompositionUpdate?: React$1.CompositionEventHandler<any> | undefined;
3175
- onCompositionUpdateCapture?: React$1.CompositionEventHandler<any> | undefined;
3176
- onFocus?: React$1.FocusEventHandler<any> | undefined;
3177
- onFocusCapture?: React$1.FocusEventHandler<any> | undefined;
3178
- onBlur?: React$1.FocusEventHandler<any> | undefined;
3179
- onBlurCapture?: React$1.FocusEventHandler<any> | undefined;
3180
- onChange?: React$1.FormEventHandler<any> | undefined;
3181
- onChangeCapture?: React$1.FormEventHandler<any> | undefined;
3182
- onBeforeInput?: React$1.FormEventHandler<any> | undefined;
3183
- onBeforeInputCapture?: React$1.FormEventHandler<any> | undefined;
3184
- onInput?: React$1.FormEventHandler<any> | undefined;
3185
- onInputCapture?: React$1.FormEventHandler<any> | undefined;
3186
- onReset?: React$1.FormEventHandler<any> | undefined;
3187
- onResetCapture?: React$1.FormEventHandler<any> | undefined;
3188
- onSubmit?: React$1.FormEventHandler<any> | undefined;
3189
- onSubmitCapture?: React$1.FormEventHandler<any> | undefined;
3190
- onInvalid?: React$1.FormEventHandler<any> | undefined;
3191
- onInvalidCapture?: React$1.FormEventHandler<any> | undefined;
3192
- onLoad?: React$1.ReactEventHandler<any> | undefined;
3193
- onLoadCapture?: React$1.ReactEventHandler<any> | undefined;
3194
- onError?: React$1.ReactEventHandler<any> | undefined;
3195
- onErrorCapture?: React$1.ReactEventHandler<any> | undefined;
3196
- onKeyDown?: React$1.KeyboardEventHandler<any> | undefined;
3197
- onKeyDownCapture?: React$1.KeyboardEventHandler<any> | undefined;
3198
- onKeyPress?: React$1.KeyboardEventHandler<any> | undefined;
3199
- onKeyPressCapture?: React$1.KeyboardEventHandler<any> | undefined;
3200
- onKeyUp?: React$1.KeyboardEventHandler<any> | undefined;
3201
- onKeyUpCapture?: React$1.KeyboardEventHandler<any> | undefined;
3202
- onAbort?: React$1.ReactEventHandler<any> | undefined;
3203
- onAbortCapture?: React$1.ReactEventHandler<any> | undefined;
3204
- onCanPlay?: React$1.ReactEventHandler<any> | undefined;
3205
- onCanPlayCapture?: React$1.ReactEventHandler<any> | undefined;
3206
- onCanPlayThrough?: React$1.ReactEventHandler<any> | undefined;
3207
- onCanPlayThroughCapture?: React$1.ReactEventHandler<any> | undefined;
3208
- onDurationChange?: React$1.ReactEventHandler<any> | undefined;
3209
- onDurationChangeCapture?: React$1.ReactEventHandler<any> | undefined;
3210
- onEmptied?: React$1.ReactEventHandler<any> | undefined;
3211
- onEmptiedCapture?: React$1.ReactEventHandler<any> | undefined;
3212
- onEncrypted?: React$1.ReactEventHandler<any> | undefined;
3213
- onEncryptedCapture?: React$1.ReactEventHandler<any> | undefined;
3214
- onEnded?: React$1.ReactEventHandler<any> | undefined;
3215
- onEndedCapture?: React$1.ReactEventHandler<any> | undefined;
3216
- onLoadedData?: React$1.ReactEventHandler<any> | undefined;
3217
- onLoadedDataCapture?: React$1.ReactEventHandler<any> | undefined;
3218
- onLoadedMetadata?: React$1.ReactEventHandler<any> | undefined;
3219
- onLoadedMetadataCapture?: React$1.ReactEventHandler<any> | undefined;
3220
- onLoadStart?: React$1.ReactEventHandler<any> | undefined;
3221
- onLoadStartCapture?: React$1.ReactEventHandler<any> | undefined;
3222
- onPause?: React$1.ReactEventHandler<any> | undefined;
3223
- onPauseCapture?: React$1.ReactEventHandler<any> | undefined;
3224
- onPlayCapture?: React$1.ReactEventHandler<any> | undefined;
3225
- onPlaying?: React$1.ReactEventHandler<any> | undefined;
3226
- onPlayingCapture?: React$1.ReactEventHandler<any> | undefined;
3227
- onProgress?: React$1.ReactEventHandler<any> | undefined;
3228
- onProgressCapture?: React$1.ReactEventHandler<any> | undefined;
3229
- onRateChange?: React$1.ReactEventHandler<any> | undefined;
3230
- onRateChangeCapture?: React$1.ReactEventHandler<any> | undefined;
3231
- onSeeked?: React$1.ReactEventHandler<any> | undefined;
3232
- onSeekedCapture?: React$1.ReactEventHandler<any> | undefined;
3233
- onSeeking?: React$1.ReactEventHandler<any> | undefined;
3234
- onSeekingCapture?: React$1.ReactEventHandler<any> | undefined;
3235
- onStalled?: React$1.ReactEventHandler<any> | undefined;
3236
- onStalledCapture?: React$1.ReactEventHandler<any> | undefined;
3237
- onSuspend?: React$1.ReactEventHandler<any> | undefined;
3238
- onSuspendCapture?: React$1.ReactEventHandler<any> | undefined;
3239
- onTimeUpdate?: React$1.ReactEventHandler<any> | undefined;
3240
- onTimeUpdateCapture?: React$1.ReactEventHandler<any> | undefined;
3241
- onVolumeChange?: React$1.ReactEventHandler<any> | undefined;
3242
- onVolumeChangeCapture?: React$1.ReactEventHandler<any> | undefined;
3243
- onWaiting?: React$1.ReactEventHandler<any> | undefined;
3244
- onWaitingCapture?: React$1.ReactEventHandler<any> | undefined;
3245
- onAuxClick?: React$1.MouseEventHandler<any> | undefined;
3246
- onAuxClickCapture?: React$1.MouseEventHandler<any> | undefined;
3247
- onClick?: React$1.MouseEventHandler<any> | undefined;
3248
- onClickCapture?: React$1.MouseEventHandler<any> | undefined;
3249
- onContextMenu?: React$1.MouseEventHandler<any> | undefined;
3250
- onContextMenuCapture?: React$1.MouseEventHandler<any> | undefined;
3251
- onDoubleClick?: React$1.MouseEventHandler<any> | undefined;
3252
- onDoubleClickCapture?: React$1.MouseEventHandler<any> | undefined;
3253
- onDragCapture?: React$1.DragEventHandler<any> | undefined;
3254
- onDragEndCapture?: React$1.DragEventHandler<any> | undefined;
3255
- onDragEnter?: React$1.DragEventHandler<any> | undefined;
3256
- onDragEnterCapture?: React$1.DragEventHandler<any> | undefined;
3257
- onDragExit?: React$1.DragEventHandler<any> | undefined;
3258
- onDragExitCapture?: React$1.DragEventHandler<any> | undefined;
3259
- onDragLeave?: React$1.DragEventHandler<any> | undefined;
3260
- onDragLeaveCapture?: React$1.DragEventHandler<any> | undefined;
3261
- onDragOver?: React$1.DragEventHandler<any> | undefined;
3262
- onDragOverCapture?: React$1.DragEventHandler<any> | undefined;
3263
- onDragStartCapture?: React$1.DragEventHandler<any> | undefined;
3264
- onDrop?: React$1.DragEventHandler<any> | undefined;
3265
- onDropCapture?: React$1.DragEventHandler<any> | undefined;
3266
- onMouseDown?: React$1.MouseEventHandler<any> | undefined;
3267
- onMouseDownCapture?: React$1.MouseEventHandler<any> | undefined;
3268
- onMouseEnter?: React$1.MouseEventHandler<any> | undefined;
3269
- onMouseLeave?: React$1.MouseEventHandler<any> | undefined;
3270
- onMouseMove?: React$1.MouseEventHandler<any> | undefined;
3271
- onMouseMoveCapture?: React$1.MouseEventHandler<any> | undefined;
3272
- onMouseOut?: React$1.MouseEventHandler<any> | undefined;
3273
- onMouseOutCapture?: React$1.MouseEventHandler<any> | undefined;
3274
- onMouseOver?: React$1.MouseEventHandler<any> | undefined;
3275
- onMouseOverCapture?: React$1.MouseEventHandler<any> | undefined;
3276
- onMouseUp?: React$1.MouseEventHandler<any> | undefined;
3277
- onMouseUpCapture?: React$1.MouseEventHandler<any> | undefined;
3278
- onSelect?: React$1.ReactEventHandler<any> | undefined;
3279
- onSelectCapture?: React$1.ReactEventHandler<any> | undefined;
3280
- onTouchCancel?: React$1.TouchEventHandler<any> | undefined;
3281
- onTouchCancelCapture?: React$1.TouchEventHandler<any> | undefined;
3282
- onTouchEnd?: React$1.TouchEventHandler<any> | undefined;
3283
- onTouchEndCapture?: React$1.TouchEventHandler<any> | undefined;
3284
- onTouchMove?: React$1.TouchEventHandler<any> | undefined;
3285
- onTouchMoveCapture?: React$1.TouchEventHandler<any> | undefined;
3286
- onTouchStart?: React$1.TouchEventHandler<any> | undefined;
3287
- onTouchStartCapture?: React$1.TouchEventHandler<any> | undefined;
3288
- onPointerDown?: React$1.PointerEventHandler<any> | undefined;
3289
- onPointerDownCapture?: React$1.PointerEventHandler<any> | undefined;
3290
- onPointerMove?: React$1.PointerEventHandler<any> | undefined;
3291
- onPointerMoveCapture?: React$1.PointerEventHandler<any> | undefined;
3292
- onPointerUp?: React$1.PointerEventHandler<any> | undefined;
3293
- onPointerUpCapture?: React$1.PointerEventHandler<any> | undefined;
3294
- onPointerCancel?: React$1.PointerEventHandler<any> | undefined;
3295
- onPointerCancelCapture?: React$1.PointerEventHandler<any> | undefined;
3296
- onPointerEnter?: React$1.PointerEventHandler<any> | undefined;
3297
- onPointerEnterCapture?: React$1.PointerEventHandler<any> | undefined;
3298
- onPointerLeave?: React$1.PointerEventHandler<any> | undefined;
3299
- onPointerLeaveCapture?: React$1.PointerEventHandler<any> | undefined;
3300
- onPointerOver?: React$1.PointerEventHandler<any> | undefined;
3301
- onPointerOverCapture?: React$1.PointerEventHandler<any> | undefined;
3302
- onPointerOut?: React$1.PointerEventHandler<any> | undefined;
3303
- onPointerOutCapture?: React$1.PointerEventHandler<any> | undefined;
3304
- onGotPointerCapture?: React$1.PointerEventHandler<any> | undefined;
3305
- onGotPointerCaptureCapture?: React$1.PointerEventHandler<any> | undefined;
3306
- onLostPointerCapture?: React$1.PointerEventHandler<any> | undefined;
3307
- onLostPointerCaptureCapture?: React$1.PointerEventHandler<any> | undefined;
3308
- onScroll?: React$1.UIEventHandler<any> | undefined;
3309
- onScrollCapture?: React$1.UIEventHandler<any> | undefined;
3310
- onWheel?: React$1.WheelEventHandler<any> | undefined;
3311
- onWheelCapture?: React$1.WheelEventHandler<any> | undefined;
3312
- onAnimationStartCapture?: React$1.AnimationEventHandler<any> | undefined;
3313
- onAnimationEnd?: React$1.AnimationEventHandler<any> | undefined;
3314
- onAnimationEndCapture?: React$1.AnimationEventHandler<any> | undefined;
3315
- onAnimationIteration?: React$1.AnimationEventHandler<any> | undefined;
3316
- onAnimationIterationCapture?: React$1.AnimationEventHandler<any> | undefined;
3317
- onTransitionEnd?: React$1.TransitionEventHandler<any> | undefined;
3318
- onTransitionEndCapture?: React$1.TransitionEventHandler<any> | undefined;
3319
- draggable?: (boolean | "false" | "true") | undefined;
3320
- slot?: string | undefined;
3321
- title?: string | undefined;
3322
- defaultChecked?: boolean | undefined;
3323
- defaultValue?: string | number | readonly string[] | undefined;
3324
- suppressContentEditableWarning?: boolean | undefined;
3325
- suppressHydrationWarning?: boolean | undefined;
3326
- accessKey?: string | undefined;
3327
- contentEditable?: "inherit" | (boolean | "false" | "true") | undefined;
3328
- contextMenu?: string | undefined;
3329
- dir?: string | undefined;
3330
- placeholder?: string | undefined;
3331
- spellCheck?: (boolean | "false" | "true") | undefined;
3332
- radioGroup?: string | undefined;
3333
- about?: string | undefined;
3334
- datatype?: string | undefined;
3335
- inlist?: any;
3336
- prefix?: string | undefined;
3337
- property?: string | undefined;
3338
- resource?: string | undefined;
3339
- typeof?: string | undefined;
3340
- vocab?: string | undefined;
3341
- autoCapitalize?: string | undefined;
3342
- autoCorrect?: string | undefined;
3343
- autoSave?: string | undefined;
3344
- itemProp?: string | undefined;
3345
- itemScope?: boolean | undefined;
3346
- itemType?: string | undefined;
3347
- itemID?: string | undefined;
3348
- itemRef?: string | undefined;
3349
- results?: number | undefined;
3350
- security?: string | undefined;
3351
- unselectable?: "off" | "on" | undefined;
3352
- inputMode?: "none" | "text" | "search" | "tel" | "url" | "email" | "numeric" | "decimal" | undefined;
3353
- is?: string | undefined;
3354
- } & MotionProps & {
3102
+ Group: React$1.ForwardRefExoticComponent<Props<unknown> & Omit<HTMLMotionProps<any>, "values"> & {
3355
3103
  children?: React$1.ReactNode;
3356
3104
  } & React$1.RefAttributes<any>>;
3357
3105
  Item: React$1.ForwardRefExoticComponent<Props$1<unknown> & {
@@ -1242,7 +1242,7 @@
1242
1242
  * This will be replaced by the build step with the latest version number.
1243
1243
  * When MotionValues are provided to motion components, warn if versions are mixed.
1244
1244
  */
1245
- this.version = "7.3.5";
1245
+ this.version = "7.4.0";
1246
1246
  /**
1247
1247
  * Duration, in milliseconds, since last updating frame.
1248
1248
  *
@@ -2339,7 +2339,7 @@
2339
2339
  function aspectRatio(box) {
2340
2340
  return calcLength(box.x) / calcLength(box.y);
2341
2341
  }
2342
- function isCloseTo(a, b, max = 0.01) {
2342
+ function isCloseTo(a, b, max = 0.1) {
2343
2343
  return distance(a, b) <= max;
2344
2344
  }
2345
2345
 
@@ -3747,7 +3747,7 @@
3747
3747
  function shouldAnimatePositionOnly(animationType, snapshot, layout) {
3748
3748
  return (animationType === "position" ||
3749
3749
  (animationType === "preserve-aspect" &&
3750
- !isCloseTo(aspectRatio(snapshot), aspectRatio(layout))));
3750
+ !isCloseTo(aspectRatio(snapshot), aspectRatio(layout), 0.2)));
3751
3751
  }
3752
3752
 
3753
3753
  function addDomEvent(target, eventName, handler, options = { passive: true }) {
@@ -4281,7 +4281,7 @@
4281
4281
  * and warn against mismatches.
4282
4282
  */
4283
4283
  {
4284
- warnOnce(nextValue.version === "7.3.5", `Attempting to mix Framer Motion versions ${nextValue.version} with 7.3.5 may not work as expected.`);
4284
+ warnOnce(nextValue.version === "7.4.0", `Attempting to mix Framer Motion versions ${nextValue.version} with 7.4.0 may not work as expected.`);
4285
4285
  }
4286
4286
  }
4287
4287
  else if (isMotionValue(prevValue)) {
@@ -4480,6 +4480,16 @@
4480
4480
  }
4481
4481
  }
4482
4482
  }
4483
+ /**
4484
+ * Update external values with initial values
4485
+ */
4486
+ if (props.values) {
4487
+ for (const key in props.values) {
4488
+ if (latestValues[key] !== undefined) {
4489
+ props.values[key].set(latestValues[key]);
4490
+ }
4491
+ }
4492
+ }
4483
4493
  /**
4484
4494
  * Determine what role this visual element should take in the variant tree.
4485
4495
  */
@@ -4725,6 +4735,9 @@
4725
4735
  * value, we'll create one if none exists.
4726
4736
  */
4727
4737
  getValue(key, defaultValue) {
4738
+ if (props.values && props.values[key]) {
4739
+ return props.values[key];
4740
+ }
4728
4741
  let value = values.get(key);
4729
4742
  if (value === undefined && defaultValue !== undefined) {
4730
4743
  value = motionValue(defaultValue);
@@ -4902,15 +4915,17 @@
4902
4915
  style[key] = valueAsType;
4903
4916
  }
4904
4917
  }
4905
- if (hasTransform || transformTemplate) {
4906
- style.transform = buildTransform(state, options, transformIsNone, transformTemplate);
4907
- }
4908
- else if (!latestValues.transform && style.transform) {
4909
- /**
4910
- * If we have previously created a transform but currently don't have any,
4911
- * reset transform style to none.
4912
- */
4913
- style.transform = "none";
4918
+ if (!latestValues.transform) {
4919
+ if (hasTransform || transformTemplate) {
4920
+ style.transform = buildTransform(state, options, transformIsNone, transformTemplate);
4921
+ }
4922
+ else if (style.transform) {
4923
+ /**
4924
+ * If we have previously created a transform but currently don't have any,
4925
+ * reset transform style to none.
4926
+ */
4927
+ style.transform = "none";
4928
+ }
4914
4929
  }
4915
4930
  /**
4916
4931
  * Build a transformOrigin style. Uses the same defaults as the browser for
@@ -1 +1 @@
1
- import{createContext as t}from"react";const e=t(null),a="undefined"!=typeof document;function r(t){return"object"==typeof t&&Object.prototype.hasOwnProperty.call(t,"current")}function n(t){return"string"==typeof t||Array.isArray(t)}function s(t){return"object"==typeof t&&"function"==typeof t.start}const o=["initial","animate","exit","whileHover","whileDrag","whileTap","whileFocus","whileInView"];function i(t){return s(t.animate)||o.some(e=>n(t[e]))}function f(t){return Boolean(i(t)||t.variants)}const c=t=>({isEnabled:e=>t.some(t=>!!e[t])}),l={measureLayout:c(["layout","layoutId","drag"]),animation:c(["animate","exit","variants","whileHover","whileTap","whileFocus","whileDrag","whileInView"]),exit:c(["exit"]),drag:c(["drag","dragControls"]),focus:c(["whileFocus"]),hover:c(["whileHover","onHoverStart","onHoverEnd"]),tap:c(["whileTap","onTap","onTapStart","onTapCancel"]),pan:c(["onPan","onPanStart","onPanSessionStart","onPanEnd"]),inView:c(["whileInView","onViewportEnter","onViewportLeave"])},d=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","svg","switch","symbol","text","tspan","use","view"];function u(t){return"string"==typeof t&&!t.includes("-")&&!!(d.indexOf(t)>-1||/[A-Z]/.test(t))}const p={},m=["transformPerspective","x","y","z","translateX","translateY","translateZ","scale","scaleX","scaleY","rotate","rotateX","rotateY","rotateZ","skew","skewX","skewY"],g=new Set(m);function h(t,{layout:e,layoutId:a}){return g.has(t)||t.startsWith("origin")||(e||void 0!==a)&&(!!p[t]||"opacity"===t)}const y=t=>!!(null==t?void 0:t.getVelocity),v={x:"translateX",y:"translateY",z:"translateZ",transformPerspective:"perspective"},w=(t,e)=>m.indexOf(t)-m.indexOf(e);function b(t){return t.startsWith("--")}const x=(t,e)=>e&&"number"==typeof t?e.transform(t):t,k=(t,e)=>a=>Math.max(Math.min(a,e),t),O=t=>t%1?Number(t.toFixed(5)):t,T=/(-)?([\d]*\.?[\d])+/g,X=/(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))/gi,Y=/^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))$/i;function $(t){return"string"==typeof t}const j={test:t=>"number"==typeof t,parse:parseFloat,transform:t=>t},L=Object.assign(Object.assign({},j),{transform:k(0,1)}),P=Object.assign(Object.assign({},j),{default:1}),S=t=>({test:e=>$(e)&&e.endsWith(t)&&1===e.split(" ").length,parse:parseFloat,transform:e=>`${e}${t}`}),W=S("deg"),Z=S("%"),A=S("px"),R=S("vh"),B=S("vw"),H=Object.assign(Object.assign({},Z),{parse:t=>Z.parse(t)/100,transform:t=>Z.transform(100*t)}),V={...j,transform:Math.round},z={borderWidth:A,borderTopWidth:A,borderRightWidth:A,borderBottomWidth:A,borderLeftWidth:A,borderRadius:A,radius:A,borderTopLeftRadius:A,borderTopRightRadius:A,borderBottomRightRadius:A,borderBottomLeftRadius:A,width:A,maxWidth:A,height:A,maxHeight:A,size:A,top:A,right:A,bottom:A,left:A,padding:A,paddingTop:A,paddingRight:A,paddingBottom:A,paddingLeft:A,margin:A,marginTop:A,marginRight:A,marginBottom:A,marginLeft:A,rotate:W,rotateX:W,rotateY:W,rotateZ:W,scale:P,scaleX:P,scaleY:P,scaleZ:P,skew:W,skewX:W,skewY:W,distance:A,translateX:A,translateY:A,translateZ:A,x:A,y:A,z:A,perspective:A,transformPerspective:A,opacity:L,originX:H,originY:H,originZ:A,zIndex:V,fillOpacity:L,strokeOpacity:L,numOctaves:V};function C(t,e,a,r){const{style:n,vars:s,transform:o,transformKeys:i,transformOrigin:f}=t;i.length=0;let c=!1,l=!1,d=!0;for(const t in e){const a=e[t];if(b(t)){s[t]=a;continue}const r=z[t],u=x(a,r);if(g.has(t)){if(c=!0,o[t]=u,i.push(t),!d)continue;a!==(r.default||0)&&(d=!1)}else t.startsWith("origin")?(l=!0,f[t]=u):n[t]=u}if(c||r?n.transform=function({transform:t,transformKeys:e},{enableHardwareAcceleration:a=!0,allowTransformNone:r=!0},n,s){let o="";e.sort(w);for(const a of e)o+=`${v[a]||a}(${t[a]}) `;return a&&!t.z&&(o+="translateZ(0)"),o=o.trim(),s?o=s(t,n?"":o):r&&n&&(o="none"),o}(t,a,d,r):!e.transform&&n.transform&&(n.transform="none"),l){const{originX:t="50%",originY:e="50%",originZ:a=0}=f;n.transformOrigin=`${t} ${e} ${a}`}}function F(t,e,a){return"string"==typeof t?t:A.transform(e+a*t)}const I={offset:"stroke-dashoffset",array:"stroke-dasharray"},D={offset:"strokeDashoffset",array:"strokeDasharray"};function E(t,{attrX:e,attrY:a,originX:r,originY:n,pathLength:s,pathSpacing:o=1,pathOffset:i=0,...f},c,l){C(t,f,c,l),t.attrs=t.style,t.style={};const{attrs:d,style:u,dimensions:p}=t;d.transform&&(p&&(u.transform=d.transform),delete d.transform),p&&(void 0!==r||void 0!==n||u.transform)&&(u.transformOrigin=function(t,e,a){return`${F(e,t.x,t.width)} ${F(a,t.y,t.height)}`}(p,void 0!==r?r:.5,void 0!==n?n:.5)),void 0!==e&&(d.x=e),void 0!==a&&(d.y=a),void 0!==s&&function(t,e,a=1,r=0,n=!0){t.pathLength=1;const s=n?I:D;t[s.offset]=A.transform(-r);const o=A.transform(e),i=A.transform(a);t[s.array]=`${o} ${i}`}(d,s,o,i,!1)}const M=t=>t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase();function K(t,{style:e,vars:a},r,n){Object.assign(t.style,e,n&&n.getProjectionStyles(r));for(const e in a)t.style.setProperty(e,a[e])}const q=new Set(["baseFrequency","diffuseConstant","kernelMatrix","kernelUnitLength","keySplines","keyTimes","limitingConeAngle","markerHeight","markerWidth","numOctaves","targetX","targetY","surfaceScale","specularConstant","specularExponent","stdDeviation","tableValues","viewBox","gradientTransform","pathLength"]);function N(t,e,a,r){K(t,e,void 0,r);for(const a in e.attrs)t.setAttribute(q.has(a)?a:M(a),e.attrs[a])}function U(t){const{style:e}=t,a={};for(const r in e)(y(e[r])||h(r,t))&&(a[r]=e[r]);return a}function G(t){const e=U(t);for(const a in t)if(y(t[a])){e["x"===a||"y"===a?"attr"+a.toUpperCase():a]=t[a]}return e}function J(t,e,a,r={},n={}){return"function"==typeof e&&(e=e(void 0!==a?a:t.custom,r,n)),"string"==typeof e&&(e=t.variants&&t.variants[e]),"function"==typeof e&&(e=e(void 0!==a?a:t.custom,r,n)),e}const Q=t=>Array.isArray(t),_=t=>Boolean(t&&"object"==typeof t&&t.mix&&t.toValue),tt=t=>Q(t)?t[t.length-1]||0:t;export{Q as A,z as B,tt as C,A as D,W as E,B as F,R as G,g as H,m as I,b as J,K,q as L,M,e as P,r as a,i as b,n as c,y as d,h as e,l as f,C as g,E as h,a as i,u as j,_ as k,f as l,s as m,N as n,U as o,$ as p,Y as q,J as r,G as s,T as t,Z as u,O as v,L as w,j as x,k as y,X as z};
1
+ import{createContext as t}from"react";const e=t(null),a="undefined"!=typeof document;function r(t){return"object"==typeof t&&Object.prototype.hasOwnProperty.call(t,"current")}function n(t){return"string"==typeof t||Array.isArray(t)}function s(t){return"object"==typeof t&&"function"==typeof t.start}const o=["initial","animate","exit","whileHover","whileDrag","whileTap","whileFocus","whileInView"];function i(t){return s(t.animate)||o.some(e=>n(t[e]))}function f(t){return Boolean(i(t)||t.variants)}const c=t=>({isEnabled:e=>t.some(t=>!!e[t])}),l={measureLayout:c(["layout","layoutId","drag"]),animation:c(["animate","exit","variants","whileHover","whileTap","whileFocus","whileDrag","whileInView"]),exit:c(["exit"]),drag:c(["drag","dragControls"]),focus:c(["whileFocus"]),hover:c(["whileHover","onHoverStart","onHoverEnd"]),tap:c(["whileTap","onTap","onTapStart","onTapCancel"]),pan:c(["onPan","onPanStart","onPanSessionStart","onPanEnd"]),inView:c(["whileInView","onViewportEnter","onViewportLeave"])},d=["animate","circle","defs","desc","ellipse","g","image","line","filter","marker","mask","metadata","path","pattern","polygon","polyline","rect","stop","svg","switch","symbol","text","tspan","use","view"];function u(t){return"string"==typeof t&&!t.includes("-")&&!!(d.indexOf(t)>-1||/[A-Z]/.test(t))}const p={},m=["transformPerspective","x","y","z","translateX","translateY","translateZ","scale","scaleX","scaleY","rotate","rotateX","rotateY","rotateZ","skew","skewX","skewY"],g=new Set(m);function h(t,{layout:e,layoutId:a}){return g.has(t)||t.startsWith("origin")||(e||void 0!==a)&&(!!p[t]||"opacity"===t)}const y=t=>!!(null==t?void 0:t.getVelocity),v={x:"translateX",y:"translateY",z:"translateZ",transformPerspective:"perspective"},w=(t,e)=>m.indexOf(t)-m.indexOf(e);function b(t){return t.startsWith("--")}const x=(t,e)=>e&&"number"==typeof t?e.transform(t):t,k=(t,e)=>a=>Math.max(Math.min(a,e),t),O=t=>t%1?Number(t.toFixed(5)):t,T=/(-)?([\d]*\.?[\d])+/g,X=/(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))/gi,Y=/^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2}(-?[\d\.]+%?)\s*[\,\/]?\s*[\d\.]*%?\))$/i;function $(t){return"string"==typeof t}const j={test:t=>"number"==typeof t,parse:parseFloat,transform:t=>t},L=Object.assign(Object.assign({},j),{transform:k(0,1)}),P=Object.assign(Object.assign({},j),{default:1}),S=t=>({test:e=>$(e)&&e.endsWith(t)&&1===e.split(" ").length,parse:parseFloat,transform:e=>`${e}${t}`}),W=S("deg"),Z=S("%"),A=S("px"),R=S("vh"),B=S("vw"),H=Object.assign(Object.assign({},Z),{parse:t=>Z.parse(t)/100,transform:t=>Z.transform(100*t)}),V={...j,transform:Math.round},z={borderWidth:A,borderTopWidth:A,borderRightWidth:A,borderBottomWidth:A,borderLeftWidth:A,borderRadius:A,radius:A,borderTopLeftRadius:A,borderTopRightRadius:A,borderBottomRightRadius:A,borderBottomLeftRadius:A,width:A,maxWidth:A,height:A,maxHeight:A,size:A,top:A,right:A,bottom:A,left:A,padding:A,paddingTop:A,paddingRight:A,paddingBottom:A,paddingLeft:A,margin:A,marginTop:A,marginRight:A,marginBottom:A,marginLeft:A,rotate:W,rotateX:W,rotateY:W,rotateZ:W,scale:P,scaleX:P,scaleY:P,scaleZ:P,skew:W,skewX:W,skewY:W,distance:A,translateX:A,translateY:A,translateZ:A,x:A,y:A,z:A,perspective:A,transformPerspective:A,opacity:L,originX:H,originY:H,originZ:A,zIndex:V,fillOpacity:L,strokeOpacity:L,numOctaves:V};function C(t,e,a,r){const{style:n,vars:s,transform:o,transformKeys:i,transformOrigin:f}=t;i.length=0;let c=!1,l=!1,d=!0;for(const t in e){const a=e[t];if(b(t)){s[t]=a;continue}const r=z[t],u=x(a,r);if(g.has(t)){if(c=!0,o[t]=u,i.push(t),!d)continue;a!==(r.default||0)&&(d=!1)}else t.startsWith("origin")?(l=!0,f[t]=u):n[t]=u}if(e.transform||(c||r?n.transform=function({transform:t,transformKeys:e},{enableHardwareAcceleration:a=!0,allowTransformNone:r=!0},n,s){let o="";e.sort(w);for(const a of e)o+=`${v[a]||a}(${t[a]}) `;return a&&!t.z&&(o+="translateZ(0)"),o=o.trim(),s?o=s(t,n?"":o):r&&n&&(o="none"),o}(t,a,d,r):n.transform&&(n.transform="none")),l){const{originX:t="50%",originY:e="50%",originZ:a=0}=f;n.transformOrigin=`${t} ${e} ${a}`}}function F(t,e,a){return"string"==typeof t?t:A.transform(e+a*t)}const I={offset:"stroke-dashoffset",array:"stroke-dasharray"},D={offset:"strokeDashoffset",array:"strokeDasharray"};function E(t,{attrX:e,attrY:a,originX:r,originY:n,pathLength:s,pathSpacing:o=1,pathOffset:i=0,...f},c,l){C(t,f,c,l),t.attrs=t.style,t.style={};const{attrs:d,style:u,dimensions:p}=t;d.transform&&(p&&(u.transform=d.transform),delete d.transform),p&&(void 0!==r||void 0!==n||u.transform)&&(u.transformOrigin=function(t,e,a){return`${F(e,t.x,t.width)} ${F(a,t.y,t.height)}`}(p,void 0!==r?r:.5,void 0!==n?n:.5)),void 0!==e&&(d.x=e),void 0!==a&&(d.y=a),void 0!==s&&function(t,e,a=1,r=0,n=!0){t.pathLength=1;const s=n?I:D;t[s.offset]=A.transform(-r);const o=A.transform(e),i=A.transform(a);t[s.array]=`${o} ${i}`}(d,s,o,i,!1)}const M=t=>t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase();function K(t,{style:e,vars:a},r,n){Object.assign(t.style,e,n&&n.getProjectionStyles(r));for(const e in a)t.style.setProperty(e,a[e])}const q=new Set(["baseFrequency","diffuseConstant","kernelMatrix","kernelUnitLength","keySplines","keyTimes","limitingConeAngle","markerHeight","markerWidth","numOctaves","targetX","targetY","surfaceScale","specularConstant","specularExponent","stdDeviation","tableValues","viewBox","gradientTransform","pathLength"]);function N(t,e,a,r){K(t,e,void 0,r);for(const a in e.attrs)t.setAttribute(q.has(a)?a:M(a),e.attrs[a])}function U(t){const{style:e}=t,a={};for(const r in e)(y(e[r])||h(r,t))&&(a[r]=e[r]);return a}function G(t){const e=U(t);for(const a in t)if(y(t[a])){e["x"===a||"y"===a?"attr"+a.toUpperCase():a]=t[a]}return e}function J(t,e,a,r={},n={}){return"function"==typeof e&&(e=e(void 0!==a?a:t.custom,r,n)),"string"==typeof e&&(e=t.variants&&t.variants[e]),"function"==typeof e&&(e=e(void 0!==a?a:t.custom,r,n)),e}const Q=t=>Array.isArray(t),_=t=>Boolean(t&&"object"==typeof t&&t.mix&&t.toValue),tt=t=>Q(t)?t[t.length-1]||0:t;export{Q as A,z as B,tt as C,A as D,W as E,B as F,R as G,g as H,m as I,b as J,K,q as L,M,e as P,r as a,i as b,n as c,y as d,h as e,l as f,C as g,E as h,a as i,u as j,_ as k,f as l,s as m,N as n,U as o,$ as p,Y as q,J as r,G as s,T as t,Z as u,O as v,L as w,j as x,k as y,X as z};
@@ -1 +1 @@
1
- import*as t from"react";import n,{createContext as e,useContext as r,useLayoutEffect as o,useEffect as a,useRef as s,useCallback as i,useMemo as u,forwardRef as c,createElement as l}from"react";import{i as d,P as m,M as f,a as p,b as y,c as g,f as v,u as h,g as S,S as E,L as w,d as C,e as V,h as A,j as b,k as M,r as P,l as T,m as j,n as x,s as D,o as L,p as B}from"./size-rollup-dom-max-assets.js";const F=e({});const I=d?o:a,O=e({strict:!1});function R(t,n,e,o){const i=r(F).visualElement,u=r(O),c=r(m),l=r(f).reducedMotion,d=s(void 0);o=o||u.renderer,!d.current&&o&&(d.current=o(t,{visualState:n,parent:i,props:e,presenceId:c?c.id:void 0,blockInitialAnimation:!!c&&!1===c.initial,reducedMotionConfig:l}));const p=d.current;return I(()=>{p&&p.syncRender()}),a(()=>{p&&p.animationState&&p.animationState.animateChanges()}),I(()=>()=>p&&p.notifyUnmount(),[]),p}function k(t){const{initial:n,animate:e}=function(t,n){if(y(t)){const{initial:n,animate:e}=t;return{initial:!1===n||g(n)?n:void 0,animate:g(e)?e:void 0}}return!1!==t.inherit?n:{}}(t,r(F));return u(()=>({initial:n,animate:e}),[H(n),H(e)])}function H(t){return Array.isArray(t)?t.join(" "):t}let U=1;class N extends n.Component{getSnapshotBeforeUpdate(){const{visualElement:t,props:n}=this.props;return t&&t.setProps(n),null}componentDidUpdate(){}render(){return this.props.children}}const K=Symbol.for("motionComponentSymbol");function W({preloadedFeatures:n,createVisualElement:e,projectionNodeConstructor:o,useRender:a,useVisualState:s,Component:u}){n&&function(t){for(const n in t)"projectionNodeConstructor"===n?v.projectionNodeConstructor=t[n]:v[n].Component=t[n]}(n);const l=c((function(c,l){const m={...r(f),...c,layoutId:_(c)},{isStatic:y}=m;let g=null;const w=k(c),C=y?void 0:h(()=>{if(S.hasEverUpdated)return U++}),V=s(c,y);if(!y&&d){w.visualElement=R(u,V,m,e);const t=r(O).strict,a=r(E);w.visualElement&&(g=w.visualElement.loadFeatures(m,t,n,C,o||v.projectionNodeConstructor,a))}return t.createElement(N,{visualElement:w.visualElement,props:m},g,t.createElement(F.Provider,{value:w},a(u,c,C,function(t,n,e){return i(r=>{r&&t.mount&&t.mount(r),n&&(r?n.mount(r):n.unmount()),e&&("function"==typeof e?e(r):p(e)&&(e.current=r))},[n])}(V,w.visualElement,l),V,y,w.visualElement)))}));return l[K]=u,l}function _({layoutId:t}){const n=r(w).id;return n&&void 0!==t?n+"-"+t:t}const q=()=>({style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{}});function z(t,n,e){for(const r in n)C(n[r])||V(r,e)||(t[r]=n[r])}function X(t,n,e){const r={};return z(r,t.style||{},t),Object.assign(r,function({transformTemplate:t},n,e){return u(()=>{const r={style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{}};return A(r,n,{enableHardwareAcceleration:!e},t),Object.assign({},r.vars,r.style)},[n])}(t,n,e)),t.transformValues?t.transformValues(r):r}function Y(t,n,e){const r={},o=X(t,n,e);return t.drag&&!1!==t.dragListener&&(r.draggable=!1,o.userSelect=o.WebkitUserSelect=o.WebkitTouchCallout="none",o.touchAction=!0===t.drag?"none":"pan-"+("x"===t.drag?"y":"x")),r.style=o,r}const G=new Set(["initial","style","variants","transition","transformTemplate","transformValues","custom","inherit","layout","layoutId","layoutDependency","onLayoutAnimationStart","onLayoutAnimationComplete","onLayoutMeasure","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","drag","dragControls","dragListener","dragConstraints","dragDirectionLock","dragSnapToOrigin","_dragX","_dragY","dragElastic","dragMomentum","dragPropagation","dragTransition","onHoverStart","onHoverEnd","layoutScroll","whileInView","onViewportEnter","onViewportLeave","viewport","whileTap","onTap","onTapStart","onTapCancel","animate","exit","variants","whileHover","whileTap","whileFocus","whileDrag","whileInView","onPan","onPanStart","onPanSessionStart","onPanEnd"]);function J(t){return G.has(t)}let Q=t=>!J(t);try{(Z=require("@emotion/is-prop-valid").default)&&(Q=t=>t.startsWith("on")?!J(t):Z(t))}catch(t){}var Z;const $=()=>({style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{},attrs:{}});function tt(t,n){const e=u(()=>{const e={style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{},attrs:{}};return b(e,n,{enableHardwareAcceleration:!1},t.transformTemplate),{...e.attrs,style:{...e.style}}},[n]);if(t.style){const n={};z(n,t.style,t),e.style={...n,...e.style}}return e}function nt(t=!1){return(n,e,r,o,{latestValues:a},s)=>{const i=(M(n)?tt:Y)(e,a,s),u={...function(t,n,e){const r={};for(const o in t)(Q(o)||!0===e&&J(o)||!n&&!J(o)||t.draggable&&o.startsWith("onDrag"))&&(r[o]=t[o]);return r}(e,"string"==typeof n,t),...i,ref:o};return r&&(u["data-projection-id"]=r),l(n,u)}}const et=t=>(n,e)=>{const o=r(F),a=r(m),s=()=>function({scrapeMotionValuesFromProps:t,createRenderState:n,onMount:e},r,o,a){const s={latestValues:rt(r,o,a,t),renderState:n()};return e&&(s.mount=t=>e(r,t,s)),s}(t,n,o,a);return e?s():h(s)};function rt(t,n,e,r){const o={},a=r(t);for(const t in a)o[t]=P(a[t]);let{initial:s,animate:i}=t;const u=y(t),c=T(t);n&&c&&!u&&!1!==t.inherit&&(void 0===s&&(s=n.initial),void 0===i&&(i=n.animate));let l=!!e&&!1===e.initial;l=l||!1===s;const d=l?i:s;if(d&&"boolean"!=typeof d&&!j(d)){(Array.isArray(d)?d:[d]).forEach(n=>{const e=x(t,n);if(!e)return;const{transitionEnd:r,transition:a,...s}=e;for(const t in s){let n=s[t];if(Array.isArray(n)){n=n[l?n.length-1:0]}null!==n&&(o[t]=n)}for(const t in r)o[t]=r[t]})}return o}const ot={useVisualState:et({scrapeMotionValuesFromProps:D,createRenderState:$,onMount:(t,n,{renderState:e,latestValues:r})=>{try{e.dimensions="function"==typeof n.getBBox?n.getBBox():n.getBoundingClientRect()}catch(t){e.dimensions={x:0,y:0,width:0,height:0}}b(e,r,{enableHardwareAcceleration:!1},t.transformTemplate),L(n,e)}})},at={useVisualState:et({scrapeMotionValuesFromProps:B,createRenderState:q})};const st=function(t){function n(n,e={}){return W(t(n,e))}if("undefined"==typeof Proxy)return n;const e=new Map;return new Proxy(n,{get:(t,r)=>(e.has(r)||e.set(r,n(r)),e.get(r))})}((function(t,{forwardMotionProps:n=!1},e,r,o){return{...M(t)?ot:at,preloadedFeatures:e,useRender:nt(n),createVisualElement:r,projectionNodeConstructor:o,Component:t}}));export{st as m};
1
+ import*as t from"react";import n,{createContext as e,useContext as r,useLayoutEffect as o,useEffect as a,useRef as s,useCallback as i,useMemo as u,forwardRef as c,createElement as l}from"react";import{i as d,P as m,M as f,a as p,b as y,c as g,f as v,u as h,g as S,S as E,L as w,d as C,e as V,h as A,j as b,k as M,r as P,l as T,m as j,n as x,s as D,o as L,p as B}from"./size-rollup-dom-max-assets.js";const F=e({});const I=d?o:a,O=e({strict:!1});function R(t,n,e,o){const i=r(F).visualElement,u=r(O),c=r(m),l=r(f).reducedMotion,d=s(void 0);o=o||u.renderer,!d.current&&o&&(d.current=o(t,{visualState:n,parent:i,props:e,presenceId:c?c.id:void 0,blockInitialAnimation:!!c&&!1===c.initial,reducedMotionConfig:l}));const p=d.current;return I(()=>{p&&p.syncRender()}),a(()=>{p&&p.animationState&&p.animationState.animateChanges()}),I(()=>()=>p&&p.notifyUnmount(),[]),p}function k(t){const{initial:n,animate:e}=function(t,n){if(y(t)){const{initial:n,animate:e}=t;return{initial:!1===n||g(n)?n:void 0,animate:g(e)?e:void 0}}return!1!==t.inherit?n:{}}(t,r(F));return u(()=>({initial:n,animate:e}),[H(n),H(e)])}function H(t){return Array.isArray(t)?t.join(" "):t}let U=1;class N extends n.Component{getSnapshotBeforeUpdate(){const{visualElement:t,props:n}=this.props;return t&&t.setProps(n),null}componentDidUpdate(){}render(){return this.props.children}}const K=Symbol.for("motionComponentSymbol");function W({preloadedFeatures:n,createVisualElement:e,projectionNodeConstructor:o,useRender:a,useVisualState:s,Component:u}){n&&function(t){for(const n in t)"projectionNodeConstructor"===n?v.projectionNodeConstructor=t[n]:v[n].Component=t[n]}(n);const l=c((function(c,l){const m={...r(f),...c,layoutId:_(c)},{isStatic:y}=m;let g=null;const w=k(c),C=y?void 0:h(()=>{if(S.hasEverUpdated)return U++}),V=s(c,y);if(!y&&d){w.visualElement=R(u,V,m,e);const t=r(O).strict,a=r(E);w.visualElement&&(g=w.visualElement.loadFeatures(m,t,n,C,o||v.projectionNodeConstructor,a))}return t.createElement(N,{visualElement:w.visualElement,props:m},g,t.createElement(F.Provider,{value:w},a(u,c,C,function(t,n,e){return i(r=>{r&&t.mount&&t.mount(r),n&&(r?n.mount(r):n.unmount()),e&&("function"==typeof e?e(r):p(e)&&(e.current=r))},[n])}(V,w.visualElement,l),V,y,w.visualElement)))}));return l[K]=u,l}function _({layoutId:t}){const n=r(w).id;return n&&void 0!==t?n+"-"+t:t}const q=()=>({style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{}});function z(t,n,e){for(const r in n)C(n[r])||V(r,e)||(t[r]=n[r])}function X(t,n,e){const r={};return z(r,t.style||{},t),Object.assign(r,function({transformTemplate:t},n,e){return u(()=>{const r={style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{}};return A(r,n,{enableHardwareAcceleration:!e},t),Object.assign({},r.vars,r.style)},[n])}(t,n,e)),t.transformValues?t.transformValues(r):r}function Y(t,n,e){const r={},o=X(t,n,e);return t.drag&&!1!==t.dragListener&&(r.draggable=!1,o.userSelect=o.WebkitUserSelect=o.WebkitTouchCallout="none",o.touchAction=!0===t.drag?"none":"pan-"+("x"===t.drag?"y":"x")),r.style=o,r}const G=new Set(["initial","style","values","variants","transition","transformTemplate","transformValues","custom","inherit","layout","layoutId","layoutDependency","onLayoutAnimationStart","onLayoutAnimationComplete","onLayoutMeasure","onBeforeLayoutMeasure","onAnimationStart","onAnimationComplete","onUpdate","onDragStart","onDrag","onDragEnd","onMeasureDragConstraints","onDirectionLock","onDragTransitionEnd","drag","dragControls","dragListener","dragConstraints","dragDirectionLock","dragSnapToOrigin","_dragX","_dragY","dragElastic","dragMomentum","dragPropagation","dragTransition","onHoverStart","onHoverEnd","layoutScroll","whileInView","onViewportEnter","onViewportLeave","viewport","whileTap","onTap","onTapStart","onTapCancel","animate","exit","variants","whileHover","whileTap","whileFocus","whileDrag","whileInView","onPan","onPanStart","onPanSessionStart","onPanEnd"]);function J(t){return G.has(t)}let Q=t=>!J(t);try{(Z=require("@emotion/is-prop-valid").default)&&(Q=t=>t.startsWith("on")?!J(t):Z(t))}catch(t){}var Z;const $=()=>({style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{},attrs:{}});function tt(t,n){const e=u(()=>{const e={style:{},transform:{},transformKeys:[],transformOrigin:{},vars:{},attrs:{}};return b(e,n,{enableHardwareAcceleration:!1},t.transformTemplate),{...e.attrs,style:{...e.style}}},[n]);if(t.style){const n={};z(n,t.style,t),e.style={...n,...e.style}}return e}function nt(t=!1){return(n,e,r,o,{latestValues:a},s)=>{const i=(M(n)?tt:Y)(e,a,s),u={...function(t,n,e){const r={};for(const o in t)(Q(o)||!0===e&&J(o)||!n&&!J(o)||t.draggable&&o.startsWith("onDrag"))&&(r[o]=t[o]);return r}(e,"string"==typeof n,t),...i,ref:o};return r&&(u["data-projection-id"]=r),l(n,u)}}const et=t=>(n,e)=>{const o=r(F),a=r(m),s=()=>function({scrapeMotionValuesFromProps:t,createRenderState:n,onMount:e},r,o,a){const s={latestValues:rt(r,o,a,t),renderState:n()};return e&&(s.mount=t=>e(r,t,s)),s}(t,n,o,a);return e?s():h(s)};function rt(t,n,e,r){const o={},a=r(t);for(const t in a)o[t]=P(a[t]);let{initial:s,animate:i}=t;const u=y(t),c=T(t);n&&c&&!u&&!1!==t.inherit&&(void 0===s&&(s=n.initial),void 0===i&&(i=n.animate));let l=!!e&&!1===e.initial;l=l||!1===s;const d=l?i:s;if(d&&"boolean"!=typeof d&&!j(d)){(Array.isArray(d)?d:[d]).forEach(n=>{const e=x(t,n);if(!e)return;const{transitionEnd:r,transition:a,...s}=e;for(const t in s){let n=s[t];if(Array.isArray(n)){n=n[l?n.length-1:0]}null!==n&&(o[t]=n)}for(const t in r)o[t]=r[t]})}return o}const ot={useVisualState:et({scrapeMotionValuesFromProps:D,createRenderState:$,onMount:(t,n,{renderState:e,latestValues:r})=>{try{e.dimensions="function"==typeof n.getBBox?n.getBBox():n.getBoundingClientRect()}catch(t){e.dimensions={x:0,y:0,width:0,height:0}}b(e,r,{enableHardwareAcceleration:!1},t.transformTemplate),L(n,e)}})},at={useVisualState:et({scrapeMotionValuesFromProps:B,createRenderState:q})};const st=function(t){function n(n,e={}){return W(t(n,e))}if("undefined"==typeof Proxy)return n;const e=new Map;return new Proxy(n,{get:(t,r)=>(e.has(r)||e.set(r,n(r)),e.get(r))})}((function(t,{forwardMotionProps:n=!1},e,r,o){return{...M(t)?ot:at,preloadedFeatures:e,useRender:nt(n),createVisualElement:r,projectionNodeConstructor:o,Component:t}}));export{st as m};