quirk-ui 0.1.217 → 0.1.218
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.
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require('../../../index38.css');const t=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require('../../../index38.css');const t=require("react/jsx-runtime"),r=require("react"),M=require("react-dom"),P=require("../../../x-Dft9NVe_.cjs"),F="_overlay_1krlg_2",K="_fadeIn_1krlg_1",X="_fadeOut_1krlg_1",G="_closing_1krlg_14",H="_container_1krlg_20",J="_modal_1krlg_50",Q="_slideUp_1krlg_1",V="_closeButton_1krlg_63",W="_content_1krlg_90",Y="_intro_1krlg_109",Z="_title_1krlg_116",O="_trigger_1krlg_126",ee="_slideUpSheet_1krlg_1",te="_slideDownSheet_1krlg_1",n={overlay:F,fadeIn:K,fadeOut:X,closing:G,container:H,"size-sm":"_size-sm_1krlg_27","size-md":"_size-md_1krlg_31","size-lg":"_size-lg_1krlg_35","size-xl":"_size-xl_1krlg_39","size-full":"_size-full_1krlg_43",modal:J,slideUp:Q,closeButton:V,content:W,intro:Y,title:Z,trigger:O,slideUpSheet:ee,slideDownSheet:te};function ne({content:m,trigger:E,isOpen:v,onOpen:o,onClose:i,size:w="md",closeOnEscape:k=!0,closeOnOverlayClick:S=!0,showCloseButton:$=!0,className:j,overlayClassName:I,style:T,formData:y,renderForm:h}){const[B,b]=r.useState(!1),[_,x]=r.useState(!1),f=r.useRef(null),p=r.useRef(null),g=v!==void 0,s=g?v:B,R=s||_,q=()=>{p.current=document.activeElement,g||b(!0),o==null||o()},d=()=>{x(!0),setTimeout(()=>{var e;x(!1),g||b(!1),i==null||i(),(e=p.current)==null||e.focus()},300)},N=()=>s?d():q(),U=()=>{S&&d()};r.useEffect(()=>{if(!k||!s)return;const e=c=>{c.key==="Escape"&&d()};return document.addEventListener("keydown",e),()=>document.removeEventListener("keydown",e)},[s,k]),r.useEffect(()=>{if(typeof document>"u")return;const e=document.getElementById("__next")??document.getElementById("root")??document.body.firstElementChild;if(!(!e||e===document.body))return s?(e.setAttribute("inert",""),e.style.overflow="hidden"):(e.removeAttribute("inert"),e.style.overflow=""),()=>{e.removeAttribute("inert"),e.style.overflow=""}},[s]),r.useEffect(()=>{if(!s||!f.current)return;const e=f.current;e.scrollTop=0;const c=e.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])'),l=c[0],a=c[c.length-1],z=u=>{u.key==="Tab"&&(u.shiftKey?document.activeElement===l&&(u.preventDefault(),a==null||a.focus()):document.activeElement===a&&(u.preventDefault(),l==null||l.focus()))};e.addEventListener("keydown",z);const L=setTimeout(()=>l==null?void 0:l.focus(),50);return()=>{e.removeEventListener("keydown",z),clearTimeout(L)}},[s]);const D=n[`size-${w}`]??"",A=m!==void 0?m:t.jsx(t.Fragment,{children:y&&h?h(y):null}),C=R?t.jsx("div",{className:`${n.overlay} ${_?n.closing:""} ${I??""}`.trim(),onClick:U,role:"dialog","aria-modal":"true",children:t.jsx("div",{className:`${D} ${n.container} ${_?n.closing:""}`,children:t.jsxs("div",{ref:f,className:`${n.modal} ${j??""}`.trim(),style:T,onClick:e=>e.stopPropagation(),children:[$&&t.jsx("button",{"aria-label":"Close",className:n.closeButton,onClick:d,type:"button",children:t.jsx(P.X,{size:20})}),t.jsx("div",{className:n.content,children:A})]})})}):null;return t.jsxs(t.Fragment,{children:[t.jsx("div",{className:n.trigger,onClick:N,children:E}),typeof window<"u"&&M.createPortal(C,document.body)]})}exports.Modal=ne;
|
|
@@ -1,61 +1,61 @@
|
|
|
1
|
-
import { jsx as
|
|
1
|
+
import { jsx as o, Fragment as E, jsxs as x } from "react/jsx-runtime";
|
|
2
2
|
import { useState as $, useRef as I, useEffect as f } from "react";
|
|
3
3
|
import { createPortal as X } from "react-dom";
|
|
4
4
|
import { X as G } from "../../../x-CnsEH4Ox.js";
|
|
5
|
-
import '../../../index38.css';const H = "
|
|
5
|
+
import '../../../index38.css';const H = "_overlay_1krlg_2", J = "_fadeIn_1krlg_1", Q = "_fadeOut_1krlg_1", V = "_closing_1krlg_14", W = "_container_1krlg_20", Y = "_modal_1krlg_50", Z = "_slideUp_1krlg_1", O = "_closeButton_1krlg_63", ee = "_content_1krlg_90", te = "_intro_1krlg_109", ne = "_title_1krlg_116", le = "_trigger_1krlg_126", oe = "_slideUpSheet_1krlg_1", re = "_slideDownSheet_1krlg_1", t = {
|
|
6
6
|
overlay: H,
|
|
7
7
|
fadeIn: J,
|
|
8
8
|
fadeOut: Q,
|
|
9
9
|
closing: V,
|
|
10
10
|
container: W,
|
|
11
|
-
"size-sm": "_size-
|
|
12
|
-
"size-md": "_size-
|
|
13
|
-
"size-lg": "_size-
|
|
14
|
-
"size-xl": "_size-
|
|
15
|
-
"size-full": "_size-
|
|
11
|
+
"size-sm": "_size-sm_1krlg_27",
|
|
12
|
+
"size-md": "_size-md_1krlg_31",
|
|
13
|
+
"size-lg": "_size-lg_1krlg_35",
|
|
14
|
+
"size-xl": "_size-xl_1krlg_39",
|
|
15
|
+
"size-full": "_size-full_1krlg_43",
|
|
16
16
|
modal: Y,
|
|
17
17
|
slideUp: Z,
|
|
18
18
|
closeButton: O,
|
|
19
19
|
content: ee,
|
|
20
20
|
intro: te,
|
|
21
21
|
title: ne,
|
|
22
|
-
trigger:
|
|
23
|
-
slideUpSheet:
|
|
24
|
-
slideDownSheet:
|
|
22
|
+
trigger: le,
|
|
23
|
+
slideUpSheet: oe,
|
|
24
|
+
slideDownSheet: re
|
|
25
25
|
};
|
|
26
|
-
function
|
|
27
|
-
content:
|
|
26
|
+
function ae({
|
|
27
|
+
content: g,
|
|
28
28
|
trigger: S,
|
|
29
|
-
isOpen:
|
|
30
|
-
onOpen:
|
|
31
|
-
onClose:
|
|
29
|
+
isOpen: v,
|
|
30
|
+
onOpen: r,
|
|
31
|
+
onClose: s,
|
|
32
32
|
size: B = "md",
|
|
33
|
-
closeOnEscape:
|
|
33
|
+
closeOnEscape: k = !0,
|
|
34
34
|
closeOnOverlayClick: T = !0,
|
|
35
35
|
showCloseButton: N = !0,
|
|
36
36
|
className: U,
|
|
37
37
|
overlayClassName: A,
|
|
38
38
|
style: C,
|
|
39
|
-
formData:
|
|
40
|
-
renderForm:
|
|
39
|
+
formData: y,
|
|
40
|
+
renderForm: h
|
|
41
41
|
}) {
|
|
42
|
-
const [D,
|
|
43
|
-
|
|
42
|
+
const [D, p] = $(!1), [u, b] = $(!1), _ = I(null), z = I(null), m = v !== void 0, n = m ? v : D, L = n || u, R = () => {
|
|
43
|
+
z.current = document.activeElement, m || p(!0), r == null || r();
|
|
44
44
|
}, c = () => {
|
|
45
|
-
|
|
45
|
+
b(!0), setTimeout(() => {
|
|
46
46
|
var e;
|
|
47
|
-
|
|
47
|
+
b(!1), m || p(!1), s == null || s(), (e = z.current) == null || e.focus();
|
|
48
48
|
}, 300);
|
|
49
49
|
}, j = () => n ? c() : R(), P = () => {
|
|
50
50
|
T && c();
|
|
51
51
|
};
|
|
52
52
|
f(() => {
|
|
53
|
-
if (!
|
|
54
|
-
const e = (
|
|
55
|
-
|
|
53
|
+
if (!k || !n) return;
|
|
54
|
+
const e = (i) => {
|
|
55
|
+
i.key === "Escape" && c();
|
|
56
56
|
};
|
|
57
57
|
return document.addEventListener("keydown", e), () => document.removeEventListener("keydown", e);
|
|
58
|
-
}, [n,
|
|
58
|
+
}, [n, k]), f(() => {
|
|
59
59
|
if (typeof document > "u") return;
|
|
60
60
|
const e = document.getElementById("__next") ?? document.getElementById("root") ?? document.body.firstElementChild;
|
|
61
61
|
if (!(!e || e === document.body))
|
|
@@ -66,28 +66,28 @@ function de({
|
|
|
66
66
|
if (!n || !_.current) return;
|
|
67
67
|
const e = _.current;
|
|
68
68
|
e.scrollTop = 0;
|
|
69
|
-
const
|
|
69
|
+
const i = e.querySelectorAll(
|
|
70
70
|
'button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])'
|
|
71
|
-
),
|
|
72
|
-
|
|
71
|
+
), l = i[0], d = i[i.length - 1], w = (a) => {
|
|
72
|
+
a.key === "Tab" && (a.shiftKey ? document.activeElement === l && (a.preventDefault(), d == null || d.focus()) : document.activeElement === d && (a.preventDefault(), l == null || l.focus()));
|
|
73
73
|
};
|
|
74
|
-
e.addEventListener("keydown",
|
|
75
|
-
const M = setTimeout(() =>
|
|
74
|
+
e.addEventListener("keydown", w);
|
|
75
|
+
const M = setTimeout(() => l == null ? void 0 : l.focus(), 50);
|
|
76
76
|
return () => {
|
|
77
|
-
e.removeEventListener("keydown",
|
|
77
|
+
e.removeEventListener("keydown", w), clearTimeout(M);
|
|
78
78
|
};
|
|
79
79
|
}, [n]);
|
|
80
|
-
const q = t[`size-${B}`] ?? "", F =
|
|
80
|
+
const q = t[`size-${B}`] ?? "", F = g !== void 0 ? g : /* @__PURE__ */ o(E, { children: y && h ? h(y) : null }), K = L ? /* @__PURE__ */ o(
|
|
81
81
|
"div",
|
|
82
82
|
{
|
|
83
|
-
className: `${t.overlay} ${
|
|
83
|
+
className: `${t.overlay} ${u ? t.closing : ""} ${A ?? ""}`.trim(),
|
|
84
84
|
onClick: P,
|
|
85
85
|
role: "dialog",
|
|
86
86
|
"aria-modal": "true",
|
|
87
|
-
children: /* @__PURE__ */
|
|
87
|
+
children: /* @__PURE__ */ o(
|
|
88
88
|
"div",
|
|
89
89
|
{
|
|
90
|
-
className: `${q} ${t.container} ${
|
|
90
|
+
className: `${q} ${t.container} ${u ? t.closing : ""}`,
|
|
91
91
|
children: /* @__PURE__ */ x(
|
|
92
92
|
"div",
|
|
93
93
|
{
|
|
@@ -96,17 +96,17 @@ function de({
|
|
|
96
96
|
style: C,
|
|
97
97
|
onClick: (e) => e.stopPropagation(),
|
|
98
98
|
children: [
|
|
99
|
-
N && /* @__PURE__ */
|
|
99
|
+
N && /* @__PURE__ */ o(
|
|
100
100
|
"button",
|
|
101
101
|
{
|
|
102
102
|
"aria-label": "Close",
|
|
103
103
|
className: t.closeButton,
|
|
104
104
|
onClick: c,
|
|
105
105
|
type: "button",
|
|
106
|
-
children: /* @__PURE__ */
|
|
106
|
+
children: /* @__PURE__ */ o(G, { size: 20 })
|
|
107
107
|
}
|
|
108
108
|
),
|
|
109
|
-
/* @__PURE__ */
|
|
109
|
+
/* @__PURE__ */ o("div", { className: t.content, children: F })
|
|
110
110
|
]
|
|
111
111
|
}
|
|
112
112
|
)
|
|
@@ -115,10 +115,10 @@ function de({
|
|
|
115
115
|
}
|
|
116
116
|
) : null;
|
|
117
117
|
return /* @__PURE__ */ x(E, { children: [
|
|
118
|
-
/* @__PURE__ */
|
|
118
|
+
/* @__PURE__ */ o("div", { className: t.trigger, onClick: j, children: S }),
|
|
119
119
|
typeof window < "u" && X(K, document.body)
|
|
120
120
|
] });
|
|
121
121
|
}
|
|
122
122
|
export {
|
|
123
|
-
|
|
123
|
+
ae as Modal
|
|
124
124
|
};
|
package/dist/index38.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.
|
|
1
|
+
._overlay_1krlg_2{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md, 1rem);overflow-y:auto;animation:_fadeIn_1krlg_1 .2s ease forwards}._overlay_1krlg_2._closing_1krlg_14{animation:_fadeOut_1krlg_1 .28s ease forwards}._container_1krlg_20{position:relative;display:flex;flex-direction:column}._size-sm_1krlg_27{width:90%;max-width:400px}._size-md_1krlg_31{width:90%;max-width:600px}._size-lg_1krlg_35{width:90%;max-width:800px}._size-xl_1krlg_39{width:90%;max-width:1200px}._size-full_1krlg_43{width:95%;height:95dvh;max-height:95dvh}._modal_1krlg_50{position:relative;background-color:var(--color-background, #fff);border-radius:var(--radius-lg, .5rem);padding:var(--spacing-xl, 2rem);padding-top:calc(var(--spacing-xl, 2rem) + .5rem);max-height:90dvh;overflow-y:auto;animation:_slideUp_1krlg_1 .3s ease forwards}._closeButton_1krlg_63{position:absolute;top:var(--spacing-sm, .5rem);right:var(--spacing-sm, .5rem);background:none;border:none;cursor:pointer;padding:var(--spacing-xs, .25rem);border-radius:var(--radius-sm, .25rem);color:var(--color-text-primary, #333);transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:1}._closeButton_1krlg_63:hover{background-color:#ffffff26}._closeButton_1krlg_63:focus-visible{outline:2px solid var(--color-primary-100, #007bff);outline-offset:2px}._content_1krlg_90{color:var(--color-text-primary, #333);line-height:var(--line-height-normal, 1.5);display:flex;flex-direction:column;gap:var(--spacing-lg)}._content_1krlg_90 video,._content_1krlg_90 img{max-width:100%;height:auto;border-radius:var(--radius-md, .5rem)}._content_1krlg_90 video{width:100%}._intro_1krlg_109{margin-bottom:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-lg, 1.5rem);border-bottom:1px solid var(--color-border, #e5e7eb)}._title_1krlg_116{font-size:var(--font-size-xl, 1.5rem);font-weight:var(--font-weight-bold, 700);color:var(--color-heading, #111);margin-bottom:var(--spacing-lg, 1.5rem);padding-right:var(--spacing-xl, 2rem);line-height:var(--line-height-heading, 1.2)}._trigger_1krlg_126{width:auto;display:inline-block;cursor:pointer}@keyframes _fadeIn_1krlg_1{0%{opacity:0}to{opacity:1}}@keyframes _fadeOut_1krlg_1{0%{opacity:1}to{opacity:0}}@keyframes _slideUp_1krlg_1{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 767px){._overlay_1krlg_2{align-items:flex-end;padding:0;overflow:hidden}._overlay_1krlg_2._closing_1krlg_14{animation:_fadeOut_1krlg_1 .28s ease forwards}._container_1krlg_20{width:100%;max-width:100%;max-height:92dvh;display:flex;flex-direction:column;border-radius:var(--radius-lg, .5rem) var(--radius-lg, .5rem) 0 0;background-color:var(--color-background, #fff);animation:_slideUpSheet_1krlg_1 .32s cubic-bezier(.32,.72,0,1) forwards;padding-bottom:env(safe-area-inset-bottom);overflow:hidden}._container_1krlg_20._closing_1krlg_14{animation:_slideDownSheet_1krlg_1 .28s cubic-bezier(.32,.72,0,1) forwards}._size-sm_1krlg_27,._size-md_1krlg_31,._size-lg_1krlg_35,._size-xl_1krlg_39,._size-full_1krlg_43{width:100%;max-width:100%;max-height:92dvh;height:auto}._closeButton_1krlg_63{position:absolute;top:var(--spacing-sm, .5rem);right:var(--spacing-sm, .5rem);background:none;border:none;cursor:pointer;padding:var(--spacing-xs, .25rem);border-radius:var(--radius-sm, .25rem);transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:1;color:var(--color-text-primary, #333)}._modal_1krlg_50{animation:none;border-radius:0;padding:calc(var(--spacing-xl) + .5rem) var(--spacing-lg) var(--spacing-lg);flex:1;min-height:0;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}._content_1krlg_90{width:100%}._title_1krlg_116{font-size:var(--font-size-lg, 1.25rem);padding-right:0}}@keyframes _slideUpSheet_1krlg_1{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes _slideDownSheet_1krlg_1{0%{transform:translateY(0)}to{transform:translateY(110%)}}
|