react-crud-mobile 1.0.428 → 1.0.430

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