UNPKG

smartopt-ui

Version:

Modern React UI component library with scoped CSS and CSS variables

31 lines (29 loc) 152 kB
(function(K,p){typeof exports=="object"&&typeof module<"u"?p(exports,require("react"),require("react-dom")):typeof define=="function"&&define.amd?define(["exports","react","react-dom"],p):(K=typeof globalThis<"u"?globalThis:K||self,p(K.SmartOptUI={},K.React,K.ReactDOM))})(this,function(K,p,Ht){"use strict";var ze={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 tt;function zt(){if(tt)return Se;tt=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 Le={};/** * @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 st;function Tt(){return st||(st=1,process.env.NODE_ENV!=="production"&&function(){function n(i){if(i==null)return null;if(typeof i=="function")return i.$$typeof===he?null:i.displayName||i.name||null;if(typeof i=="string")return i;switch(i){case S:return"Fragment";case B:return"Portal";case z:return"Profiler";case k:return"StrictMode";case Q:return"Suspense";case q: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 I:return(i._context.displayName||"Context")+".Consumer";case P:var j=i.render;return i=i.displayName,i||(i=j.displayName||j.name||"",i=i!==""?"ForwardRef("+i+")":"ForwardRef"),i;case N:return j=i.displayName||null,j!==null?j:n(i.type)||"Memo";case G:j=i._payload,i=i._init;try{return n(i(j))}catch{}}return null}function e(i){return""+i}function t(i){try{e(i);var j=!1}catch{j=!0}if(j){j=console;var M=j.error,R=typeof Symbol=="function"&&Symbol.toStringTag&&i[Symbol.toStringTag]||i.constructor.name||"Object";return M.call(j,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",R),e(i)}}function s(){}function r(){if(me===0){ve=console.log,we=console.info,O=console.warn,J=console.error,te=console.group,y=console.groupCollapsed,v=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:oe({},i,{value:ve}),info:oe({},i,{value:we}),warn:oe({},i,{value:O}),error:oe({},i,{value:J}),group:oe({},i,{value:te}),groupCollapsed:oe({},i,{value:y}),groupEnd:oe({},i,{value:v})})}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(M){var j=M.stack.trim().match(/\n( *(at )?)/);W=j&&j[1]||"",V=-1<M.stack.indexOf(` at`)?" (<anonymous>)":-1<M.stack.indexOf("@")?"@unknown:0:0":""}return` `+W+i+V}function l(i,j){if(!i||se)return"";var M=ue.get(i);if(M!==void 0)return M;se=!0,M=Error.prepareStackTrace,Error.prepareStackTrace=void 0;var R=null;R=U.H,U.H=null,r();try{var ie={DetermineComponentFrameRoot:function(){try{if(j){var E=function(){throw Error()};if(Object.defineProperty(E.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(E,[])}catch(X){var Z=X}Reflect.construct(i,[],E)}else{try{E.call()}catch(X){Z=X}i.call(E.prototype)}}else{try{throw Error()}catch(X){Z=X}(E=i())&&typeof E.catch=="function"&&E.catch(function(){})}}catch(X){if(X&&Z&&typeof X.stack=="string")return[X.stack,Z.stack]}return[null,null]}};ie.DetermineComponentFrameRoot.displayName="DetermineComponentFrameRoot";var _=Object.getOwnPropertyDescriptor(ie.DetermineComponentFrameRoot,"name");_&&_.configurable&&Object.defineProperty(ie.DetermineComponentFrameRoot,"name",{value:"DetermineComponentFrameRoot"});var T=ie.DetermineComponentFrameRoot(),pe=T[0],Ee=T[1];if(pe&&Ee){var ce=pe.split(` `),be=Ee.split(` `);for(T=_=0;_<ce.length&&!ce[_].includes("DetermineComponentFrameRoot");)_++;for(;T<be.length&&!be[T].includes("DetermineComponentFrameRoot");)T++;if(_===ce.length||T===be.length)for(_=ce.length-1,T=be.length-1;1<=_&&0<=T&&ce[_]!==be[T];)T--;for(;1<=_&&0<=T;_--,T--)if(ce[_]!==be[T]){if(_!==1||T!==1)do if(_--,T--,0>T||ce[_]!==be[T]){var h=` `+ce[_].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<=_&&0<=T);break}}}finally{se=!1,U.H=R,a(),Error.prepareStackTrace=M}return ce=(ce=i?i.displayName||i.name:"")?A(ce):"",typeof i=="function"&&ue.set(i,ce),ce}function c(i){if(i==null)return"";if(typeof i=="function"){var j=i.prototype;return l(i,!(!j||!j.isReactComponent))}if(typeof i=="string")return A(i);switch(i){case Q:return A("Suspense");case q:return A("SuspenseList")}if(typeof i=="object")switch(i.$$typeof){case P:return i=l(i.render,!1),i;case N:return c(i.type);case G:j=i._payload,i=i._init;try{return c(i(j))}catch{}}return""}function u(){var i=U.A;return i===null?null:i.getOwner()}function g(i){if(ae.call(i,"key")){var j=Object.getOwnPropertyDescriptor(i,"key").get;if(j&&j.isReactWarning)return!1}return i.key!==void 0}function f(i,j){function M(){Oe||(Oe=!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)",j))}M.isReactWarning=!0,Object.defineProperty(i,"key",{get:M,configurable:!0})}function d(){var i=n(this.type);return je[i]||(je[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 m(i,j,M,R,ie,_){return M=_.ref,i={$$typeof:H,type:i,key:j,props:_,_owner:ie},(M!==void 0?M: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 x(i,j,M,R,ie,_){if(typeof i=="string"||typeof i=="function"||i===S||i===z||i===k||i===Q||i===q||i===ee||typeof i=="object"&&i!==null&&(i.$$typeof===G||i.$$typeof===N||i.$$typeof===F||i.$$typeof===I||i.$$typeof===P||i.$$typeof===fe||i.getModuleId!==void 0)){var T=j.children;if(T!==void 0)if(R)if(Ae(T)){for(R=0;R<T.length;R++)w(T[R],i);Object.freeze&&Object.freeze(T)}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 w(T,i)}else T="",(i===void 0||typeof i=="object"&&i!==null&&Object.keys(i).length===0)&&(T+=" 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?R="null":Ae(i)?R="array":i!==void 0&&i.$$typeof===H?(R="<"+(n(i.type)||"Unknown")+" />",T=" Did you accidentally export a JSX literal instead of a component?"):R=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",R,T);if(ae.call(j,"key")){T=n(i);var pe=Object.keys(j).filter(function(ce){return ce!=="key"});R=0<pe.length?"{key: someKey, "+pe.join(": ..., ")+": ...}":"{key: someKey}",Qe[T+R]||(pe=0<pe.length?"{"+pe.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} />`,R,T,pe,T),Qe[T+R]=!0)}if(T=null,M!==void 0&&(t(M),T=""+M),g(j)&&(t(j.key),T=""+j.key),"key"in j){M={};for(var Ee in j)Ee!=="key"&&(M[Ee]=j[Ee])}else M=j;return T&&f(M,typeof i=="function"?i.displayName||i.name||"Unknown":i),m(i,T,_,ie,u(),M)}function w(i,j){if(typeof i=="object"&&i&&i.$$typeof!==De){if(Ae(i))for(var M=0;M<i.length;M++){var R=i[M];D(R)&&L(R,j)}else if(D(i))i._store&&(i._store.validated=1);else if(i===null||typeof i!="object"?M=null:(M=re&&i[re]||i["@@iterator"],M=typeof M=="function"?M:null),typeof M=="function"&&M!==i.entries&&(M=M.call(i),M!==i))for(;!(i=M.next()).done;)D(i.value)&&L(i.value,j)}}function D(i){return typeof i=="object"&&i!==null&&i.$$typeof===H}function L(i,j){if(i._store&&!i._store.validated&&i.key==null&&(i._store.validated=1,j=C(j),!de[j])){de[j]=!0;var M="";i&&i._owner!=null&&i._owner!==u()&&(M=null,typeof i._owner.tag=="number"?M=n(i._owner.type):typeof i._owner.name=="string"&&(M=i._owner.name),M=" It was passed a child from "+M+".");var R=U.getCurrentStack;U.getCurrentStack=function(){var ie=c(i.type);return R&&(ie+=R()||""),ie},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.',j,M),U.getCurrentStack=R}}function C(i){var j="",M=u();return M&&(M=n(M.type))&&(j=` Check the render method of \``+M+"`."),j||(i=n(i))&&(j=` Check the top-level render call using <`+i+">."),j}var b=p,H=Symbol.for("react.transitional.element"),B=Symbol.for("react.portal"),S=Symbol.for("react.fragment"),k=Symbol.for("react.strict_mode"),z=Symbol.for("react.profiler"),I=Symbol.for("react.consumer"),F=Symbol.for("react.context"),P=Symbol.for("react.forward_ref"),Q=Symbol.for("react.suspense"),q=Symbol.for("react.suspense_list"),N=Symbol.for("react.memo"),G=Symbol.for("react.lazy"),ee=Symbol.for("react.offscreen"),re=Symbol.iterator,he=Symbol.for("react.client.reference"),U=b.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,ae=Object.prototype.hasOwnProperty,oe=Object.assign,fe=Symbol.for("react.client.reference"),Ae=Array.isArray,me=0,ve,we,O,J,te,y,v;s.__reactDisabledLog=!0;var W,V,se=!1,ue=new(typeof WeakMap=="function"?WeakMap:Map),De=Symbol.for("react.client.reference"),Oe,je={},Qe={},de={};Le.Fragment=S,Le.jsx=function(i,j,M,R,ie){return x(i,j,M,!1,R,ie)},Le.jsxs=function(i,j,M,R,ie){return x(i,j,M,!0,R,ie)}}()),Le}var nt;function Gt(){return nt||(nt=1,process.env.NODE_ENV==="production"?ze.exports=zt():ze.exports=Tt()),ze.exports}var o=Gt();const rt=({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:m="",onClick:x,...w})=>{const D=["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":"",m].filter(Boolean).join(" ");return o.jsx("button",{className:D,onClick:x,disabled:d,...w,children:n})},ke=({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 o.jsx("input",{type:n,className:g,placeholder:A,disabled:t,onChange:r,value:a,...l})},Rt=({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 o.jsxs("label",{className:f,children:[o.jsx("input",{type:"checkbox",className:"smartopt-checkbox__input",checked:e,onChange:t,disabled:r,...l}),o.jsxs("span",{className:"smartopt-checkbox__box",children:[e&&!A&&o.jsx("svg",{className:"smartopt-checkbox__check-icon",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",strokeLinecap:"round",strokeLinejoin:"round",children:o.jsx("polyline",{points:"20 6 9 17 4 12"})}),A&&o.jsx("svg",{className:"smartopt-checkbox__indeterminate-icon",viewBox:"0 0 24 24",fill:"currentColor",children:o.jsx("rect",{x:"4",y:"11",width:"16",height:"2"})})]}),n&&o.jsx("span",{className:"smartopt-checkbox__label",children:n})]})},Ft=({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 o.jsxs("label",{className:d,children:[o.jsx("input",{type:"radio",className:"smartopt-radio__input",checked:t,onChange:s,disabled:a,value:e,name:l,...c}),o.jsx("span",{className:"smartopt-radio__box",children:t&&o.jsx("span",{className:"smartopt-radio__dot"})}),n&&o.jsx("span",{className:"smartopt-radio__label",children:n})]})},Jt=({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 o.jsx("button",{type:"button",className:g,role:"switch","aria-checked":n,onClick:()=>!s&&(e==null?void 0:e(!n)),disabled:s,...a,children:o.jsx("span",{className:"smartopt-toggle__slider"})})},Zt=({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]=p.useState(!1),[m,x]=p.useState(c?Array.isArray(e)?e:[]:e),w=p.useRef(null),D="smartopt-select",L=s!=="default"?`smartopt-select--${s}`:"",C=r!=="md"?`smartopt-select--${r}`:"",S=[D,L,C,a?"smartopt-select--disabled":"",f?"smartopt-select--open":"",c?"smartopt-select--multiple":"",A].filter(Boolean).join(" ");p.useEffect(()=>{const N=G=>{w.current&&!w.current.contains(G.target)&&d(!1)};return document.addEventListener("mousedown",N),()=>{document.removeEventListener("mousedown",N)}},[]),p.useEffect(()=>{x(c?Array.isArray(e)?e:[]:e)},[e,c]);const k=N=>{t(N)},z=N=>{const G=m.includes(N)?m.filter(ee=>ee!==N):[...m,N];x(G),t({target:{value:G}})},I=()=>{if(m.length===n.length)x([]),t({target:{value:[]}});else{const N=n.filter(G=>!G.disabled).map(G=>G.value);x(N),t({target:{value:N}})}},F=(N,G)=>{G.stopPropagation();const ee=m.filter(re=>re!==N);x(ee),t({target:{value:ee}})},P=N=>{const G=n.find(ee=>ee.value===N);return G?G.label:""},Q=()=>{a||d(!f)},q=()=>!c||m.length===0?null:o.jsx("div",{className:"smartopt-select__tags",children:m.map(N=>o.jsxs("div",{className:"smartopt-select__tag",children:[o.jsx("span",{className:"smartopt-select__tag-text",children:P(N)}),o.jsx("button",{type:"button",className:"smartopt-select__tag-remove",onClick:G=>F(N,G),children:"✕"})]},N))});return c?o.jsxs("div",{ref:w,className:"smartopt-select__wrapper",children:[o.jsxs("div",{className:S,onClick:Q,children:[o.jsx("div",{className:"smartopt-select__content",children:m.length>0?q():o.jsx("span",{className:"smartopt-select__placeholder",children:l})}),o.jsx("div",{className:"smartopt-select__arrow",children:o.jsx("svg",{className:"smartopt-select__arrow-icon",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:o.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"})})})]}),f&&o.jsxs("div",{className:"smartopt-select__dropdown",children:[u&&n.length>1&&o.jsx("div",{className:"smartopt-select__option smartopt-select__option--select-all",onClick:I,children:o.jsx("span",{className:"smartopt-select__option-text",children:m.length===n.length?"Tümünü Kaldır":"Tümünü Seç"})}),n.map(N=>o.jsxs("div",{className:`smartopt-select__option ${m.includes(N.value)?"smartopt-select__option--selected":""} ${N.disabled?"smartopt-select__option--disabled":""}`,onClick:()=>!N.disabled&&z(N.value),children:[o.jsx("span",{className:"smartopt-select__option-text",children:N.label}),m.includes(N.value)&&o.jsx("svg",{className:"smartopt-select__option-check",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:o.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:"2",d:"M5 13l4 4L19 7"})})]},N.value))]})]}):o.jsxs("div",{className:"smartopt-select__wrapper",children:[o.jsxs("select",{className:S,value:m,onChange:k,disabled:a,...g,children:[o.jsx("option",{value:"",disabled:!0,children:l}),n.map(N=>o.jsx("option",{value:N.value,disabled:N.disabled,children:N.label},N.value))]}),o.jsx("div",{className:"smartopt-select__arrow",children:o.jsx("svg",{className:"smartopt-select__arrow-icon",fill:"none",viewBox:"0 0 24 24",stroke:"currentColor",children:o.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"})})})]})},Ut=({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 o.jsx("div",{className:A,...s,children:n})},at="",ot="