UNPKG

smartopt-ui

Version:

Modern React UI component library with scoped CSS and CSS variables

810 lines (808 loc) 201 kB
import De, { useState as R, useRef as he, useEffect as ce, useLayoutEffect as Ht, createContext as nt, useContext as rt, useCallback as zt, lazy as ot, Suspense as Tt } from "react"; import { createPortal as Rt } from "react-dom"; var Te = { exports: {} }, Se = {}; /** * @license React * react-jsx-runtime.production.js * * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ var At; function Gt() { if (At) return Se; At = 1; var n = Symbol.for("react.transitional.element"), e = Symbol.for("react.fragment"); function t(s, r, a) { var A = null; if (a !== void 0 && (A = "" + a), r.key !== void 0 && (A = "" + r.key), "key" in r) { a = {}; for (var l in r) l !== "key" && (a[l] = r[l]); } else a = r; return r = a.ref, { $$typeof: n, type: s, key: A, ref: r !== void 0 ? r : null, props: a }; } return Se.Fragment = e, Se.jsx = t, Se.jsxs = t, Se; } var Ie = {}; /** * @license React * react-jsx-runtime.development.js * * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ var it; function Ft() { return it || (it = 1, process.env.NODE_ENV !== "production" && function() { function n(i) { if (i == null) return null; if (typeof i == "function") return i.$$typeof === pe ? null : i.displayName || i.name || null; if (typeof i == "string") return i; switch (i) { case P: return "Fragment"; case M: return "Portal"; case H: return "Profiler"; case k: return "StrictMode"; case O: return "Suspense"; case X: return "SuspenseList"; } if (typeof i == "object") switch (typeof i.tag == "number" && console.error( "Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue." ), i.$$typeof) { case F: return (i.displayName || "Context") + ".Provider"; case S: return (i._context.displayName || "Context") + ".Consumer"; case Q: var D = i.render; return i = i.displayName, i || (i = D.displayName || D.name || "", i = i !== "" ? "ForwardRef(" + i + ")" : "ForwardRef"), i; case B: return D = i.displayName || null, D !== null ? D : n(i.type) || "Memo"; case T: D = i._payload, i = i._init; try { return n(i(D)); } catch { } } return null; } function e(i) { return "" + i; } function t(i) { try { e(i); var D = !1; } catch { D = !0; } if (D) { D = console; var j = D.error, G = typeof Symbol == "function" && Symbol.toStringTag && i[Symbol.toStringTag] || i.constructor.name || "Object"; return j.call( D, "The provided key is an unsupported type %s. This value must be coerced to a string before using it here.", G ), e(i); } } function s() { } function r() { if (me === 0) { Ee = console.log, be = console.info, N = console.warn, J = console.error, ee = console.group, E = console.groupCollapsed, b = console.groupEnd; var i = { configurable: !0, enumerable: !0, value: s, writable: !0 }; Object.defineProperties(console, { info: i, log: i, warn: i, error: i, group: i, groupCollapsed: i, groupEnd: i }); } me++; } function a() { if (me--, me === 0) { var i = { configurable: !0, enumerable: !0, writable: !0 }; Object.defineProperties(console, { log: re({}, i, { value: Ee }), info: re({}, i, { value: be }), warn: re({}, i, { value: N }), error: re({}, i, { value: J }), group: re({}, i, { value: ee }), groupCollapsed: re({}, i, { value: E }), groupEnd: re({}, i, { value: b }) }); } 0 > me && console.error( "disabledDepth fell below zero. This is a bug in React. Please file an issue." ); } function A(i) { if (W === void 0) try { throw Error(); } catch (j) { var D = j.stack.trim().match(/\n( *(at )?)/); W = D && D[1] || "", V = -1 < j.stack.indexOf(` at`) ? " (<anonymous>)" : -1 < j.stack.indexOf("@") ? "@unknown:0:0" : ""; } return ` ` + W + i + V; } function l(i, D) { if (!i || te) return ""; var j = ue.get(i); if (j !== void 0) return j; te = !0, j = Error.prepareStackTrace, Error.prepareStackTrace = void 0; var G = null; G = U.H, U.H = null, r(); try { var Ae = { DetermineComponentFrameRoot: function() { try { if (D) { var v = function() { throw Error(); }; if (Object.defineProperty(v.prototype, "props", { set: function() { throw Error(); } }), typeof Reflect == "object" && Reflect.construct) { try { Reflect.construct(v, []); } catch (K) { var Z = K; } Reflect.construct(i, [], v); } else { try { v.call(); } catch (K) { Z = K; } i.call(v.prototype); } } else { try { throw Error(); } catch (K) { Z = K; } (v = i()) && typeof v.catch == "function" && v.catch(function() { }); } } catch (K) { if (K && Z && typeof K.stack == "string") return [K.stack, Z.stack]; } return [null, null]; } }; Ae.DetermineComponentFrameRoot.displayName = "DetermineComponentFrameRoot"; var q = Object.getOwnPropertyDescriptor( Ae.DetermineComponentFrameRoot, "name" ); q && q.configurable && Object.defineProperty( Ae.DetermineComponentFrameRoot, "name", { value: "DetermineComponentFrameRoot" } ); var z = Ae.DetermineComponentFrameRoot(), xe = z[0], ye = z[1]; if (xe && ye) { var le = xe.split(` `), ve = ye.split(` `); for (z = q = 0; q < le.length && !le[q].includes( "DetermineComponentFrameRoot" ); ) q++; for (; z < ve.length && !ve[z].includes( "DetermineComponentFrameRoot" ); ) z++; if (q === le.length || z === ve.length) for (q = le.length - 1, z = ve.length - 1; 1 <= q && 0 <= z && le[q] !== ve[z]; ) z--; for (; 1 <= q && 0 <= z; q--, z--) if (le[q] !== ve[z]) { if (q !== 1 || z !== 1) do if (q--, z--, 0 > z || le[q] !== ve[z]) { var h = ` ` + le[q].replace( " at new ", " at " ); return i.displayName && h.includes("<anonymous>") && (h = h.replace("<anonymous>", i.displayName)), typeof i == "function" && ue.set(i, h), h; } while (1 <= q && 0 <= z); break; } } } finally { te = !1, U.H = G, a(), Error.prepareStackTrace = j; } return le = (le = i ? i.displayName || i.name : "") ? A(le) : "", typeof i == "function" && ue.set(i, le), le; } function c(i) { if (i == null) return ""; if (typeof i == "function") { var D = i.prototype; return l( i, !(!D || !D.isReactComponent) ); } if (typeof i == "string") return A(i); switch (i) { case O: return A("Suspense"); case X: return A("SuspenseList"); } if (typeof i == "object") switch (i.$$typeof) { case Q: return i = l(i.render, !1), i; case B: return c(i.type); case T: D = i._payload, i = i._init; try { return c(i(D)); } catch { } } return ""; } function u() { var i = U.A; return i === null ? null : i.getOwner(); } function g(i) { if (ne.call(i, "key")) { var D = Object.getOwnPropertyDescriptor(i, "key").get; if (D && D.isReactWarning) return !1; } return i.key !== void 0; } function f(i, D) { function j() { Ne || (Ne = !0, console.error( "%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)", D )); } j.isReactWarning = !0, Object.defineProperty(i, "key", { get: j, configurable: !0 }); } function d() { var i = n(this.type); return Me[i] || (Me[i] = !0, console.error( "Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release." )), i = this.props.ref, i !== void 0 ? i : null; } function p(i, D, j, G, Ae, q) { return j = q.ref, i = { $$typeof: I, type: i, key: D, props: q, _owner: Ae }, (j !== void 0 ? j : null) !== null ? Object.defineProperty(i, "ref", { enumerable: !1, get: d }) : Object.defineProperty(i, "ref", { enumerable: !1, value: null }), i._store = {}, Object.defineProperty(i._store, "validated", { configurable: !1, enumerable: !1, writable: !0, value: 0 }), Object.defineProperty(i, "_debugInfo", { configurable: !1, enumerable: !1, writable: !0, value: null }), Object.freeze && (Object.freeze(i.props), Object.freeze(i)), i; } function m(i, D, j, G, Ae, q) { if (typeof i == "string" || typeof i == "function" || i === P || i === H || i === k || i === O || i === X || i === $ || typeof i == "object" && i !== null && (i.$$typeof === T || i.$$typeof === B || i.$$typeof === F || i.$$typeof === S || i.$$typeof === Q || i.$$typeof === fe || i.getModuleId !== void 0)) { var z = D.children; if (z !== void 0) if (G) if (ae(z)) { for (G = 0; G < z.length; G++) C(z[G], i); Object.freeze && Object.freeze(z); } else console.error( "React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead." ); else C(z, i); } else z = "", (i === void 0 || typeof i == "object" && i !== null && Object.keys(i).length === 0) && (z += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports."), i === null ? G = "null" : ae(i) ? G = "array" : i !== void 0 && i.$$typeof === I ? (G = "<" + (n(i.type) || "Unknown") + " />", z = " Did you accidentally export a JSX literal instead of a component?") : G = typeof i, console.error( "React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", G, z ); if (ne.call(D, "key")) { z = n(i); var xe = Object.keys(D).filter(function(le) { return le !== "key"; }); G = 0 < xe.length ? "{key: someKey, " + xe.join(": ..., ") + ": ...}" : "{key: someKey}", Oe[z + G] || (xe = 0 < xe.length ? "{" + xe.join(": ..., ") + ": ...}" : "{}", console.error( `A props object containing a "key" prop is being spread into JSX: let props = %s; <%s {...props} /> React keys must be passed directly to JSX without using spread: let props = %s; <%s key={someKey} {...props} />`, G, z, xe, z ), Oe[z + G] = !0); } if (z = null, j !== void 0 && (t(j), z = "" + j), g(D) && (t(D.key), z = "" + D.key), "key" in D) { j = {}; for (var ye in D) ye !== "key" && (j[ye] = D[ye]); } else j = D; return z && f( j, typeof i == "function" ? i.displayName || i.name || "Unknown" : i ), p(i, z, q, Ae, u(), j); } function C(i, D) { if (typeof i == "object" && i && i.$$typeof !== je) { if (ae(i)) for (var j = 0; j < i.length; j++) { var G = i[j]; y(G) && L(G, D); } else if (y(i)) i._store && (i._store.validated = 1); else if (i === null || typeof i != "object" ? j = null : (j = se && i[se] || i["@@iterator"], j = typeof j == "function" ? j : null), typeof j == "function" && j !== i.entries && (j = j.call(i), j !== i)) for (; !(i = j.next()).done; ) y(i.value) && L(i.value, D); } } function y(i) { return typeof i == "object" && i !== null && i.$$typeof === I; } function L(i, D) { if (i._store && !i._store.validated && i.key == null && (i._store.validated = 1, D = x(D), !de[D])) { de[D] = !0; var j = ""; i && i._owner != null && i._owner !== u() && (j = null, typeof i._owner.tag == "number" ? j = n(i._owner.type) : typeof i._owner.name == "string" && (j = i._owner.name), j = " It was passed a child from " + j + "."); var G = U.getCurrentStack; U.getCurrentStack = function() { var Ae = c(i.type); return G && (Ae += G() || ""), Ae; }, console.error( 'Each child in a list should have a unique "key" prop.%s%s See https://react.dev/link/warning-keys for more information.', D, j ), U.getCurrentStack = G; } } function x(i) { var D = "", j = u(); return j && (j = n(j.type)) && (D = ` Check the render method of \`` + j + "`."), D || (i = n(i)) && (D = ` Check the top-level render call using <` + i + ">."), D; } var w = De, I = Symbol.for("react.transitional.element"), M = Symbol.for("react.portal"), P = Symbol.for("react.fragment"), k = Symbol.for("react.strict_mode"), H = Symbol.for("react.profiler"), S = Symbol.for("react.consumer"), F = Symbol.for("react.context"), Q = Symbol.for("react.forward_ref"), O = Symbol.for("react.suspense"), X = Symbol.for("react.suspense_list"), B = Symbol.for("react.memo"), T = Symbol.for("react.lazy"), $ = Symbol.for("react.offscreen"), se = Symbol.iterator, pe = Symbol.for("react.client.reference"), U = w.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, ne = Object.prototype.hasOwnProperty, re = Object.assign, fe = Symbol.for("react.client.reference"), ae = Array.isArray, me = 0, Ee, be, N, J, ee, E, b; s.__reactDisabledLog = !0; var W, V, te = !1, ue = new (typeof WeakMap == "function" ? WeakMap : Map)(), je = Symbol.for("react.client.reference"), Ne, Me = {}, Oe = {}, de = {}; Ie.Fragment = P, Ie.jsx = function(i, D, j, G, Ae) { return m(i, D, j, !1, G, Ae); }, Ie.jsxs = function(i, D, j, G, Ae) { return m(i, D, j, !0, G, Ae); }; }()), Ie; } var lt; function Jt() { return lt || (lt = 1, process.env.NODE_ENV === "production" ? Te.exports = Gt() : Te.exports = Ft()), Te.exports; } var o = Jt(); const Zt = ({ children: n, width: e = "md", height: t = "md", padding: s = "md", textColor: r = "white", textSize: a = "md", bgColor: A = "primary", hoverColor: l = "primary", activeScale: c = !0, activeColor: u = "primary-active", activeShadow: g = !0, rounded: f = "md", disabled: d = !1, className: p = "", onClick: m, ...C }) => { const y = [ "smartopt-button", `smartopt-button--width-${e}`, `smartopt-button--height-${t}`, `smartopt-button--padding-${s}`, `smartopt-button--textColor-${r}`, `smartopt-button--textSize-${a}`, `smartopt-button--bgColor-${A}`, `smartopt-button--hoverColor-${l}`, c ? "smartopt-button--activeScale" : "", `smartopt-button--activeColor-${u}`, g ? "smartopt-button--activeShadow" : "", `smartopt-button--rounded-${f}`, d ? "smartopt-button--disabled" : "", p ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsx( "button", { className: y, onClick: m, disabled: d, ...C, children: n } ); }, Ge = ({ type: n = "text", variant: e = "default", disabled: t = !1, className: s = "", onChange: r, value: a, placeholder: A = "", ...l }) => { const c = "smartopt-input", u = e !== "default" ? `smartopt-input--${e}` : "", g = [ c, u, s ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsx( "input", { type: n, className: g, placeholder: A, disabled: t, onChange: r, value: a, ...l } ); }, fn = ({ label: n, checked: e, onChange: t, size: s = "md", disabled: r = !1, className: a = "", indeterminate: A = !1, ...l }) => { const c = "smartopt-checkbox", u = s !== "md" ? `smartopt-checkbox--${s}` : "", f = [ c, u, r ? "smartopt-checkbox--disabled" : "", a ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsxs("label", { className: f, children: [ /* @__PURE__ */ o.jsx( "input", { type: "checkbox", className: "smartopt-checkbox__input", checked: e, onChange: t, disabled: r, ...l } ), /* @__PURE__ */ o.jsxs("span", { className: "smartopt-checkbox__box", children: [ e && !A && /* @__PURE__ */ o.jsx( "svg", { className: "smartopt-checkbox__check-icon", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", strokeLinejoin: "round", children: /* @__PURE__ */ o.jsx("polyline", { points: "20 6 9 17 4 12" }) } ), A && /* @__PURE__ */ o.jsx( "svg", { className: "smartopt-checkbox__indeterminate-icon", viewBox: "0 0 24 24", fill: "currentColor", children: /* @__PURE__ */ o.jsx("rect", { x: "4", y: "11", width: "16", height: "2" }) } ) ] }), n && /* @__PURE__ */ o.jsx("span", { className: "smartopt-checkbox__label", children: n }) ] }); }, hn = ({ label: n, value: e, checked: t, onChange: s, size: r = "md", disabled: a = !1, className: A = "", name: l, ...c }) => { const u = "smartopt-radio", g = r !== "md" ? `smartopt-radio--${r}` : "", d = [ u, g, a ? "smartopt-radio--disabled" : "", A ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsxs("label", { className: d, children: [ /* @__PURE__ */ o.jsx( "input", { type: "radio", className: "smartopt-radio__input", checked: t, onChange: s, disabled: a, value: e, name: l, ...c } ), /* @__PURE__ */ o.jsx("span", { className: "smartopt-radio__box", children: t && /* @__PURE__ */ o.jsx("span", { className: "smartopt-radio__dot" }) }), n && /* @__PURE__ */ o.jsx("span", { className: "smartopt-radio__label", children: n }) ] }); }, pn = ({ checked: n = !1, onChange: e, size: t = "auto", disabled: s = !1, className: r = "", ...a }) => { const A = "smartopt-toggle", l = t !== "auto" ? `smartopt-toggle--${t}` : "", g = [ A, l, s ? "smartopt-toggle--disabled" : "", n ? "smartopt-toggle--checked" : "", r ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsx( "button", { type: "button", className: g, role: "switch", "aria-checked": n, onClick: () => !s && (e == null ? void 0 : e(!n)), disabled: s, ...a, children: /* @__PURE__ */ o.jsx("span", { className: "smartopt-toggle__slider" }) } ); }, mn = ({ options: n = [], value: e, onChange: t, variant: s = "default", size: r = "md", disabled: a = !1, className: A = "", placeholder: l = "Seçiniz", multiple: c = !1, selectAllOption: u = !0, ...g }) => { const [f, d] = R(!1), [p, m] = R( c ? Array.isArray(e) ? e : [] : e ), C = he(null), y = "smartopt-select", L = s !== "default" ? `smartopt-select--${s}` : "", x = r !== "md" ? `smartopt-select--${r}` : "", P = [ y, L, x, a ? "smartopt-select--disabled" : "", f ? "smartopt-select--open" : "", c ? "smartopt-select--multiple" : "", A ].filter(Boolean).join(" "); ce(() => { const B = (T) => { C.current && !C.current.contains(T.target) && d(!1); }; return document.addEventListener("mousedown", B), () => { document.removeEventListener("mousedown", B); }; }, []), ce(() => { m(c ? Array.isArray(e) ? e : [] : e); }, [e, c]); const k = (B) => { t(B); }, H = (B) => { const T = p.includes(B) ? p.filter(($) => $ !== B) : [...p, B]; m(T), t({ target: { value: T } }); }, S = () => { if (p.length === n.length) m([]), t({ target: { value: [] } }); else { const B = n.filter((T) => !T.disabled).map((T) => T.value); m(B), t({ target: { value: B } }); } }, F = (B, T) => { T.stopPropagation(); const $ = p.filter((se) => se !== B); m($), t({ target: { value: $ } }); }, Q = (B) => { const T = n.find(($) => $.value === B); return T ? T.label : ""; }, O = () => { a || d(!f); }, X = () => !c || p.length === 0 ? null : /* @__PURE__ */ o.jsx("div", { className: "smartopt-select__tags", children: p.map((B) => /* @__PURE__ */ o.jsxs( "div", { className: "smartopt-select__tag", children: [ /* @__PURE__ */ o.jsx("span", { className: "smartopt-select__tag-text", children: Q(B) }), /* @__PURE__ */ o.jsx( "button", { type: "button", className: "smartopt-select__tag-remove", onClick: (T) => F(B, T), children: "✕" } ) ] }, B )) }); return c ? /* @__PURE__ */ o.jsxs("div", { ref: C, className: "smartopt-select__wrapper", children: [ /* @__PURE__ */ o.jsxs( "div", { className: P, onClick: O, children: [ /* @__PURE__ */ o.jsx("div", { className: "smartopt-select__content", children: p.length > 0 ? X() : /* @__PURE__ */ o.jsx("span", { className: "smartopt-select__placeholder", children: l }) }), /* @__PURE__ */ o.jsx("div", { className: "smartopt-select__arrow", children: /* @__PURE__ */ o.jsx( "svg", { className: "smartopt-select__arrow-icon", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: /* @__PURE__ */ o.jsx( "path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" } ) } ) }) ] } ), f && /* @__PURE__ */ o.jsxs("div", { className: "smartopt-select__dropdown", children: [ u && n.length > 1 && /* @__PURE__ */ o.jsx( "div", { className: "smartopt-select__option smartopt-select__option--select-all", onClick: S, children: /* @__PURE__ */ o.jsx("span", { className: "smartopt-select__option-text", children: p.length === n.length ? "Tümünü Kaldır" : "Tümünü Seç" }) } ), n.map((B) => /* @__PURE__ */ o.jsxs( "div", { className: `smartopt-select__option ${p.includes(B.value) ? "smartopt-select__option--selected" : ""} ${B.disabled ? "smartopt-select__option--disabled" : ""}`, onClick: () => !B.disabled && H(B.value), children: [ /* @__PURE__ */ o.jsx("span", { className: "smartopt-select__option-text", children: B.label }), p.includes(B.value) && /* @__PURE__ */ o.jsx("svg", { className: "smartopt-select__option-check", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: /* @__PURE__ */ o.jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: "2", d: "M5 13l4 4L19 7" }) }) ] }, B.value )) ] }) ] }) : /* @__PURE__ */ o.jsxs("div", { className: "smartopt-select__wrapper", children: [ /* @__PURE__ */ o.jsxs( "select", { className: P, value: p, onChange: k, disabled: a, ...g, children: [ /* @__PURE__ */ o.jsx("option", { value: "", disabled: !0, children: l }), n.map((B) => /* @__PURE__ */ o.jsx( "option", { value: B.value, disabled: B.disabled, children: B.label }, B.value )) ] } ), /* @__PURE__ */ o.jsx("div", { className: "smartopt-select__arrow", children: /* @__PURE__ */ o.jsx( "svg", { className: "smartopt-select__arrow-icon", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: /* @__PURE__ */ o.jsx( "path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" } ) } ) }) ] }); }, xn = ({ children: n, variant: e = "default", className: t = "", ...s }) => { const r = "smartopt-card", a = e !== "default" ? `smartopt-card--${e}` : "", A = [ r, a, t ].filter(Boolean).join(" "); return /* @__PURE__ */ o.jsx("div", { className: A, ...s, children: n }); }, Bt = "", Nt = "