react-crud-mobile 1.0.481 → 1.0.482
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/react-crud-mobile.cjs.development.js +9 -6
- package/dist/react-crud-mobile.cjs.development.js.map +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js.map +1 -1
- package/dist/react-crud-mobile.esm.js +9 -6
- package/dist/react-crud-mobile.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/elements/core/UIModal.tsx +6 -4
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),n=e(t),r=require("react-crud-utils"),i=require("react-native"),l=require("react/jsx-runtime"),a=e(require("@expo/vector-icons/Ionicons")),o=require("@expo/vector-icons"),s=e(require("react-native-vector-icons/FontAwesome")),c=require("react-native-safe-area-context");function u(){return(u=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(null,arguments)}function d(e){var a=t.useState(r.Utils.nvl(e.scope,r.ScopeUtils.create(e)))[0],o=r.Utils.nvl(e.crud,a.crud),s=r.Utils.nvl(e.validateScope,"global"),c=r.Utils.nvl(e.part,"child");if(a.isInput())return l.jsx(l.Fragment,{});var p,x,h=function(e){var t=e.child;if(!t)return l.jsx(l.Fragment,{});if("string"==typeof t)return l.jsx(l.Fragment,{children:t});var n=t.type,i=u({},t.props);return delete i.children,"string"==typeof n?r.Utils.isEmpty(t.props.children)?l.jsx(n,u({},i)):l.jsx(n,u({},i,{children:l.jsx(d,u({transient:!0,validateScope:s},t.props,{scope:a,crud:o}))})):"function"==typeof n?l.jsx(n,u({validateScope:s},t.props,{parent:a,crud:o})):r.Utils.isEmpty(t.props.children)?l.jsx(l.Fragment,{}):l.jsx(d,u({validateScope:s},t.props,{scope:a,crud:o,transient:!0}))},g=function(){return l.jsx(l.Fragment,e.elements?{children:Object.entries(e.elements).map((function(e,t){return l.jsx(A,u({crud:o},e[1]))}))}:{children:n.Children.map(e.children,(function(e){return l.jsx(h,{child:e})}))})};return e.transient?l.jsx(g,{}):r.Utils.isEmpty(e.children)&&r.Utils.isEmpty(e.elements)?l.jsx(l.Fragment,{}):l.jsx(l.Fragment,{children:l.jsx(i.View,{style:(p=c,x=r.Utils.nvl(p,"root"),u({},f[x],e.style,a.getStyle(p))),children:l.jsx(g,{})})})}var f=i.StyleSheet.create({child:{width:"100%"},inner:{width:"100%"}});function p(e){var i=e.scope,o=t.useState(0),s=o[0],c=o[1],f=i.original,p=i.getItems(),x=0,h=[],g=t.useState(null),y=g[0],m=g[1],j=function(e,t){void 0===t&&(t=!0),e&&i.execute({event:{validate:t,validateScope:f.validateScope,action:function(){i.changeValue(e.data),y=e,c(s=e.index),m(e)}}})},v=function(e){var t,n="ui-tabs-item ui-click";return(null==(t=y)?void 0:t.index)===e.index&&(n+=" ui-tab-selected"),n},b=function(e,t){var n=u({},e.props);t||(t=i.crud.data);var l=r.CrudUtils.create("tabs",{data:t,changed:t,parent:i.crud}),a=r.Utils.resolve(n,l);!1!==a.rendered&&h.push(u({},a,{child:e,element:a,original:n,index:x++,data:t}))};n.Children.map(e.children,(function(e,t){if(r.Utils.isEmpty(p))b(e,{});else for(var n in p)b(e,p[n])})),y||j(h[s],!1);var w=function(e){j(h[s+e])},S="stepper"===f.layout;return l.jsx("div",{className:i.getStyleClass("inner"),style:i.getStyle("inner"),children:l.jsxs("div",{className:"ui-tabs-content",children:[l.jsx("div",{className:"ui-tabs-items",children:h.map((function(e,t){return l.jsxs("div",{className:v(e),onClick:function(){j(e)},children:[S&&l.jsx("div",{className:"ui-tab-item-divisor"}),l.jsxs("div",{className:"ui-tab-item-inner",children:[S&&l.jsx("div",{className:"ui-step-line"}),l.jsx("div",{className:"ui-tab-item-label",children:S?e.index+1:e.label})]})]},r.Utils.key(f.id,"tab",t))}))}),y&&l.jsxs(l.Fragment,{children:[S&&l.jsx("div",{className:"ui-tabs-label",children:y.label}),l.jsx("div",{className:"ui-tabs-area",children:l.jsx(d,u({},e,{scope:i,children:y.child}))}),"stepper"===f.layout&&l.jsxs("div",{className:"ui-tabs-actions",children:[l.jsx(J.Output,{space:6,layout:"left",children:l.jsx(J.Include,u({},e,{transient:!0,name:"left",default:l.jsx(J.Button,{rendered:s>0,icon:l.jsx(a,{}),click:function(){w(-1)}})}))}),l.jsx(J.Output,{space:6,layout:"right",children:l.jsx(J.Include,u({},e,{transient:!0,name:"right",default:l.jsx(J.Button,{rendered:s<h.length-1,icon:l.jsx(a,{}),click:function(){w(1)}})}))})]})]})]})})}function x(e){var t=e.scope;return t.getItems(),r.Utils.asList(t.original.columns),l.jsx("div",{className:"ui-chart-data"})}function h(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:g.link,children:"Clique aqui para acessar o React Native"})})}var g={link:{}};function y(e){return l.jsx(l.Fragment,{children:l.jsx(h,u({},e.defaultsInput,e.defaultsUI))})}function m(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:j.link,children:"Clique aqui para acessar o React Native"})})}var j={link:{}};function v(e){var t=e.scope,n=t.getValue();return l.jsx(o.Ionicons,{name:n,style:t.getStyle("icon")})}function b(e){var t=e.scope,n=t.original,r=n.color,a=n.label,s=n.icon;r||(r="primary");var c={buttonLabel:{color:"#ffffff",fontWeight:"500",fontSize:16,paddingRight:10,paddingLeft:10},buttonInner:{flexDirection:"row",alignItems:"center",justifyContent:"center",height:44,minWidth:44},buttonIcon:{color:"#fff",fontSize:18},button:{alignItems:"center",margin:"auto",width:"100%",textAlign:"center",verticalAling:"middle",borderRadius:24,backgroundColor:r,color:"#ffffff",justifyContent:"center",flex:1}},d=function(e,n){var r=u({},c[e],n);return t.getStyle(e,r)},f={};return a?s&&(f.button={padding:0,paddingHorizontal:20}):(f.button={width:"auto"},f.icon={padding:5}),l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(e){t.call("click",{})},style:d("button",f.button),children:l.jsxs(i.View,{style:d("buttonInner"),children:[s&&l.jsx(l.Fragment,{children:l.jsx(o.Ionicons,{size:30,style:d("buttonIcon",f.icon),name:s})}),a&&l.jsx(i.Text,{style:d("buttonLabel"),children:a})]})})}function w(e){var n=t.useState(!1),a=n[0],o=n[1],c=e.scope,d=r.Utils.nvl(c.getOptions(),[]),f=c.attr("placeholder","Selecione..."),p=c.getDisplayValue(),x=r.useTheme(),h=function(){o(!a)},g=function(e,t){return u({},S[e],c.getStyle(e),t)};return l.jsxs(i.View,{style:g("selectRoot"),children:[l.jsxs(i.TouchableOpacity,{onPress:h,style:g("selectInput"),children:[l.jsx(i.Text,{style:g("selectLabel"),children:r.Utils.nvl(p,f)}),l.jsx(s,{name:"angle-down",size:20,color:"#888"})]}),l.jsxs(i.Modal,{animationType:"slide",transparent:!0,visible:a,onRequestClose:function(){return o(!1)},children:[l.jsx(i.StatusBar,{barStyle:"dark-content",backgroundColor:x.colors.primary}),l.jsxs(i.SafeAreaView,{style:g("modalSafe"),children:[l.jsxs(i.View,{style:g("modalHeader"),children:[l.jsx(i.TouchableOpacity,{onPress:function(){return o(!1)},style:g("modalCloseButton"),children:l.jsx(i.Text,{style:g("modalCloseText"),children:"X"})}),l.jsx(i.Text,{style:g("modalTitle"),children:f})]}),l.jsx(i.View,{style:g("modalContent"),children:l.jsx(J.List,{data:d,name:c.getName("list"),click:function(e){c.changeValue(e.value),h()},children:l.jsx(J.Value,{value:"#{@this.label}"})})})]})]})]})}var S=i.StyleSheet.create({selectRoot:{justifyContent:"flex-start",alignItems:"flex-start"},selectInput:{width:"100%",flexDirection:"row",borderWidth:1,borderColor:"#a9a9a9",borderRadius:20,paddingHorizontal:15,paddingVertical:10},selectLabel:{flex:1},modalSafe:{flex:1,backgroundColor:"#f5f5f5",paddingTop:i.StatusBar.currentHeight||0},modalHeader:{flexDirection:"row",alignItems:"center",padding:15,backgroundColor:"#6200ea"},modalCloseButton:{padding:10},modalCloseText:{fontSize:18,color:"white"},modalTitle:{fontSize:18,color:"white",fontWeight:"bold",marginLeft:10},modalContent:{flex:1,width:"100%",alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap",padding:20}});function C(e){var n=e.scope,a=r.Utils.nvl(n.getValue(),!1),o=t.useState(a),s=o[1];return l.jsx(i.Switch,{value:o[0],onValueChange:function(e){n.changeValue(e),s(e)}})}function T(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:I.link,children:"Clique aqui para acessar o React Native"})})}var I={link:{}};function k(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:V.link,children:"Clique aqui para acessar o React Native"})})}var V={link:{}};function U(e){var n=e.scope,a=r.Utils.nvl(n.getValue(),""),s=n.getLabel(),c=n.getPart("placeholder",null,s),d=n.original,f=t.useState(a),p=f[0],x=f[1];return l.jsxs(l.Fragment,{children:[n.getPart("left"),l.jsx(i.TextInput,{style:u({},n.getStyle("input",D.input),void 0),onChangeText:function(e){n.changeValue(e),x(e)},value:p,placeholder:c}),d.icon&&l.jsx(o.Ionicons,{name:d.icon,size:n.attr("iconSize",20),color:n.attr("iconColor","#888")}),n.getPart("right")]})}var D=i.StyleSheet.create({base:{flexDirection:"row",alignItems:"center",borderWidth:1,borderColor:"borderColor",borderRadius:20,paddingHorizontal:10,paddingVertical:5,padding:10,paddingLeft:5,paddingRight:10},icon:{marginRight:10},input:{marginHorizontal:0,marginVertical:0,height:40,flex:1}});function F(e){var n=e.scope,i=e.item,a=e.index,o=""+n.key("row",a),s=t.useState(r.ScopeUtils.create({parent:n,name:o,crud:n.crud,index:a,type:"row",data:i}))[0];return l.jsx(l.Fragment,{children:l.jsx(d,{scope:s,crud:s.crud,children:e.children})})}function L(e){var t,n,a=e.scope,s=a.crud,c=a.original,d=r.Utils.nvl(c.cols,1),f=Math.floor(100/d)+"%",p=r.Utils.nvl(a.getItems(),[]),x=null==(t={repeat:P,list:R})?void 0:t[c.type],h=function(e,t){return a.getStyle(e,u({},t,x[e]))},g=function(e){var t=h("row",{});return d>0&&(t.width=f),t},y=function(){if(!r.Utils.isEmpty(p))return l.jsx(l.Fragment,{});var e=a.attr("empty","Sem registro");return e?"string"==typeof e?l.jsx(i.Text,{style:a.getStyle("empty",{flex:1,fontWeight:500,fontSize:20,padding:10,textAlign:"center",justifyContent:"center",alignItems:"center"}),children:e}):l.jsx(l.Fragment,{children:e}):l.jsx(l.Fragment,{})};return l.jsxs(l.Fragment,{children:[!1!==c.search&&l.jsx(J.Text,{placeholder:"Pesquisar...",field:"query",crud:s,right:l.jsx(o.Ionicons,{name:"search",size:20,color:"#888"})}),l.jsxs(i.View,{style:(n=h("container",{}),d>1&&(n=u({},n,{flexDirection:"row",flexWrap:"wrap"})),n),children:[l.jsx(y,{}),p.map((function(t,n){return l.jsx(i.TouchableHighlight,{style:g(),underlayColor:"transparent",onPress:function(e){!function(e){a.call("click",{value:e,item:e,edit:!0})}(t)},children:l.jsx(i.View,{style:h("rowInner"),children:l.jsx(F,{scope:a,item:t,index:n,children:e.children})})},"k-"+n)}))]})]})}var R=i.StyleSheet.create({container:{flex:1,width:"100%",flexDirection:"row",flexWrap:"wrap",alignItems:"stretch"},row:{padding:5,width:"100%"},rowInner:{flexGrow:1,justifyContent:"center",alignItems:"center",backgroundColor:"#f5f5f5",borderRadius:8,padding:10,width:"100%"},text:{fontSize:18,fontWeight:"bold"}}),P=i.StyleSheet.create({container:{flex:1,width:"100%",flexDirection:"row",flexWrap:"wrap",gap:10,alignItems:"stretch"},row:{padding:0,width:"100%"},rowInner:{flexGrow:1,justifyContent:"center",alignItems:"center",padding:0,width:"100%"},text:{fontSize:18,fontWeight:"bold"}});function B(e){var n=e.scope,a=r.Utils.nvl(n.getOptions(),[]),o=n.getInputValue(),s=t.useState(0),c=s[0],d=s[1],f=function(e){return(null==e?void 0:e.value)===o},p=function(t){var a=t.item,o=t.index,s=f(a),c=u({},z.text);return s&&(c.color="#ffffff"),r.Utils.isEmpty(e.children)?l.jsx(i.Text,{style:c,children:a.label}):l.jsx(F,{scope:n,item:a.object,index:o,children:e.children})},x=function(e){var t=u({},z.item,n.getStyle("item")),r=Math.floor(100/a.length)+"%";if(f(e)){var i=n.getPart("selectedColor",void 0,"primary");(t=u({},t,n.getStyle("selected",{backgroundColor:i,color:"#ffffff"}))).color||(t.color="#ffffff")}return t.width=r,t};return l.jsx(l.Fragment,{children:a.map((function(e,t){return l.jsx(i.TouchableHighlight,{style:x(e),onPress:function(t){!function(e){n.changeValue(e.object),d(++c)}(e)},children:l.jsx(p,{item:e,index:t})},"k-"+t)}))})}var z=i.StyleSheet.create({container:{flex:1,width:"100%",gap:10,justifyContent:"center",flexDirection:"row"},item:{padding:15,marginVertical:8,backgroundColor:"#f5f5f5",borderRadius:8,justifyContent:"center",width:"auto",flexDirection:"row"},text:{fontSize:16,fontWeight:500}});function q(e){var n=e.scope,a=n.original,s=t.useState(0),c=s[0],d=s[1],f=n.getValue(0),p=a.color;p||(p="primary");var x={padding:10,alignItems:"center",height:44,width:44,textAlign:"center",verticalAling:"middle",borderRadius:24,backgroundColor:p,color:"#ffffff",justifyContent:"center"},h={buttonLabel:{color:"#ffffff",fontWeight:"500",fontSize:16},value:{flex:1,flexDirection:"row",textAlign:"center"},buttonInner:{flexDirection:"row",alignItems:"center",justifyContent:"center"},buttonIcon:{color:"#fff",fontSize:18},button:x,addButton:u({},x),delButton:u({},x)},g=function(e){n.changeValue(f+e),d(++c)},y=function(e,t){var r=u({},h[e],t);return n.getStyle(e,r)};return l.jsxs(l.Fragment,{children:[l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(){g(-1)},style:y("delButton"),children:l.jsx(o.Ionicons,{size:30,style:y("buttonIcon"),name:"remove"})}),l.jsx(i.Text,{style:y("value"),children:r.Utils.nvl(f,0)}),l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(){g(1)},style:y("addButton"),children:l.jsx(o.Ionicons,{size:30,style:y("buttonIcon"),name:"add"})})]})}function O(e){var n=t.useState(!1),a=n[0],o=n[1],s=e.scope,c=s.crud,f=s.getLabel(),p=r.useTheme(),x=function(e,t){var n=u({},W[e],t);return u({},s.getStyle(e,n))},h=function(e){o(a=e)};return s.show=function(e){var t=e.crud,n=s.getName("modal"),i=r.Utils.nvl(e.item,{}),l=r.CrudUtils.create("dialog",{parent:t,name:n,data:i,edit:!0===e.edit,scope:s});s.currentDialog=l,h(!0)},s.hide=function(e){s.currentDialog=null,h(!1)},t.useEffect((function(){i.StatusBar.setBarStyle("light-content"),null==i.StatusBar.setBackgroundColor||i.StatusBar.setBackgroundColor(p.colors.primary)}),[a]),s.currentDialog?l.jsx(i.Modal,{animationType:"slide",transparent:!0,visible:a,onRequestClose:function(){s.close({scope:s,crud:c,event:{}})},children:l.jsxs(i.SafeAreaView,{style:x("modalSafe"),children:[l.jsxs(i.View,{style:x("modalHeader"),children:[l.jsx(i.TouchableOpacity,{onPress:function(){return o(!1)},style:x("modalCloseButton"),children:l.jsx(i.Text,{style:x("modalCloseText"),children:"X"})}),l.jsx(i.Text,{style:x("modalTitle"),children:f})]}),l.jsx(i.ScrollView,{contentContainerStyle:{flexGrow:1},style:x("modalContent"),children:l.jsx(i.View,{style:{flex:1},children:l.jsx(d,{scope:s,crud:s.currentDialog,children:e.children})})})]})}):l.jsx(l.Fragment,{})}var W=i.StyleSheet.create({modalSafe:{flex:1,backgroundColor:"primary",width:"100%"},modalHeader:{flexDirection:"row",alignItems:"center",padding:15,backgroundColor:"primary"},modalCloseButton:{padding:10},modalCloseText:{fontSize:18,color:"white"},modalTitle:{fontSize:18,color:"white",fontWeight:"bold",marginLeft:10},modalContent:{flex:1,backgroundColor:"#f5f5f5",padding:20}});function E(e){var n=e.scope,a=e.children,o=r.useTheme(),s=n.getPart("header",null,[]);return t.useEffect((function(){i.StatusBar.setBarStyle("light-content"),null==i.StatusBar.setBackgroundColor||i.StatusBar.setBackgroundColor(o.colors.primary)}),[]),l.jsx(c.SafeAreaProvider,{children:l.jsxs(c.SafeAreaView,{style:n.getStyle("view",N.view),children:[l.jsx(i.StatusBar,{barStyle:"light-content"}),l.jsxs(i.KeyboardAvoidingView,{behavior:"ios"===i.Platform.OS?"padding":"height",style:{flex:1,justifyContent:"center"},children:[s,l.jsx(i.View,{style:n.getStyle("container",N.container),children:l.jsx(i.ScrollView,{keyboardShouldPersistTaps:"handled",style:n.getStyle("scroll",N.scroll),children:l.jsx(d,{scope:n,children:a})})})]})]})})}var N=i.StyleSheet.create({scroll:{padding:10},container:{backgroundColor:"primary"},view:{backgroundColor:"primary"}}),H=t.createContext({});function A(e){var n,a,s=t.useContext(H),c=r.Utils.nvl(e.theme,null==s?void 0:s.theme),f=r.Utils.nvl(e.crud,null==s?void 0:s.crud),h=t.useState(r.ScopeUtils.create(u({crud:f},e,{theme:c})))[0];f=h.crud;var g=t.useState(0),j=g[0],S=g[1],I=t.useState(null),V=I[0],D=I[1],F=h.getOptions(),R=h.original,P=t.useRef(null);h.update=function(){S(++j)},h.updateElement=function(){S(++j)};var z=function(){var e=R.custom;return e?l.jsx(A,"string"==typeof e?{element:{value:e,type:"dummy"},crud:f}:u({type:e.type,tag:e.type},e.props,{crud:f})):l.jsx(l.Fragment,{})};if(h.is("type","dummy"))return l.jsx(l.Fragment,{children:h.getDisplayValue()});var W=function(e){var t=e.target.value;h.isType("integer","int","number")?t=parseInt(t):h.isType("decimal")&&(t=parseFloat(t)),h.isType("select","complete")&&(t=h.getSelectedItem(t)),h.changeValue(t),h.update()},N=function(e){h.call("click")},M={scope:h,crud:f,onChange:W};h.isType("password")&&(M.type="password");var K=function(){return!(h.isInput()||r.Utils.isEmpty(e.children)&&r.Utils.isEmpty(e.elements))},Q=h.is("type","text","number","phone","postalCode","money","password","email"),J=function(e){var t,n=r.Utils.nvl(R.type,"none"),i=r.Utils.nvl(e,"root"),l=u({},X[i],null==G||null==(t=G[n])?void 0:t[i]),a=K();return e||a||(l=u({},l)),a&&e&&(l=u({},l,_[e])),Q&&(l=u({},l,G.input[i])),u({},l,h.getStyle(e,l))},Y=J("element"),Z={required:h.isRequired(),size:"small",scope:h,crud:f,style:Y,placeholder:h.attr("placeholder","Digite aqui")};h.error=function(e){V=e,D(e)},null!=(n=R.list)&&n.url||null!=(a=R.load)&&a.url||h.start(),t.useEffect((function(){h.start()}));var $=function(){return"string"==typeof R.icon?l.jsx(o.Ionicons,{name:R.icon,style:h.getStyle("icon")}):l.jsx(l.Fragment,{children:R.icon})};return h.open=function(e){i.Linking.openURL(e.url)},t.useLayoutEffect((function(){if(null!=P&&P.current&&h.is("type","card","list","tabs","stepper")){var e=null==P?void 0:P.current;if(null!=e&&e.classList){var t=r.HtmlUtils.getBGColor(e);e.classList.add("rgb(255, 255, 255)"===t?"ui-dark":"ui-light")}}})),!h.isRendered()||h.is("type","define")?l.jsx(l.Fragment,{}):l.jsx(H.Provider,{value:{crud:f,theme:c},children:l.jsx(i.View,{ref:P,style:J(),children:l.jsxs(l.Fragment,{children:[void 0!==R.label&&!1!==R.label&&!h.isType("button","dialog","modal")&&l.jsx(i.Text,{style:J("label"),children:h.getLabel()}),!K()&&l.jsxs(l.Fragment,{children:[l.jsxs(i.View,{style:J("inner"),children:[h.is("type","button")&&l.jsxs(b,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:[R.icon&&l.jsx($,{}),R.label&&l.jsx(i.Text,{style:h.getPart("label","button"),children:h.getLabel()})]})),h.is("type","icon")&&l.jsx(v,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:h.getDisplayValue()})),h.is("type","link")&&l.jsxs(m,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:[R.icon&&l.jsx($,{}),R.label&&l.jsx(i.Text,{style:h.getPart("label","link"),children:h.getLabel()})]})),Q&&l.jsx(U,u({},M,Z,{InputProps:u({},R.inputProps)})),h.is("type","complete","autocomplete")&&l.jsx(y,{scope:h,defaultsInput:M,defaultsUI:Z}),h.is("type","quantity")&&l.jsx(q,{scope:h,defaultsInput:M,defaultsUI:Z}),h.is("type","checkbox","boolean","switch")&&l.jsx(C,u({checked:!0===h.getValue()},M,{onChange:function(){var e=h.getValue();W({target:{value:!(!0===e)}})}})),h.is("type","select")&&l.jsx(w,u({},M,Z,{value:h.getSelectedValue()})),h.is("type","toggle")&&l.jsx(B,u({},M,Z,{value:h.getSelectedValue()})),h.is("type","radio")&&l.jsx(k,u({},M,Z,{row:!0,children:F.map((function(e,t){return l.jsx(T,{control:l.jsx(k,u({},Z)),label:e.label,value:e.value},"i"+t)}))})),h.is("type","custom")&&l.jsx(z,{}),h.is("type","column")&&l.jsxs(l.Fragment,{children:[h.is("format","img")&&l.jsx(i.Image,{source:h.getDisplayValue()}),h.is("format","icon")&&l.jsx(v,{scope:h,crud:f}),!h.is("format","icon","img")&&l.jsx(i.Text,{children:h.getDisplayValue()})]}),h.is("type","output","value")&&l.jsx(i.Text,{style:J("value"),children:h.getDisplayValue()})]}),V&&l.jsx(i.View,{style:J("error"),children:V})]}),h.isType("list","repeat")&&l.jsx(L,u({},e,{scope:h,crud:f})),h.isType("dialog")&&l.jsx(O,u({},e,{scope:h,crud:f})),h.isType("chart")&&l.jsx(x,u({},e,{scope:h,crud:f})),h.isType("tabs")&&l.jsx(p,u({},e,{scope:h,crud:f})),h.isType("view")&&l.jsx(E,u({},e,{scope:h,crud:f})),!h.isType("tabs","view","grid","list","define","repeat","modal","dialog","chart")&&l.jsx(d,u({},e,{scope:h,crud:f,style:J("inner")}))]})})})}var M={backgroundColor:"white",padding:16,borderRadius:10,width:"100%",shadowColor:"#888",shadowOffset:{width:0,height:1},shadowOpacity:.25,shadowRadius:3.84,elevation:3},G={view:{inner:{width:"100%",alignItems:"normal",flex:1},container:{width:"100%",backgroundColor:"#f5f5f5",flex:1,gap:10},child:{width:"100%",flex:1,gap:10,padding:10},root:{width:"100%",flex:1,alignItems:"normal",padding:0}}};G.card=i.StyleSheet.create({root:u({},M),inner:{flex:1,width:"100%",paddingBottom:10,paddingTop:5,alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap",gap:10}}),G.input=i.StyleSheet.create({inner:{flex:1,width:"100%",paddingBottom:0,paddingTop:0,alignItems:"center",borderWidth:1,borderColor:"borderColor",borderRadius:20,paddingHorizontal:15,alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap"}}),G.quantity={inner:u({},M,{padding:5,borderRadius:25,flexWrap:"nowrap",flex:1,flexDirection:"row",justifyContent:"center",alignItems:"center"})},G.toggle=i.StyleSheet.create({inner:u({},M,{flex:1,width:"100%",gap:10,justifyContent:"center",flexDirection:"row",paddingHorizontal:10,paddingVertical:0,alignSelf:"flex-start",flexWrap:"nowrap"})});var X=i.StyleSheet.create({root:{gap:5,flexDirection:"column",flexWrap:"wrap",width:"100%",alignItems:"flex-start"},label:{width:"100%",fontWeight:500,fontSize:12},inner:{width:"100%"}}),_=i.StyleSheet.create({root:{gap:10},label:{width:"100%",fontWeight:500,fontSize:24}});function K(e){if(!1===e.rendered)return l.jsx(l.Fragment,{});var t=r.ComponentUtils.getDefine(e,e.name,e.position);return r.Utils.isEmpty(t)&&(t=e.default),r.Utils.isEmpty(t)?l.jsx(l.Fragment,{children:t}):l.jsx((function(t){var n=e.tag;return r.Utils.isEmpty(n)?l.jsx(l.Fragment,{children:t.children}):l.jsx(n,u({},t,{children:t.children}))}),u({},e.tagProps,{children:l.jsx(d,u({transient:!0},e,{scope:e.scope,crud:e.crud,part:e.name,children:t}))}))}var Q=["type"],J={List:function(e){return l.jsx(A,u({},e,{type:"list"}))},Row:function(e){return l.jsx(A,u({},e,{type:"row"}))},Value:function(e){return l.jsx(A,u({},e,{type:"value"}))},Label:function(e){return l.jsx(A,u({},e,{type:"label"}))},Repeat:function(e){return l.jsx(A,u({},e,{type:"repeat",props:{search:!1}}))},Define:function(e){return l.jsx(A,u({},e,{type:"define"}))},Include:function(e){return l.jsx(K,u({},e))},Column:function(e){var t=function(e,t){if(null==e)return{};var n={};for(var r in e)if({}.hasOwnProperty.call(e,r)){if(-1!==t.indexOf(r))continue;n[r]=e[r]}return n}(e,Q);return l.jsx(A,u({},t,{type:"column"}))},Input:function(e){return l.jsx(A,u({},e))},Text:function(e){return l.jsx(A,u({},e,{type:"text"}))},Email:function(e){return l.jsx(A,u({},e,{type:"email"}))},Button:function(e){return l.jsx(A,u({},e,{type:"button"}))},Link:function(e){return l.jsx(A,u({},e,{type:"link"}))},Icon:function(e){return l.jsx(A,u({},e,{type:"icon"}))},Output:function(e){return l.jsx(A,u({},e,{type:"output"}))},Form:function(e){return l.jsx(A,u({},e,{type:"form"}))},Crud:function(e){return l.jsx(A,u({},e,{type:"crud"}))},View:function(e){return l.jsx(A,u({},e,{type:"view",transient:!0}))},Bottom:function(e){return l.jsx(A,u({},e,{type:"bottom"}))},Dialog:function(e){return l.jsx(A,u({},e,{type:"dialog"}))},Content:function(e){return l.jsx(A,u({},e,{type:"content"}))},Top:function(e){return l.jsx(A,u({},e,{type:"top"}))},Card:function(e){return l.jsx(A,u({},e,{type:"card"}))},Tab:function(e){return l.jsx(A,u({},e,{type:"tab"}))},Tabs:function(e){return l.jsx(A,u({},e,{type:"tabs"}))},Step:function(e){return l.jsx(A,u({},e,{type:"tab",layout:"step"}))},Stepper:function(e){return l.jsx(A,u({},e,{type:"tabs",layout:"stepper"}))},Money:function(e){return l.jsx(A,u({},e,{type:"money"}))},Chart:function(e){return l.jsx(A,u({},e,{type:"chart"}))},Password:function(e){return l.jsx(A,u({},e,{type:"password"}))},Complete:function(e){return l.jsx(A,u({},e,{type:"complete"}))},Checkbox:function(e){return l.jsx(A,u({},e,{type:"switch"}))},Switch:function(e){return l.jsx(A,u({},e,{type:"switch"}))},Radio:function(e){return l.jsx(A,u({},e,{type:"radio"}))},Select:function(e){return l.jsx(A,u({},e,{type:"select"}))},Toggle:function(e){return l.jsx(A,u({},e,{type:"toggle"}))},Entity:function(e){return l.jsx(A,u({},e,{type:"entity"}))},Element:function(e){return l.jsx(A,u({},e,{type:"element"}))},Quantity:function(e){return l.jsx(A,u({},e,{type:"quantity"}))}};exports.UI=J;
|
|
1
|
+
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),n=e(t),r=require("react-crud-utils"),i=require("react-native"),l=require("react/jsx-runtime"),a=e(require("@expo/vector-icons/Ionicons")),o=require("@expo/vector-icons"),s=e(require("react-native-vector-icons/FontAwesome")),c=require("react-native-safe-area-context");function u(){return(u=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(null,arguments)}function d(e){var a=t.useState(r.Utils.nvl(e.scope,r.ScopeUtils.create(e)))[0],o=r.Utils.nvl(e.crud,a.crud),s=r.Utils.nvl(e.validateScope,"global"),c=r.Utils.nvl(e.part,"child");if(a.isInput())return l.jsx(l.Fragment,{});var p,x,h=function(e){var t=e.child;if(!t)return l.jsx(l.Fragment,{});if("string"==typeof t)return l.jsx(l.Fragment,{children:t});var n=t.type,i=u({},t.props);return delete i.children,"string"==typeof n?r.Utils.isEmpty(t.props.children)?l.jsx(n,u({},i)):l.jsx(n,u({},i,{children:l.jsx(d,u({transient:!0,validateScope:s},t.props,{scope:a,crud:o}))})):"function"==typeof n?l.jsx(n,u({validateScope:s},t.props,{parent:a,crud:o})):r.Utils.isEmpty(t.props.children)?l.jsx(l.Fragment,{}):l.jsx(d,u({validateScope:s},t.props,{scope:a,crud:o,transient:!0}))},g=function(){return l.jsx(l.Fragment,e.elements?{children:Object.entries(e.elements).map((function(e,t){return l.jsx(A,u({crud:o},e[1]))}))}:{children:n.Children.map(e.children,(function(e){return l.jsx(h,{child:e})}))})};return e.transient?l.jsx(g,{}):r.Utils.isEmpty(e.children)&&r.Utils.isEmpty(e.elements)?l.jsx(l.Fragment,{}):l.jsx(l.Fragment,{children:l.jsx(i.View,{style:(p=c,x=r.Utils.nvl(p,"root"),u({},f[x],e.style,a.getStyle(p))),children:l.jsx(g,{})})})}var f=i.StyleSheet.create({child:{width:"100%"},inner:{width:"100%"}});function p(e){var i=e.scope,o=t.useState(0),s=o[0],c=o[1],f=i.original,p=i.getItems(),x=0,h=[],g=t.useState(null),y=g[0],m=g[1],j=function(e,t){void 0===t&&(t=!0),e&&i.execute({event:{validate:t,validateScope:f.validateScope,action:function(){i.changeValue(e.data),y=e,c(s=e.index),m(e)}}})},v=function(e){var t,n="ui-tabs-item ui-click";return(null==(t=y)?void 0:t.index)===e.index&&(n+=" ui-tab-selected"),n},b=function(e,t){var n=u({},e.props);t||(t=i.crud.data);var l=r.CrudUtils.create("tabs",{data:t,changed:t,parent:i.crud}),a=r.Utils.resolve(n,l);!1!==a.rendered&&h.push(u({},a,{child:e,element:a,original:n,index:x++,data:t}))};n.Children.map(e.children,(function(e,t){if(r.Utils.isEmpty(p))b(e,{});else for(var n in p)b(e,p[n])})),y||j(h[s],!1);var w=function(e){j(h[s+e])},S="stepper"===f.layout;return l.jsx("div",{className:i.getStyleClass("inner"),style:i.getStyle("inner"),children:l.jsxs("div",{className:"ui-tabs-content",children:[l.jsx("div",{className:"ui-tabs-items",children:h.map((function(e,t){return l.jsxs("div",{className:v(e),onClick:function(){j(e)},children:[S&&l.jsx("div",{className:"ui-tab-item-divisor"}),l.jsxs("div",{className:"ui-tab-item-inner",children:[S&&l.jsx("div",{className:"ui-step-line"}),l.jsx("div",{className:"ui-tab-item-label",children:S?e.index+1:e.label})]})]},r.Utils.key(f.id,"tab",t))}))}),y&&l.jsxs(l.Fragment,{children:[S&&l.jsx("div",{className:"ui-tabs-label",children:y.label}),l.jsx("div",{className:"ui-tabs-area",children:l.jsx(d,u({},e,{scope:i,children:y.child}))}),"stepper"===f.layout&&l.jsxs("div",{className:"ui-tabs-actions",children:[l.jsx(J.Output,{space:6,layout:"left",children:l.jsx(J.Include,u({},e,{transient:!0,name:"left",default:l.jsx(J.Button,{rendered:s>0,icon:l.jsx(a,{}),click:function(){w(-1)}})}))}),l.jsx(J.Output,{space:6,layout:"right",children:l.jsx(J.Include,u({},e,{transient:!0,name:"right",default:l.jsx(J.Button,{rendered:s<h.length-1,icon:l.jsx(a,{}),click:function(){w(1)}})}))})]})]})]})})}function x(e){var t=e.scope;return t.getItems(),r.Utils.asList(t.original.columns),l.jsx("div",{className:"ui-chart-data"})}function h(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:g.link,children:"Clique aqui para acessar o React Native"})})}var g={link:{}};function y(e){return l.jsx(l.Fragment,{children:l.jsx(h,u({},e.defaultsInput,e.defaultsUI))})}function m(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:j.link,children:"Clique aqui para acessar o React Native"})})}var j={link:{}};function v(e){var t=e.scope,n=t.getValue();return l.jsx(o.Ionicons,{name:n,style:t.getStyle("icon")})}function b(e){var t=e.scope,n=t.original,r=n.color,a=n.label,s=n.icon;r||(r="primary");var c={buttonLabel:{color:"#ffffff",fontWeight:"500",fontSize:16,paddingRight:10,paddingLeft:10},buttonInner:{flexDirection:"row",alignItems:"center",justifyContent:"center",height:44,minWidth:44},buttonIcon:{color:"#fff",fontSize:18},button:{alignItems:"center",margin:"auto",width:"100%",textAlign:"center",verticalAling:"middle",borderRadius:24,backgroundColor:r,color:"#ffffff",justifyContent:"center",flex:1}},d=function(e,n){var r=u({},c[e],n);return t.getStyle(e,r)},f={};return a?s&&(f.button={padding:0,paddingHorizontal:20}):(f.button={width:"auto"},f.icon={padding:5}),l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(e){t.call("click",{})},style:d("button",f.button),children:l.jsxs(i.View,{style:d("buttonInner"),children:[s&&l.jsx(l.Fragment,{children:l.jsx(o.Ionicons,{size:30,style:d("buttonIcon",f.icon),name:s})}),a&&l.jsx(i.Text,{style:d("buttonLabel"),children:a})]})})}function w(e){var n=t.useState(!1),a=n[0],o=n[1],c=e.scope,d=r.Utils.nvl(c.getOptions(),[]),f=c.attr("placeholder","Selecione..."),p=c.getDisplayValue(),x=r.useTheme(),h=function(){o(!a)},g=function(e,t){return u({},S[e],c.getStyle(e),t)};return l.jsxs(i.View,{style:g("selectRoot"),children:[l.jsxs(i.TouchableOpacity,{onPress:h,style:g("selectInput"),children:[l.jsx(i.Text,{style:g("selectLabel"),children:r.Utils.nvl(p,f)}),l.jsx(s,{name:"angle-down",size:20,color:"#888"})]}),l.jsxs(i.Modal,{animationType:"slide",transparent:!0,visible:a,onRequestClose:function(){return o(!1)},children:[l.jsx(i.StatusBar,{barStyle:"dark-content",backgroundColor:x.colors.primary}),l.jsxs(i.SafeAreaView,{style:g("modalSafe"),children:[l.jsxs(i.View,{style:g("modalHeader"),children:[l.jsx(i.TouchableOpacity,{onPress:function(){return o(!1)},style:g("modalCloseButton"),children:l.jsx(i.Text,{style:g("modalCloseText"),children:"X"})}),l.jsx(i.Text,{style:g("modalTitle"),children:f})]}),l.jsx(i.View,{style:g("modalContent"),children:l.jsx(J.List,{data:d,name:c.getName("list"),click:function(e){c.changeValue(e.value),h()},children:l.jsx(J.Value,{value:"#{@this.label}"})})})]})]})]})}var S=i.StyleSheet.create({selectRoot:{justifyContent:"flex-start",alignItems:"flex-start"},selectInput:{width:"100%",flexDirection:"row",borderWidth:1,borderColor:"#a9a9a9",borderRadius:20,paddingHorizontal:15,paddingVertical:10},selectLabel:{flex:1},modalSafe:{flex:1,backgroundColor:"#f5f5f5",paddingTop:i.StatusBar.currentHeight||0},modalHeader:{flexDirection:"row",alignItems:"center",padding:15,backgroundColor:"#6200ea"},modalCloseButton:{padding:10},modalCloseText:{fontSize:18,color:"white"},modalTitle:{fontSize:18,color:"white",fontWeight:"bold",marginLeft:10},modalContent:{flex:1,width:"100%",alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap",padding:20}});function C(e){var n=e.scope,a=r.Utils.nvl(n.getValue(),!1),o=t.useState(a),s=o[1];return l.jsx(i.Switch,{value:o[0],onValueChange:function(e){n.changeValue(e),s(e)}})}function T(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:I.link,children:"Clique aqui para acessar o React Native"})})}var I={link:{}};function k(e){return l.jsx(i.TouchableOpacity,{onPress:function(){i.Linking.openURL("https://reactnative.dev/")},children:l.jsx(i.Text,{style:V.link,children:"Clique aqui para acessar o React Native"})})}var V={link:{}};function U(e){var n=e.scope,a=r.Utils.nvl(n.getValue(),""),s=n.getLabel(),c=n.getPart("placeholder",null,s),d=n.original,f=t.useState(a),p=f[0],x=f[1];return l.jsxs(l.Fragment,{children:[n.getPart("left"),l.jsx(i.TextInput,{style:u({},n.getStyle("input",D.input),void 0),onChangeText:function(e){n.changeValue(e),x(e)},value:p,placeholder:c}),d.icon&&l.jsx(o.Ionicons,{name:d.icon,size:n.attr("iconSize",20),color:n.attr("iconColor","#888")}),n.getPart("right")]})}var D=i.StyleSheet.create({base:{flexDirection:"row",alignItems:"center",borderWidth:1,borderColor:"borderColor",borderRadius:20,paddingHorizontal:10,paddingVertical:5,padding:10,paddingLeft:5,paddingRight:10},icon:{marginRight:10},input:{marginHorizontal:0,marginVertical:0,height:40,flex:1}});function F(e){var n=e.scope,i=e.item,a=e.index,o=""+n.key("row",a),s=t.useState(r.ScopeUtils.create({parent:n,name:o,crud:n.crud,index:a,type:"row",data:i}))[0];return l.jsx(l.Fragment,{children:l.jsx(d,{scope:s,crud:s.crud,children:e.children})})}function L(e){var t,n,a=e.scope,s=a.crud,c=a.original,d=r.Utils.nvl(c.cols,1),f=Math.floor(100/d)+"%",p=r.Utils.nvl(a.getItems(),[]),x=null==(t={repeat:P,list:R})?void 0:t[c.type],h=function(e,t){return a.getStyle(e,u({},t,x[e]))},g=function(e){var t=h("row",{});return d>0&&(t.width=f),t},y=function(){if(!r.Utils.isEmpty(p))return l.jsx(l.Fragment,{});var e=a.attr("empty","Sem registro");return e?"string"==typeof e?l.jsx(i.Text,{style:a.getStyle("empty",{flex:1,fontWeight:500,fontSize:20,padding:10,textAlign:"center",justifyContent:"center",alignItems:"center"}),children:e}):l.jsx(l.Fragment,{children:e}):l.jsx(l.Fragment,{})};return l.jsxs(l.Fragment,{children:[!1!==c.search&&l.jsx(J.Text,{placeholder:"Pesquisar...",field:"query",crud:s,right:l.jsx(o.Ionicons,{name:"search",size:20,color:"#888"})}),l.jsxs(i.View,{style:(n=h("container",{}),d>1&&(n=u({},n,{flexDirection:"row",flexWrap:"wrap"})),n),children:[l.jsx(y,{}),p.map((function(t,n){return l.jsx(i.TouchableHighlight,{style:g(),underlayColor:"transparent",onPress:function(e){!function(e){a.call("click",{value:e,item:e,edit:!0})}(t)},children:l.jsx(i.View,{style:h("rowInner"),children:l.jsx(F,{scope:a,item:t,index:n,children:e.children})})},"k-"+n)}))]})]})}var R=i.StyleSheet.create({container:{flex:1,width:"100%",flexDirection:"row",flexWrap:"wrap",alignItems:"stretch"},row:{padding:5,width:"100%"},rowInner:{flexGrow:1,justifyContent:"center",alignItems:"center",backgroundColor:"#f5f5f5",borderRadius:8,padding:10,width:"100%"},text:{fontSize:18,fontWeight:"bold"}}),P=i.StyleSheet.create({container:{flex:1,width:"100%",flexDirection:"row",flexWrap:"wrap",gap:10,alignItems:"stretch"},row:{padding:0,width:"100%"},rowInner:{flexGrow:1,justifyContent:"center",alignItems:"center",padding:0,width:"100%"},text:{fontSize:18,fontWeight:"bold"}});function B(e){var n=e.scope,a=r.Utils.nvl(n.getOptions(),[]),o=n.getInputValue(),s=t.useState(0),c=s[0],d=s[1],f=function(e){return(null==e?void 0:e.value)===o},p=function(t){var a=t.item,o=t.index,s=f(a),c=u({},z.text);return s&&(c.color="#ffffff"),r.Utils.isEmpty(e.children)?l.jsx(i.Text,{style:c,children:a.label}):l.jsx(F,{scope:n,item:a.object,index:o,children:e.children})},x=function(e){var t=u({},z.item,n.getStyle("item")),r=Math.floor(100/a.length)+"%";if(f(e)){var i=n.getPart("selectedColor",void 0,"primary");(t=u({},t,n.getStyle("selected",{backgroundColor:i,color:"#ffffff"}))).color||(t.color="#ffffff")}return t.width=r,t};return l.jsx(l.Fragment,{children:a.map((function(e,t){return l.jsx(i.TouchableHighlight,{style:x(e),onPress:function(t){!function(e){n.changeValue(e.object),d(++c)}(e)},children:l.jsx(p,{item:e,index:t})},"k-"+t)}))})}var z=i.StyleSheet.create({container:{flex:1,width:"100%",gap:10,justifyContent:"center",flexDirection:"row"},item:{padding:15,marginVertical:8,backgroundColor:"#f5f5f5",borderRadius:8,justifyContent:"center",width:"auto",flexDirection:"row"},text:{fontSize:16,fontWeight:500}});function q(e){var n=e.scope,a=n.original,s=t.useState(0),c=s[0],d=s[1],f=n.getValue(0),p=a.color;p||(p="primary");var x={padding:10,alignItems:"center",height:44,width:44,textAlign:"center",verticalAling:"middle",borderRadius:24,backgroundColor:p,color:"#ffffff",justifyContent:"center"},h={buttonLabel:{color:"#ffffff",fontWeight:"500",fontSize:16},value:{flex:1,flexDirection:"row",textAlign:"center"},buttonInner:{flexDirection:"row",alignItems:"center",justifyContent:"center"},buttonIcon:{color:"#fff",fontSize:18},button:x,addButton:u({},x),delButton:u({},x)},g=function(e){n.changeValue(f+e),d(++c)},y=function(e,t){var r=u({},h[e],t);return n.getStyle(e,r)};return l.jsxs(l.Fragment,{children:[l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(){g(-1)},style:y("delButton"),children:l.jsx(o.Ionicons,{size:30,style:y("buttonIcon"),name:"remove"})}),l.jsx(i.Text,{style:y("value"),children:r.Utils.nvl(f,0)}),l.jsx(i.TouchableHighlight,{underlayColor:"transparent",onPress:function(){g(1)},style:y("addButton"),children:l.jsx(o.Ionicons,{size:30,style:y("buttonIcon"),name:"add"})})]})}function O(e){var n=t.useState(!1),a=n[0],o=n[1],s=e.scope,c=s.crud,f=s.getLabel(),p=r.useTheme(),x=function(e,t){var n=u({},W[e],t);return u({},s.getStyle(e,n))},h=function(e){o(a=e)};if(s.show=function(e){var t=e.crud,n=s.getName("modal"),i=r.Utils.nvl(e.item,{}),l=r.CrudUtils.create("dialog",{parent:t,name:n,data:i,edit:!0===e.edit,scope:s});s.currentDialog=l,h(!0)},s.hide=function(e){s.currentDialog=null,h(!1)},t.useEffect((function(){i.StatusBar.setBarStyle("light-content"),null==i.StatusBar.setBackgroundColor||i.StatusBar.setBackgroundColor(p.colors.primary)}),[a]),!s.currentDialog)return l.jsx(l.Fragment,{});var g=function(){s.close({scope:s,crud:c,event:{}})};return l.jsx(i.Modal,{animationType:"slide",transparent:!0,visible:a,onRequestClose:function(){return g},children:l.jsxs(i.SafeAreaView,{style:x("modalSafe"),children:[l.jsxs(i.View,{style:x("modalHeader"),children:[l.jsx(i.TouchableOpacity,{onPress:function(){return g},style:x("modalCloseButton"),children:l.jsx(i.Text,{style:x("modalCloseText"),children:"X"})}),l.jsx(i.Text,{style:x("modalTitle"),children:f})]}),l.jsx(i.ScrollView,{contentContainerStyle:{flexGrow:1},style:x("modalContent"),children:l.jsx(i.View,{style:{flex:1},children:l.jsx(d,{scope:s,crud:s.currentDialog,children:e.children})})})]})})}var W=i.StyleSheet.create({modalSafe:{flex:1,backgroundColor:"primary",width:"100%"},modalHeader:{flexDirection:"row",alignItems:"center",padding:15,backgroundColor:"primary"},modalCloseButton:{padding:10},modalCloseText:{fontSize:18,color:"white"},modalTitle:{fontSize:18,color:"white",fontWeight:"bold",marginLeft:10},modalContent:{flex:1,backgroundColor:"#f5f5f5",padding:20}});function E(e){var n=e.scope,a=e.children,o=r.useTheme(),s=n.getPart("header",null,[]);return t.useEffect((function(){i.StatusBar.setBarStyle("light-content"),null==i.StatusBar.setBackgroundColor||i.StatusBar.setBackgroundColor(o.colors.primary)}),[]),l.jsx(c.SafeAreaProvider,{children:l.jsxs(c.SafeAreaView,{style:n.getStyle("view",N.view),children:[l.jsx(i.StatusBar,{barStyle:"light-content"}),l.jsxs(i.KeyboardAvoidingView,{behavior:"ios"===i.Platform.OS?"padding":"height",style:{flex:1,justifyContent:"center"},children:[s,l.jsx(i.View,{style:n.getStyle("container",N.container),children:l.jsx(i.ScrollView,{keyboardShouldPersistTaps:"handled",style:n.getStyle("scroll",N.scroll),children:l.jsx(d,{scope:n,children:a})})})]})]})})}var N=i.StyleSheet.create({scroll:{padding:10},container:{backgroundColor:"primary"},view:{backgroundColor:"primary"}}),H=t.createContext({});function A(e){var n,a,s=t.useContext(H),c=r.Utils.nvl(e.theme,null==s?void 0:s.theme),f=r.Utils.nvl(e.crud,null==s?void 0:s.crud),h=t.useState(r.ScopeUtils.create(u({crud:f},e,{theme:c})))[0];f=h.crud;var g=t.useState(0),j=g[0],S=g[1],I=t.useState(null),V=I[0],D=I[1],F=h.getOptions(),R=h.original,P=t.useRef(null);h.update=function(){S(++j)},h.updateElement=function(){S(++j)};var z=function(){var e=R.custom;return e?l.jsx(A,"string"==typeof e?{element:{value:e,type:"dummy"},crud:f}:u({type:e.type,tag:e.type},e.props,{crud:f})):l.jsx(l.Fragment,{})};if(h.is("type","dummy"))return l.jsx(l.Fragment,{children:h.getDisplayValue()});var W=function(e){var t=e.target.value;h.isType("integer","int","number")?t=parseInt(t):h.isType("decimal")&&(t=parseFloat(t)),h.isType("select","complete")&&(t=h.getSelectedItem(t)),h.changeValue(t),h.update()},N=function(e){h.call("click")},M={scope:h,crud:f,onChange:W};h.isType("password")&&(M.type="password");var K=function(){return!(h.isInput()||r.Utils.isEmpty(e.children)&&r.Utils.isEmpty(e.elements))},Q=h.is("type","text","number","phone","postalCode","money","password","email"),J=function(e){var t,n=r.Utils.nvl(R.type,"none"),i=r.Utils.nvl(e,"root"),l=u({},X[i],null==G||null==(t=G[n])?void 0:t[i]),a=K();return e||a||(l=u({},l)),a&&e&&(l=u({},l,_[e])),Q&&(l=u({},l,G.input[i])),u({},l,h.getStyle(e,l))},Y=J("element"),Z={required:h.isRequired(),size:"small",scope:h,crud:f,style:Y,placeholder:h.attr("placeholder","Digite aqui")};h.error=function(e){V=e,D(e)},null!=(n=R.list)&&n.url||null!=(a=R.load)&&a.url||h.start(),t.useEffect((function(){h.start()}));var $=function(){return"string"==typeof R.icon?l.jsx(o.Ionicons,{name:R.icon,style:h.getStyle("icon")}):l.jsx(l.Fragment,{children:R.icon})};return h.open=function(e){i.Linking.openURL(e.url)},t.useLayoutEffect((function(){if(null!=P&&P.current&&h.is("type","card","list","tabs","stepper")){var e=null==P?void 0:P.current;if(null!=e&&e.classList){var t=r.HtmlUtils.getBGColor(e);e.classList.add("rgb(255, 255, 255)"===t?"ui-dark":"ui-light")}}})),!h.isRendered()||h.is("type","define")?l.jsx(l.Fragment,{}):l.jsx(H.Provider,{value:{crud:f,theme:c},children:l.jsx(i.View,{ref:P,style:J(),children:l.jsxs(l.Fragment,{children:[void 0!==R.label&&!1!==R.label&&!h.isType("button","dialog","modal")&&l.jsx(i.Text,{style:J("label"),children:h.getLabel()}),!K()&&l.jsxs(l.Fragment,{children:[l.jsxs(i.View,{style:J("inner"),children:[h.is("type","button")&&l.jsxs(b,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:[R.icon&&l.jsx($,{}),R.label&&l.jsx(i.Text,{style:h.getPart("label","button"),children:h.getLabel()})]})),h.is("type","icon")&&l.jsx(v,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:h.getDisplayValue()})),h.is("type","link")&&l.jsxs(m,u({},Z,{onClick:N,variant:h.attr("variant","outlined"),children:[R.icon&&l.jsx($,{}),R.label&&l.jsx(i.Text,{style:h.getPart("label","link"),children:h.getLabel()})]})),Q&&l.jsx(U,u({},M,Z,{InputProps:u({},R.inputProps)})),h.is("type","complete","autocomplete")&&l.jsx(y,{scope:h,defaultsInput:M,defaultsUI:Z}),h.is("type","quantity")&&l.jsx(q,{scope:h,defaultsInput:M,defaultsUI:Z}),h.is("type","checkbox","boolean","switch")&&l.jsx(C,u({checked:!0===h.getValue()},M,{onChange:function(){var e=h.getValue();W({target:{value:!(!0===e)}})}})),h.is("type","select")&&l.jsx(w,u({},M,Z,{value:h.getSelectedValue()})),h.is("type","toggle")&&l.jsx(B,u({},M,Z,{value:h.getSelectedValue()})),h.is("type","radio")&&l.jsx(k,u({},M,Z,{row:!0,children:F.map((function(e,t){return l.jsx(T,{control:l.jsx(k,u({},Z)),label:e.label,value:e.value},"i"+t)}))})),h.is("type","custom")&&l.jsx(z,{}),h.is("type","column")&&l.jsxs(l.Fragment,{children:[h.is("format","img")&&l.jsx(i.Image,{source:h.getDisplayValue()}),h.is("format","icon")&&l.jsx(v,{scope:h,crud:f}),!h.is("format","icon","img")&&l.jsx(i.Text,{children:h.getDisplayValue()})]}),h.is("type","output","value")&&l.jsx(i.Text,{style:J("value"),children:h.getDisplayValue()})]}),V&&l.jsx(i.View,{style:J("error"),children:V})]}),h.isType("list","repeat")&&l.jsx(L,u({},e,{scope:h,crud:f})),h.isType("dialog")&&l.jsx(O,u({},e,{scope:h,crud:f})),h.isType("chart")&&l.jsx(x,u({},e,{scope:h,crud:f})),h.isType("tabs")&&l.jsx(p,u({},e,{scope:h,crud:f})),h.isType("view")&&l.jsx(E,u({},e,{scope:h,crud:f})),!h.isType("tabs","view","grid","list","define","repeat","modal","dialog","chart")&&l.jsx(d,u({},e,{scope:h,crud:f,style:J("inner")}))]})})})}var M={backgroundColor:"white",padding:16,borderRadius:10,width:"100%",shadowColor:"#888",shadowOffset:{width:0,height:1},shadowOpacity:.25,shadowRadius:3.84,elevation:3},G={view:{inner:{width:"100%",alignItems:"normal",flex:1},container:{width:"100%",backgroundColor:"#f5f5f5",flex:1,gap:10},child:{width:"100%",flex:1,gap:10,padding:10},root:{width:"100%",flex:1,alignItems:"normal",padding:0}}};G.card=i.StyleSheet.create({root:u({},M),inner:{flex:1,width:"100%",paddingBottom:10,paddingTop:5,alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap",gap:10}}),G.input=i.StyleSheet.create({inner:{flex:1,width:"100%",paddingBottom:0,paddingTop:0,alignItems:"center",borderWidth:1,borderColor:"borderColor",borderRadius:20,paddingHorizontal:15,alignSelf:"flex-start",flexDirection:"row",flexWrap:"wrap"}}),G.quantity={inner:u({},M,{padding:5,borderRadius:25,flexWrap:"nowrap",flex:1,flexDirection:"row",justifyContent:"center",alignItems:"center"})},G.toggle=i.StyleSheet.create({inner:u({},M,{flex:1,width:"100%",gap:10,justifyContent:"center",flexDirection:"row",paddingHorizontal:10,paddingVertical:0,alignSelf:"flex-start",flexWrap:"nowrap"})});var X=i.StyleSheet.create({root:{gap:5,flexDirection:"column",flexWrap:"wrap",width:"100%",alignItems:"flex-start"},label:{width:"100%",fontWeight:500,fontSize:12},inner:{width:"100%"}}),_=i.StyleSheet.create({root:{gap:10},label:{width:"100%",fontWeight:500,fontSize:24}});function K(e){if(!1===e.rendered)return l.jsx(l.Fragment,{});var t=r.ComponentUtils.getDefine(e,e.name,e.position);return r.Utils.isEmpty(t)&&(t=e.default),r.Utils.isEmpty(t)?l.jsx(l.Fragment,{children:t}):l.jsx((function(t){var n=e.tag;return r.Utils.isEmpty(n)?l.jsx(l.Fragment,{children:t.children}):l.jsx(n,u({},t,{children:t.children}))}),u({},e.tagProps,{children:l.jsx(d,u({transient:!0},e,{scope:e.scope,crud:e.crud,part:e.name,children:t}))}))}var Q=["type"],J={List:function(e){return l.jsx(A,u({},e,{type:"list"}))},Row:function(e){return l.jsx(A,u({},e,{type:"row"}))},Value:function(e){return l.jsx(A,u({},e,{type:"value"}))},Label:function(e){return l.jsx(A,u({},e,{type:"label"}))},Repeat:function(e){return l.jsx(A,u({},e,{type:"repeat",props:{search:!1}}))},Define:function(e){return l.jsx(A,u({},e,{type:"define"}))},Include:function(e){return l.jsx(K,u({},e))},Column:function(e){var t=function(e,t){if(null==e)return{};var n={};for(var r in e)if({}.hasOwnProperty.call(e,r)){if(-1!==t.indexOf(r))continue;n[r]=e[r]}return n}(e,Q);return l.jsx(A,u({},t,{type:"column"}))},Input:function(e){return l.jsx(A,u({},e))},Text:function(e){return l.jsx(A,u({},e,{type:"text"}))},Email:function(e){return l.jsx(A,u({},e,{type:"email"}))},Button:function(e){return l.jsx(A,u({},e,{type:"button"}))},Link:function(e){return l.jsx(A,u({},e,{type:"link"}))},Icon:function(e){return l.jsx(A,u({},e,{type:"icon"}))},Output:function(e){return l.jsx(A,u({},e,{type:"output"}))},Form:function(e){return l.jsx(A,u({},e,{type:"form"}))},Crud:function(e){return l.jsx(A,u({},e,{type:"crud"}))},View:function(e){return l.jsx(A,u({},e,{type:"view",transient:!0}))},Bottom:function(e){return l.jsx(A,u({},e,{type:"bottom"}))},Dialog:function(e){return l.jsx(A,u({},e,{type:"dialog"}))},Content:function(e){return l.jsx(A,u({},e,{type:"content"}))},Top:function(e){return l.jsx(A,u({},e,{type:"top"}))},Card:function(e){return l.jsx(A,u({},e,{type:"card"}))},Tab:function(e){return l.jsx(A,u({},e,{type:"tab"}))},Tabs:function(e){return l.jsx(A,u({},e,{type:"tabs"}))},Step:function(e){return l.jsx(A,u({},e,{type:"tab",layout:"step"}))},Stepper:function(e){return l.jsx(A,u({},e,{type:"tabs",layout:"stepper"}))},Money:function(e){return l.jsx(A,u({},e,{type:"money"}))},Chart:function(e){return l.jsx(A,u({},e,{type:"chart"}))},Password:function(e){return l.jsx(A,u({},e,{type:"password"}))},Complete:function(e){return l.jsx(A,u({},e,{type:"complete"}))},Checkbox:function(e){return l.jsx(A,u({},e,{type:"switch"}))},Switch:function(e){return l.jsx(A,u({},e,{type:"switch"}))},Radio:function(e){return l.jsx(A,u({},e,{type:"radio"}))},Select:function(e){return l.jsx(A,u({},e,{type:"select"}))},Toggle:function(e){return l.jsx(A,u({},e,{type:"toggle"}))},Entity:function(e){return l.jsx(A,u({},e,{type:"entity"}))},Element:function(e){return l.jsx(A,u({},e,{type:"element"}))},Quantity:function(e){return l.jsx(A,u({},e,{type:"quantity"}))}};exports.UI=J;
|
|
2
2
|
//# sourceMappingURL=react-crud-mobile.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n\n return { ...def, ...props.style, ...scope.getStyle(part) };\n };\n\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n\n return <Ionicons name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n\n let color = element.color;\n let label = element.label;\n let icon = element.icon;\n\n if (!color) color = 'primary';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n paddingRight: 10,\n paddingLeft: 10,\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n height: 44,\n minWidth: 44,\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: {\n alignItems: 'center',\n margin: 'auto',\n width: '100%',\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n flex: 1,\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n let extra: any = {};\n\n if (!label) {\n extra.button = { width: 'auto' };\n extra.icon = { padding: 5 };\n } else if (icon) {\n extra.button = { padding: 0, paddingHorizontal: 20 };\n }\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={style('button', extra.button)}\n >\n <View style={style('buttonInner')}>\n {icon && (\n <>\n <Ionicons\n size={30}\n style={style('buttonIcon', extra.icon)}\n name={icon}\n />\n </>\n )}\n {label && <Text style={style('buttonLabel')}>{label}</Text>}\n </View>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport { ChildType, MethodType, useTheme, Utils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n} from 'react-native';\nimport Icon from 'react-native-vector-icons/FontAwesome';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = useTheme();\n\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const onClick = ({ crud, value }: MethodType) => {\n scope.changeValue(value);\n handlePress();\n };\n\n const style = (part: string, extra?: any) => {\n return { ...styles[part], ...scope.getStyle(part), ...extra };\n };\n\n return (\n <View style={style('selectRoot')}>\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Icon name=\"angle-down\" size={20} color=\"#888\" />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={() => setModalVisible(false)}\n >\n <StatusBar\n barStyle=\"dark-content\"\n backgroundColor={theme.colors.primary}\n />\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{placeholder}</Text>\n </View>\n <View style={style('modalContent')}>\n <UI.List data={items} name={scope.getName('list')} click={onClick}>\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderWidth: 1,\n borderColor: '#a9a9a9',\n borderRadius: 20,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n paddingTop: StatusBar.currentHeight || 0, // Considera a altura da barra de status no Android\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: '#6200ea',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n width: '100%',\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 20,\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.nvl(scope.getValue(), '');\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n return (\n <>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flexDirection: 'row',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 10,\n paddingVertical: 5,\n padding: 10,\n paddingLeft: 5,\n paddingRight: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const parent = props.scope;\n const item = props.item;\n const index = props.index;\n const name = `${parent.key('row', index)}`;\n const row = {\n parent,\n name,\n crud: parent.crud,\n index,\n type: 'row',\n data: item,\n };\n let [scope] = useState(ScopeUtils.create(row));\n\n return (\n <>\n <UIChildren scope={scope} crud={scope.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n}\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(original.cols, 1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const items = Utils.nvl(scope.getItems(), []);\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n\n const onClick = (item: any) => {\n scope.call('click', { value: item, item, edit: true });\n };\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getRowStyle = (extra?: any) => {\n let row = getStyle('row', {});\n\n if (cols > 0) {\n row.width = rowWidth;\n }\n\n return row;\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n let Empty = () => {\n if (!Utils.isEmpty(items)) {\n return <></>;\n }\n\n let empty = scope.attr('empty', 'Sem registro');\n\n if (!empty) {\n return <></>;\n }\n\n if (typeof empty === 'string') {\n return (\n <Text\n style={scope.getStyle('empty', {\n flex: 1,\n fontWeight: 500,\n fontSize: 20,\n padding: 10,\n textAlign: 'center',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n right={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n\n <View style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getRowStyle()}\n underlayColor={'transparent'}\n onPress={e => {\n onClick(item);\n }}\n >\n <View style={getStyle('rowInner')}>\n <UIListRow scope={scope} item={item} index={i}>\n {props.children}\n </UIListRow>\n </View>\n </TouchableHighlight>\n ))}\n </View>\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n alignItems: 'stretch',\n },\n row: {\n padding: 5,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n padding: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n alignItems: 'stretch',\n },\n row: {\n padding: 0,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n padding: 0,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 15,\n marginVertical: 8,\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 16,\n fontWeight: 500,\n },\n});\n","import { Ionicons } from '@expo/vector-icons';\nimport { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIQuantity(props: ChildType) {\n const scope = props.scope;\n const element = scope.original;\n\n let [index, setIndex] = useState(0);\n\n const value = scope.getValue(0);\n\n let color = element.color;\n\n if (!color) color = 'primary';\n\n const btn = {\n padding: 10,\n alignItems: 'center',\n height: 44,\n width: 44,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { useEffect, useState } from 'react';\nimport {\n ChildType,\n CrudUtils,\n MethodType,\n useTheme,\n Utils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\n\nexport default function UIModal(props: ChildType) {\n let [modalVisible, setModalVisible] = useState(false);\n\n const scope = props.scope;\n const crud = scope.crud;\n const label = scope.getLabel();\n const theme = useTheme();\n\n const style = (part: string, extra?: any) => {\n let st = { ...styles[part], ...extra };\n\n return { ...scope.getStyle(part, st) };\n };\n\n const toggle = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.show = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let data = Utils.nvl(args.item, {});\n let edit = args.edit === true;\n let d = CrudUtils.create('dialog', {\n parent: crud,\n name,\n data,\n edit,\n scope,\n });\n\n scope.currentDialog = d;\n\n toggle(true);\n };\n\n scope.hide = (args?: MethodType) => {\n scope.currentDialog = null;\n\n toggle(false);\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, [modalVisible]);\n\n if (!scope.currentDialog) {\n return <></>;\n }\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={() => {\n scope.close({ scope, crud, event: {} });\n }}\n >\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{label}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1 }}\n style={style('modalContent')}\n >\n <View style={{ flex: 1 }}>\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {props.children}\n </UIChildren>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalSafe: {\n flex: 1,\n backgroundColor: 'primary',\n width: '100%',\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: 'primary',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n padding: 20,\n },\n});\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n ScrollView,\n StyleSheet,\n TouchableWithoutFeedback,\n View,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, useTheme } from 'react-crud-utils';\nimport { useEffect } from 'react';\nimport { StatusBar } from 'react-native';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = useTheme();\n const header = scope.getPart('header', null, []);\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n return (\n <SafeAreaProvider>\n <SafeAreaContextView style={scope.getStyle('view', styles.view)}>\n <StatusBar barStyle=\"light-content\" />\n\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n {header}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n keyboardShouldPersistTaps=\"handled\"\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {\n backgroundColor: 'primary',\n },\n view: {\n backgroundColor: 'primary',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n ChildType,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport { Image, Linking, StyleSheet, Text, View } from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n\n crud = scope.crud;\n\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key], ...elementStyle?.[type]?.[key] };\n let hasChild = hasChildren();\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n if (isInput) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n return { ...def, ...scope.getStyle(part, def) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <View ref={ref} style={getStyle()}>\n <>\n {isShowLabel() && (\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', 'icon') && (\n <UIIcon\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {scope.getDisplayValue()}\n </UIIcon>\n )}\n {scope.is('type', 'link') && (\n <UILink\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'link')}>\n {scope.getLabel()}\n </Text>\n )}\n </UILink>\n )}\n {isInput && (\n <UIInput\n {...defaultsInput}\n {...defaultsUI}\n InputProps={{ ...original.inputProps }}\n />\n )}\n {scope.is('type', 'complete', 'autocomplete') && (\n <UIComplete\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'quantity') && (\n <UIQuantity\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\n <UISwitch\n checked={isChecked()}\n {...defaultsInput}\n onChange={onCheck}\n />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && (\n <UIIcon scope={scope} crud={crud} />\n )}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>\n {scope.getDisplayValue()}\n </Text>\n )}\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n </View>\n </CrudContext.Provider>\n );\n}\n\nconst box: any = {\n backgroundColor: 'white',\n padding: 16,\n borderRadius: 10,\n width: '100%',\n shadowColor: '#888', // iOS\n shadowOffset: { width: 0, height: 1 }, // iOS\n shadowOpacity: 0.25, // iOS\n shadowRadius: 3.84, // iOS\n elevation: 3, // Android\n};\n\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: '#f5f5f5',\n flex: 1,\n gap: 10,\n },\n child: {\n width: '100%',\n flex: 1,\n gap: 10,\n padding: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\nelementStyle.card = StyleSheet.create({\n root: {\n ...box,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 10,\n paddingTop: 5,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n});\n\nelementStyle.input = StyleSheet.create({\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.quantity = {\n inner: {\n ...box,\n padding: 5,\n borderRadius: 25,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n paddingHorizontal: 10,\n paddingVertical: 0,\n alignSelf: 'flex-start',\n flexWrap: 'nowrap',\n },\n});\n\nconst styles = StyleSheet.create({\n root: {\n gap: 5,\n flexDirection: 'column',\n flexWrap: 'wrap',\n width: '100%',\n alignItems: 'flex-start',\n },\n label: { width: '100%', fontWeight: 500, fontSize: 12 },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import { ListType } from 'react-crud-utils';\nimport { UserType } from 'react-crud-utils';\nimport { InputType } from 'react-crud-utils';\nimport { ChartType } from 'react-crud-utils';\nimport { ContainerType } from 'react-crud-utils';\nimport { ListInputType } from 'react-crud-utils';\nimport UIElement from './UIElement';\nimport { TabsType } from 'react-crud-utils';\nimport { DefineType } from 'react-crud-utils';\nimport { ButtonType } from 'react-crud-utils';\nimport { LinkType } from 'react-crud-utils';\nimport UIInclude from './core/UIInclude';\n\nconst UI = {\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: ButtonType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n};\nexport default UI;\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","key","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","s","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","push","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","UIButton","color","buttonLabel","fontWeight","fontSize","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","handlePress","Icon","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","borderWidth","borderColor","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","marginRight","input","marginHorizontal","marginVertical","UIListRow","UIList","row","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","getRowStyle","Empty","empty","search","field","right","edit","container","rowInner","flexGrow","text","gap","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","st","toggle","vis","show","args","d","currentDialog","hide","useEffect","setBarStyle","setBackgroundColor","close","ScrollView","contentContainerStyle","UIView","header","SafeAreaProvider","SafeAreaContextView","view","KeyboardAvoidingView","behavior","Platform","OS","keyboardShouldPersistTaps","scroll","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","update","updateElement","c","custom","tag","is","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","def","elementStyle","_elementStyle$type","hasChild","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","current","classList","bg","HtmlUtils","getBGColor","add","isRendered","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","root","card","paddingBottom","quantity","UIInclude","includes","ComponentUtils","getDefine","position","tagProp","Tag","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n\n return { ...def, ...props.style, ...scope.getStyle(part) };\n };\n\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n\n return <Ionicons name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n\n let color = element.color;\n let label = element.label;\n let icon = element.icon;\n\n if (!color) color = 'primary';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n paddingRight: 10,\n paddingLeft: 10,\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n height: 44,\n minWidth: 44,\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: {\n alignItems: 'center',\n margin: 'auto',\n width: '100%',\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n flex: 1,\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n let extra: any = {};\n\n if (!label) {\n extra.button = { width: 'auto' };\n extra.icon = { padding: 5 };\n } else if (icon) {\n extra.button = { padding: 0, paddingHorizontal: 20 };\n }\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={style('button', extra.button)}\n >\n <View style={style('buttonInner')}>\n {icon && (\n <>\n <Ionicons\n size={30}\n style={style('buttonIcon', extra.icon)}\n name={icon}\n />\n </>\n )}\n {label && <Text style={style('buttonLabel')}>{label}</Text>}\n </View>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport { ChildType, MethodType, useTheme, Utils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n} from 'react-native';\nimport Icon from 'react-native-vector-icons/FontAwesome';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = useTheme();\n\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const onClick = ({ crud, value }: MethodType) => {\n scope.changeValue(value);\n handlePress();\n };\n\n const style = (part: string, extra?: any) => {\n return { ...styles[part], ...scope.getStyle(part), ...extra };\n };\n\n return (\n <View style={style('selectRoot')}>\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Icon name=\"angle-down\" size={20} color=\"#888\" />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={() => setModalVisible(false)}\n >\n <StatusBar\n barStyle=\"dark-content\"\n backgroundColor={theme.colors.primary}\n />\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{placeholder}</Text>\n </View>\n <View style={style('modalContent')}>\n <UI.List data={items} name={scope.getName('list')} click={onClick}>\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderWidth: 1,\n borderColor: '#a9a9a9',\n borderRadius: 20,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n paddingTop: StatusBar.currentHeight || 0, // Considera a altura da barra de status no Android\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: '#6200ea',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n width: '100%',\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 20,\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.nvl(scope.getValue(), '');\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n return (\n <>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flexDirection: 'row',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 10,\n paddingVertical: 5,\n padding: 10,\n paddingLeft: 5,\n paddingRight: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const parent = props.scope;\n const item = props.item;\n const index = props.index;\n const name = `${parent.key('row', index)}`;\n const row = {\n parent,\n name,\n crud: parent.crud,\n index,\n type: 'row',\n data: item,\n };\n let [scope] = useState(ScopeUtils.create(row));\n\n return (\n <>\n <UIChildren scope={scope} crud={scope.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n}\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(original.cols, 1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const items = Utils.nvl(scope.getItems(), []);\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n\n const onClick = (item: any) => {\n scope.call('click', { value: item, item, edit: true });\n };\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getRowStyle = (extra?: any) => {\n let row = getStyle('row', {});\n\n if (cols > 0) {\n row.width = rowWidth;\n }\n\n return row;\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n let Empty = () => {\n if (!Utils.isEmpty(items)) {\n return <></>;\n }\n\n let empty = scope.attr('empty', 'Sem registro');\n\n if (!empty) {\n return <></>;\n }\n\n if (typeof empty === 'string') {\n return (\n <Text\n style={scope.getStyle('empty', {\n flex: 1,\n fontWeight: 500,\n fontSize: 20,\n padding: 10,\n textAlign: 'center',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n right={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n\n <View style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getRowStyle()}\n underlayColor={'transparent'}\n onPress={e => {\n onClick(item);\n }}\n >\n <View style={getStyle('rowInner')}>\n <UIListRow scope={scope} item={item} index={i}>\n {props.children}\n </UIListRow>\n </View>\n </TouchableHighlight>\n ))}\n </View>\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n alignItems: 'stretch',\n },\n row: {\n padding: 5,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n padding: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n alignItems: 'stretch',\n },\n row: {\n padding: 0,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n padding: 0,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 15,\n marginVertical: 8,\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 16,\n fontWeight: 500,\n },\n});\n","import { Ionicons } from '@expo/vector-icons';\nimport { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIQuantity(props: ChildType) {\n const scope = props.scope;\n const element = scope.original;\n\n let [index, setIndex] = useState(0);\n\n const value = scope.getValue(0);\n\n let color = element.color;\n\n if (!color) color = 'primary';\n\n const btn = {\n padding: 10,\n alignItems: 'center',\n height: 44,\n width: 44,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { useEffect, useState } from 'react';\nimport {\n ChildType,\n CrudUtils,\n MethodType,\n useTheme,\n Utils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\n\nexport default function UIModal(props: ChildType) {\n let [modalVisible, setModalVisible] = useState(false);\n\n const scope = props.scope;\n const crud = scope.crud;\n const label = scope.getLabel();\n const theme = useTheme();\n\n const style = (part: string, extra?: any) => {\n let st = { ...styles[part], ...extra };\n\n return { ...scope.getStyle(part, st) };\n };\n\n const toggle = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.show = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let data = Utils.nvl(args.item, {});\n let edit = args.edit === true;\n let d = CrudUtils.create('dialog', {\n parent: crud,\n name,\n data,\n edit,\n scope,\n });\n\n scope.currentDialog = d;\n\n toggle(true);\n };\n\n scope.hide = (args?: MethodType) => {\n scope.currentDialog = null;\n\n toggle(false);\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, [modalVisible]);\n\n if (!scope.currentDialog) {\n return <></>;\n }\n\n let onClose = () => {\n scope.close({ scope, crud, event: {} });\n };\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={() => onClose}\n >\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => onClose}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{label}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1 }}\n style={style('modalContent')}\n >\n <View style={{ flex: 1 }}>\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {props.children}\n </UIChildren>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalSafe: {\n flex: 1,\n backgroundColor: 'primary',\n width: '100%',\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: 'primary',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n padding: 20,\n },\n});\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n ScrollView,\n StyleSheet,\n TouchableWithoutFeedback,\n View,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, useTheme } from 'react-crud-utils';\nimport { useEffect } from 'react';\nimport { StatusBar } from 'react-native';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = useTheme();\n const header = scope.getPart('header', null, []);\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n return (\n <SafeAreaProvider>\n <SafeAreaContextView style={scope.getStyle('view', styles.view)}>\n <StatusBar barStyle=\"light-content\" />\n\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n {header}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n keyboardShouldPersistTaps=\"handled\"\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {\n backgroundColor: 'primary',\n },\n view: {\n backgroundColor: 'primary',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n ChildType,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport { Image, Linking, StyleSheet, Text, View } from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n\n crud = scope.crud;\n\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key], ...elementStyle?.[type]?.[key] };\n let hasChild = hasChildren();\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n if (isInput) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n return { ...def, ...scope.getStyle(part, def) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <View ref={ref} style={getStyle()}>\n <>\n {isShowLabel() && (\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', 'icon') && (\n <UIIcon\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {scope.getDisplayValue()}\n </UIIcon>\n )}\n {scope.is('type', 'link') && (\n <UILink\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'link')}>\n {scope.getLabel()}\n </Text>\n )}\n </UILink>\n )}\n {isInput && (\n <UIInput\n {...defaultsInput}\n {...defaultsUI}\n InputProps={{ ...original.inputProps }}\n />\n )}\n {scope.is('type', 'complete', 'autocomplete') && (\n <UIComplete\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'quantity') && (\n <UIQuantity\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\n <UISwitch\n checked={isChecked()}\n {...defaultsInput}\n onChange={onCheck}\n />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && (\n <UIIcon scope={scope} crud={crud} />\n )}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>\n {scope.getDisplayValue()}\n </Text>\n )}\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n </View>\n </CrudContext.Provider>\n );\n}\n\nconst box: any = {\n backgroundColor: 'white',\n padding: 16,\n borderRadius: 10,\n width: '100%',\n shadowColor: '#888', // iOS\n shadowOffset: { width: 0, height: 1 }, // iOS\n shadowOpacity: 0.25, // iOS\n shadowRadius: 3.84, // iOS\n elevation: 3, // Android\n};\n\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: '#f5f5f5',\n flex: 1,\n gap: 10,\n },\n child: {\n width: '100%',\n flex: 1,\n gap: 10,\n padding: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\nelementStyle.card = StyleSheet.create({\n root: {\n ...box,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 10,\n paddingTop: 5,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n});\n\nelementStyle.input = StyleSheet.create({\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.quantity = {\n inner: {\n ...box,\n padding: 5,\n borderRadius: 25,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n paddingHorizontal: 10,\n paddingVertical: 0,\n alignSelf: 'flex-start',\n flexWrap: 'nowrap',\n },\n});\n\nconst styles = StyleSheet.create({\n root: {\n gap: 5,\n flexDirection: 'column',\n flexWrap: 'wrap',\n width: '100%',\n alignItems: 'flex-start',\n },\n label: { width: '100%', fontWeight: 500, fontSize: 12 },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import { ListType } from 'react-crud-utils';\nimport { UserType } from 'react-crud-utils';\nimport { InputType } from 'react-crud-utils';\nimport { ChartType } from 'react-crud-utils';\nimport { ContainerType } from 'react-crud-utils';\nimport { ListInputType } from 'react-crud-utils';\nimport UIElement from './UIElement';\nimport { TabsType } from 'react-crud-utils';\nimport { DefineType } from 'react-crud-utils';\nimport { ButtonType } from 'react-crud-utils';\nimport { LinkType } from 'react-crud-utils';\nimport UIInclude from './core/UIInclude';\n\nconst UI = {\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: ButtonType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n};\nexport default UI;\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","key","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","s","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","push","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","UIButton","color","buttonLabel","fontWeight","fontSize","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","handlePress","Icon","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","borderWidth","borderColor","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","marginRight","input","marginHorizontal","marginVertical","UIListRow","UIList","row","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","getRowStyle","Empty","empty","search","field","right","edit","container","rowInner","flexGrow","text","gap","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","st","toggle","vis","show","args","d","currentDialog","hide","useEffect","setBarStyle","setBackgroundColor","onClose","close","ScrollView","contentContainerStyle","UIView","header","SafeAreaProvider","SafeAreaContextView","view","KeyboardAvoidingView","behavior","Platform","OS","keyboardShouldPersistTaps","scroll","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","update","updateElement","c","custom","tag","is","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","def","elementStyle","_elementStyle$type","hasChild","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","current","classList","bg","HtmlUtils","getBGColor","add","isRendered","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","root","card","paddingBottom","quantity","UIInclude","includes","ComponentUtils","getDefine","position","tagProp","Tag","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity"],"mappings":"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"}
|