react-crud-mobile 1.0.533 → 1.0.535
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/react-crud-mobile.cjs.development.js +8 -2
- package/dist/react-crud-mobile.cjs.development.js.map +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js.map +1 -1
- package/dist/react-crud-mobile.esm.js +8 -2
- package/dist/react-crud-mobile.esm.js.map +1 -1
- package/package.json +73 -73
- package/src/elements/UI.tsx +67 -67
- package/src/elements/UIChildren.tsx +127 -127
- package/src/elements/UIComplete.tsx +14 -14
- package/src/elements/UIElement.tsx +548 -548
- package/src/elements/UITag.tsx +13 -13
- package/src/elements/charts/ElChart.tsx +10 -10
- package/src/elements/core/UIButton.tsx +85 -85
- package/src/elements/core/UIIcon.tsx +8 -8
- package/src/elements/core/UIInclude.tsx +40 -40
- package/src/elements/core/UIInput.tsx +69 -69
- package/src/elements/core/UIList.tsx +173 -173
- package/src/elements/core/UIListRow.tsx +32 -32
- package/src/elements/core/UIModal.tsx +173 -165
- package/src/elements/core/UIQuantity.tsx +97 -97
- package/src/elements/core/UISelect.tsx +122 -122
- package/src/elements/core/UIToggle.tsx +102 -102
- package/src/elements/core/UIView.tsx +42 -42
- package/src/elements/index.ts +1 -1
- package/src/elements/tabs/ElTabs.tsx +178 -178
- package/src/index.ts +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.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 = 'primaryLight';\r\n\r\n const styles: any = {\r\n buttonLabel: {\r\n color: '#ffffff',\r\n fontWeight: '500',\r\n fontSize: 16,\r\n paddingRight: 10,\r\n paddingLeft: 10,\r\n },\r\n buttonInner: {\r\n flexDirection: 'row',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n height: 44,\r\n minWidth: 44,\r\n },\r\n buttonIcon: {\r\n color: '#fff',\r\n fontSize: 18,\r\n },\r\n button: {\r\n alignItems: 'center',\r\n margin: 'auto',\r\n width: '100%',\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 let extra: any = {};\r\n\r\n if (!label) {\r\n extra.button = { width: 'auto' };\r\n extra.icon = { padding: 5 };\r\n } else if (icon) {\r\n extra.button = { padding: 0, paddingHorizontal: 20 };\r\n }\r\n return (\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClick}\r\n style={style('button', extra.button)}\r\n >\r\n <View style={style('buttonInner')}>\r\n {icon && (\r\n <>\r\n <Ionicons\r\n size={30}\r\n style={style('buttonIcon', extra.icon)}\r\n name={icon}\r\n />\r\n </>\r\n )}\r\n {label && <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 { Ionicons } from '@expo/vector-icons';\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 <Ionicons name=\"arrow-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, ComponentUtils, 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 const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\r\n const add = ComponentUtils.getDefine(props, 'add');\r\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\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 const isShowAdd = () => {\r\n if (!Utils.isEmpty(items)) {\r\n return true;\r\n }\r\n return hideAddWhenEmpty !== true;\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 <UIListRow scope={scope} item={item} index={i}>\r\n {props.children}\r\n </UIListRow>\r\n </TouchableHighlight>\r\n ))}\r\n {isShowAdd() && <>{add}</>}\r\n </View>\r\n </>\r\n );\r\n}\r\n\r\nconst stylesList = 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 margin: 3,\r\n width: '100%',\r\n backgroundColor: '#f5f5f5',\r\n gap: 10,\r\n borderRadius: 8,\r\n },\r\n rowInner: {\r\n flexGrow: 1, // ✅ cresce conforme o conteúdo\r\n justifyContent: 'center',\r\n alignItems: 'center',\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\r\nconst stylesRepeat = StyleSheet.create({\r\n container: {\r\n flex: 1,\r\n width: '100%',\r\n flexDirection: 'row',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n alignItems: 'stretch',\r\n },\r\n row: {\r\n padding: 0,\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 padding: 0,\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 ViewUtils,\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 let [index, setIndex] = useState(0);\r\n let main = ViewUtils.getCrud('view');\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 onClose = () => {\r\n scope.close({ scope, crud: scope.currentDialog, event: {} });\r\n };\r\n\r\n const toggle = vis => {\r\n modalVisible = vis;\r\n setModalVisible(modalVisible);\r\n };\r\n\r\n scope.update = () => {\r\n setIndex(++index);\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 def: any = {};\r\n\r\n if (crud.is('search')) {\r\n def.parent = crud.parent;\r\n def.search = crud;\r\n }\r\n\r\n let d = CrudUtils.create('dialog', {\r\n parent: crud,\r\n name,\r\n dialog: main.dialog,\r\n data,\r\n edit,\r\n scope,\r\n ...def,\r\n });\r\n\r\n main.dialog = d;\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 let old = scope.currentDialog;\r\n\r\n main.dialog = Utils.nvl(old.dialog, null);\r\n scope.currentDialog = null;\r\n\r\n toggle(false);\r\n\r\n if (main.dialog) {\r\n main.dialog.update();\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\r\n }, [modalVisible]);\r\n\r\n let curr = scope.currentDialog;\r\n\r\n if (!curr) {\r\n return <></>;\r\n }\r\n\r\n if (curr.uuid !== main.dialog.uuid) {\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={onClose}\r\n >\r\n <SafeAreaView style={style('modalSafe')}>\r\n <View style={style('modalHeader')}>\r\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\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 { ScrollView, StyleSheet, View } from 'react-native';\r\n\r\nimport UIChildren from '../UIChildren';\r\nimport { ChildType, useTheme } from 'react-crud-utils';\r\nimport { useEffect } from 'react';\r\nimport { StatusBar } from 'react-native';\r\n\r\nexport default function UIView({ scope, children }: ChildType) {\r\n const theme = useTheme();\r\n const header = scope.getPart('header', null, []);\r\n\r\n useEffect(() => {\r\n StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\r\n }, []);\r\n return (\r\n <>\r\n {header}\r\n <View style={scope.getStyle('container', styles.container)}>\r\n <ScrollView\r\n keyboardShouldPersistTaps=\"handled\"\r\n contentContainerStyle={scope.getStyle('contentContainer', {})}\r\n style={scope.getStyle('scroll', styles.scroll)}\r\n >\r\n <UIChildren scope={scope}>{children}</UIChildren>\r\n </ScrollView>\r\n </View>\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n scroll: {\r\n padding: 10,\r\n },\r\n container: {\r\n backgroundColor: 'primary',\r\n },\r\n view: {\r\n backgroundColor: 'primary',\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\nimport UIView from './core/UIView';\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.isType(\r\n 'tabs',\r\n 'view',\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 style={getStyle('value')}>\r\n {scope.getDisplayValue()}\r\n </Text>\r\n )}\r\n </View>\r\n {error && <View style={getStyle('error')}>{error}</View>}\r\n </>\r\n )}\r\n {scope.isType('list', 'repeat') && (\r\n <UIList {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('dialog') && (\r\n <UIModal {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('chart') && (\r\n <ElChart {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('tabs') && (\r\n <ElTabs {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {scope.isType('view') && (\r\n <UIView {...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.view = {\r\n inner: {\r\n width: '100%',\r\n alignItems: 'normal',\r\n flex: 1,\r\n },\r\n container: {\r\n width: '100%',\r\n backgroundColor: '#f5f5f5',\r\n flex: 1,\r\n gap: 10,\r\n },\r\n child: {\r\n width: '100%',\r\n flex: 1,\r\n gap: 10,\r\n padding: 10,\r\n },\r\n root: {\r\n width: '100%',\r\n flex: 1,\r\n alignItems: 'normal',\r\n padding: 0,\r\n },\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\nimport SafeView from './core/SafeView';\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 SafeView: SafeView,\r\n};\r\nexport default UI;\r\n","import {\r\n Keyboard,\r\n KeyboardAvoidingView,\r\n Platform,\r\n StatusBar,\r\n StyleProp,\r\n TouchableWithoutFeedback,\r\n ViewStyle,\r\n} from 'react-native';\r\nimport {\r\n SafeAreaProvider,\r\n SafeAreaView as SafeAreaContextView,\r\n} from 'react-native-safe-area-context';\r\nimport { useTheme } from 'react-crud-utils';\r\nimport { useEffect } from 'react';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function SafeView(props: SafeViewType) {\r\n const theme = useTheme();\r\n const dismissKeyboard = () => {\r\n if (Platform.OS !== 'web') {\r\n Keyboard.dismiss();\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\r\n }, []);\r\n\r\n return (\r\n <SafeAreaProvider>\r\n <StatusBar barStyle=\"light-content\" />\r\n <SafeAreaContextView\r\n style={{\r\n backgroundColor: theme.colors?.primary,\r\n ...props.viewStyle,\r\n flex: 1,\r\n }}\r\n >\r\n <KeyboardAvoidingView\r\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\r\n style={{\r\n flex: 1, // 🔹 Ocupa 100% da tela\r\n justifyContent: 'center',\r\n }}\r\n >\r\n <TouchableWithoutFeedback\r\n onPress={dismissKeyboard}\r\n accessible={false}\r\n >\r\n <>{props.children}</>\r\n </TouchableWithoutFeedback>\r\n </KeyboardAvoidingView>\r\n </SafeAreaContextView>\r\n </SafeAreaProvider>\r\n );\r\n}\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","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","handlePress","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","borderWidth","borderColor","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","marginRight","input","marginHorizontal","marginVertical","UIListRow","UIList","row","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","add","ComponentUtils","getDefine","hideAddWhenEmpty","getRowStyle","Empty","empty","search","field","right","edit","container","gap","rowInner","flexGrow","text","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","main","ViewUtils","getCrud","st","onClose","close","currentDialog","toggle","vis","update","show","args","def","is","d","dialog","hide","useEffect","setBarStyle","setBackgroundColor","curr","uuid","ScrollView","contentContainerStyle","UIView","header","keyboardShouldPersistTaps","scroll","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","updateElement","c","custom","tag","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","elementStyle","_elementStyle$type","hasChild","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","current","classList","bg","HtmlUtils","getBGColor","isRendered","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","root","card","paddingBottom","quantity","UIInclude","includes","position","tagProp","Tag","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","Platform","OS","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n\n return { ...def, ...props.style, ...scope.getStyle(part) };\n };\n\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n\n return <Ionicons name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n\n let color = element.color;\n let label = element.label;\n let icon = element.icon;\n\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n paddingRight: 10,\n paddingLeft: 10,\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n height: 44,\n minWidth: 44,\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: {\n alignItems: 'center',\n margin: 'auto',\n width: '100%',\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n flex: 1,\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n let extra: any = {};\n\n if (!label) {\n extra.button = { width: 'auto' };\n extra.icon = { padding: 5 };\n } else if (icon) {\n extra.button = { padding: 0, paddingHorizontal: 20 };\n }\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={style('button', extra.button)}\n >\n <View style={style('buttonInner')}>\n {icon && (\n <>\n <Ionicons\n size={30}\n style={style('buttonIcon', extra.icon)}\n name={icon}\n />\n </>\n )}\n {label && <Text style={style('buttonLabel')}>{label}</Text>}\n </View>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport { ChildType, MethodType, useTheme, Utils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = useTheme();\n\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const onClick = ({ crud, value }: MethodType) => {\n scope.changeValue(value);\n handlePress();\n };\n\n const style = (part: string, extra?: any) => {\n return { ...styles[part], ...scope.getStyle(part), ...extra };\n };\n\n return (\n <View style={style('selectRoot')}>\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Ionicons name=\"arrow-down\" size={20} color=\"#888\" />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={() => setModalVisible(false)}\n >\n <StatusBar\n barStyle=\"dark-content\"\n backgroundColor={theme.colors.primary}\n />\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{placeholder}</Text>\n </View>\n <View style={style('modalContent')}>\n <UI.List data={items} name={scope.getName('list')} click={onClick}>\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderWidth: 1,\n borderColor: '#a9a9a9',\n borderRadius: 20,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n paddingTop: StatusBar.currentHeight || 0, // Considera a altura da barra de status no Android\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: '#6200ea',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n width: '100%',\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 20,\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.nvl(scope.getValue(), '');\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n return (\n <>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flexDirection: 'row',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 10,\n paddingVertical: 5,\n padding: 10,\n paddingLeft: 5,\n paddingRight: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const parent = props.scope;\n const item = props.item;\n const index = props.index;\n const name = `${parent.key('row', index)}`;\n const row = {\n parent,\n name,\n crud: parent.crud,\n index,\n type: 'row',\n data: item,\n };\n let [scope] = useState(ScopeUtils.create(row));\n\n return (\n <>\n <UIChildren scope={scope} crud={scope.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n}\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(original.cols, 1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const items = Utils.nvl(scope.getItems(), []);\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n const onClick = (item: any) => {\n scope.call('click', { value: item, item, edit: true });\n };\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getRowStyle = (extra?: any) => {\n let row = getStyle('row', {});\n\n if (cols > 0) {\n row.width = rowWidth;\n }\n\n return row;\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n const isShowAdd = () => {\n if (!Utils.isEmpty(items)) {\n return true;\n }\n return hideAddWhenEmpty !== true;\n };\n\n let Empty = () => {\n if (!Utils.isEmpty(items)) {\n return <></>;\n }\n\n let empty = scope.attr('empty', 'Sem registro');\n\n if (!empty) {\n return <></>;\n }\n\n if (typeof empty === 'string') {\n return (\n <Text\n style={scope.getStyle('empty', {\n flex: 1,\n fontWeight: 500,\n fontSize: 20,\n padding: 10,\n textAlign: 'center',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n right={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n\n <View style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getRowStyle()}\n underlayColor={'transparent'}\n onPress={e => {\n onClick(item);\n }}\n >\n <UIListRow scope={scope} item={item} index={i}>\n {props.children}\n </UIListRow>\n </TouchableHighlight>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n alignItems: 'stretch',\n },\n row: {\n padding: 5,\n margin: 3,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 8,\n padding: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n alignItems: 'stretch',\n },\n row: {\n padding: 0,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n padding: 0,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 15,\n marginVertical: 8,\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 16,\n fontWeight: '500',\n },\n});\n","import { Ionicons } from '@expo/vector-icons';\nimport { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIQuantity(props: ChildType) {\n const scope = props.scope;\n const element = scope.original;\n\n let [index, setIndex] = useState(0);\n\n const value = scope.getValue(0);\n\n let color = element.color;\n\n if (!color) color = 'primary';\n\n const btn = {\n padding: 10,\n alignItems: 'center',\n height: 44,\n width: 44,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { useEffect, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n useTheme,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\n\nexport default function UIModal(props: ChildType) {\n let [modalVisible, setModalVisible] = useState(false);\n let [index, setIndex] = useState(0);\n let main = ViewUtils.getCrud('view');\n\n const scope = props.scope;\n const label = scope.getLabel();\n const theme = useTheme();\n\n const style = (part: string, extra?: any) => {\n let st = { ...styles[part], ...extra };\n\n return { ...scope.getStyle(part, st) };\n };\n\n const onClose = () => {\n scope.close({ scope, crud: scope.currentDialog, event: {} });\n };\n\n const toggle = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.update = () => {\n setIndex(++index);\n };\n scope.show = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let data = Utils.nvl(args.item, {});\n let edit = args.edit === true;\n let def: any = {};\n\n if (crud.is('search')) {\n def.parent = crud.parent;\n def.search = crud;\n }\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n name,\n dialog: main.dialog,\n data,\n edit,\n scope,\n ...def,\n });\n\n main.dialog = d;\n\n scope.currentDialog = d;\n\n toggle(true);\n };\n\n scope.hide = (args?: MethodType) => {\n let old = scope.currentDialog;\n\n main.dialog = Utils.nvl(old.dialog, null);\n scope.currentDialog = null;\n\n toggle(false);\n\n if (main.dialog?.scope) {\n main.dialog.scope.update();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, [modalVisible]);\n\n let curr = scope.currentDialog;\n\n if (!curr) {\n return <></>;\n }\n\n if (curr.uuid !== main.dialog.uuid) {\n return <></>;\n }\n\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1 }}\n style={style('modalContent')}\n >\n <View style={{ flex: 1 }}>\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {props.children}\n </UIChildren>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalSafe: {\n flex: 1,\n backgroundColor: 'primary',\n width: '100%',\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: 'primary',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n padding: 20,\n },\n});\n","import { ScrollView, StyleSheet, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, useTheme } from 'react-crud-utils';\nimport { useEffect } from 'react';\nimport { StatusBar } from 'react-native';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = useTheme();\n const header = scope.getPart('header', null, []);\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n return (\n <>\n {header}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {})}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {\n backgroundColor: 'primary',\n },\n view: {\n backgroundColor: 'primary',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n ChildType,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport { Image, Linking, StyleSheet, Text, View } from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n\n crud = scope.crud;\n\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key], ...elementStyle?.[type]?.[key] };\n let hasChild = hasChildren();\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n if (isInput) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n return { ...def, ...scope.getStyle(part, def) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <View ref={ref} style={getStyle()}>\n <>\n {isShowLabel() && (\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', 'icon') && (\n <UIIcon\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {scope.getDisplayValue()}\n </UIIcon>\n )}\n {scope.is('type', 'link') && (\n <UILink\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'link')}>\n {scope.getLabel()}\n </Text>\n )}\n </UILink>\n )}\n {isInput && (\n <UIInput\n {...defaultsInput}\n {...defaultsUI}\n InputProps={{ ...original.inputProps }}\n />\n )}\n {scope.is('type', 'complete', 'autocomplete') && (\n <UIComplete\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'quantity') && (\n <UIQuantity\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\n <UISwitch\n checked={isChecked()}\n {...defaultsInput}\n onChange={onCheck}\n />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && (\n <UIIcon scope={scope} crud={crud} />\n )}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>\n {scope.getDisplayValue()}\n </Text>\n )}\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n </View>\n </CrudContext.Provider>\n );\n}\n\nconst box: any = {\n backgroundColor: 'white',\n padding: 16,\n borderRadius: 10,\n width: '100%',\n shadowColor: '#888', // iOS\n shadowOffset: { width: 0, height: 1 }, // iOS\n shadowOpacity: 0.25, // iOS\n shadowRadius: 3.84, // iOS\n elevation: 3, // Android\n};\n\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: '#f5f5f5',\n flex: 1,\n gap: 10,\n },\n child: {\n width: '100%',\n flex: 1,\n gap: 10,\n padding: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\nelementStyle.card = StyleSheet.create({\n root: {\n ...box,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 10,\n paddingTop: 5,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n});\n\nelementStyle.input = StyleSheet.create({\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.quantity = {\n inner: {\n ...box,\n padding: 5,\n borderRadius: 25,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n paddingHorizontal: 10,\n paddingVertical: 0,\n alignSelf: 'flex-start',\n flexWrap: 'nowrap',\n },\n});\n\nconst styles = StyleSheet.create({\n root: {\n gap: 5,\n flexDirection: 'column',\n flexWrap: 'wrap',\n width: '100%',\n alignItems: 'flex-start',\n },\n label: { width: '100%', fontWeight: 500, fontSize: 12 },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import { ListType } from 'react-crud-utils';\nimport { UserType } from 'react-crud-utils';\nimport { InputType } from 'react-crud-utils';\nimport { ChartType } from 'react-crud-utils';\nimport { ContainerType } from 'react-crud-utils';\nimport { ListInputType } from 'react-crud-utils';\nimport UIElement from './UIElement';\nimport { TabsType } from 'react-crud-utils';\nimport { DefineType } from 'react-crud-utils';\nimport { ButtonType } from 'react-crud-utils';\nimport { LinkType } from 'react-crud-utils';\nimport UIInclude from './core/UIInclude';\nimport SafeView from './core/SafeView';\n\nconst UI = {\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: ButtonType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n SafeView: SafeView,\n};\nexport default UI;\n","import {\r\n Keyboard,\r\n KeyboardAvoidingView,\r\n Platform,\r\n StatusBar,\r\n StyleProp,\r\n TouchableWithoutFeedback,\r\n ViewStyle,\r\n} from 'react-native';\r\nimport {\r\n SafeAreaProvider,\r\n SafeAreaView as SafeAreaContextView,\r\n} from 'react-native-safe-area-context';\r\nimport { useTheme } from 'react-crud-utils';\r\nimport { useEffect } from 'react';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function SafeView(props: SafeViewType) {\r\n const theme = useTheme();\r\n const dismissKeyboard = () => {\r\n if (Platform.OS !== 'web') {\r\n Keyboard.dismiss();\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\r\n }, []);\r\n\r\n return (\r\n <SafeAreaProvider>\r\n <StatusBar barStyle=\"light-content\" />\r\n <SafeAreaContextView\r\n style={{\r\n backgroundColor: theme.colors?.primary,\r\n ...props.viewStyle,\r\n flex: 1,\r\n }}\r\n >\r\n <KeyboardAvoidingView\r\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\r\n style={{\r\n flex: 1, // 🔹 Ocupa 100% da tela\r\n justifyContent: 'center',\r\n }}\r\n >\r\n <TouchableWithoutFeedback\r\n onPress={dismissKeyboard}\r\n accessible={false}\r\n >\r\n <>{props.children}</>\r\n </TouchableWithoutFeedback>\r\n </KeyboardAvoidingView>\r\n </SafeAreaContextView>\r\n </SafeAreaProvider>\r\n );\r\n}\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","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","handlePress","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","borderWidth","borderColor","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","marginRight","input","marginHorizontal","marginVertical","UIListRow","UIList","row","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","add","ComponentUtils","getDefine","hideAddWhenEmpty","getRowStyle","Empty","empty","search","field","right","edit","container","gap","rowInner","flexGrow","text","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","main","ViewUtils","getCrud","st","onClose","close","currentDialog","toggle","vis","update","show","args","def","is","d","dialog","hide","_main$dialog","useEffect","setBarStyle","setBackgroundColor","curr","uuid","headerRight","ScrollView","contentContainerStyle","UIView","header","keyboardShouldPersistTaps","scroll","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","updateElement","c","custom","tag","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","elementStyle","_elementStyle$type","hasChild","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","current","classList","bg","HtmlUtils","getBGColor","isRendered","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","root","card","paddingBottom","quantity","UIInclude","includes","position","tagProp","Tag","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","Platform","OS","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"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"}
|
|
@@ -1054,12 +1054,13 @@ function UIModal(props) {
|
|
|
1054
1054
|
toggle(true);
|
|
1055
1055
|
};
|
|
1056
1056
|
scope.hide = function (args) {
|
|
1057
|
+
var _main$dialog;
|
|
1057
1058
|
var old = scope.currentDialog;
|
|
1058
1059
|
main.dialog = Utils.nvl(old.dialog, null);
|
|
1059
1060
|
scope.currentDialog = null;
|
|
1060
1061
|
toggle(false);
|
|
1061
|
-
if (main.dialog) {
|
|
1062
|
-
main.dialog.update();
|
|
1062
|
+
if ((_main$dialog = main.dialog) != null && _main$dialog.scope) {
|
|
1063
|
+
main.dialog.scope.update();
|
|
1063
1064
|
}
|
|
1064
1065
|
};
|
|
1065
1066
|
useEffect(function () {
|
|
@@ -1073,6 +1074,7 @@ function UIModal(props) {
|
|
|
1073
1074
|
if (curr.uuid !== main.dialog.uuid) {
|
|
1074
1075
|
return /*#__PURE__*/jsx(Fragment, {});
|
|
1075
1076
|
}
|
|
1077
|
+
var headerRight = ComponentUtils.getDefine(props, 'header', 'right');
|
|
1076
1078
|
return /*#__PURE__*/jsx(Modal, {
|
|
1077
1079
|
animationType: "slide",
|
|
1078
1080
|
transparent: true,
|
|
@@ -1092,6 +1094,10 @@ function UIModal(props) {
|
|
|
1092
1094
|
}), /*#__PURE__*/jsx(Text, {
|
|
1093
1095
|
style: style('modalTitle'),
|
|
1094
1096
|
children: label
|
|
1097
|
+
}), !Utils.isEmpty(headerRight) && /*#__PURE__*/jsx(UIChildren, {
|
|
1098
|
+
scope: scope,
|
|
1099
|
+
crud: scope.currentDialog,
|
|
1100
|
+
children: headerRight
|
|
1095
1101
|
})]
|
|
1096
1102
|
}), /*#__PURE__*/jsx(ScrollView, {
|
|
1097
1103
|
contentContainerStyle: {
|