react-crud-mobile 1.3.372 → 1.3.374
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/react-crud-mobile.cjs.development.js +1 -7
- package/dist/react-crud-mobile.cjs.development.js.map +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js.map +1 -1
- package/dist/react-crud-mobile.esm.js +1 -7
- package/dist/react-crud-mobile.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/elements/core/UIOrder.tsx +250 -6
@@ -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/elements/core/UIModal.tsx","../src/elements/core/UIHeader.tsx","../src/elements/core/UIView.tsx","../src/elements/core/UIDraggableList.tsx","../src/elements/core/UIOrder.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx","../src/elements/core/GestureView.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 if (props.transient) {\n return <Draw />;\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 let css: any = scope.getStyle('icon');\n let fontSize = scope.part('size', 20);\n let size = scope.part('iconSize', fontSize);\n\n if (scope.original?.transient) {\n css = { ...css, ...scope.getStyle() };\n }\n\n return <Aux size={size} name={name} style={css} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\nimport UI from '../UI';\n\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\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 = scope.getPart('icon');\n\n //ajuste align v6\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: 400,\n fontSize: 15,\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: 16,\n },\n button: {\n backgroundColor: color,\n borderRadius: 20,\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' || variant === 'outlined') {\n css.backgroundColor = 'transparent';\n css.color = Utils.nvl(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 def: any = { ...extra?.button };\n\n if (variant === 'outlined') {\n def.borderWidth = 1;\n def.borderColor = Utils.nvl(color, 'text');\n }\n\n if (size) {\n def = { ...def, ...BUTTONS_SIZE[size] };\n }\n\n if (!label) {\n def = { ...def, borderRadius: 20 };\n }\n\n let css = style('button', def);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\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 <UI.Icon\n size={Utils.nvl(element.iconSize, 30)}\n style={iconStyle}\n value={icon}\n />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useRef, useState } from 'react';\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\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 original = scope.original;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const scrollRef = useRef(null);\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\n const modalColor = Utils.nvl(headerStyle.color, 'white');\n const defaults = { color: modalColor };\n const onClick = ({ crud, value }: MethodType) => {\n let val = value as any;\n\n if (original.isObject && val?.object) {\n scope.changeValue(val?.object);\n } else if (val?.value) {\n scope.changeValue(val?.value);\n } else {\n scope.changeValue(value);\n }\n\n setModalVisible(false);\n };\n\n const style = (part: string, extra?: any) => {\n let all = { ...styles[part], ...extra };\n\n return scope.getStyle(part, all);\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n\n const getLabelStyle = () => {\n const css: any = style('selectLabel');\n let fs = parseInt(css.fontSize);\n\n if (!fs) {\n fs = 14;\n }\n\n let lh = Utils.nvl(css.lineHeight, fs + 2);\n\n css.fontSize = fs;\n css.lineHeight = lh;\n\n return css;\n };\n\n const labelStyle = getLabelStyle();\n const defIconSize = Utils.nvl(labelStyle.fontSize, 14) + 2;\n const iconSize = scope.getPart('iconSize', null, defIconSize);\n\n //v4\n\n return (\n <View\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\n style={style('selectRoot')}\n >\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={labelStyle}>{Utils.nvl(value, placeholder)}</Text>\n <Ionicons\n name=\"chevron-down-outline\"\n size={iconSize}\n color={scope.getPart('iconColor', null, iconColor)}\n style={style('iconStyle', {})}\n />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={handlePress}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"close\"\n size={24}\n color={modalColor}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n <View\n style={{\n flex: 1,\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n }}\n >\n <UI.List\n data={items}\n name={scope.getName('list')}\n layout=\"card\"\n search={original.search === true}\n click={onClick}\n rowStyle={{\n paddingLeft: 15,\n paddinRight: 15,\n ...original?.rowStyle,\n }}\n {...original?.listProps}\n >\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </ScrollView>\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 borderWidth: 1,\n borderStyle: 'solid',\n borderColor: '#dedede',\n paddingVertical: 10,\n },\n selectLabel: { flex: 1, fontSize: 14 },\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 },\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 element = scope.original;\n const [height, setHeight] = useState(80);\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\n let type = scope.getPart('type', null, 'text');\n let decode = {\n textarea: {\n multiline: true,\n autoHeight: element.autoHeight !== false,\n textAlignVertical: 'top',\n numberOfLines: 5,\n style: { height: Math.max(80, height) },\n baseStyle: { paddingVertical: 10 },\n },\n };\n\n //v5\n let defs = { ...Utils.nvl(decode[type], {}), ...element.inputProps };\n let inputStyle = Utils.call(() => {\n let size = element.size;\n let css: any = {};\n\n if (size === 'small') {\n css.height = 30;\n css.fontSize = 12;\n }\n\n css.fontSize = Utils.nvl(element.fontSize, css.fontSize);\n css = { ...style('input'), ...style(type, css) };\n css.lineHeight = parseInt(css.fontSize) + 2;\n //v1\n return css;\n });\n\n if (defs.autoHeight) {\n defs.onContentSizeChange = event => {\n setHeight(event.nativeEvent.contentSize.height);\n };\n\n inputStyle = { ...inputStyle, ...defs.style };\n }\n\n return (\n <>\n <View style={style('base', defs?.baseStyle)}>\n {scope.getPart('left')}\n <TextInput\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n {...defs}\n style={inputStyle}\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: 10,\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 paddingVertical: 0,\n height: 40,\n width: '100%',\n flex: 1, // Para o input ocupar o espaço restante\n },\n textarea: {\n marginHorizontal: 0,\n marginVertical: 0,\n paddingVertical: 10,\n width: '100%',\n height: 'auto',\n alignSelf: 'stretch',\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 //v5\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 transient 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 row.selected = row.getPart('isSelectedRow', undefined, false);\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 30 });\n\n if (row.selected) {\n css = { ...css, ...row.getStyle('rowSelected', {}) };\n } else {\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\n }\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, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, 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 const hideEmpty = original.hideEmpty;\n\n //v2\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 let empty = scope.attr('empty', 'Sem registro');\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search !== false && !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 = Utils.getValue(filterBy, 'none', o).toLowerCase();\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 let isEmpty = Utils.isEmpty(items);\n\n const isShowAdd = () => {\n if (!isEmpty) {\n return true;\n }\n return hideAddWhenEmpty !== true;\n };\n\n let Empty = () => {\n if (!isEmpty) {\n return <></>;\n }\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: 400,\n fontSize: 18,\n padding: 10,\n textAlign: 'center',\n width: '100%',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n if (empty === false && isEmpty) {\n return <></>;\n }\n\n return (\n <View 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 let items = Utils.nvl(scope.getItems(), []);\n\n if (hideEmpty && Utils.isEmpty(items)) {\n return <></>;\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, ...scope.getStyle('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 const backgroundColor = item.backgroundColor;\n const color = item.color;\n\n if (item.backgroundColor) style = { ...style, backgroundColor };\n if (item.color) style = { ...style, color };\n } else {\n style.backgroundColor = '#fff';\n style.color = '#000';\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <View style={{ ...styles.container, ...scope.getStyle('items') }}>\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 </View>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n justifyContent: 'center',\n flexDirection: 'row',\n alignItems: 'center',\n margin: 3,\n gap: 5,\n },\n item: {\n backgroundColor: 'background',\n justifyContent: 'center',\n alignItems: 'center',\n width: 'auto',\n flexDirection: 'row',\n flex: 1,\n padding: 5,\n borderRadius: 2,\n },\n text: {\n fontSize: 13,\n fontWeight: '400',\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 { useRef, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface UIModalType extends ChildType {\n open?: boolean;\n dialog?: any;\n}\n\nexport default function UIModal(props: UIModalType) {\n const scrollRef = useRef(null);\n\n let owner = props.scope;\n let [index, setIndex] = useState(0);\n let dialog = owner.currentDialog;\n //v2\n\n let curr = dialog?.crud;\n\n if (!dialog) {\n return <></>;\n }\n\n dialog.update = () => {\n setIndex(++index);\n };\n\n if (dialog.debug) console.log(dialog);\n\n //const modalVisible = curr.uuid === main.dialog?.crud?.uuid;\n const scope = dialog.scope;\n const label = scope.getLabel();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n const bottom = ComponentUtils.getDefine(props, 'bottom');\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: dialog?.crud, event: {} });\n };\n\n scope.put('scrollRef', scrollRef);\n\n const original = owner.original;\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n let key = `${curr.name}-${index}`;\n\n let ModalContent = ({ children }) => {\n let disableScroll = scope.part('disableScroll', false);\n let disableContent = scope.part('disableContent', false);\n\n if (disableContent) {\n return <>{children}</>;\n }\n\n if (disableScroll) {\n return <View style={style('modalContent')}>{children}</View>;\n }\n return (\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n {children}\n </ScrollView>\n );\n };\n\n const ModalView = ({ children }) => {\n if (original.gesture) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const ModalInner = () => {\n let Content = () => {\n if (dialog?.component) {\n let cprops = dialog.props;\n let Aux = dialog.component;\n\n return <Aux key={curr.uuid} crud={curr} {...cprops} />;\n }\n\n return (\n <UIChildren scope={scope} crud={curr}>\n {props.children}\n </UIChildren>\n );\n };\n\n let content = <Content />;\n\n if (original.transient) {\n return <View style={style('modalSafe')}>{content}</View>;\n }\n\n return (\n <>\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={onClose}\n style={style('modalCloseButton')}\n >\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={curr} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ModalContent>{content}</ModalContent>\n {bottom}\n </SafeAreaView>\n <UIToast />\n </>\n );\n };\n return (\n <ModalView>\n <Modal\n key={key}\n animationType=\"slide\"\n transparent={true}\n visible={true}\n onRequestClose={onClose}\n >\n <ModalInner />\n </Modal>\n </ModalView>\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: 22,\n fontWeight: 600,\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n },\n});\n","import { Text, View } from 'react-native';\n\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\n\nexport default function UIHeader({ scope }: 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\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 return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n </>\n );\n}\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\nimport { useRef } from 'react';\nimport UIToast from './UIToast';\nimport UIHeader from './UIHeader';\n\nexport default function UIView({ scope, children }: ChildType) {\n const scrollRef = useRef(null);\n const original = scope.original;\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 //v3\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let Container = () => {\n if (original.scroll === false) {\n return <UIChildren scope={scope}>{children}</UIChildren>;\n }\n\n return (\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 );\n };\n return (\n <>\n <UIHeader scope={scope} />\n <Container />\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n paddingTop: 10,\n paddingBottom: 10,\n paddingLeft: 15,\n paddingRight: 15,\n },\n container: {},\n view: {},\n});\n","import React, { useRef, useState, useEffect } from 'react';\r\nimport { ChildType, OptionType } from 'react-crud-utils';\r\nimport {\r\n View,\r\n Text,\r\n StyleSheet,\r\n Animated,\r\n PanResponder,\r\n TouchableOpacity,\r\n} from 'react-native';\r\n\r\nconst ITEM_HEIGHT = 70;\r\n\r\nexport default function UIDraggableList(props: ChildType) {\r\n const scope = props.scope;\r\n const initial: OptionType[] = scope.getOptions();\r\n\r\n const [items, setItems] = useState<OptionType[]>(initial);\r\n const [draggingId, setDraggingId] = useState<string | null>(null);\r\n\r\n // O tipo Animated.Value em um ambiente TypeScript puro não tem o método ._value,\r\n // mas é a propriedade interna usada para acessar o valor diretamente.\r\n // Usamos 'any' no acesso para suprimir o erro TS.\r\n const positions = useRef<Record<string, Animated.Value>>(\r\n Object.fromEntries(\r\n initial.map((it, i) => [it.value, new Animated.Value(i * ITEM_HEIGHT)])\r\n )\r\n ).current;\r\n\r\n const panRespondersRef = useRef<Record<string, any>>({});\r\n\r\n const activeItem = useRef<OptionType | null>(null);\r\n const activeIndex = useRef<number>(-1);\r\n const offsetY = useRef(0);\r\n\r\n // Armazena a lista mais recente em uma ref para uso em funções de PanResponder\r\n const itemsRef = useRef(items);\r\n useEffect(() => {\r\n itemsRef.current = items;\r\n }, [items]);\r\n\r\n // 1. Atualiza posições apenas para itens existentes\r\n useEffect(() => {\r\n items.forEach((it, idx) => {\r\n if (!positions[it.value])\r\n positions[it.value] = new Animated.Value(idx * ITEM_HEIGHT);\r\n\r\n Animated.spring(positions[it.value], {\r\n toValue: idx * ITEM_HEIGHT,\r\n useNativeDriver: false,\r\n }).start();\r\n });\r\n }, [items]);\r\n\r\n const createPanResponder = (item: OptionType) =>\r\n PanResponder.create({\r\n onStartShouldSetPanResponder: () => true,\r\n onPanResponderGrant: () => {\r\n // Use itemsRef.current para obter a lista mais recente no momento do arrasto.\r\n const currentItems = itemsRef.current;\r\n if (\r\n !positions[item.value] ||\r\n !currentItems.find(it => it.value === item.value)\r\n )\r\n return;\r\n\r\n activeItem.current = item;\r\n activeIndex.current = currentItems.findIndex(\r\n it => it.value === item.value\r\n );\r\n // CORREÇÃO: Usa a propriedade interna _value para acessar o valor atual\r\n offsetY.current = (positions[item.value] as any)._value; // 👈 CORREÇÃO APLICADA\r\n setDraggingId(item.value);\r\n },\r\n onPanResponderMove: (_, gesture) => {\r\n const currentItems = itemsRef.current;\r\n if (\r\n !positions[item.value] ||\r\n !currentItems.find(it => it.value === item.value)\r\n )\r\n return;\r\n\r\n const y = offsetY.current + gesture.dy;\r\n positions[item.value].setValue(y);\r\n\r\n const targetIndex = Math.max(\r\n 0,\r\n Math.min(\r\n currentItems.length - 1,\r\n Math.floor((y + ITEM_HEIGHT / 2) / ITEM_HEIGHT)\r\n )\r\n );\r\n\r\n currentItems.forEach((other, idx) => {\r\n if (other.value === item.value || !positions[other.value]) return;\r\n let targetY = idx * ITEM_HEIGHT;\r\n if (idx > activeIndex.current && idx <= targetIndex)\r\n targetY = (idx - 1) * ITEM_HEIGHT;\r\n else if (idx < activeIndex.current && idx >= targetIndex)\r\n targetY = (idx + 1) * ITEM_HEIGHT;\r\n\r\n Animated.timing(positions[other.value], {\r\n toValue: targetY,\r\n duration: 120,\r\n useNativeDriver: false,\r\n }).start();\r\n });\r\n },\r\n onPanResponderRelease: () => {\r\n const moved = activeItem.current;\r\n const currentItems = itemsRef.current;\r\n\r\n if (\r\n !moved ||\r\n !positions[moved.value] ||\r\n !currentItems.find(it => it.value === moved.value)\r\n )\r\n return;\r\n\r\n // CORREÇÃO: Usa a propriedade interna _value para obter a posição final\r\n const finalY = (positions[moved.value] as any)._value; // 👈 CORREÇÃO APLICADA\r\n const newIndex = Math.max(\r\n 0,\r\n Math.min(\r\n currentItems.length - 1,\r\n Math.floor((finalY + ITEM_HEIGHT / 2) / ITEM_HEIGHT)\r\n )\r\n );\r\n\r\n const oldIndex = activeIndex.current;\r\n const updated = [...currentItems];\r\n const [removed] = updated.splice(oldIndex, 1);\r\n updated.splice(newIndex, 0, removed);\r\n\r\n // Atualiza o state com a nova ordem.\r\n setItems(updated);\r\n\r\n // A animação final agora está no useEffect, mas fazemos a limpeza das refs.\r\n setDraggingId(null);\r\n activeItem.current = null;\r\n activeIndex.current = -1;\r\n },\r\n });\r\n\r\n // Cria/Reusa os PanResponders\r\n items.forEach(it => {\r\n if (!panRespondersRef.current[it.value]) {\r\n panRespondersRef.current[it.value] = createPanResponder(it);\r\n }\r\n });\r\n\r\n const removeItem = (id: string) => {\r\n if (draggingId === id) {\r\n setDraggingId(null);\r\n activeItem.current = null;\r\n activeIndex.current = -1;\r\n }\r\n\r\n // CORREÇÃO: Delete a referência Animated.Value *e* a referência PanResponder\r\n if (positions[id]) {\r\n delete positions[id];\r\n }\r\n if (panRespondersRef.current[id]) {\r\n delete panRespondersRef.current[id];\r\n }\r\n\r\n setItems(prev => {\r\n const updated = prev.filter(it => it.value !== id);\r\n\r\n // Anima os itens restantes para seus novos índices\r\n updated.forEach((it, idx) => {\r\n if (positions[it.value])\r\n Animated.spring(positions[it.value], {\r\n toValue: idx * ITEM_HEIGHT,\r\n useNativeDriver: false,\r\n }).start();\r\n });\r\n\r\n return updated;\r\n });\r\n };\r\n\r\n return (\r\n <View style={styles.container}>\r\n <Text style={styles.title}>\r\n Lista Dragável (Esperando que a correção final funcione 🙏)\r\n </Text>\r\n <View style={{ height: items.length * ITEM_HEIGHT, width: '100%' }}>\r\n {items.map(item => {\r\n const y = positions[item.value];\r\n if (!y) return null;\r\n\r\n const isDragging = draggingId === item.value;\r\n return (\r\n <Animated.View\r\n key={item.value}\r\n {...(panRespondersRef.current[item.value]?.panHandlers ?? {})}\r\n style={[\r\n styles.item,\r\n {\r\n position: 'absolute',\r\n left: 0,\r\n right: 0,\r\n height: ITEM_HEIGHT - 8,\r\n transform: [{ translateY: y }],\r\n zIndex: isDragging ? 999 : 0,\r\n elevation: isDragging ? 999 : 0,\r\n },\r\n ]}\r\n >\r\n <View style={styles.handle}>\r\n <Text style={styles.handleText}>≡</Text>\r\n </View>\r\n <Text style={styles.itemText}>{item.label}</Text>\r\n <TouchableOpacity\r\n onPress={() => removeItem(item.value)}\r\n style={styles.del}\r\n >\r\n <Text style={{ color: '#fff' }}>X</Text>\r\n </TouchableOpacity>\r\n </Animated.View>\r\n );\r\n })}\r\n </View>\r\n </View>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n container: { flex: 1, paddingHorizontal: 20, backgroundColor: '#f5f7fb' },\r\n title: { fontSize: 18, fontWeight: '600', marginBottom: 12 },\r\n item: {\r\n backgroundColor: '#fff',\r\n borderRadius: 10,\r\n marginVertical: 4,\r\n paddingHorizontal: 12,\r\n alignItems: 'center',\r\n flexDirection: 'row',\r\n elevation: 3,\r\n shadowColor: '#000',\r\n shadowOpacity: 0.05,\r\n shadowRadius: 6,\r\n },\r\n handle: { width: 40, alignItems: 'center', justifyContent: 'center' },\r\n handleText: { fontSize: 22, color: '#666' },\r\n itemText: { fontSize: 16, flex: 1 },\r\n del: {\r\n backgroundColor: '#e74c3c',\r\n height: 34,\r\n width: 34,\r\n borderRadius: 6,\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n },\r\n});\r\n","import React from 'react';\nimport { ChildType } from 'react-crud-utils';\nimport UIDraggableList from './UIDraggableList';\n\nexport default function UIOrder(props: ChildType) {\n return (\n <>\n <UIDraggableList {...props} />\n </>\n );\n}\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n MethodType,\n ActionType,\n ComponentUtils,\n CrudUtils,\n ViewUtils,\n Scope,\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';\nimport UIOrder from './core/UIOrder';\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<Scope>(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n scope.compile(props);\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 if (scope.currentDialog?.component) return;\n\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 'textarea',\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 (scope.isType('icon')) return false;\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 isTouch =\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\n let custom: any = {};\n\n if (isTouch) {\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Tag = (props: any) => {\n let Aux: any = View;\n\n if (isTouch) {\n Aux = TouchableHighlight;\n }\n\n if (scope.isType('dialog', 'order') || original.transient) {\n return <>{props.children}</>;\n }\n\n return <Aux {...props} />;\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', '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 && (\n <View\n style={getStyle('error', {\n fontSize: 12,\n paddingTop: 4,\n color: '#e55b5b',\n })}\n >\n {error}\n </View>\n )}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('order') && (\n <UIOrder {...props} scope={scope} crud={crud} />\n )}\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 {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\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n <UIModal {...props} scope={scope} crud={crud} />\n </>\n );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (scope.isType('list')) {\n let empty = scope.getPart('empty', null, undefined);\n let items = scope.getItems();\n\n if (empty === false && Utils.isEmpty(items)) {\n isCard = false;\n }\n }\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n let borderWidth = original.boxBorder;\n\n if (borderWidth || borderWidth === 0) {\n if (borderWidth === true) {\n borderWidth = 1;\n }\n\n box = { ...box, borderWidth };\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 if (scope.isInput() || original.container) {\n return (\n <View\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\n >\n {props.children}\n </View>\n );\n }\n return <>{props.children}</>;\n };\n\n scope.dialogShow = (args?: MethodType) => {\n let event = Utils.nvl(args?.event, {});\n\n if (event?.debug) console.log(args);\n\n let caller = args.caller;\n let main = ViewUtils.getCrud('view');\n let parent = main.dialog;\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 let component = event?.component;\n let elo = Utils.nvl(caller?.original, original);\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 crudData = crud.data;\n let eventData = Utils.nvl(event.data, event.send);\n\n if (typeof eventData === 'function') {\n eventData = eventData.call(this, args);\n }\n\n if (event.send === false || event.data === false) {\n crudData = {};\n }\n\n let data = Utils.nvl(eventData, args.item, rowItem, crudData, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: crud,\n name,\n data,\n edit,\n scope,\n ...def,\n });\n\n let el: any = {\n label: elo.label,\n icon: elo.icon,\n type: 'dialog',\n };\n\n let close = event.dialog?.close;\n\n if (typeof event.dialog === 'object') {\n el = { ...el, ...event.dialog };\n }\n\n if (event.header) el.header = event.header;\n if (event.label) el.label = event.label;\n if (event.title) el.title = event.title;\n\n let label = Utils.nvl(el.title, el.label);\n\n el.label = label;\n\n let dialogScope = ScopeUtils.create({\n parent: scope,\n crud: d,\n ...el,\n owner: scope,\n });\n\n let dialog = {\n crud: d,\n label,\n parent,\n component,\n scope: dialogScope,\n close,\n props: event.props,\n debug: event.debug,\n };\n\n main.dialog = dialog;\n scope.currentDialog = dialog;\n\n if (parent) parent.update?.();\n scope.update();\n };\n\n scope.dialogHide = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let current = main.dialog;\n let next = Utils.nvl(current.parent, null);\n\n main.dialog = next;\n scope.currentDialog = next;\n\n let nextScope = next?.scope?.parent;\n let currScope = current?.scope?.parent;\n\n if (currScope) {\n const close = current.close;\n\n currScope.update();\n\n if (close) {\n if (close?.debug) console.log('Fechando');\n current.scope.call('close', { close });\n }\n }\n\n if (nextScope) {\n nextScope.update();\n }\n };\n\n if (original.hideEmpty && !scope.isType('list', 'select', 'complete')) {\n let value = scope.getValue();\n\n if (Utils.isEmpty(value)) return <></>;\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: 1,\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//v5\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.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\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 root: {\n height: 'auto',\n },\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n borderRadius: 2,\n justifyContent: 'center',\n flexDirection: 'row',\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: 600,\n fontSize: 12,\n paddingVertical: 3,\n color: 'labelColor',\n },\n inner: { width: '100%', justifyContent: 'space-between' },\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';\nimport GestureView from './core/GestureView';\n\nconst UI = {\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\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 Textarea: (props: InputType) => <UIElement {...props} type=\"textarea\" />,\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\" transient />,\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 GestureView: GestureView,\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';\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 //v2\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 return (\n <SafeAreaProvider>\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'flex-start',\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","import { StyleProp, ViewStyle } from 'react-native';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function GestureView(props: SafeViewType) {\n return (\n <GestureHandlerRootView style={{ flex: 1 }}>\n {props.children}\n </GestureHandlerRootView>\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","Aux","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","fontSize","size","_scope$original","BUTTONS_SIZE","small","minWidth","height","UIButton","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","Icon","iconSize","value","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","labelStyle","fs","parseInt","lh","lineHeight","getLabelStyle","defIconSize","Modal","animationType","transparent","visible","onRequestClose","SafeAreaView","ScrollView","contentContainerStyle","flexGrow","paddingBottom","nestedScrollEnabled","ref","flex","paddingLeft","paddingRight","paddingTop","List","getName","search","isObject","object","rowStyle","paddinRight","listProps","Value","selectRoot","selectInput","paddingHorizontal","borderStyle","paddingVertical","selectLabel","modalTop","modalSafe","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","el","setHeight","CustomIcon","decode","textarea","multiline","autoHeight","textAlignVertical","numberOfLines","Math","baseStyle","defs","inputProps","inputStyle","onContentSizeChange","nativeEvent","contentSize","TextInput","onChangeText","base","alignSelf","flexWrap","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","isVisible","setIsVisible","useEffect","interval","setInterval","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","hideEmpty","LocalData","setIndex","empty","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","textAlign","field","marginBottom","change","container","display","UIToggle","options","getInputValue","isSelected","Item","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","UIModal","owner","dialog","currentDialog","curr","headerRight","st","onClose","close","put","setViewScope","ModalContent","disableScroll","_ref2","gesture","GestureHandlerRootView","content","component","uuid","UIHeader","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","UIView","onScroll","ViewUtils","getCrud","scroll","Container","scrollEventThrottle","keyboardShouldPersistTaps","view","UIDraggableList","setItems","draggingId","setDraggingId","positions","fromEntries","it","Animated","panRespondersRef","activeItem","activeIndex","offsetY","itemsRef","forEach","idx","spring","toValue","useNativeDriver","start","PanResponder","onStartShouldSetPanResponder","onPanResponderGrant","currentItems","find","findIndex","_value","onPanResponderMove","_","dy","targetIndex","ITEM_HEIGHT","other","targetY","timing","duration","onPanResponderRelease","moved","newIndex","oldIndex","updated","concat","_updated$splice","splice","title","isDragging","_panRespondersRef$cur","_panRespondersRef$cur2","panHandlers","position","left","right","transform","translateY","zIndex","elevation","handle","handleText","itemText","prev","filter","del","shadowColor","shadowOpacity","shadowRadius","UIOrder","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","visibilityTime","prompt","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseFloat","getSelectedItem","_scope$currentDialog","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","open","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Inner","InputProps","checked","getSelectedValue","control","Image","source","define","Card","isCard","box","boxStyle","boxBorder","dialogShow","caller","main","rowItem","elo","crudData","eventData","send","_this","d","root","_event$dialog","dialogHide","next","nextScope","_next$scope","currScope","_current$scope","Provider","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Textarea","Email","Link","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","useTheme","SafeAreaProvider","SafeAreaContextView","viewStyle","StatusBar","barStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible","GestureView"],"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/elements/core/UIModal.tsx","../src/elements/core/UIHeader.tsx","../src/elements/core/UIView.tsx","../src/elements/core/UIOrder.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx","../src/elements/core/GestureView.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 if (props.transient) {\n return <Draw />;\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 let css: any = scope.getStyle('icon');\n let fontSize = scope.part('size', 20);\n let size = scope.part('iconSize', fontSize);\n\n if (scope.original?.transient) {\n css = { ...css, ...scope.getStyle() };\n }\n\n return <Aux size={size} name={name} style={css} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\nimport UI from '../UI';\n\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\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 = scope.getPart('icon');\n\n //ajuste align v6\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: 400,\n fontSize: 15,\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: 16,\n },\n button: {\n backgroundColor: color,\n borderRadius: 20,\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' || variant === 'outlined') {\n css.backgroundColor = 'transparent';\n css.color = Utils.nvl(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 def: any = { ...extra?.button };\n\n if (variant === 'outlined') {\n def.borderWidth = 1;\n def.borderColor = Utils.nvl(color, 'text');\n }\n\n if (size) {\n def = { ...def, ...BUTTONS_SIZE[size] };\n }\n\n if (!label) {\n def = { ...def, borderRadius: 20 };\n }\n\n let css = style('button', def);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\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 <UI.Icon\n size={Utils.nvl(element.iconSize, 30)}\n style={iconStyle}\n value={icon}\n />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useRef, useState } from 'react';\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\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 original = scope.original;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const scrollRef = useRef(null);\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\n const modalColor = Utils.nvl(headerStyle.color, 'white');\n const defaults = { color: modalColor };\n const onClick = ({ crud, value }: MethodType) => {\n let val = value as any;\n\n if (original.isObject && val?.object) {\n scope.changeValue(val?.object);\n } else if (val?.value) {\n scope.changeValue(val?.value);\n } else {\n scope.changeValue(value);\n }\n\n setModalVisible(false);\n };\n\n const style = (part: string, extra?: any) => {\n let all = { ...styles[part], ...extra };\n\n return scope.getStyle(part, all);\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n\n const getLabelStyle = () => {\n const css: any = style('selectLabel');\n let fs = parseInt(css.fontSize);\n\n if (!fs) {\n fs = 14;\n }\n\n let lh = Utils.nvl(css.lineHeight, fs + 2);\n\n css.fontSize = fs;\n css.lineHeight = lh;\n\n return css;\n };\n\n const labelStyle = getLabelStyle();\n const defIconSize = Utils.nvl(labelStyle.fontSize, 14) + 2;\n const iconSize = scope.getPart('iconSize', null, defIconSize);\n\n //v4\n\n return (\n <View\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\n style={style('selectRoot')}\n >\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={labelStyle}>{Utils.nvl(value, placeholder)}</Text>\n <Ionicons\n name=\"chevron-down-outline\"\n size={iconSize}\n color={scope.getPart('iconColor', null, iconColor)}\n style={style('iconStyle', {})}\n />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={handlePress}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"close\"\n size={24}\n color={modalColor}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n <View\n style={{\n flex: 1,\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n }}\n >\n <UI.List\n data={items}\n name={scope.getName('list')}\n layout=\"card\"\n search={original.search === true}\n click={onClick}\n rowStyle={{\n paddingLeft: 15,\n paddinRight: 15,\n ...original?.rowStyle,\n }}\n {...original?.listProps}\n >\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </ScrollView>\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 borderWidth: 1,\n borderStyle: 'solid',\n borderColor: '#dedede',\n paddingVertical: 10,\n },\n selectLabel: { flex: 1, fontSize: 14 },\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 },\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 element = scope.original;\n const [height, setHeight] = useState(80);\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\n let type = scope.getPart('type', null, 'text');\n let decode = {\n textarea: {\n multiline: true,\n autoHeight: element.autoHeight !== false,\n textAlignVertical: 'top',\n numberOfLines: 5,\n style: { height: Math.max(80, height) },\n baseStyle: { paddingVertical: 10 },\n },\n };\n\n //v5\n let defs = { ...Utils.nvl(decode[type], {}), ...element.inputProps };\n let inputStyle = Utils.call(() => {\n let size = element.size;\n let css: any = {};\n\n if (size === 'small') {\n css.height = 30;\n css.fontSize = 12;\n }\n\n css.fontSize = Utils.nvl(element.fontSize, css.fontSize);\n css = { ...style('input'), ...style(type, css) };\n css.lineHeight = parseInt(css.fontSize) + 2;\n //v1\n return css;\n });\n\n if (defs.autoHeight) {\n defs.onContentSizeChange = event => {\n setHeight(event.nativeEvent.contentSize.height);\n };\n\n inputStyle = { ...inputStyle, ...defs.style };\n }\n\n return (\n <>\n <View style={style('base', defs?.baseStyle)}>\n {scope.getPart('left')}\n <TextInput\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n {...defs}\n style={inputStyle}\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: 10,\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 paddingVertical: 0,\n height: 40,\n width: '100%',\n flex: 1, // Para o input ocupar o espaço restante\n },\n textarea: {\n marginHorizontal: 0,\n marginVertical: 0,\n paddingVertical: 10,\n width: '100%',\n height: 'auto',\n alignSelf: 'stretch',\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 //v5\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 transient 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 row.selected = row.getPart('isSelectedRow', undefined, false);\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 30 });\n\n if (row.selected) {\n css = { ...css, ...row.getStyle('rowSelected', {}) };\n } else {\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\n }\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, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, 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 const hideEmpty = original.hideEmpty;\n\n //v2\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 let empty = scope.attr('empty', 'Sem registro');\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search !== false && !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 = Utils.getValue(filterBy, 'none', o).toLowerCase();\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 let isEmpty = Utils.isEmpty(items);\n\n const isShowAdd = () => {\n if (!isEmpty) {\n return true;\n }\n return hideAddWhenEmpty !== true;\n };\n\n let Empty = () => {\n if (!isEmpty) {\n return <></>;\n }\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: 400,\n fontSize: 18,\n padding: 10,\n textAlign: 'center',\n width: '100%',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n if (empty === false && isEmpty) {\n return <></>;\n }\n\n return (\n <View 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 let items = Utils.nvl(scope.getItems(), []);\n\n if (hideEmpty && Utils.isEmpty(items)) {\n return <></>;\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, ...scope.getStyle('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 const backgroundColor = item.backgroundColor;\n const color = item.color;\n\n if (item.backgroundColor) style = { ...style, backgroundColor };\n if (item.color) style = { ...style, color };\n } else {\n style.backgroundColor = '#fff';\n style.color = '#000';\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <View style={{ ...styles.container, ...scope.getStyle('items') }}>\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 </View>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n justifyContent: 'center',\n flexDirection: 'row',\n alignItems: 'center',\n margin: 3,\n gap: 5,\n },\n item: {\n backgroundColor: 'background',\n justifyContent: 'center',\n alignItems: 'center',\n width: 'auto',\n flexDirection: 'row',\n flex: 1,\n padding: 5,\n borderRadius: 2,\n },\n text: {\n fontSize: 13,\n fontWeight: '400',\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 { useRef, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface UIModalType extends ChildType {\n open?: boolean;\n dialog?: any;\n}\n\nexport default function UIModal(props: UIModalType) {\n const scrollRef = useRef(null);\n\n let owner = props.scope;\n let [index, setIndex] = useState(0);\n let dialog = owner.currentDialog;\n //v2\n\n let curr = dialog?.crud;\n\n if (!dialog) {\n return <></>;\n }\n\n dialog.update = () => {\n setIndex(++index);\n };\n\n if (dialog.debug) console.log(dialog);\n\n //const modalVisible = curr.uuid === main.dialog?.crud?.uuid;\n const scope = dialog.scope;\n const label = scope.getLabel();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n const bottom = ComponentUtils.getDefine(props, 'bottom');\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: dialog?.crud, event: {} });\n };\n\n scope.put('scrollRef', scrollRef);\n\n const original = owner.original;\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n let key = `${curr.name}-${index}`;\n\n let ModalContent = ({ children }) => {\n let disableScroll = scope.part('disableScroll', false);\n let disableContent = scope.part('disableContent', false);\n\n if (disableContent) {\n return <>{children}</>;\n }\n\n if (disableScroll) {\n return <View style={style('modalContent')}>{children}</View>;\n }\n return (\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n {children}\n </ScrollView>\n );\n };\n\n const ModalView = ({ children }) => {\n if (original.gesture) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const ModalInner = () => {\n let Content = () => {\n if (dialog?.component) {\n let cprops = dialog.props;\n let Aux = dialog.component;\n\n return <Aux key={curr.uuid} crud={curr} {...cprops} />;\n }\n\n return (\n <UIChildren scope={scope} crud={curr}>\n {props.children}\n </UIChildren>\n );\n };\n\n let content = <Content />;\n\n if (original.transient) {\n return <View style={style('modalSafe')}>{content}</View>;\n }\n\n return (\n <>\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={onClose}\n style={style('modalCloseButton')}\n >\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={curr} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ModalContent>{content}</ModalContent>\n {bottom}\n </SafeAreaView>\n <UIToast />\n </>\n );\n };\n return (\n <ModalView>\n <Modal\n key={key}\n animationType=\"slide\"\n transparent={true}\n visible={true}\n onRequestClose={onClose}\n >\n <ModalInner />\n </Modal>\n </ModalView>\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: 22,\n fontWeight: 600,\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n },\n});\n","import { Text, View } from 'react-native';\n\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\n\nexport default function UIHeader({ scope }: 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\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 return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n </>\n );\n}\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\nimport { useRef } from 'react';\nimport UIToast from './UIToast';\nimport UIHeader from './UIHeader';\n\nexport default function UIView({ scope, children }: ChildType) {\n const scrollRef = useRef(null);\n const original = scope.original;\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 //v3\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let Container = () => {\n if (original.scroll === false) {\n return <UIChildren scope={scope}>{children}</UIChildren>;\n }\n\n return (\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 );\n };\n return (\n <>\n <UIHeader scope={scope} />\n <Container />\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n paddingTop: 10,\n paddingBottom: 10,\n paddingLeft: 15,\n paddingRight: 15,\n },\n container: {},\n view: {},\n});\n","import React, { useRef, useState, useEffect } from 'react';\nimport { ChildType, OptionType } from 'react-crud-utils';\nimport {\n View,\n Text,\n StyleSheet,\n Animated,\n PanResponder,\n TouchableOpacity,\n} from 'react-native';\n\nconst ITEM_HEIGHT = 70;\n\nexport default function UIOrder(props: ChildType) {\n const scope = props.scope;\n const initial: OptionType[] = scope.getOptions();\n\n const [items, setItems] = useState<OptionType[]>(initial);\n const [draggingId, setDraggingId] = useState<string | null>(null);\n\n // O tipo Animated.Value em um ambiente TypeScript puro não tem o método ._value,\n // mas é a propriedade interna usada para acessar o valor diretamente.\n // Usamos 'any' no acesso para suprimir o erro TS.\n const positions = useRef<Record<string, Animated.Value>>(\n Object.fromEntries(\n initial.map((it, i) => [it.value, new Animated.Value(i * ITEM_HEIGHT)])\n )\n ).current;\n\n const panRespondersRef = useRef<Record<string, any>>({});\n\n const activeItem = useRef<OptionType | null>(null);\n const activeIndex = useRef<number>(-1);\n const offsetY = useRef(0);\n\n // Armazena a lista mais recente em uma ref para uso em funções de PanResponder\n const itemsRef = useRef(items);\n useEffect(() => {\n itemsRef.current = items;\n }, [items]);\n\n // 1. Atualiza posições apenas para itens existentes\n useEffect(() => {\n items.forEach((it, idx) => {\n if (!positions[it.value])\n positions[it.value] = new Animated.Value(idx * ITEM_HEIGHT);\n\n Animated.spring(positions[it.value], {\n toValue: idx * ITEM_HEIGHT,\n useNativeDriver: false,\n }).start();\n });\n }, [items]);\n\n const createPanResponder = (item: OptionType) =>\n PanResponder.create({\n onStartShouldSetPanResponder: () => true,\n onPanResponderGrant: () => {\n // Use itemsRef.current para obter a lista mais recente no momento do arrasto.\n const currentItems = itemsRef.current;\n if (\n !positions[item.value] ||\n !currentItems.find(it => it.value === item.value)\n )\n return;\n\n activeItem.current = item;\n activeIndex.current = currentItems.findIndex(\n it => it.value === item.value\n );\n // CORREÇÃO: Usa a propriedade interna _value para acessar o valor atual\n offsetY.current = (positions[item.value] as any)._value; // 👈 CORREÇÃO APLICADA\n setDraggingId(item.value);\n },\n onPanResponderMove: (_, gesture) => {\n const currentItems = itemsRef.current;\n if (\n !positions[item.value] ||\n !currentItems.find(it => it.value === item.value)\n )\n return;\n\n const y = offsetY.current + gesture.dy;\n positions[item.value].setValue(y);\n\n const targetIndex = Math.max(\n 0,\n Math.min(\n currentItems.length - 1,\n Math.floor((y + ITEM_HEIGHT / 2) / ITEM_HEIGHT)\n )\n );\n\n currentItems.forEach((other, idx) => {\n if (other.value === item.value || !positions[other.value]) return;\n let targetY = idx * ITEM_HEIGHT;\n if (idx > activeIndex.current && idx <= targetIndex)\n targetY = (idx - 1) * ITEM_HEIGHT;\n else if (idx < activeIndex.current && idx >= targetIndex)\n targetY = (idx + 1) * ITEM_HEIGHT;\n\n Animated.timing(positions[other.value], {\n toValue: targetY,\n duration: 120,\n useNativeDriver: false,\n }).start();\n });\n },\n onPanResponderRelease: () => {\n const moved = activeItem.current;\n const currentItems = itemsRef.current;\n\n if (\n !moved ||\n !positions[moved.value] ||\n !currentItems.find(it => it.value === moved.value)\n )\n return;\n\n // CORREÇÃO: Usa a propriedade interna _value para obter a posição final\n const finalY = (positions[moved.value] as any)._value; // 👈 CORREÇÃO APLICADA\n const newIndex = Math.max(\n 0,\n Math.min(\n currentItems.length - 1,\n Math.floor((finalY + ITEM_HEIGHT / 2) / ITEM_HEIGHT)\n )\n );\n\n const oldIndex = activeIndex.current;\n const updated = [...currentItems];\n const [removed] = updated.splice(oldIndex, 1);\n updated.splice(newIndex, 0, removed);\n\n // Atualiza o state com a nova ordem.\n setItems(updated);\n\n // A animação final agora está no useEffect, mas fazemos a limpeza das refs.\n setDraggingId(null);\n activeItem.current = null;\n activeIndex.current = -1;\n },\n });\n\n // Cria/Reusa os PanResponders\n items.forEach(it => {\n if (!panRespondersRef.current[it.value]) {\n panRespondersRef.current[it.value] = createPanResponder(it);\n }\n });\n\n const removeItem = (id: string) => {\n if (draggingId === id) {\n setDraggingId(null);\n activeItem.current = null;\n activeIndex.current = -1;\n }\n\n // CORREÇÃO: Delete a referência Animated.Value *e* a referência PanResponder\n if (positions[id]) {\n delete positions[id];\n }\n if (panRespondersRef.current[id]) {\n delete panRespondersRef.current[id];\n }\n\n setItems(prev => {\n const updated = prev.filter(it => it.value !== id);\n\n // Anima os itens restantes para seus novos índices\n updated.forEach((it, idx) => {\n if (positions[it.value])\n Animated.spring(positions[it.value], {\n toValue: idx * ITEM_HEIGHT,\n useNativeDriver: false,\n }).start();\n });\n\n return updated;\n });\n };\n\n return (\n <View style={styles.container}>\n <Text style={styles.title}>\n Lista Dragável (Esperando que a correção final funcione 🙏)\n </Text>\n <View style={{ height: items.length * ITEM_HEIGHT, width: '100%' }}>\n {items.map(item => {\n const y = positions[item.value];\n if (!y) return null;\n\n const isDragging = draggingId === item.value;\n return (\n <Animated.View\n key={item.value}\n {...(panRespondersRef.current[item.value]?.panHandlers ?? {})}\n style={[\n styles.item,\n {\n position: 'absolute',\n left: 0,\n right: 0,\n height: ITEM_HEIGHT - 8,\n transform: [{ translateY: y }],\n zIndex: isDragging ? 999 : 0,\n elevation: isDragging ? 999 : 0,\n },\n ]}\n >\n <View style={styles.handle}>\n <Text style={styles.handleText}>≡</Text>\n </View>\n <Text style={styles.itemText}>{item.label}</Text>\n <TouchableOpacity\n onPress={() => removeItem(item.value)}\n style={styles.del}\n >\n <Text style={{ color: '#fff' }}>X</Text>\n </TouchableOpacity>\n </Animated.View>\n );\n })}\n </View>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n container: { flex: 1, paddingHorizontal: 20, backgroundColor: '#f5f7fb' },\n title: { fontSize: 18, fontWeight: '600', marginBottom: 12 },\n item: {\n backgroundColor: '#fff',\n borderRadius: 10,\n marginVertical: 4,\n paddingHorizontal: 12,\n alignItems: 'center',\n flexDirection: 'row',\n elevation: 3,\n shadowColor: '#000',\n shadowOpacity: 0.05,\n shadowRadius: 6,\n },\n handle: { width: 40, alignItems: 'center', justifyContent: 'center' },\n handleText: { fontSize: 22, color: '#666' },\n itemText: { fontSize: 16, flex: 1 },\n del: {\n backgroundColor: '#e74c3c',\n height: 34,\n width: 34,\n borderRadius: 6,\n alignItems: 'center',\n justifyContent: 'center',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n MethodType,\n ActionType,\n ComponentUtils,\n CrudUtils,\n ViewUtils,\n Scope,\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';\nimport UIOrder from './core/UIOrder';\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<Scope>(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n scope.compile(props);\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 if (scope.currentDialog?.component) return;\n\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 'textarea',\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 (scope.isType('icon')) return false;\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 isTouch =\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\n let custom: any = {};\n\n if (isTouch) {\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Tag = (props: any) => {\n let Aux: any = View;\n\n if (isTouch) {\n Aux = TouchableHighlight;\n }\n\n if (scope.isType('dialog', 'order') || original.transient) {\n return <>{props.children}</>;\n }\n\n return <Aux {...props} />;\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', '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 && (\n <View\n style={getStyle('error', {\n fontSize: 12,\n paddingTop: 4,\n color: '#e55b5b',\n })}\n >\n {error}\n </View>\n )}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('order') && (\n <UIOrder {...props} scope={scope} crud={crud} />\n )}\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 {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\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n <UIModal {...props} scope={scope} crud={crud} />\n </>\n );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (scope.isType('list')) {\n let empty = scope.getPart('empty', null, undefined);\n let items = scope.getItems();\n\n if (empty === false && Utils.isEmpty(items)) {\n isCard = false;\n }\n }\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n let borderWidth = original.boxBorder;\n\n if (borderWidth || borderWidth === 0) {\n if (borderWidth === true) {\n borderWidth = 1;\n }\n\n box = { ...box, borderWidth };\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 if (scope.isInput() || original.container) {\n return (\n <View\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\n >\n {props.children}\n </View>\n );\n }\n return <>{props.children}</>;\n };\n\n scope.dialogShow = (args?: MethodType) => {\n let event = Utils.nvl(args?.event, {});\n\n if (event?.debug) console.log(args);\n\n let caller = args.caller;\n let main = ViewUtils.getCrud('view');\n let parent = main.dialog;\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 let component = event?.component;\n let elo = Utils.nvl(caller?.original, original);\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 crudData = crud.data;\n let eventData = Utils.nvl(event.data, event.send);\n\n if (typeof eventData === 'function') {\n eventData = eventData.call(this, args);\n }\n\n if (event.send === false || event.data === false) {\n crudData = {};\n }\n\n let data = Utils.nvl(eventData, args.item, rowItem, crudData, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: crud,\n name,\n data,\n edit,\n scope,\n ...def,\n });\n\n let el: any = {\n label: elo.label,\n icon: elo.icon,\n type: 'dialog',\n };\n\n let close = event.dialog?.close;\n\n if (typeof event.dialog === 'object') {\n el = { ...el, ...event.dialog };\n }\n\n if (event.header) el.header = event.header;\n if (event.label) el.label = event.label;\n if (event.title) el.title = event.title;\n\n let label = Utils.nvl(el.title, el.label);\n\n el.label = label;\n\n let dialogScope = ScopeUtils.create({\n parent: scope,\n crud: d,\n ...el,\n owner: scope,\n });\n\n let dialog = {\n crud: d,\n label,\n parent,\n component,\n scope: dialogScope,\n close,\n props: event.props,\n debug: event.debug,\n };\n\n main.dialog = dialog;\n scope.currentDialog = dialog;\n\n if (parent) parent.update?.();\n scope.update();\n };\n\n scope.dialogHide = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let current = main.dialog;\n let next = Utils.nvl(current.parent, null);\n\n main.dialog = next;\n scope.currentDialog = next;\n\n let nextScope = next?.scope?.parent;\n let currScope = current?.scope?.parent;\n\n if (currScope) {\n const close = current.close;\n\n currScope.update();\n\n if (close) {\n if (close?.debug) console.log('Fechando');\n current.scope.call('close', { close });\n }\n }\n\n if (nextScope) {\n nextScope.update();\n }\n };\n\n if (original.hideEmpty && !scope.isType('list', 'select', 'complete')) {\n let value = scope.getValue();\n\n if (Utils.isEmpty(value)) return <></>;\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: 1,\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//v5\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.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\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 root: {\n height: 'auto',\n },\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n borderRadius: 2,\n justifyContent: 'center',\n flexDirection: 'row',\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: 600,\n fontSize: 12,\n paddingVertical: 3,\n color: 'labelColor',\n },\n inner: { width: '100%', justifyContent: 'space-between' },\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';\nimport GestureView from './core/GestureView';\n\nconst UI = {\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\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 Textarea: (props: InputType) => <UIElement {...props} type=\"textarea\" />,\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\" transient />,\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 GestureView: GestureView,\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';\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 //v2\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 return (\n <SafeAreaProvider>\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'flex-start',\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","import { StyleProp, ViewStyle } from 'react-native';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function GestureView(props: SafeViewType) {\n return (\n <GestureHandlerRootView style={{ flex: 1 }}>\n {props.children}\n </GestureHandlerRootView>\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","Aux","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","fontSize","size","_scope$original","BUTTONS_SIZE","small","minWidth","height","UIButton","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","Icon","iconSize","value","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","labelStyle","fs","parseInt","lh","lineHeight","getLabelStyle","defIconSize","Modal","animationType","transparent","visible","onRequestClose","SafeAreaView","ScrollView","contentContainerStyle","flexGrow","paddingBottom","nestedScrollEnabled","ref","flex","paddingLeft","paddingRight","paddingTop","List","getName","search","isObject","object","rowStyle","paddinRight","listProps","Value","selectRoot","selectInput","paddingHorizontal","borderStyle","paddingVertical","selectLabel","modalTop","modalSafe","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","el","setHeight","CustomIcon","decode","textarea","multiline","autoHeight","textAlignVertical","numberOfLines","Math","baseStyle","defs","inputProps","inputStyle","onContentSizeChange","nativeEvent","contentSize","TextInput","onChangeText","base","alignSelf","flexWrap","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","isVisible","setIsVisible","useEffect","interval","setInterval","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","hideEmpty","LocalData","setIndex","empty","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","textAlign","field","marginBottom","change","container","display","UIToggle","options","getInputValue","isSelected","Item","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","UIModal","owner","dialog","currentDialog","curr","headerRight","st","onClose","close","put","setViewScope","ModalContent","disableScroll","_ref2","gesture","GestureHandlerRootView","content","component","uuid","UIHeader","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","UIView","onScroll","ViewUtils","getCrud","scroll","Container","scrollEventThrottle","keyboardShouldPersistTaps","view","UIOrder","setItems","draggingId","setDraggingId","positions","fromEntries","it","Animated","panRespondersRef","activeItem","activeIndex","offsetY","itemsRef","forEach","idx","spring","toValue","useNativeDriver","start","PanResponder","onStartShouldSetPanResponder","onPanResponderGrant","currentItems","find","findIndex","_value","onPanResponderMove","_","dy","targetIndex","ITEM_HEIGHT","other","targetY","timing","duration","onPanResponderRelease","moved","newIndex","oldIndex","updated","concat","_updated$splice","splice","title","isDragging","_panRespondersRef$cur","_panRespondersRef$cur2","panHandlers","position","left","right","transform","translateY","zIndex","elevation","handle","handleText","itemText","prev","filter","del","shadowColor","shadowOpacity","shadowRadius","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","visibilityTime","prompt","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseFloat","getSelectedItem","_scope$currentDialog","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","open","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Inner","InputProps","checked","getSelectedValue","control","Image","source","define","Card","isCard","box","boxStyle","boxBorder","dialogShow","caller","main","rowItem","elo","crudData","eventData","send","_this","d","root","_event$dialog","dialogHide","next","nextScope","_next$scope","currScope","_current$scope","Provider","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Textarea","Email","Link","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","useTheme","SafeAreaProvider","SafeAreaContextView","viewStyle","StatusBar","barStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible","GestureView"],"mappings":"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"}
|