react-crud-mobile 1.0.921 → 1.0.922

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +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/UISlider.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/hooks/useIsVisible.ts","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIToast.tsx","../src/utils/MobileUtils.ts","../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 let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...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 {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\nconst ICONS_SIZE: any = { small: { fontSize: 14 } };\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n let size = Utils.nvl(element.size, 'default');\n let align = Utils.nvl(element.align, 'center');\n let variant = Utils.nvl(element.variant, 'default');\n\n let color = element.color;\n let label = scope.getLabel();\n let icon = element.icon;\n\n //ajuste align v1\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\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 backgroundColor: color,\n borderRadius: 24,\n gap: 10,\n justifyContent: 'center',\n alignItems: 'center',\n flexDirection: 'row',\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 let css = scope.getStyle(part, s);\n\n if (variant === 'text') {\n css.backgroundColor = 'transparent';\n css.color = 'text';\n }\n\n if (size === 'small') {\n css.fontSize = 12;\n css.fontWeight = 500;\n }\n\n if (size === 'medium') {\n css.fontSize = 14;\n css.fontWeight = 500;\n }\n\n if (align === 'left') {\n css.justifyContent = 'flex-start';\n }\n return css;\n };\n\n let extra: any = {};\n\n if (icon) {\n extra.button = { height: 40, padding: 0 };\n } else {\n extra.button = { height: 50 };\n }\n\n const buttonStyle = Utils.call(() => {\n let css = style('button', extra.button);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\n }\n\n if (variant === 'text') {\n css.backgroundColor = 'transparent';\n css.color = 'text';\n }\n\n if (size) {\n css = { ...css, ...BUTTONS_SIZE[size] };\n }\n\n if (align === 'left') {\n css.justifyContent = 'flex-start';\n }\n return css;\n });\n\n const buttonLabel = style('buttonLabel');\n const iconStyle = Utils.call(() => {\n let css: any = style('buttonIcon', extra.icon);\n\n if (variant === 'text') {\n css.color = 'text';\n }\n\n if (size) {\n css = { ...css, ...ICONS_SIZE[size] };\n }\n\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\n\n return css;\n });\n\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={buttonStyle}\n >\n <>\n {icon && (\n <>\n <Ionicons size={30} style={iconStyle} name={icon} />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport {\n ChildType,\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} 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 const main = ViewUtils.getCrud('view');\n\n const handlePress = () => {\n const _modalVisible = !modalVisible;\n\n main.data.selectIsOpen = _modalVisible;\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 const isModalVisible = () => {\n return modalVisible;\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={isModalVisible()}\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 flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 5,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: 'background',\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 style={scope.getStyle('element')}\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 { useState } from 'react';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\nimport Slider from '@react-native-community/slider';\r\n\r\nexport default function UISlider(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), 0);\r\n const [value, setValue] = useState(initial);\r\n\r\n //redeploy 0\r\n\r\n let onChange = v => {\r\n v = Utils.nvl(v, 0);\r\n\r\n console.log(v);\r\n\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n let step = scope.attr('step', 1);\r\n let min = scope.attr('min', 0);\r\n let max = scope.attr('min', 100);\r\n\r\n let onSlideScroll = (scrollEnabled: boolean) => {\r\n let viewScope = ComponentUtils.getViewScope();\r\n\r\n if (scope.original.debug) {\r\n console.log(viewScope);\r\n }\r\n\r\n if (viewScope) {\r\n let scrollRef = viewScope.get('scrollRef');\r\n\r\n if (scrollRef) scrollRef.current?.setNativeProps?.({ scrollEnabled });\r\n }\r\n };\r\n return (\r\n <>\r\n <Slider\r\n minimumValue={min}\r\n maximumValue={max}\r\n step={step}\r\n minimumTrackTintColor=\"#1EB1FC\"\r\n maximumTrackTintColor=\"#d3d3d3\"\r\n thumbTintColor=\"#1EB1FC\"\r\n value={value}\r\n onSlidingStart={() => onSlideScroll(false)}\r\n onSlidingComplete={() => onSlideScroll(true)}\r\n style={{ width: '100%', height: 40, ...scope.getStyle('element') }}\r\n onValueChange={onChange} // Alterna o estado\r\n />\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.call(() => {\n let val = Utils.nvl(scope.getValue(), '');\n\n if (val && val?.push) {\n return val.join(', ').trim();\n }\n return val;\n });\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 v = 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 const CustomIcon = () => {\n let icon = el.icon;\n\n if (icon) {\n if (typeof icon === 'string') {\n return (\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 </>\n );\n }\n return <>{icon}</>;\n }\n return <></>;\n };\n return (\n <>\n <View style={style('base')}>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n <CustomIcon />\n </View>\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 5,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 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, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = scope.getPart('cols', undefined, -1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n let renderedRow = row.getPart('renderedItem', undefined, true);\n\n if (renderedRow === false) {\n return <></>;\n }\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: 'background',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, 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(scope.getPart('cols', undefined, 1));\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\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 LocalData = () => {\n let [index, setIndex] = useState(scope.updateIndex);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n let keyData = scope.key('data');\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = o[filterBy];\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\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 <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n );\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n style={{ marginBottom: 10 }}\n change={{\n action: () => {\n scope.search();\n },\n }}\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n <LocalData />\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\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: 10,\n marginVertical: 8,\n backgroundColor: 'background',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 15,\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: 0,\n alignItems: 'center',\n height: 30,\n width: 30,\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 fontWeight: '500',\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 { StyleSheet } from 'react-native';\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\n\nexport default function UIToast() {\n const toastConfig = {\n success: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n contentContainerStyle={{ paddingHorizontal: 15 }}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n error: props => (\n <ErrorToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n info: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n };\n\n const styles = StyleSheet.create({\n darkToast: {\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\n borderLeftColor: '#222', // borda mais escura\n },\n text: {\n color: '#fff', // letras brancas\n textAlign: 'center',\n },\n });\n return <Toast config={toastConfig} />;\n}\n","//import { ThemeUtils, Utils } from 'react-crud-utils';\r\n//import { StatusBar } from 'react-native';\r\n\r\nexport default class MobileUtils {\r\n static syncTheme() {\r\n // let current = ThemeUtils.getCurrentTheme();\r\n //let dec: any = { light: 'light-content', dark: 'dark-content' };\r\n //let name = Utils.nvl(dec[current?.theme], dec.light);\r\n //StatusBar.setBarStyle?.(name);\r\n //StatusBar.setBackgroundColor?.(current?.colors?.theme);\r\n }\r\n}\r\n","import { useEffect, useRef, 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';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport MobileUtils from '../../utils/MobileUtils';\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 = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const scrollRef = useRef(null);\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\n scope.dialogShow = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n\n if (crud.is('row')) {\n def.parent = crud.parent.parent;\n def.search = crud.parent;\n\n rowItem = crud.data;\n } else if (crud.is('search')) {\n def.parent = crud.parent;\n def.search = crud;\n }\n\n let data = Utils.nvl(args.item, rowItem, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: 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 scope.update();\n };\n\n scope.dialogHide = (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 scope.update();\n };\n\n useEffect(() => {\n MobileUtils.syncTheme();\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 scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\n <Ionicons\n name=\"chevron-back-outline\"\n size={24}\n color={color}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={scope.currentDialog} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\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 <UIToast />\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n padding: 10,\n },\n});\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport {\n ChildType,\n ComponentUtils,\n HtmlUtils,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport { useEffect, useRef } from 'react';\nimport UIToast from './UIToast';\nimport MobileUtils from '../../utils/MobileUtils';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = scope.getTheme();\n const header = scope.getPart('header', null, []);\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\n const scrollRef = useRef(null);\n\n useEffect(() => {\n MobileUtils.syncTheme();\n }, []);\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n let headerStyleFull = Utils.call(() => {\n let css = scope.getStyle('header', headerStyle);\n let bg = css.backgroundColor;\n\n if (bg) {\n css.color = HtmlUtils.getTextColor(bg);\n }\n return css;\n });\n\n let hasHeader = !Utils.isEmpty(header);\n let AuxHeader = () => {\n if (typeof header === 'string') {\n return <Text style={headerTextStyle}>{header}</Text>;\n }\n return <>{header}</>;\n };\n\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n ref={scrollRef}\n nestedScrollEnabled={true}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {\n paddingBottom: 50,\n })}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {},\n view: {},\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 MethodType,\n ActionType,\n ComponentUtils,\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 UISlider from './core/UISlider';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} 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';\nimport Toast from 'react-native-toast-message';\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 let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n crud = scope.crud;\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 scope.toast = (message: string, type = 'info', args?: any) => {\n Toast.show({\n type, // 'success' | 'error' | 'info'\n text1: message,\n position: 'bottom', // 'top' é outra opção\n visibilityTime: 3000, // tempo que fica visível em ms\n ...args,\n });\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\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 'integer',\n 'int',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string, extra?: any) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n type = Utils.nvl(original.layout, type);\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\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 let Tag: any = View;\n let custom: any = {};\n\n if (!scope.isType('input', 'grid', 'list', 'repeat') && original.click) {\n Tag = TouchableHighlight;\n\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Inner = () => {\n return (\n <>\n {scope.getPart('render', null, <></>)}\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.isType('slider') && (\n <UISlider {...defaultsInput} onChange={onCheck} />\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') && <UIIcon scope={scope} crud={crud} />}\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')}>{scope.getDisplayValue()}</Text>\n )}\n </>\n );\n };\n\n let Include = ({ name, style }: any) => {\n if (props[name]) {\n let define = ComponentUtils.getDefine(props, name);\n\n if (!Utils.isEmpty(define)) {\n return (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle(name, style)}\n >\n {define}\n </UIChildren>\n );\n }\n }\n return <></>;\n };\n\n let Container = () => {\n return (\n <>\n {isShowLabel() && (\n <View\n style={getStyle('outerLabel', {\n alignSelf: 'flex-start',\n flexDirection: 'row',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n width: '100%',\n })}\n >\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n <Include name=\"actions\" style={{ width: 'auto' }} />\n </View>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n <Inner />\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 );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n return (\n <View style={getStyle('card', { ...box })}>\n <View\n style={getStyle('boxInner', {\n paddingHorizontal: 15,\n paddingVertical: 10,\n })}\n >\n {props.children}\n </View>\n </View>\n );\n }\n\n return <>{props.children}</>;\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <Card>\n <Container />\n </Card>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nlet boxStyle = StyleSheet.create({\n box: {\n borderWidth: 0,\n borderColor: '#dedede',\n borderStyle: 'solid',\n backgroundColor: 'white',\n borderRadius: 12,\n width: '100%',\n shadowColor: '#000',\n shadowOpacity: 0.1,\n shadowRadius: 4,\n },\n});\n\nconst box: any = {\n ...boxStyle.box,\n};\n//v2\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: 'background',\n flex: 1,\n gap: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 0,\n },\n inner: {\n flex: 1,\n width: '100%',\n padding: 0,\n gap: 10,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.switch = {\n inner: {\n padding: 5,\n },\n};\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n padding: 5,\n paddingHorizontal: 5,\n paddingVertical: 5,\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: {\n fontWeight: 400,\n marginTop: 5,\n fontSize: 12,\n color: 'labelColor',\n },\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 {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n SliderType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\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: IconType) => <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 Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\n SafeView: SafeView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\nimport { useEffect } from 'react';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n //ajustes tema v1\n StatusBar.setBarStyle(Utils.nvl(theme.theme, 'light-content'));\n StatusBar.setBackgroundColor?.(theme.colors.theme);\n }, []);\n\n return (\n <SafeAreaProvider>\n <StatusBar barStyle=\"light-content\" />\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","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","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","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","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","BUTTONS_SIZE","small","minWidth","height","ICONS_SIZE","fontSize","UIButton","size","align","variant","color","getLabel","buttonLabel","fontWeight","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","h","iconStyle","TouchableHighlight","underlayColor","e","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","main","ViewUtils","getCrud","handlePress","_modalVisible","selectIsOpen","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","flex","selectInput","paddingHorizontal","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","scrollRef","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","getPart","el","CustomIcon","TextInput","onChangeText","base","paddingBottom","borderWidth","borderColor","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","useRef","isVisible","ref","setIsVisible","useEffect","interval","setInterval","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","LocalData","setIndex","keyData","search","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","empty","textAlign","field","marginBottom","change","container","display","text","UIToggle","options","getInputValue","isSelected","Item","object","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","contentContainerStyle","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","MobileUtils","syncTheme","UIModal","getTheme","headerStyle","_theme$styles","defaults","header","st","onClose","close","currentDialog","toggle","vis","dialogShow","args","rowItem","is","d","root","dialog","dialogHide","_main$dialog","curr","uuid","_main$dialog2","headerRight","put","setViewScope","ScrollView","flexGrow","nestedScrollEnabled","modalTop","UIView","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","AuxHeader","onScroll","scroll","scrollEventThrottle","keyboardShouldPersistTaps","view","CrudContext","createContext","ctx","useContext","_useState3","setError","updateElement","toast","message","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","open","useLayoutEffect","classList","getBGColor","isRendered","Tag","Inner","InputProps","inputProps","checked","getSelectedValue","control","Image","source","define","Container","Card","box","boxStyle","Provider","borderStyle","shadowColor","shadowOpacity","shadowRadius","paddingLeft","quantity","marginTop","UIInclude","tagProp","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","setBarStyle","setBackgroundColor","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","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/UISlider.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/hooks/useIsVisible.ts","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIToast.tsx","../src/utils/MobileUtils.ts","../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 let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...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 {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } 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 let size = Utils.nvl(element.size, 'default');\n let align = Utils.nvl(element.align, 'center');\n let variant = Utils.nvl(element.variant, 'default');\n\n let color = element.color;\n let label = scope.getLabel();\n let icon = element.icon;\n\n //ajuste align v1\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\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 backgroundColor: color,\n borderRadius: 24,\n gap: 10,\n justifyContent: 'center',\n alignItems: 'center',\n flexDirection: 'row',\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let css = { ...styles[part], ...extra };\n\n if (variant === 'text') {\n css.backgroundColor = 'transparent';\n css.color = 'text';\n }\n\n if (size === 'small') {\n css.fontSize = 12;\n css.fontWeight = 500;\n }\n\n if (size === 'medium') {\n css.fontSize = 14;\n css.fontWeight = 500;\n }\n\n if (align === 'left') {\n css.justifyContent = 'flex-start';\n }\n\n return scope.getStyle(part, css);\n };\n\n let extra: any = {};\n\n if (icon) {\n extra.button = { height: 40, padding: 0 };\n } else {\n extra.button = { height: 50 };\n }\n\n const buttonStyle = Utils.call(() => {\n let css = style('button', extra.button);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\n }\n return css;\n });\n\n const buttonLabel = style('buttonLabel');\n const iconStyle = Utils.call(() => {\n let css: any = style('buttonIcon', extra.icon);\n\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\n\n return css;\n });\n\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={buttonStyle}\n >\n <>\n {icon && (\n <>\n <Ionicons size={30} style={iconStyle} name={icon} />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport {\n ChildType,\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} 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 const main = ViewUtils.getCrud('view');\n\n const handlePress = () => {\n const _modalVisible = !modalVisible;\n\n main.data.selectIsOpen = _modalVisible;\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 const isModalVisible = () => {\n return modalVisible;\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={isModalVisible()}\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 flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 5,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: 'background',\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 style={scope.getStyle('element')}\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 { useState } from 'react';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\nimport Slider from '@react-native-community/slider';\r\n\r\nexport default function UISlider(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), 0);\r\n const [value, setValue] = useState(initial);\r\n\r\n //redeploy 0\r\n\r\n let onChange = v => {\r\n v = Utils.nvl(v, 0);\r\n\r\n console.log(v);\r\n\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n let step = scope.attr('step', 1);\r\n let min = scope.attr('min', 0);\r\n let max = scope.attr('min', 100);\r\n\r\n let onSlideScroll = (scrollEnabled: boolean) => {\r\n let viewScope = ComponentUtils.getViewScope();\r\n\r\n if (scope.original.debug) {\r\n console.log(viewScope);\r\n }\r\n\r\n if (viewScope) {\r\n let scrollRef = viewScope.get('scrollRef');\r\n\r\n if (scrollRef) scrollRef.current?.setNativeProps?.({ scrollEnabled });\r\n }\r\n };\r\n return (\r\n <>\r\n <Slider\r\n minimumValue={min}\r\n maximumValue={max}\r\n step={step}\r\n minimumTrackTintColor=\"#1EB1FC\"\r\n maximumTrackTintColor=\"#d3d3d3\"\r\n thumbTintColor=\"#1EB1FC\"\r\n value={value}\r\n onSlidingStart={() => onSlideScroll(false)}\r\n onSlidingComplete={() => onSlideScroll(true)}\r\n style={{ width: '100%', height: 40, ...scope.getStyle('element') }}\r\n onValueChange={onChange} // Alterna o estado\r\n />\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.call(() => {\n let val = Utils.nvl(scope.getValue(), '');\n\n if (val && val?.push) {\n return val.join(', ').trim();\n }\n return val;\n });\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 v = 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 const CustomIcon = () => {\n let icon = el.icon;\n\n if (icon) {\n if (typeof icon === 'string') {\n return (\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 </>\n );\n }\n return <>{icon}</>;\n }\n return <></>;\n };\n return (\n <>\n <View style={style('base')}>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n <CustomIcon />\n </View>\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 5,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 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, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = scope.getPart('cols', undefined, -1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n let renderedRow = row.getPart('renderedItem', undefined, true);\n\n if (renderedRow === false) {\n return <></>;\n }\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: 'background',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, 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(scope.getPart('cols', undefined, 1));\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\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 LocalData = () => {\n let [index, setIndex] = useState(scope.updateIndex);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n let keyData = scope.key('data');\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = o[filterBy];\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\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 <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n );\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n style={{ marginBottom: 10 }}\n change={{\n action: () => {\n scope.search();\n },\n }}\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n <LocalData />\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\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: 10,\n marginVertical: 8,\n backgroundColor: 'background',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 15,\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: 0,\n alignItems: 'center',\n height: 30,\n width: 30,\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 fontWeight: '500',\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 { StyleSheet } from 'react-native';\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\n\nexport default function UIToast() {\n const toastConfig = {\n success: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n contentContainerStyle={{ paddingHorizontal: 15 }}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n error: props => (\n <ErrorToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n info: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n };\n\n const styles = StyleSheet.create({\n darkToast: {\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\n borderLeftColor: '#222', // borda mais escura\n },\n text: {\n color: '#fff', // letras brancas\n textAlign: 'center',\n },\n });\n return <Toast config={toastConfig} />;\n}\n","//import { ThemeUtils, Utils } from 'react-crud-utils';\r\n//import { StatusBar } from 'react-native';\r\n\r\nexport default class MobileUtils {\r\n static syncTheme() {\r\n // let current = ThemeUtils.getCurrentTheme();\r\n //let dec: any = { light: 'light-content', dark: 'dark-content' };\r\n //let name = Utils.nvl(dec[current?.theme], dec.light);\r\n //StatusBar.setBarStyle?.(name);\r\n //StatusBar.setBackgroundColor?.(current?.colors?.theme);\r\n }\r\n}\r\n","import { useEffect, useRef, 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';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport MobileUtils from '../../utils/MobileUtils';\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 = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const scrollRef = useRef(null);\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\n scope.dialogShow = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n\n if (crud.is('row')) {\n def.parent = crud.parent.parent;\n def.search = crud.parent;\n\n rowItem = crud.data;\n } else if (crud.is('search')) {\n def.parent = crud.parent;\n def.search = crud;\n }\n\n let data = Utils.nvl(args.item, rowItem, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: 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 scope.update();\n };\n\n scope.dialogHide = (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 scope.update();\n };\n\n useEffect(() => {\n MobileUtils.syncTheme();\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 scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\n <Ionicons\n name=\"chevron-back-outline\"\n size={24}\n color={color}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={scope.currentDialog} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\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 <UIToast />\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n padding: 10,\n },\n});\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport {\n ChildType,\n ComponentUtils,\n HtmlUtils,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport { useEffect, useRef } from 'react';\nimport UIToast from './UIToast';\nimport MobileUtils from '../../utils/MobileUtils';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = scope.getTheme();\n const header = scope.getPart('header', null, []);\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\n const scrollRef = useRef(null);\n\n useEffect(() => {\n MobileUtils.syncTheme();\n }, []);\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n let headerStyleFull = Utils.call(() => {\n let css = scope.getStyle('header', headerStyle);\n let bg = css.backgroundColor;\n\n if (bg) {\n css.color = HtmlUtils.getTextColor(bg);\n }\n return css;\n });\n\n let hasHeader = !Utils.isEmpty(header);\n let AuxHeader = () => {\n if (typeof header === 'string') {\n return <Text style={headerTextStyle}>{header}</Text>;\n }\n return <>{header}</>;\n };\n\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n ref={scrollRef}\n nestedScrollEnabled={true}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {\n paddingBottom: 50,\n })}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {},\n view: {},\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 MethodType,\n ActionType,\n ComponentUtils,\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 UISlider from './core/UISlider';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} 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';\nimport Toast from 'react-native-toast-message';\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 let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n crud = scope.crud;\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 scope.toast = (message: string, type = 'info', args?: any) => {\n Toast.show({\n type, // 'success' | 'error' | 'info'\n text1: message,\n position: 'bottom', // 'top' é outra opção\n visibilityTime: 3000, // tempo que fica visível em ms\n ...args,\n });\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\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 'integer',\n 'int',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string, extra?: any) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n type = Utils.nvl(original.layout, type);\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\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 let Tag: any = View;\n let custom: any = {};\n\n if (!scope.isType('input', 'grid', 'list', 'repeat') && original.click) {\n Tag = TouchableHighlight;\n\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Inner = () => {\n return (\n <>\n {scope.getPart('render', null, <></>)}\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.isType('slider') && (\n <UISlider {...defaultsInput} onChange={onCheck} />\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') && <UIIcon scope={scope} crud={crud} />}\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')}>{scope.getDisplayValue()}</Text>\n )}\n </>\n );\n };\n\n let Include = ({ name, style }: any) => {\n if (props[name]) {\n let define = ComponentUtils.getDefine(props, name);\n\n if (!Utils.isEmpty(define)) {\n return (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle(name, style)}\n >\n {define}\n </UIChildren>\n );\n }\n }\n return <></>;\n };\n\n let Container = () => {\n return (\n <>\n {isShowLabel() && (\n <View\n style={getStyle('outerLabel', {\n alignSelf: 'flex-start',\n flexDirection: 'row',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n width: '100%',\n })}\n >\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n <Include name=\"actions\" style={{ width: 'auto' }} />\n </View>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n <Inner />\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 );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n return (\n <View style={getStyle('card', { ...box })}>\n <View\n style={getStyle('boxInner', {\n paddingHorizontal: 15,\n paddingVertical: 10,\n })}\n >\n {props.children}\n </View>\n </View>\n );\n }\n\n return <>{props.children}</>;\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <Card>\n <Container />\n </Card>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nlet boxStyle = StyleSheet.create({\n box: {\n borderWidth: 0,\n borderColor: '#dedede',\n borderStyle: 'solid',\n backgroundColor: 'white',\n borderRadius: 12,\n width: '100%',\n shadowColor: '#000',\n shadowOpacity: 0.1,\n shadowRadius: 4,\n },\n});\n\nconst box: any = {\n ...boxStyle.box,\n};\n//v2\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: 'background',\n flex: 1,\n gap: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 0,\n },\n inner: {\n flex: 1,\n width: '100%',\n padding: 0,\n gap: 10,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.switch = {\n inner: {\n padding: 5,\n },\n};\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n padding: 5,\n paddingHorizontal: 5,\n paddingVertical: 5,\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: {\n fontWeight: 400,\n marginTop: 5,\n fontSize: 12,\n color: 'labelColor',\n },\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 {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n SliderType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\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: IconType) => <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 Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\n SafeView: SafeView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\nimport { useEffect } from 'react';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n //ajustes tema v1\n StatusBar.setBarStyle(Utils.nvl(theme.theme, 'light-content'));\n StatusBar.setBackgroundColor?.(theme.colors.theme);\n }, []);\n\n return (\n <SafeAreaProvider>\n <StatusBar barStyle=\"light-content\" />\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","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","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","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","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","UIButton","size","align","variant","color","getLabel","buttonLabel","fontWeight","fontSize","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","h","iconStyle","TouchableHighlight","underlayColor","e","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","main","ViewUtils","getCrud","handlePress","_modalVisible","selectIsOpen","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","flex","selectInput","paddingHorizontal","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","scrollRef","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","getPart","el","CustomIcon","TextInput","onChangeText","base","paddingBottom","borderWidth","borderColor","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","useRef","isVisible","ref","setIsVisible","useEffect","interval","setInterval","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","LocalData","setIndex","keyData","search","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","empty","textAlign","field","marginBottom","change","container","display","text","UIToggle","options","getInputValue","isSelected","Item","object","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","contentContainerStyle","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","MobileUtils","syncTheme","UIModal","getTheme","headerStyle","_theme$styles","defaults","header","st","onClose","close","currentDialog","toggle","vis","dialogShow","args","rowItem","is","d","root","dialog","dialogHide","_main$dialog","curr","uuid","_main$dialog2","headerRight","put","setViewScope","ScrollView","flexGrow","nestedScrollEnabled","modalTop","UIView","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","AuxHeader","onScroll","scroll","scrollEventThrottle","keyboardShouldPersistTaps","view","CrudContext","createContext","ctx","useContext","_useState3","setError","updateElement","toast","message","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","open","useLayoutEffect","classList","getBGColor","isRendered","Tag","Inner","InputProps","inputProps","checked","getSelectedValue","control","Image","source","define","Container","Card","box","boxStyle","Provider","borderStyle","shadowColor","shadowOpacity","shadowRadius","paddingLeft","quantity","marginTop","UIInclude","tagProp","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","setBarStyle","setBackgroundColor","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"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"}