react-crud-mobile 1.3.290 → 1.3.292

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UISlider.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/hooks/useIsVisible.ts","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIToast.tsx","../src/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';\r\nimport UIElement from './UIElement';\r\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, View } from 'react-native';\r\n\r\ninterface UIChildrenType {\r\n scope: Scope;\r\n crud?: Crud;\r\n validateScope?: String;\r\n children?: any;\r\n elements?: any;\r\n transient?: boolean;\r\n part?: string;\r\n style?: any;\r\n childProps?: any;\r\n}\r\n\r\nexport default function UIChildren(props: UIChildrenType) {\r\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\r\n let crud = Utils.nvl(props.crud, scope.crud);\r\n let validateScope = Utils.nvl(props.validateScope, 'global');\r\n let name = Utils.nvl(props.part, 'child');\r\n\r\n if (scope.isInput()) {\r\n return <></>;\r\n }\r\n\r\n let Paint = ({ child }: any) => {\r\n if (!child) {\r\n return <></>;\r\n }\r\n if (typeof child === 'string') {\r\n return <>{child}</>;\r\n }\r\n\r\n let Custom = child.type;\r\n let pps = { ...child.props };\r\n\r\n delete pps.children;\r\n\r\n if (typeof Custom === 'string') {\r\n if (Utils.isEmpty(child.props.children)) {\r\n return <Custom {...pps} />;\r\n }\r\n return (\r\n <Custom {...pps}>\r\n <UIChildren\r\n transient\r\n validateScope={validateScope}\r\n {...child.props}\r\n scope={scope}\r\n crud={crud}\r\n ></UIChildren>\r\n </Custom>\r\n );\r\n } else if (typeof Custom === 'function') {\r\n return (\r\n <Custom\r\n validateScope={validateScope}\r\n {...child.props}\r\n parent={scope}\r\n crud={crud}\r\n ></Custom>\r\n );\r\n }\r\n\r\n if (!Utils.isEmpty(child.props?.children)) {\r\n return (\r\n <UIChildren\r\n validateScope={validateScope}\r\n {...child.props}\r\n scope={scope}\r\n crud={crud}\r\n transient\r\n ></UIChildren>\r\n );\r\n }\r\n return <></>;\r\n };\r\n\r\n const Draw = () => {\r\n if (props.elements) {\r\n return (\r\n <>\r\n {Object.entries(props.elements).map((t: any, k) => {\r\n return <UIElement crud={crud} {...t[1]} />;\r\n })}\r\n </>\r\n );\r\n }\r\n return (\r\n <>\r\n {React.Children.map(props.children, child => {\r\n return <Paint child={child}></Paint>;\r\n })}\r\n </>\r\n );\r\n };\r\n\r\n if (props.transient) {\r\n return <Draw />;\r\n }\r\n\r\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\r\n return <></>;\r\n }\r\n\r\n const getStyle = (part?: string) => {\r\n let key = Utils.nvl(part, 'root');\r\n let def = styles[key];\r\n let css = {};\r\n\r\n if (!Utils.isEmpty(props.style)) {\r\n if (props.style?.push) {\r\n Utils.each(props.style, s => {\r\n if (s) {\r\n css = { ...css, ...s };\r\n }\r\n });\r\n } else {\r\n css = { ...props.style };\r\n }\r\n }\r\n return { ...def, ...css, ...scope.getStyle(part) };\r\n };\r\n\r\n if (props.transient) {\r\n return <Draw />;\r\n }\r\n return (\r\n <>\r\n <View style={getStyle(name)}>\r\n <Draw />\r\n </View>\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n child: { width: '100%' },\r\n inner: { width: '100%' },\r\n});\r\n","import React, { useState, useEffect } from 'react';\r\nimport UIChildren from '../UIChildren';\r\nimport UI from '../UI';\r\n\r\nimport Ionicons from '@expo/vector-icons/Ionicons';\r\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\r\n\r\nexport default function ElTabs(props: ChildType) {\r\n let scope = props.scope;\r\n let [selectedIndex, setSelectedIndex]: any = useState(0);\r\n let element = scope.original;\r\n let items = scope.getItems();\r\n let counter = 0;\r\n\r\n let tabs: any = [];\r\n let [selected, setSelected]: any = useState(null);\r\n\r\n const onChangeTab = (tab: any, validate = true) => {\r\n if (tab) {\r\n scope.execute({\r\n event: {\r\n validate,\r\n validateScope: element.validateScope,\r\n action: () => {\r\n scope.changeValue(tab.data);\r\n\r\n selected = tab;\r\n selectedIndex = tab.index;\r\n\r\n setSelectedIndex(selectedIndex);\r\n setSelected(tab);\r\n },\r\n },\r\n });\r\n }\r\n };\r\n\r\n const getStyleClass = (t: any) => {\r\n let s = 'ui-tabs-item ui-click';\r\n\r\n if (selected?.index === t.index) {\r\n s = s + ' ui-tab-selected';\r\n }\r\n return s;\r\n };\r\n\r\n const addTab = (child: any, item: any) => {\r\n let original = { ...child.props };\r\n\r\n if (!item) {\r\n item = scope.crud.data;\r\n }\r\n\r\n let crudTab = CrudUtils.create('tabs', {\r\n data: item,\r\n changed: item,\r\n parent: scope.crud,\r\n });\r\n\r\n let element = Utils.resolve(original, crudTab);\r\n\r\n if (element.rendered === false) {\r\n return;\r\n }\r\n\r\n tabs.push({\r\n ...element,\r\n child,\r\n element,\r\n original,\r\n index: counter++,\r\n data: item,\r\n });\r\n };\r\n\r\n React.Children.map(props.children, (child, index) => {\r\n if (Utils.isEmpty(items)) {\r\n addTab(child, {});\r\n } else {\r\n for (const i in items) {\r\n let o = items[i];\r\n\r\n addTab(child, o);\r\n }\r\n }\r\n });\r\n\r\n if (!selected) {\r\n onChangeTab(tabs[selectedIndex], false);\r\n }\r\n\r\n const nav = (i: any) => {\r\n let t = tabs[selectedIndex + i];\r\n\r\n onChangeTab(t);\r\n };\r\n\r\n const previous = () => {\r\n nav(-1);\r\n };\r\n\r\n const next = () => {\r\n nav(1);\r\n };\r\n\r\n let isStepper = element.layout === 'stepper';\r\n\r\n return (\r\n <div\r\n className={scope.getStyleClass('inner')}\r\n style={scope.getStyle('inner')}\r\n >\r\n <div className=\"ui-tabs-content\">\r\n <div className=\"ui-tabs-items\">\r\n {tabs.map((t: any, i: number) => (\r\n <div\r\n key={Utils.key(element.id, 'tab', i)}\r\n className={getStyleClass(t)}\r\n onClick={() => {\r\n onChangeTab(t);\r\n }}\r\n >\r\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\r\n <div className=\"ui-tab-item-inner\">\r\n {isStepper && <div className=\"ui-step-line\" />}\r\n <div className=\"ui-tab-item-label\">\r\n {isStepper ? t.index + 1 : t.label}\r\n </div>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n {selected && (\r\n <>\r\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\r\n <div className=\"ui-tabs-area\">\r\n <UIChildren {...props} scope={scope}>\r\n {selected.child}\r\n </UIChildren>\r\n </div>\r\n {element.layout === 'stepper' && (\r\n <div className=\"ui-tabs-actions\">\r\n <UI.Output space={6} layout=\"left\">\r\n <UI.Include\r\n {...props}\r\n transient\r\n name=\"left\"\r\n default={\r\n <UI.Button\r\n rendered={selectedIndex > 0}\r\n icon={<Ionicons />}\r\n click={previous}\r\n />\r\n }\r\n />\r\n </UI.Output>\r\n <UI.Output space={6} layout=\"right\">\r\n <UI.Include\r\n {...props}\r\n transient\r\n name=\"right\"\r\n default={\r\n <UI.Button\r\n rendered={selectedIndex < tabs.length - 1}\r\n icon={<Ionicons />}\r\n click={next}\r\n />\r\n }\r\n />\r\n </UI.Output>\r\n </div>\r\n )}\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import React from \"react\";\r\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\r\n\r\nexport default function ElChart(props: ChildType) {\r\n let scope: Scope = props.scope;\r\n let items: any = scope.getItems();\r\n let columns = Utils.asList(scope.original.columns);\r\n\r\n return <div className=\"ui-chart-data\"></div>;\r\n}\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\r\nimport AutoComplete from './core/UIAutoComplete';\r\n\r\nexport default function UIComplete({\r\n defaultsInput,\r\n defaultsUI,\r\n scope,\r\n}: ChildType) {\r\n return (\r\n <>\r\n <AutoComplete {...defaultsInput} {...defaultsUI} />\r\n </>\r\n );\r\n}\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\r\n Ionicons,\r\n MaterialCommunityIcons,\r\n AntDesign,\r\n Entypo,\r\n EvilIcons,\r\n} from '@expo/vector-icons';\r\n\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIIcon({ scope }: ChildType) {\r\n let name = scope.getValue();\r\n let libs: any = {\r\n ion: Ionicons,\r\n ant: AntDesign,\r\n entypo: Entypo,\r\n evil: EvilIcons,\r\n material: MaterialCommunityIcons,\r\n };\r\n\r\n let library = Utils.nvl(scope.original.library, 'ion');\r\n let Aux = libs[library];\r\n\r\n return <Aux name={name} style={scope.getStyle('icon')} />;\r\n}\r\n","import { Ionicons } from '@expo/vector-icons';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Text, TouchableHighlight, View } from 'react-native';\r\n\r\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\r\n\r\nexport default function UIButton(props: ChildType) {\r\n let scope = props.scope;\r\n let element = scope.original;\r\n let size = Utils.nvl(element.size, 'default');\r\n let align = Utils.nvl(element.align, 'center');\r\n let variant = Utils.nvl(element.variant, 'default');\r\n\r\n let color = element.color;\r\n let label = scope.getLabel();\r\n let icon = scope.getPart('icon');\r\n\r\n //ajuste align v5\r\n if (!color) color = 'primaryLight';\r\n\r\n const styles: any = {\r\n buttonLabel: {\r\n color: '#ffffff',\r\n fontWeight: 400,\r\n fontSize: 15,\r\n },\r\n buttonInner: {\r\n flexDirection: 'row',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n height: 44,\r\n minWidth: 44,\r\n },\r\n buttonIcon: {\r\n color: '#fff',\r\n fontSize: 16,\r\n },\r\n button: {\r\n backgroundColor: color,\r\n borderRadius: 20,\r\n gap: 10,\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n flexDirection: 'row',\r\n },\r\n };\r\n\r\n const onClick = (e: any) => {\r\n scope.call('click', {});\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let css = { ...styles[part], ...extra };\r\n\r\n if (variant === 'text' || variant === 'outlined') {\r\n css.backgroundColor = 'transparent';\r\n css.color = Utils.nvl(color, 'text');\r\n }\r\n\r\n if (size === 'small') {\r\n css.fontSize = 12;\r\n css.fontWeight = 500;\r\n }\r\n\r\n if (size === 'medium') {\r\n css.fontSize = 14;\r\n css.fontWeight = 500;\r\n }\r\n\r\n if (align === 'left') {\r\n css.justifyContent = 'flex-start';\r\n }\r\n\r\n return scope.getStyle(part, css);\r\n };\r\n\r\n let extra: any = {};\r\n\r\n if (icon) {\r\n extra.button = { height: 40, padding: 0 };\r\n } else {\r\n extra.button = { height: 50 };\r\n }\r\n\r\n const buttonStyle = Utils.call(() => {\r\n let def: any = { ...extra?.button };\r\n\r\n if (variant === 'outlined') {\r\n def.borderWidth = 1;\r\n def.borderColor = Utils.nvl(color, 'text');\r\n }\r\n\r\n if (size) {\r\n def = { ...def, ...BUTTONS_SIZE[size] };\r\n }\r\n\r\n if (!label) {\r\n def = { ...def, borderRadius: 20 };\r\n }\r\n\r\n let css = style('button', def);\r\n\r\n if (!css.width) {\r\n let h = css.height;\r\n\r\n if (typeof h === 'number') {\r\n css.minWidth = h;\r\n }\r\n }\r\n\r\n return css;\r\n });\r\n\r\n const buttonLabel = style('buttonLabel');\r\n const iconStyle = Utils.call(() => {\r\n let css: any = style('buttonIcon', extra.icon);\r\n\r\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\r\n\r\n return css;\r\n });\r\n\r\n return (\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClick}\r\n style={buttonStyle}\r\n >\r\n <>\r\n {icon && (\r\n <>\r\n <Ionicons\r\n size={Utils.nvl(element.iconSize, 30)}\r\n style={iconStyle}\r\n name={icon}\r\n />\r\n </>\r\n )}\r\n {label && <Text style={buttonLabel}>{label}</Text>}\r\n </>\r\n </TouchableHighlight>\r\n );\r\n}\r\n","import { useRef, useState } from 'react';\r\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\r\nimport {\r\n Text,\r\n TouchableOpacity,\r\n StyleSheet,\r\n Modal,\r\n View,\r\n SafeAreaView,\r\n ScrollView,\r\n} from 'react-native';\r\nimport { Ionicons } from '@expo/vector-icons';\r\nimport UI from '../UI';\r\n\r\nexport default function UISelect(props: ChildType) {\r\n const [modalVisible, setModalVisible] = useState(false);\r\n const scope = props.scope;\r\n const original = scope.original;\r\n const items = Utils.nvl(scope.getOptions(), []);\r\n const placeholder = scope.attr('placeholder', 'Selecione...');\r\n const value = scope.getDisplayValue();\r\n const theme = scope.getTheme();\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const handlePress = () => {\r\n setModalVisible(!modalVisible);\r\n };\r\n\r\n const scrollRef = useRef(null);\r\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\r\n const modalColor = Utils.nvl(headerStyle.color, 'white');\r\n const defaults = { color: modalColor };\r\n const onClick = ({ crud, value }: MethodType) => {\r\n let val = value as any;\r\n\r\n if (original.isObject && val?.object) {\r\n scope.changeValue(val?.object);\r\n } else if (val?.value) {\r\n scope.changeValue(val?.value);\r\n } else {\r\n scope.changeValue(value);\r\n }\r\n\r\n setModalVisible(false);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let all = { ...styles[part], ...extra };\r\n\r\n return scope.getStyle(part, all);\r\n };\r\n\r\n const isModalVisible = () => {\r\n return modalVisible;\r\n };\r\n //v4\r\n\r\n return (\r\n <View\r\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\r\n style={style('selectRoot')}\r\n >\r\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\r\n <Text style={style('selectLabel')}>\r\n {Utils.nvl(value, placeholder)}\r\n </Text>\r\n <Ionicons\r\n name=\"chevron-down-outline\"\r\n size={scope.getPart('iconSize', null, 24)}\r\n color={scope.getPart('iconColor', null, iconColor)}\r\n style={style('iconStyle', {})}\r\n />\r\n </TouchableOpacity>\r\n <Modal\r\n animationType=\"slide\"\r\n transparent={true}\r\n visible={isModalVisible()}\r\n onRequestClose={() => setModalVisible(false)}\r\n >\r\n <SafeAreaView style={style('modalTop')} />\r\n <SafeAreaView style={style('modalSafe')}>\r\n <View style={scope.getStyle('header', headerStyle)}>\r\n <TouchableOpacity\r\n onPress={handlePress}\r\n style={style('modalCloseButton')}\r\n >\r\n <Ionicons\r\n name=\"close\"\r\n size={24}\r\n color={modalColor}\r\n style={style('modalCloseText', defaults)}\r\n />\r\n </TouchableOpacity>\r\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\r\n </View>\r\n <ScrollView\r\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\r\n style={style('modalContent')}\r\n nestedScrollEnabled={true}\r\n ref={scrollRef}\r\n >\r\n <View\r\n style={{\r\n flex: 1,\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n }}\r\n >\r\n <UI.List\r\n data={items}\r\n name={scope.getName('list')}\r\n layout=\"card\"\r\n search={original.search === true}\r\n click={onClick}\r\n rowStyle={{\r\n paddingLeft: 15,\r\n paddinRight: 15,\r\n ...original?.rowStyle,\r\n }}\r\n {...original?.listProps}\r\n >\r\n <UI.Value value=\"#{@this.label}\" />\r\n </UI.List>\r\n </View>\r\n </ScrollView>\r\n </SafeAreaView>\r\n </Modal>\r\n </View>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n selectRoot: {\r\n justifyContent: 'flex-start',\r\n alignItems: 'flex-start',\r\n flex: 1,\r\n },\r\n selectInput: {\r\n width: '100%',\r\n flexDirection: 'row',\r\n borderRadius: 5,\r\n paddingHorizontal: 15,\r\n borderWidth: 1,\r\n borderStyle: 'solid',\r\n borderColor: '#dedede',\r\n paddingVertical: 10,\r\n },\r\n selectLabel: { flex: 1 },\r\n modalTop: {\r\n backgroundColor: 'primary',\r\n width: '100%',\r\n },\r\n modalSafe: {\r\n flex: 1,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n },\r\n modalCloseButton: {\r\n padding: 10,\r\n },\r\n modalCloseText: {\r\n fontSize: 18,\r\n color: 'white',\r\n },\r\n modalTitle: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n marginLeft: 10,\r\n },\r\n modalContent: {\r\n flex: 1,\r\n backgroundColor: 'background',\r\n },\r\n});\r\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n 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';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, TextInput, View } from 'react-native';\r\nimport { Ionicons } from '@expo/vector-icons';\r\n\r\nexport default function UIInput(props: ChildType) {\r\n let scope = props.scope;\r\n let initial = Utils.call(() => {\r\n let val = Utils.nvl(scope.getValue(), '');\r\n\r\n if (val && val?.push) {\r\n return val.join(', ').trim();\r\n }\r\n return val;\r\n });\r\n\r\n let label = scope.getLabel();\r\n let placeholder = scope.getPart('placeholder', null, label);\r\n let el = scope.original;\r\n\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n v = scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n return { ...scope.getStyle(part, styles[part]), ...extra };\r\n };\r\n\r\n const CustomIcon = () => {\r\n let icon = el.icon;\r\n\r\n if (icon) {\r\n if (typeof icon === 'string') {\r\n return (\r\n <>\r\n {el.icon && (\r\n <Ionicons\r\n name={el.icon}\r\n size={scope.attr('iconSize', 20)}\r\n color={scope.attr('iconColor', '#888')}\r\n />\r\n )}\r\n </>\r\n );\r\n }\r\n return <>{icon}</>;\r\n }\r\n return <></>;\r\n };\r\n\r\n let type = scope.getPart('type', 'none');\r\n let decode = {\r\n textarea: { multiline: true, textAlignVertical: 'top', numberOfLines: 5 },\r\n };\r\n\r\n let defs = { ...Utils.nvl(decode[type], {}), ...scope.original.inputProps };\r\n\r\n return (\r\n <>\r\n <View style={style('base')}>\r\n {scope.getPart('left')}\r\n <TextInput\r\n style={style('input')}\r\n onChangeText={onChange}\r\n value={value}\r\n placeholder={placeholder}\r\n {...defs}\r\n />\r\n <CustomIcon />\r\n </View>\r\n {scope.getPart('right')}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n base: {\r\n flex: 1,\r\n width: '100%',\r\n paddingBottom: 0,\r\n paddingTop: 0,\r\n alignItems: 'center',\r\n borderWidth: 1,\r\n borderColor: 'borderColor',\r\n borderRadius: 5,\r\n paddingHorizontal: 15,\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n },\r\n icon: {\r\n marginRight: 10, // Espaço entre ícone e input\r\n },\r\n input: {\r\n marginHorizontal: 0,\r\n marginVertical: 0,\r\n height: 40,\r\n flex: 1, // Para o input ocupar o espaço restante\r\n },\r\n});\r\n","import React, { useRef, useState } from 'react';\r\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport UIChildren from '../UIChildren';\r\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\r\nimport { useIsVisible } from '../../hooks/useIsVisible';\r\n\r\ninterface UIListRowType extends ChildType {\r\n item: any;\r\n index: number;\r\n}\r\n\r\nexport default function UIListRow(props: UIListRowType) {\r\n const scope = props.scope;\r\n const index = props.index;\r\n const original = scope.original;\r\n const item = props.item;\r\n const cols = scope.getPart('cols', undefined, -1);\r\n const rowWidth = Math.floor(100 / cols) + '%';\r\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\r\n const name = `${scope.key('row', index, '')}`;\r\n const [row] = useState(\r\n ScopeUtils.create({\r\n ...original,\r\n parent: scope,\r\n name,\r\n crud: scope.crud,\r\n index,\r\n type: 'row',\r\n data: item,\r\n })\r\n );\r\n\r\n //v5\r\n const targetRef = useRef(null);\r\n const isVisible = useIsVisible(targetRef, row);\r\n\r\n const onClick = (item: any) => {\r\n row.call('click', { value: item, item, edit: true, index });\r\n };\r\n\r\n const Child = () => {\r\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\r\n return <></>;\r\n }\r\n return (\r\n <>\r\n <UIChildren transient scope={row} crud={row.crud}>\r\n {props.children}\r\n </UIChildren>\r\n </>\r\n );\r\n };\r\n\r\n const ListItem = () => {\r\n let [updateIndex, setUpdateIndex] = useState(0);\r\n let key = scope.key('item');\r\n\r\n row.selected = row.getPart('isSelectedRow', undefined, false);\r\n\r\n const getRowStyle = () => {\r\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\r\n\r\n if (row.selected) {\r\n css = { ...css, ...row.getStyle('rowSelected', {}) };\r\n } else {\r\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\r\n }\r\n\r\n if (cols > 0) {\r\n css.width = rowWidth;\r\n }\r\n\r\n return css;\r\n };\r\n\r\n row.update = () => {\r\n scope.updateIndex = scope.updateIndex + 1;\r\n\r\n setUpdateIndex(++updateIndex);\r\n };\r\n\r\n let renderedRow = row.getPart('renderedItem', undefined, true);\r\n\r\n if (renderedRow === false) {\r\n return <></>;\r\n }\r\n\r\n if (!original.click) {\r\n return (\r\n <View key={key} style={getRowStyle()} ref={targetRef}>\r\n <Child />\r\n </View>\r\n );\r\n }\r\n return (\r\n <TouchableHighlight\r\n key={key}\r\n style={getRowStyle()}\r\n underlayColor={'transparent'}\r\n ref={targetRef}\r\n onPress={e => {\r\n e.stopPropagation();\r\n onClick(item);\r\n }}\r\n >\r\n <Child />\r\n </TouchableHighlight>\r\n );\r\n };\r\n\r\n return <ListItem />;\r\n}\r\n\r\nconst stylesList = StyleSheet.create({\r\n row: {\r\n padding: 5,\r\n margin: 0,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n gap: 10,\r\n borderRadius: 8,\r\n justifyContent: 'center',\r\n },\r\n});\r\n\r\nconst stylesRepeat = StyleSheet.create({\r\n row: {\r\n padding: 0,\r\n width: '100%',\r\n justifyContent: 'center',\r\n },\r\n});\r\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';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, View } from 'react-native';\r\nimport UIListRow from './UIListRow';\r\nimport UI from '../UI';\r\nimport { Ionicons } from '@expo/vector-icons';\r\n\r\nexport default function UIList(props: ChildType) {\r\n const scope = props.scope;\r\n const crud = scope.crud;\r\n const original = scope.original;\r\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\r\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\r\n const add = ComponentUtils.getDefine(props, 'add');\r\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\r\n const hideEmpty = original.hideEmpty;\r\n\r\n //v2\r\n const getStyle = (key: string, extra?: any) => {\r\n return scope.getStyle(key, { ...extra, ...styles[key] });\r\n };\r\n\r\n const getContainerStyle = (extra?: any) => {\r\n let row = getStyle('container', {});\r\n\r\n if (cols > 1) {\r\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\r\n }\r\n\r\n return row;\r\n };\r\n\r\n const LocalData = () => {\r\n let [index, setIndex] = useState(scope.updateIndex);\r\n let empty = scope.attr('empty', 'Sem registro');\r\n\r\n scope.update = () => {\r\n scope.updateIndex = ++index;\r\n\r\n setIndex(index);\r\n };\r\n\r\n const items = Utils.call(() => {\r\n let list = Utils.nvl(scope.getItems(), []);\r\n\r\n if (original.search !== false && !original.list?.url) {\r\n let query = crud\r\n .get('query', '')\r\n .toLowerCase()\r\n .trim() as string;\r\n\r\n if (query.length > 1) {\r\n let filters: any[] = [];\r\n let filterBy = Utils.nvl(original.filterBy, 'label');\r\n\r\n Utils.each(list, o => {\r\n let label = Utils.getValue(filterBy, 'none', o).toLowerCase();\r\n\r\n if (label) {\r\n if (label.includes(query)) {\r\n filters.push(o);\r\n }\r\n }\r\n });\r\n\r\n return filters;\r\n }\r\n }\r\n return list;\r\n });\r\n\r\n let isEmpty = Utils.isEmpty(items);\r\n\r\n const isShowAdd = () => {\r\n if (!isEmpty) {\r\n return true;\r\n }\r\n return hideAddWhenEmpty !== true;\r\n };\r\n\r\n let Empty = () => {\r\n if (!isEmpty) {\r\n return <></>;\r\n }\r\n\r\n if (!empty) {\r\n return <></>;\r\n }\r\n\r\n if (typeof empty === 'string') {\r\n return (\r\n <Text\r\n style={scope.getStyle('empty', {\r\n flex: 1,\r\n fontWeight: 400,\r\n fontSize: 18,\r\n padding: 10,\r\n textAlign: 'center',\r\n width: '100%',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n })}\r\n >\r\n {empty}\r\n </Text>\r\n );\r\n }\r\n\r\n return <>{empty}</>;\r\n };\r\n\r\n if (empty === false && isEmpty) {\r\n return <></>;\r\n }\r\n\r\n return (\r\n <View style={getContainerStyle()}>\r\n <Empty />\r\n {items.map((item: any, i: number) => (\r\n <UIListRow index={i} item={item} scope={scope}>\r\n {props.children}\r\n </UIListRow>\r\n ))}\r\n {isShowAdd() && <>{add}</>}\r\n </View>\r\n );\r\n };\r\n\r\n let items = Utils.nvl(scope.getItems(), []);\r\n\r\n if (hideEmpty && Utils.isEmpty(items)) {\r\n return <></>;\r\n }\r\n\r\n return (\r\n <>\r\n {original.search !== false && (\r\n <UI.Text\r\n placeholder=\"Pesquisar...\"\r\n field=\"query\"\r\n crud={crud}\r\n style={{ marginBottom: 10 }}\r\n change={{\r\n action: () => {\r\n scope.search();\r\n },\r\n }}\r\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\r\n />\r\n )}\r\n <LocalData />\r\n </>\r\n );\r\n}\r\n\r\nconst stylesList = StyleSheet.create({\r\n container: {\r\n display: 'flex',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n width: '100%',\r\n },\r\n text: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n },\r\n});\r\n\r\nconst stylesRepeat = StyleSheet.create({\r\n container: {\r\n display: 'flex',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n width: '100%',\r\n },\r\n text: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n },\r\n});\r\n","import React, { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\r\nimport UIListRow from './UIListRow';\r\n\r\nexport default function UIToggle(props: ChildType) {\r\n const scope = props.scope;\r\n const options = Utils.nvl(scope.getOptions(), []);\r\n const value = scope.getInputValue();\r\n\r\n let [index, setIndex] = useState(0);\r\n\r\n const isSelected = (item: any) => {\r\n return item?.value === value;\r\n };\r\n\r\n const onClick = (item: any) => {\r\n scope.changeValue(item.object);\r\n setIndex(++index);\r\n };\r\n\r\n const Item = ({ item, index }) => {\r\n let selected = isSelected(item);\r\n let style: any = { ...styles.text };\r\n\r\n if (selected) style.color = '#ffffff';\r\n\r\n if (Utils.isEmpty(props.children)) {\r\n return <Text style={style}>{item.label}</Text>;\r\n }\r\n\r\n return (\r\n <UIListRow scope={scope} item={item.object} index={index}>\r\n {props.children}\r\n </UIListRow>\r\n );\r\n };\r\n\r\n const getItemStyle = (item: any) => {\r\n let style = { ...styles.item, ...scope.getStyle('item') };\r\n\r\n let wPart = 100 / options.length;\r\n let width = Math.floor(wPart) + '%';\r\n\r\n if (isSelected(item)) {\r\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\r\n let st = scope.getStyle('selected', {\r\n backgroundColor: selectedColor,\r\n color: '#ffffff',\r\n });\r\n\r\n style = { ...style, ...st };\r\n\r\n if (!style.color) {\r\n style.color = '#ffffff';\r\n }\r\n }\r\n\r\n style.width = width;\r\n\r\n return style;\r\n };\r\n\r\n return (\r\n <>\r\n {options.map((item: any, i: number) => (\r\n <TouchableHighlight\r\n key={`k-${i}`}\r\n style={getItemStyle(item)}\r\n onPress={e => {\r\n onClick(item);\r\n }}\r\n >\r\n <Item item={item} index={i} />\r\n </TouchableHighlight>\r\n ))}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n container: {\r\n flex: 1,\r\n width: '100%',\r\n gap: 10,\r\n justifyContent: 'center',\r\n flexDirection: 'row',\r\n },\r\n item: {\r\n padding: 10,\r\n marginVertical: 8,\r\n backgroundColor: 'background',\r\n borderRadius: 8,\r\n justifyContent: 'center',\r\n width: 'auto',\r\n flexDirection: 'row',\r\n },\r\n text: {\r\n fontSize: 15,\r\n fontWeight: '500',\r\n },\r\n});\r\n","import { Ionicons } from '@expo/vector-icons';\r\nimport { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Text, TouchableHighlight, View } from 'react-native';\r\n\r\nexport default function UIQuantity(props: ChildType) {\r\n const scope = props.scope;\r\n const element = scope.original;\r\n\r\n let [index, setIndex] = useState(0);\r\n\r\n const value = scope.getValue(0);\r\n\r\n let color = element.color;\r\n\r\n if (!color) color = 'primary';\r\n\r\n const btn = {\r\n padding: 0,\r\n alignItems: 'center',\r\n height: 30,\r\n width: 30,\r\n textAlign: 'center',\r\n verticalAling: 'middle',\r\n borderRadius: 24,\r\n backgroundColor: color,\r\n color: '#ffffff',\r\n justifyContent: 'center',\r\n };\r\n\r\n const styles: any = {\r\n buttonLabel: {\r\n color: '#ffffff',\r\n fontWeight: '500',\r\n fontSize: 16,\r\n },\r\n value: {\r\n flex: 1,\r\n flexDirection: 'row',\r\n textAlign: 'center',\r\n fontWeight: '500',\r\n },\r\n buttonInner: {\r\n flexDirection: 'row',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n },\r\n buttonIcon: {\r\n color: '#fff',\r\n fontSize: 18,\r\n },\r\n button: btn,\r\n addButton: {\r\n ...btn,\r\n },\r\n delButton: {\r\n ...btn,\r\n },\r\n };\r\n\r\n const change = (val: number) => {\r\n scope.changeValue(value + val);\r\n setIndex(++index);\r\n };\r\n\r\n const onClickAdd = () => {\r\n change(1);\r\n };\r\n\r\n const onClickDel = () => {\r\n change(-1);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let s = { ...styles[part], ...extra };\r\n return scope.getStyle(part, s);\r\n };\r\n\r\n return (\r\n <>\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClickDel}\r\n style={style('delButton')}\r\n >\r\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\r\n </TouchableHighlight>\r\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClickAdd}\r\n style={style('addButton')}\r\n >\r\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\r\n </TouchableHighlight>\r\n </>\r\n );\r\n}\r\n","import { StyleSheet } from 'react-native';\r\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\r\n\r\nexport default function UIToast() {\r\n const toastConfig = {\r\n success: props => (\r\n <BaseToast\r\n {...props}\r\n style={styles.darkToast}\r\n contentContainerStyle={{ paddingHorizontal: 15 }}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n error: props => (\r\n <ErrorToast\r\n {...props}\r\n style={styles.darkToast}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n info: props => (\r\n <BaseToast\r\n {...props}\r\n style={styles.darkToast}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n };\r\n\r\n const styles = StyleSheet.create({\r\n darkToast: {\r\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\r\n borderLeftColor: '#222', // borda mais escura\r\n },\r\n text: {\r\n color: '#fff', // letras brancas\r\n textAlign: 'center',\r\n },\r\n });\r\n return <Toast config={toastConfig} />;\r\n}\r\n","import { useRef, useState } from 'react';\r\nimport {\r\n ChildType,\r\n ComponentUtils,\r\n CrudUtils,\r\n MethodType,\r\n Utils,\r\n ViewUtils,\r\n} from 'react-crud-utils';\r\nimport {\r\n Text,\r\n TouchableOpacity,\r\n StyleSheet,\r\n Modal,\r\n View,\r\n SafeAreaView,\r\n ScrollView,\r\n} from 'react-native';\r\nimport UIChildren from '../UIChildren';\r\nimport Ionicons from '@expo/vector-icons/Ionicons';\r\nimport UIToast from './UIToast';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\n\r\ninterface UIModalType extends ChildType {\r\n open?: boolean;\r\n dialog?: any;\r\n}\r\n\r\nexport default function UIModal(props: UIModalType) {\r\n const scrollRef = useRef(null);\r\n\r\n let owner = props.scope;\r\n let [index, setIndex] = useState(0);\r\n let dialog = owner.currentDialog;\r\n //v2\r\n\r\n let curr = dialog?.crud;\r\n\r\n if (!dialog) {\r\n return <></>;\r\n }\r\n\r\n dialog.update = () => {\r\n setIndex(++index);\r\n };\r\n\r\n if (dialog.debug) console.log(dialog);\r\n\r\n //const modalVisible = curr.uuid === main.dialog?.crud?.uuid;\r\n const scope = dialog.scope;\r\n const label = scope.getLabel();\r\n const theme = scope.getTheme();\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\r\n const bottom = ComponentUtils.getDefine(props, 'bottom');\r\n\r\n const style = (part: string, extra?: any) => {\r\n let st = { ...styles[part], ...extra };\r\n\r\n return { ...scope.getStyle(part, st) };\r\n };\r\n\r\n const onClose = () => {\r\n scope.close({ scope, crud: dialog?.crud, event: {} });\r\n };\r\n\r\n scope.put('scrollRef', scrollRef);\r\n\r\n const original = owner.original;\r\n\r\n ComponentUtils.setViewScope(scope);\r\n\r\n let color = Utils.nvl(headerStyle.color, 'white');\r\n let defaults = { color };\r\n let key = `${curr.name}-${index}`;\r\n\r\n let ModalContent = ({ children }) => {\r\n let disableScroll = scope.part('disableScroll', false);\r\n let disableContent = scope.part('disableContent', false);\r\n\r\n if (disableContent) {\r\n return <>{children}</>;\r\n }\r\n\r\n if (disableScroll) {\r\n return <View style={style('modalContent')}>{children}</View>;\r\n }\r\n return (\r\n <ScrollView\r\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\r\n style={style('modalContent')}\r\n nestedScrollEnabled={true}\r\n ref={scrollRef}\r\n >\r\n {children}\r\n </ScrollView>\r\n );\r\n };\r\n\r\n const ModalView = ({ children }) => {\r\n if (original.gesture) {\r\n return (\r\n <GestureHandlerRootView\r\n style={{\r\n flex: 1,\r\n }}\r\n >\r\n {children}\r\n </GestureHandlerRootView>\r\n );\r\n }\r\n return <>{children}</>;\r\n };\r\n\r\n const ModalInner = () => {\r\n let Content = () => {\r\n if (dialog?.component) {\r\n let cprops = dialog.props;\r\n let Aux = dialog.component;\r\n\r\n return <Aux key={curr.uuid} crud={curr} {...cprops} />;\r\n }\r\n\r\n return (\r\n <UIChildren scope={scope} crud={curr}>\r\n {props.children}\r\n </UIChildren>\r\n );\r\n };\r\n\r\n let content = <Content />;\r\n\r\n if (original.transient) {\r\n return <View style={style('modalSafe')}>{content}</View>;\r\n }\r\n\r\n return (\r\n <>\r\n <SafeAreaView style={style('modalTop')} />\r\n <SafeAreaView style={style('modalSafe')}>\r\n <View style={scope.getStyle('header', headerStyle)}>\r\n <TouchableOpacity\r\n onPress={onClose}\r\n style={style('modalCloseButton')}\r\n >\r\n <Ionicons\r\n name=\"chevron-back-outline\"\r\n size={24}\r\n color={color}\r\n style={style('modalCloseText', defaults)}\r\n />\r\n </TouchableOpacity>\r\n <Text style={style('modalTitle', defaults)}>{label}</Text>\r\n {!Utils.isEmpty(headerRight) && (\r\n <UIChildren scope={scope} crud={curr} transient>\r\n {headerRight}\r\n </UIChildren>\r\n )}\r\n </View>\r\n <ModalContent>{content}</ModalContent>\r\n {bottom}\r\n </SafeAreaView>\r\n <UIToast />\r\n </>\r\n );\r\n };\r\n return (\r\n <ModalView>\r\n <Modal\r\n key={key}\r\n animationType=\"slide\"\r\n transparent={true}\r\n visible={true}\r\n onRequestClose={onClose}\r\n >\r\n <ModalInner />\r\n </Modal>\r\n </ModalView>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n modalTop: {\r\n backgroundColor: 'primary',\r\n width: '100%',\r\n },\r\n modalSafe: {\r\n flex: 1,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n },\r\n modalCloseButton: {\r\n padding: 10,\r\n },\r\n modalCloseText: {\r\n fontSize: 18,\r\n color: 'white',\r\n },\r\n modalTitle: {\r\n fontSize: 22,\r\n fontWeight: 600,\r\n marginLeft: 10,\r\n },\r\n modalContent: {\r\n flex: 1,\r\n backgroundColor: 'background',\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n },\r\n});\r\n","import { Text, View } from 'react-native';\r\n\r\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIHeader({ scope }: ChildType) {\r\n const theme = scope.getTheme();\r\n const header = scope.getPart('header', null, []);\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\r\n\r\n let headerStyleFull = Utils.call(() => {\r\n let css = scope.getStyle('header', headerStyle);\r\n let bg = css.backgroundColor;\r\n\r\n if (bg) {\r\n css.color = HtmlUtils.getTextColor(bg);\r\n }\r\n return css;\r\n });\r\n\r\n let hasHeader = !Utils.isEmpty(header);\r\n let AuxHeader = () => {\r\n if (typeof header === 'string') {\r\n return <Text style={headerTextStyle}>{header}</Text>;\r\n }\r\n return <>{header}</>;\r\n };\r\n\r\n return (\r\n <>\r\n {hasHeader && (\r\n <View style={headerStyleFull}>\r\n <AuxHeader />\r\n </View>\r\n )}\r\n </>\r\n );\r\n}\r\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\r\n\r\nimport UIChildren from '../UIChildren';\r\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\r\nimport { useRef } from 'react';\r\nimport UIToast from './UIToast';\r\nimport UIHeader from './UIHeader';\r\n\r\nexport default function UIView({ scope, children }: ChildType) {\r\n const scrollRef = useRef(null);\r\n const original = scope.original;\r\n\r\n const onScroll = () => {\r\n const crud = ViewUtils.getCrud();\r\n\r\n Utils.each(crud.scroll, s => {\r\n if (s.onScroll) {\r\n s.onScroll.call(s);\r\n }\r\n });\r\n };\r\n\r\n //v3\r\n scope.put('scrollRef', scrollRef);\r\n\r\n ComponentUtils.setViewScope(scope);\r\n\r\n let Container = () => {\r\n if (original.scroll === false) {\r\n return <UIChildren scope={scope}>{children}</UIChildren>;\r\n }\r\n\r\n return (\r\n <View style={scope.getStyle('container', styles.container)}>\r\n <ScrollView\r\n onScroll={onScroll}\r\n scrollEventThrottle={16}\r\n ref={scrollRef}\r\n nestedScrollEnabled={true}\r\n keyboardShouldPersistTaps=\"handled\"\r\n contentContainerStyle={scope.getStyle('contentContainer', {\r\n paddingBottom: 50,\r\n })}\r\n style={scope.getStyle('scroll', styles.scroll)}\r\n >\r\n <UIChildren scope={scope}>{children}</UIChildren>\r\n </ScrollView>\r\n </View>\r\n );\r\n };\r\n return (\r\n <>\r\n <UIHeader scope={scope} />\r\n <Container />\r\n <UIToast /> {/* <- este componente precisa estar aqui */}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n scroll: {\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n },\r\n container: {},\r\n view: {},\r\n});\r\n","import React, { useState } from 'react';\r\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, TouchableOpacity, View } from 'react-native';\r\nimport UI from '../UI';\r\nimport { Ionicons, MaterialCommunityIcons } from '@expo/vector-icons';\r\nimport DraggableFlatList, {\r\n ScaleDecorator,\r\n} from 'react-native-draggable-flatlist';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\nimport UIHeader from './UIHeader';\r\nimport UIChildren from '../UIChildren';\r\n\r\nexport default function UIOrder(props: ChildType) {\r\n const scope = props.scope;\r\n const crud = scope.crud;\r\n const original = scope.original;\r\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\r\n\r\n const getStyle = (key: string, extra?: any) => {\r\n return scope.getStyle(key, { ...extra, ...styles[key] });\r\n };\r\n\r\n const getContainerStyle = (extra?: any) => {\r\n let row = getStyle('container', {});\r\n\r\n if (cols > 1) {\r\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\r\n }\r\n\r\n return row;\r\n };\r\n\r\n const items = Utils.call(() => {\r\n let list = Utils.nvl(scope.getItems(), []);\r\n\r\n if (original.search && !original.list?.url) {\r\n let query = crud\r\n .get('query', '')\r\n .toLowerCase()\r\n .trim() as string;\r\n\r\n if (query.length > 1) {\r\n let filters: any[] = [];\r\n let filterBy = Utils.nvl(original.filterBy, 'label');\r\n\r\n Utils.each(list, o => {\r\n let label = o[filterBy];\r\n\r\n if (label) {\r\n if (label.includes(query)) {\r\n filters.push(o);\r\n }\r\n }\r\n });\r\n\r\n return filters;\r\n }\r\n }\r\n return list;\r\n });\r\n\r\n //v2\r\n\r\n const renderItem = ({ item, drag, isActive, getIndex }) => {\r\n const index = getIndex();\r\n const name = `${scope.key('row', index, '')}`;\r\n const [row] = useState(\r\n ScopeUtils.create({\r\n ...original,\r\n parent: scope,\r\n name,\r\n crud: scope.crud,\r\n index,\r\n type: 'row',\r\n data: item,\r\n })\r\n );\r\n\r\n let css = { ...scope.getStyle('row') };\r\n\r\n if (isActive) {\r\n css = { ...css, ...scope.getStyle('active') };\r\n }\r\n\r\n if (isActive) {\r\n css = { ...css, ...row.getStyle('rowSelected', {}) };\r\n } else {\r\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\r\n }\r\n const Child = () => {\r\n if (Utils.isEmpty(props.children)) {\r\n return (\r\n <>\r\n <MaterialCommunityIcons name=\"drag\" size={24} color=\"black\" />\r\n <Text style={styles.text}>{scope.getItemLabel(item)}</Text>\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n <UIChildren transient scope={row} crud={row.crud}>\r\n {props.children}\r\n </UIChildren>\r\n </>\r\n );\r\n };\r\n return (\r\n <ScaleDecorator>\r\n <TouchableOpacity\r\n style={[\r\n styles.row,\r\n { backgroundColor: isActive ? 'lightblue' : 'white' },\r\n { ...css },\r\n ]}\r\n delayLongPress={100}\r\n onLongPress={drag} // Initiate drag on long press\r\n >\r\n <Child />\r\n </TouchableOpacity>\r\n </ScaleDecorator>\r\n );\r\n };\r\n\r\n const OrderView = ({ children }) => {\r\n if (original.gesture !== false) {\r\n return (\r\n <GestureHandlerRootView\r\n style={{\r\n flex: 1,\r\n width: '100%',\r\n ...scope.getStyle('order', { justifyContent: 'flex-start' }),\r\n }}\r\n >\r\n {children}\r\n </GestureHandlerRootView>\r\n );\r\n }\r\n return <>{children}</>;\r\n };\r\n\r\n const Header = ({ pos }) => {\r\n const hPos = Utils.nvl(original.headerPos, 'outer');\r\n\r\n if (hPos !== pos) return <></>;\r\n\r\n return <UIHeader scope={scope} />;\r\n };\r\n\r\n let OrderData = () => {\r\n const [data, setData] = useState(items);\r\n\r\n return (\r\n <DraggableFlatList\r\n data={data}\r\n ListHeaderComponent={<Header pos=\"inner\" />}\r\n ListFooterComponent={<>{scope.getPart('footer')}</>}\r\n renderItem={renderItem}\r\n containerStyle={{ ...scope.getStyle('list') }}\r\n keyExtractor={item => {\r\n let key = scope.getItemValue(item);\r\n\r\n if (original?.debug) {\r\n console.log(key);\r\n }\r\n return key;\r\n }}\r\n onDragEnd={({ data }) => {\r\n setData(data);\r\n scope.changeValue(data);\r\n }}\r\n />\r\n );\r\n };\r\n return (\r\n <OrderView>\r\n <Header pos=\"outer\" />\r\n <OrderData />\r\n </OrderView>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n row: {\r\n flexDirection: 'row',\r\n gap: 10,\r\n padding: 15,\r\n borderBottomWidth: 1,\r\n borderBottomColor: '#ccc',\r\n },\r\n text: {\r\n fontSize: 18,\r\n },\r\n});\r\n","import React, {\r\n createContext,\r\n useContext,\r\n useEffect,\r\n useLayoutEffect,\r\n useRef,\r\n useState,\r\n} from 'react';\r\nimport UIChildren from './UIChildren';\r\nimport ElTabs from './tabs/ElTabs';\r\nimport ElChart from './charts/ElChart';\r\nimport UIComplete from './UIComplete';\r\nimport {\r\n Crud,\r\n HtmlUtils,\r\n ScopeUtils,\r\n Utils,\r\n ElementType,\r\n MethodType,\r\n ActionType,\r\n ComponentUtils,\r\n CrudUtils,\r\n ViewUtils,\r\n Scope,\r\n} from 'react-crud-utils';\r\nimport UILink from './core/UILink';\r\nimport UIIcon from './core/UIIcon';\r\nimport UIButton from './core/UIButton';\r\nimport UISelect from './core/UISelect';\r\nimport UISwitch from './core/UISwitch';\r\nimport UISlider from './core/UISlider';\r\nimport UIOption from './core/UIOption';\r\nimport UIRadio from './core/UIRadio';\r\nimport UIInput from './core/UIInput';\r\nimport {\r\n Alert,\r\n Image,\r\n Linking,\r\n StyleSheet,\r\n Text,\r\n TouchableHighlight,\r\n View,\r\n} from 'react-native';\r\nimport UIList from './core/UIList';\r\nimport UIToggle from './core/UIToggle';\r\nimport UIQuantity from './core/UIQuantity';\r\nimport UIModal from './core/UIModal';\r\nimport { Ionicons } from '@expo/vector-icons';\r\nimport UIView from './core/UIView';\r\nimport Toast from 'react-native-toast-message';\r\nimport UIOrder from './core/UIOrder';\r\n\r\nconst CrudContext = createContext<any>({});\r\n\r\nexport default function UIElement(props: ElementType) {\r\n const ctx = useContext(CrudContext);\r\n const theme = Utils.nvl(props.theme, ctx?.theme);\r\n\r\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\r\n let [scope] = useState<Scope>(ScopeUtils.create({ crud, ...props, theme }));\r\n let [index, setIndex] = useState(0);\r\n let [error, setError]: string | any = useState(null);\r\n\r\n scope.compile(props);\r\n\r\n crud = scope.crud;\r\n\r\n let options: any = scope.getOptions();\r\n\r\n let original = scope.original;\r\n let ref = useRef(null);\r\n\r\n scope.update = () => {\r\n setIndex(++index);\r\n };\r\n\r\n scope.updateElement = () => {\r\n setIndex(++index);\r\n };\r\n\r\n scope.toast = (message: string, type = 'info', args?: any) => {\r\n Toast.show({\r\n type, // 'success' | 'error' | 'info'\r\n text1: message,\r\n position: 'bottom', // 'top' é outra opção\r\n visibilityTime: 3000, // tempo que fica visível em ms\r\n ...args,\r\n });\r\n };\r\n\r\n scope.prompt = (args: MethodType) => {\r\n let event = args.event as ActionType;\r\n\r\n if (event) {\r\n let message = 'Você tem certeza que deseja continuar?';\r\n let title = 'Atenção';\r\n let prompt = event.prompt;\r\n\r\n if (typeof prompt === 'string') {\r\n message = prompt;\r\n }\r\n\r\n if (typeof prompt === 'object') {\r\n message = Utils.nvl(prompt.message, message);\r\n title = Utils.nvl(prompt.title, title);\r\n }\r\n\r\n Alert.alert(\r\n title,\r\n message,\r\n [\r\n {\r\n text: 'Cancelar',\r\n style: 'cancel',\r\n },\r\n {\r\n text: 'Confirmar',\r\n onPress: () => scope.execute(args),\r\n },\r\n ],\r\n { cancelable: false }\r\n );\r\n }\r\n };\r\n const Custom = () => {\r\n let c: any = original.custom;\r\n\r\n if (c) {\r\n if (typeof c === 'string') {\r\n return (\r\n <UIElement\r\n element={{ value: c, type: 'dummy' }}\r\n crud={crud}\r\n ></UIElement>\r\n );\r\n }\r\n\r\n return (\r\n <UIElement\r\n type={c.type}\r\n tag={c.type}\r\n {...c.props}\r\n crud={crud}\r\n ></UIElement>\r\n );\r\n }\r\n\r\n return <></>;\r\n };\r\n\r\n if (scope.is('type', 'dummy')) {\r\n return <>{scope.getDisplayValue()}</>;\r\n }\r\n\r\n let onCheck = () => {\r\n let v = scope.getValue();\r\n let check = !(v === true);\r\n\r\n onChange({ target: { value: check } });\r\n };\r\n\r\n let onChange = (e: any) => {\r\n let val = e.target.value;\r\n\r\n if (scope.isType('integer', 'int', 'number')) {\r\n val = parseInt(val);\r\n } else if (scope.isType('decimal')) {\r\n val = parseFloat(val);\r\n }\r\n\r\n if (scope.isType('select', 'complete')) {\r\n val = scope.getSelectedItem(val);\r\n }\r\n\r\n scope.changeValue(val);\r\n scope.update();\r\n };\r\n\r\n let onClick = (e: any) => {\r\n if (scope.currentDialog?.component) return;\r\n\r\n scope.call('click');\r\n };\r\n\r\n let defaultsInput: any = {\r\n scope,\r\n crud,\r\n onChange: onChange,\r\n };\r\n\r\n if (scope.isType('password')) {\r\n defaultsInput.type = 'password';\r\n }\r\n\r\n let isChecked = () => {\r\n let v = scope.getValue();\r\n\r\n return v === true;\r\n };\r\n\r\n let hasChildren = () => {\r\n if (scope.isInput()) {\r\n return false;\r\n }\r\n\r\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\r\n };\r\n\r\n let isInput = scope.is(\r\n 'type',\r\n 'text',\r\n 'textarea',\r\n 'number',\r\n 'integer',\r\n 'int',\r\n 'phone',\r\n 'postalCode',\r\n 'money',\r\n 'password',\r\n 'email'\r\n );\r\n\r\n const getStyle = (part?: string, extra?: any) => {\r\n let type = Utils.nvl(original.type, 'none');\r\n let key = Utils.nvl(part, 'root');\r\n let def = { ...styles[key] };\r\n let hasChild = hasChildren();\r\n\r\n type = Utils.nvl(original.layout, type);\r\n\r\n if (!part && !hasChild) {\r\n def = { ...def };\r\n }\r\n\r\n if (scope.isInput()) {\r\n def = { ...def, ...elementStyle.input[key] };\r\n }\r\n\r\n def = { ...def, ...elementStyle?.[type]?.[key] };\r\n\r\n if (hasChild && part) {\r\n def = { ...def, ...withChildStyles[part] };\r\n }\r\n\r\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\r\n };\r\n\r\n let elStyle = getStyle('element');\r\n\r\n let defaultsUI: any = {\r\n required: scope.isRequired(),\r\n size: 'small',\r\n scope,\r\n crud,\r\n style: elStyle,\r\n placeholder: scope.attr('placeholder', 'Digite aqui'),\r\n };\r\n\r\n scope.error = (msg: string) => {\r\n error = msg;\r\n setError(msg);\r\n };\r\n\r\n if (!original.list?.url && !original.load?.url) {\r\n scope.start();\r\n }\r\n\r\n useEffect(() => {\r\n scope.start();\r\n });\r\n\r\n const CustomIcon = () => {\r\n if (typeof original.icon === 'string') {\r\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\r\n }\r\n return <>{original.icon}</>;\r\n };\r\n\r\n scope.open = (args: any) => {\r\n Linking.openURL(args.url);\r\n };\r\n\r\n useLayoutEffect(() => {\r\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\r\n let el: any = ref?.current;\r\n\r\n if (el?.classList) {\r\n let bg = HtmlUtils.getBGColor(el);\r\n\r\n if (bg === 'rgb(255, 255, 255)') {\r\n el.classList.add('ui-dark');\r\n } else {\r\n el.classList.add('ui-light');\r\n }\r\n }\r\n }\r\n });\r\n\r\n const isShowLabel = () => {\r\n if (\r\n typeof original.label !== 'undefined' &&\r\n original.label !== false &&\r\n !scope.isType('button', 'dialog', 'modal')\r\n ) {\r\n return true;\r\n }\r\n\r\n return false;\r\n };\r\n\r\n const isShowInner = () => {\r\n if (hasChildren()) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n\r\n if (!scope.isRendered() || scope.is('type', 'define')) {\r\n return <></>;\r\n }\r\n\r\n const isShowChild = () => {\r\n if (\r\n scope.isType(\r\n 'tabs',\r\n 'view',\r\n 'grid',\r\n 'list',\r\n 'define',\r\n 'repeat',\r\n 'modal',\r\n 'dialog',\r\n 'chart'\r\n )\r\n ) {\r\n return false;\r\n }\r\n\r\n return true;\r\n };\r\n\r\n let isTouch =\r\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\r\n let custom: any = {};\r\n\r\n if (isTouch) {\r\n custom.underlayColor = 'transparent';\r\n custom.onPress = onClick;\r\n }\r\n\r\n let Tag = (props: any) => {\r\n let Aux: any = View;\r\n\r\n if (isTouch) {\r\n Aux = TouchableHighlight;\r\n }\r\n\r\n if (scope.isType('dialog', 'order') || original.transient) {\r\n return <>{props.children}</>;\r\n }\r\n\r\n return <Aux {...props} />;\r\n };\r\n\r\n let Inner = () => {\r\n return (\r\n <>\r\n {scope.getPart('render', null, <></>)}\r\n {scope.is('type', 'button') && (\r\n <UIButton\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {original.icon && <CustomIcon />}\r\n {original.label && (\r\n <Text style={scope.getPart('label', 'button')}>\r\n {scope.getLabel()}\r\n </Text>\r\n )}\r\n </UIButton>\r\n )}\r\n {scope.is('type', 'icon') && (\r\n <UIIcon\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {scope.getDisplayValue()}\r\n </UIIcon>\r\n )}\r\n {scope.is('type', 'link') && (\r\n <UILink\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {original.icon && <CustomIcon />}\r\n {original.label && (\r\n <Text style={scope.getPart('label', 'link')}>\r\n {scope.getLabel()}\r\n </Text>\r\n )}\r\n </UILink>\r\n )}\r\n {isInput && (\r\n <UIInput\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n InputProps={{ ...original.inputProps }}\r\n />\r\n )}\r\n {scope.is('type', 'complete', 'autocomplete') && (\r\n <UIComplete\r\n scope={scope}\r\n defaultsInput={defaultsInput}\r\n defaultsUI={defaultsUI}\r\n />\r\n )}\r\n {scope.is('type', 'quantity') && (\r\n <UIQuantity\r\n scope={scope}\r\n defaultsInput={defaultsInput}\r\n defaultsUI={defaultsUI}\r\n />\r\n )}\r\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\r\n <UISwitch\r\n checked={isChecked()}\r\n {...defaultsInput}\r\n onChange={onCheck}\r\n />\r\n )}\r\n {scope.isType('slider') && (\r\n <UISlider {...defaultsInput} onChange={onCheck} />\r\n )}\r\n {scope.is('type', 'select') && (\r\n <UISelect\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n value={scope.getSelectedValue()}\r\n />\r\n )}\r\n {scope.is('type', 'toggle') && (\r\n <UIToggle\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n value={scope.getSelectedValue()}\r\n />\r\n )}\r\n {scope.is('type', 'radio') && (\r\n <UIRadio {...defaultsInput} {...defaultsUI} row>\r\n {options.map((row: any, i: number) => (\r\n <UIOption\r\n key={'i' + i}\r\n control={<UIRadio {...defaultsUI} />}\r\n label={row.label}\r\n value={row.value}\r\n />\r\n ))}\r\n </UIRadio>\r\n )}\r\n {scope.is('type', 'custom') && <Custom />}\r\n {scope.is('type', 'column') && (\r\n <>\r\n {scope.is('format', 'img') && (\r\n <Image source={scope.getDisplayValue()} />\r\n )}\r\n {scope.is('format', 'icon') && <UIIcon scope={scope} crud={crud} />}\r\n {!scope.is('format', 'icon', 'img') && (\r\n <Text>{scope.getDisplayValue()}</Text>\r\n )}\r\n </>\r\n )}\r\n {scope.is('type', 'output', 'value') && (\r\n <Text style={getStyle('value')}>{scope.getDisplayValue()}</Text>\r\n )}\r\n </>\r\n );\r\n };\r\n\r\n let Include = ({ name, style }: any) => {\r\n if (props[name]) {\r\n let define = ComponentUtils.getDefine(props, name);\r\n\r\n if (!Utils.isEmpty(define)) {\r\n return (\r\n <UIChildren\r\n {...props}\r\n scope={scope}\r\n crud={crud}\r\n style={getStyle(name, style)}\r\n >\r\n {define}\r\n </UIChildren>\r\n );\r\n }\r\n }\r\n return <></>;\r\n };\r\n\r\n let Container = () => {\r\n return (\r\n <>\r\n {isShowLabel() && (\r\n <View\r\n style={getStyle('outerLabel', {\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n display: 'flex',\r\n justifyContent: 'space-between',\r\n alignItems: 'center',\r\n width: '100%',\r\n })}\r\n >\r\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\r\n <Include name=\"actions\" style={{ width: 'auto' }} />\r\n </View>\r\n )}\r\n {isShowInner() && (\r\n <>\r\n <View style={getStyle('inner')}>\r\n <Inner />\r\n </View>\r\n {error && (\r\n <View\r\n style={getStyle('error', {\r\n fontSize: 12,\r\n paddingTop: 4,\r\n color: '#e55b5b',\r\n })}\r\n >\r\n {error}\r\n </View>\r\n )}\r\n </>\r\n )}\r\n {scope.isType('list', 'repeat') && (\r\n <UIList {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('order') && (\r\n <UIOrder {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {scope.isType('chart') && (\r\n <ElChart {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('tabs') && (\r\n <ElTabs {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {scope.isType('view') && (\r\n <UIView {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {isShowChild() && (\r\n <UIChildren\r\n {...props}\r\n scope={scope}\r\n crud={crud}\r\n style={getStyle('inner')}\r\n />\r\n )}\r\n <UIModal {...props} scope={scope} crud={crud} />\r\n </>\r\n );\r\n };\r\n\r\n let Card = (props: any) => {\r\n let isCard = scope.is('type|layout', 'card');\r\n\r\n if (scope.isType('list')) {\r\n let empty = scope.getPart('empty', null, undefined);\r\n let items = scope.getItems();\r\n\r\n if (empty === false && Utils.isEmpty(items)) {\r\n isCard = false;\r\n }\r\n }\r\n\r\n if (isCard) {\r\n let box = {\r\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\r\n };\r\n\r\n return (\r\n <View style={getStyle('card', { ...box })}>\r\n <View\r\n style={getStyle('boxInner', {\r\n paddingHorizontal: 15,\r\n paddingVertical: 10,\r\n })}\r\n >\r\n {props.children}\r\n </View>\r\n </View>\r\n );\r\n }\r\n\r\n if (scope.isInput() || original.container) {\r\n return (\r\n <View\r\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\r\n >\r\n {props.children}\r\n </View>\r\n );\r\n }\r\n return <>{props.children}</>;\r\n };\r\n\r\n scope.dialogShow = (args?: MethodType) => {\r\n let event = Utils.nvl(args?.event, {});\r\n\r\n if (event?.debug) console.log(args);\r\n\r\n let caller = args.caller;\r\n let main = ViewUtils.getCrud('view');\r\n let parent = main.dialog;\r\n let { crud } = args;\r\n let name = scope.getName('modal');\r\n let edit = args.edit === true;\r\n let def: any = {};\r\n let rowItem = null;\r\n let component = event?.component;\r\n let elo = Utils.nvl(caller?.original, original);\r\n\r\n if (crud.is('row')) {\r\n def.parent = crud.parent.parent;\r\n def.search = crud.parent;\r\n\r\n rowItem = crud.data;\r\n } else if (crud.is('search')) {\r\n def.parent = crud.parent;\r\n def.search = crud;\r\n }\r\n\r\n let crudData = crud.data;\r\n let eventData = Utils.nvl(event.data, event.send);\r\n\r\n if (typeof eventData === 'function') {\r\n eventData = eventData.call(this, args);\r\n }\r\n\r\n if (event.send === false || event.data === false) {\r\n crudData = {};\r\n }\r\n\r\n let data = Utils.nvl(eventData, args.item, rowItem, crudData, {});\r\n\r\n let d = CrudUtils.create('dialog', {\r\n parent: crud,\r\n root: crud,\r\n name,\r\n data,\r\n edit,\r\n scope,\r\n ...def,\r\n });\r\n\r\n let el: any = {\r\n label: elo.label,\r\n icon: elo.icon,\r\n type: 'dialog',\r\n };\r\n\r\n let close = event.dialog?.close;\r\n\r\n if (typeof event.dialog === 'object') {\r\n el = { ...el, ...event.dialog };\r\n }\r\n\r\n if (event.header) el.header = event.header;\r\n if (event.label) el.label = event.label;\r\n if (event.title) el.title = event.title;\r\n\r\n let label = Utils.nvl(el.title, el.label);\r\n\r\n el.label = label;\r\n\r\n let dialogScope = ScopeUtils.create({\r\n parent: scope,\r\n crud: d,\r\n ...el,\r\n owner: scope,\r\n });\r\n\r\n let dialog = {\r\n crud: d,\r\n label,\r\n parent,\r\n component,\r\n scope: dialogScope,\r\n close,\r\n props: event.props,\r\n debug: event.debug,\r\n };\r\n\r\n main.dialog = dialog;\r\n scope.currentDialog = dialog;\r\n\r\n if (parent) parent.update?.();\r\n scope.update();\r\n };\r\n\r\n scope.dialogHide = (args?: MethodType) => {\r\n let main = ViewUtils.getCrud('view');\r\n let current = main.dialog;\r\n let next = Utils.nvl(current.parent, null);\r\n\r\n main.dialog = next;\r\n scope.currentDialog = next;\r\n\r\n let nextScope = next?.scope?.parent;\r\n let currScope = current?.scope?.parent;\r\n\r\n if (currScope) {\r\n const close = current.close;\r\n\r\n currScope.update();\r\n\r\n if (close) {\r\n if (close?.debug) console.log('Fechando');\r\n current.scope.call('close', { close });\r\n }\r\n }\r\n\r\n if (nextScope) {\r\n nextScope.update();\r\n }\r\n };\r\n\r\n return (\r\n <CrudContext.Provider value={{ crud, theme }}>\r\n <Tag ref={ref} style={getStyle()} {...custom}>\r\n <Card>\r\n <Container />\r\n </Card>\r\n </Tag>\r\n </CrudContext.Provider>\r\n );\r\n}\r\n\r\nlet boxStyle = StyleSheet.create({\r\n box: {\r\n borderWidth: 0,\r\n borderColor: '#dedede',\r\n borderStyle: 'solid',\r\n backgroundColor: 'white',\r\n borderRadius: 12,\r\n width: '100%',\r\n shadowColor: '#000',\r\n shadowOpacity: 0.1,\r\n shadowRadius: 4,\r\n },\r\n});\r\n\r\nconst box: any = {\r\n ...boxStyle.box,\r\n};\r\n//v4\r\nconst elementStyle: any = {};\r\n\r\nelementStyle.view = {\r\n inner: {\r\n width: '100%',\r\n alignItems: 'normal',\r\n flex: 1,\r\n },\r\n container: {\r\n width: '100%',\r\n backgroundColor: 'background',\r\n flex: 1,\r\n gap: 10,\r\n },\r\n root: {\r\n width: '100%',\r\n flex: 1,\r\n alignItems: 'normal',\r\n padding: 0,\r\n },\r\n};\r\n\r\nelementStyle.input = StyleSheet.create({\r\n label: {\r\n paddingLeft: 0,\r\n },\r\n inner: {\r\n flex: 1,\r\n width: '100%',\r\n padding: 0,\r\n gap: 10,\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n flexWrap: 'wrap',\r\n },\r\n});\r\n\r\nelementStyle.quantity = {\r\n inner: {\r\n ...box,\r\n backgroundColor: 'primarySoft',\r\n fontWeight: 600,\r\n fontSize: 16,\r\n borderRadius: 25,\r\n borderWidth: 0,\r\n paddingHorizontal: 5,\r\n paddingVertical: 5,\r\n flexWrap: 'nowrap',\r\n flex: 1,\r\n flexDirection: 'row',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n },\r\n};\r\n\r\nelementStyle.toggle = StyleSheet.create({\r\n inner: {\r\n ...box,\r\n flex: 1,\r\n width: '100%',\r\n gap: 10,\r\n justifyContent: 'center',\r\n flexDirection: 'row',\r\n paddingHorizontal: 10,\r\n paddingVertical: 0,\r\n alignSelf: 'flex-start',\r\n flexWrap: 'nowrap',\r\n },\r\n});\r\n\r\nconst styles = StyleSheet.create({\r\n root: {\r\n gap: 5,\r\n flexDirection: 'column',\r\n flexWrap: 'wrap',\r\n width: '100%',\r\n alignItems: 'flex-start',\r\n },\r\n label: {\r\n fontWeight: 400,\r\n fontSize: 12,\r\n paddingVertical: 3,\r\n color: 'labelColor',\r\n },\r\n inner: { width: '100%' },\r\n});\r\n\r\nconst withChildStyles = StyleSheet.create({\r\n root: {\r\n gap: 10,\r\n },\r\n label: {\r\n width: '100%',\r\n fontWeight: 500,\r\n fontSize: 24,\r\n },\r\n});\r\n","import UIChildren from '../UIChildren';\r\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIInclude(props: DefineType) {\r\n if (props.rendered === false) {\r\n return <></>;\r\n }\r\n\r\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\r\n\r\n if (Utils.isEmpty(includes)) {\r\n includes = props.default;\r\n }\r\n\r\n if (!Utils.isEmpty(includes)) {\r\n let Aux = (tagProp: any) => {\r\n let Tag: any = props.tag;\r\n\r\n if (!Utils.isEmpty(Tag)) {\r\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\r\n }\r\n return <>{tagProp.children}</>;\r\n };\r\n\r\n return (\r\n <Aux {...props.tagProps}>\r\n <UIChildren\r\n transient\r\n {...props}\r\n scope={props.scope}\r\n crud={props.crud}\r\n part={props.name}\r\n >\r\n {includes}\r\n </UIChildren>\r\n </Aux>\r\n );\r\n }\r\n return <>{includes}</>;\r\n}\r\n","import {\r\n ListType,\r\n UserType,\r\n InputType,\r\n ChartType,\r\n ContainerType,\r\n ListInputType,\r\n TabsType,\r\n DefineType,\r\n ButtonType,\r\n IconType,\r\n LinkType,\r\n SliderType,\r\n} from 'react-crud-utils';\r\nimport UIElement from './UIElement';\r\n\r\nimport UIInclude from './core/UIInclude';\r\nimport SafeView from './core/SafeView';\r\nimport GestureView from './core/GestureView';\r\n\r\nconst UI = {\r\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\r\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\r\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\r\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\r\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\r\n Repeat: (props: ListType) => (\r\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\r\n ),\r\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\r\n Include: (props: DefineType) => <UIInclude {...props} />,\r\n Column: ({ type = 'column', ...props }: UserType) => (\r\n <UIElement {...props} type=\"column\" />\r\n ),\r\n Input: (props: InputType) => <UIElement {...props} />,\r\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\r\n Textarea: (props: InputType) => <UIElement {...props} type=\"textarea\" />,\r\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\r\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\r\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\r\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\r\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\r\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\r\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\r\n View: (props: ContainerType) => (\r\n <UIElement {...props} type=\"view\" transient />\r\n ),\r\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\r\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\r\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\r\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\r\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\r\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\r\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\r\n Step: (props: ContainerType) => (\r\n <UIElement {...props} type=\"tab\" layout=\"step\" />\r\n ),\r\n Stepper: (props: TabsType) => (\r\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\r\n ),\r\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\r\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\r\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\r\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\r\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\r\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\r\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\r\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\r\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\r\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\r\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\r\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\r\n Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\r\n SafeView: SafeView,\r\n GestureView: GestureView,\r\n};\r\nexport default UI;\r\n","import {\r\n Keyboard,\r\n KeyboardAvoidingView,\r\n Platform,\r\n StatusBar,\r\n StyleProp,\r\n TouchableWithoutFeedback,\r\n ViewStyle,\r\n} from 'react-native';\r\nimport {\r\n SafeAreaProvider,\r\n SafeAreaView as SafeAreaContextView,\r\n} from 'react-native-safe-area-context';\r\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function SafeView(props: SafeViewType) {\r\n let theme = ThemeUtils.getCurrentTheme();\r\n //v2\r\n\r\n if (Utils.isEmpty(theme)) {\r\n theme = useTheme();\r\n }\r\n\r\n const dismissKeyboard = () => {\r\n if (Platform.OS !== 'web') {\r\n Keyboard.dismiss();\r\n }\r\n };\r\n\r\n return (\r\n <SafeAreaProvider>\r\n <SafeAreaContextView\r\n style={{\r\n backgroundColor: theme.colors?.theme,\r\n ...props.viewStyle,\r\n flex: 1,\r\n }}\r\n >\r\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\r\n <KeyboardAvoidingView\r\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\r\n style={{\r\n flex: 1, // 🔹 Ocupa 100% da tela\r\n justifyContent: 'flex-start',\r\n }}\r\n >\r\n <TouchableWithoutFeedback\r\n onPress={dismissKeyboard}\r\n accessible={false}\r\n >\r\n <>{props.children}</>\r\n </TouchableWithoutFeedback>\r\n </KeyboardAvoidingView>\r\n </SafeAreaContextView>\r\n </SafeAreaProvider>\r\n );\r\n}\r\n","import { StyleProp, ViewStyle } from 'react-native';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function GestureView(props: SafeViewType) {\r\n return (\r\n <GestureHandlerRootView style={{ flex: 1 }}>\r\n {props.children}\r\n </GestureHandlerRootView>\r\n );\r\n}\r\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","BUTTONS_SIZE","small","minWidth","height","UIButton","size","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","fontSize","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","iconSize","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","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","CustomIcon","defs","textarea","multiline","textAlignVertical","numberOfLines","inputProps","TextInput","onChangeText","base","alignSelf","flexWrap","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","isVisible","setIsVisible","useEffect","interval","setInterval","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","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","renderItem","drag","isActive","getIndex","getItemLabel","ScaleDecorator","delayLongPress","onLongPress","Header","_ref3","pos","headerPos","OrderData","setData","DraggableFlatList","ListHeaderComponent","ListFooterComponent","containerStyle","keyExtractor","getItemValue","onDragEnd","_ref4","borderBottomWidth","borderBottomColor","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","_scope$currentDialog","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","open","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Aux","Inner","InputProps","checked","getSelectedValue","control","Image","source","define","Card","isCard","box","boxStyle","dialogShow","caller","main","rowItem","elo","crudData","eventData","send","_this","d","root","_event$dialog","dialogHide","next","nextScope","_next$scope","currScope","_current$scope","Provider","shadowColor","shadowOpacity","shadowRadius","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Textarea","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","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';\r\nimport UIElement from './UIElement';\r\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, View } from 'react-native';\r\n\r\ninterface UIChildrenType {\r\n scope: Scope;\r\n crud?: Crud;\r\n validateScope?: String;\r\n children?: any;\r\n elements?: any;\r\n transient?: boolean;\r\n part?: string;\r\n style?: any;\r\n childProps?: any;\r\n}\r\n\r\nexport default function UIChildren(props: UIChildrenType) {\r\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\r\n let crud = Utils.nvl(props.crud, scope.crud);\r\n let validateScope = Utils.nvl(props.validateScope, 'global');\r\n let name = Utils.nvl(props.part, 'child');\r\n\r\n if (scope.isInput()) {\r\n return <></>;\r\n }\r\n\r\n let Paint = ({ child }: any) => {\r\n if (!child) {\r\n return <></>;\r\n }\r\n if (typeof child === 'string') {\r\n return <>{child}</>;\r\n }\r\n\r\n let Custom = child.type;\r\n let pps = { ...child.props };\r\n\r\n delete pps.children;\r\n\r\n if (typeof Custom === 'string') {\r\n if (Utils.isEmpty(child.props.children)) {\r\n return <Custom {...pps} />;\r\n }\r\n return (\r\n <Custom {...pps}>\r\n <UIChildren\r\n transient\r\n validateScope={validateScope}\r\n {...child.props}\r\n scope={scope}\r\n crud={crud}\r\n ></UIChildren>\r\n </Custom>\r\n );\r\n } else if (typeof Custom === 'function') {\r\n return (\r\n <Custom\r\n validateScope={validateScope}\r\n {...child.props}\r\n parent={scope}\r\n crud={crud}\r\n ></Custom>\r\n );\r\n }\r\n\r\n if (!Utils.isEmpty(child.props?.children)) {\r\n return (\r\n <UIChildren\r\n validateScope={validateScope}\r\n {...child.props}\r\n scope={scope}\r\n crud={crud}\r\n transient\r\n ></UIChildren>\r\n );\r\n }\r\n return <></>;\r\n };\r\n\r\n const Draw = () => {\r\n if (props.elements) {\r\n return (\r\n <>\r\n {Object.entries(props.elements).map((t: any, k) => {\r\n return <UIElement crud={crud} {...t[1]} />;\r\n })}\r\n </>\r\n );\r\n }\r\n return (\r\n <>\r\n {React.Children.map(props.children, child => {\r\n return <Paint child={child}></Paint>;\r\n })}\r\n </>\r\n );\r\n };\r\n\r\n if (props.transient) {\r\n return <Draw />;\r\n }\r\n\r\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\r\n return <></>;\r\n }\r\n\r\n const getStyle = (part?: string) => {\r\n let key = Utils.nvl(part, 'root');\r\n let def = styles[key];\r\n let css = {};\r\n\r\n if (!Utils.isEmpty(props.style)) {\r\n if (props.style?.push) {\r\n Utils.each(props.style, s => {\r\n if (s) {\r\n css = { ...css, ...s };\r\n }\r\n });\r\n } else {\r\n css = { ...props.style };\r\n }\r\n }\r\n return { ...def, ...css, ...scope.getStyle(part) };\r\n };\r\n\r\n if (props.transient) {\r\n return <Draw />;\r\n }\r\n return (\r\n <>\r\n <View style={getStyle(name)}>\r\n <Draw />\r\n </View>\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n child: { width: '100%' },\r\n inner: { width: '100%' },\r\n});\r\n","import React, { useState, useEffect } from 'react';\r\nimport UIChildren from '../UIChildren';\r\nimport UI from '../UI';\r\n\r\nimport Ionicons from '@expo/vector-icons/Ionicons';\r\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\r\n\r\nexport default function ElTabs(props: ChildType) {\r\n let scope = props.scope;\r\n let [selectedIndex, setSelectedIndex]: any = useState(0);\r\n let element = scope.original;\r\n let items = scope.getItems();\r\n let counter = 0;\r\n\r\n let tabs: any = [];\r\n let [selected, setSelected]: any = useState(null);\r\n\r\n const onChangeTab = (tab: any, validate = true) => {\r\n if (tab) {\r\n scope.execute({\r\n event: {\r\n validate,\r\n validateScope: element.validateScope,\r\n action: () => {\r\n scope.changeValue(tab.data);\r\n\r\n selected = tab;\r\n selectedIndex = tab.index;\r\n\r\n setSelectedIndex(selectedIndex);\r\n setSelected(tab);\r\n },\r\n },\r\n });\r\n }\r\n };\r\n\r\n const getStyleClass = (t: any) => {\r\n let s = 'ui-tabs-item ui-click';\r\n\r\n if (selected?.index === t.index) {\r\n s = s + ' ui-tab-selected';\r\n }\r\n return s;\r\n };\r\n\r\n const addTab = (child: any, item: any) => {\r\n let original = { ...child.props };\r\n\r\n if (!item) {\r\n item = scope.crud.data;\r\n }\r\n\r\n let crudTab = CrudUtils.create('tabs', {\r\n data: item,\r\n changed: item,\r\n parent: scope.crud,\r\n });\r\n\r\n let element = Utils.resolve(original, crudTab);\r\n\r\n if (element.rendered === false) {\r\n return;\r\n }\r\n\r\n tabs.push({\r\n ...element,\r\n child,\r\n element,\r\n original,\r\n index: counter++,\r\n data: item,\r\n });\r\n };\r\n\r\n React.Children.map(props.children, (child, index) => {\r\n if (Utils.isEmpty(items)) {\r\n addTab(child, {});\r\n } else {\r\n for (const i in items) {\r\n let o = items[i];\r\n\r\n addTab(child, o);\r\n }\r\n }\r\n });\r\n\r\n if (!selected) {\r\n onChangeTab(tabs[selectedIndex], false);\r\n }\r\n\r\n const nav = (i: any) => {\r\n let t = tabs[selectedIndex + i];\r\n\r\n onChangeTab(t);\r\n };\r\n\r\n const previous = () => {\r\n nav(-1);\r\n };\r\n\r\n const next = () => {\r\n nav(1);\r\n };\r\n\r\n let isStepper = element.layout === 'stepper';\r\n\r\n return (\r\n <div\r\n className={scope.getStyleClass('inner')}\r\n style={scope.getStyle('inner')}\r\n >\r\n <div className=\"ui-tabs-content\">\r\n <div className=\"ui-tabs-items\">\r\n {tabs.map((t: any, i: number) => (\r\n <div\r\n key={Utils.key(element.id, 'tab', i)}\r\n className={getStyleClass(t)}\r\n onClick={() => {\r\n onChangeTab(t);\r\n }}\r\n >\r\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\r\n <div className=\"ui-tab-item-inner\">\r\n {isStepper && <div className=\"ui-step-line\" />}\r\n <div className=\"ui-tab-item-label\">\r\n {isStepper ? t.index + 1 : t.label}\r\n </div>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n {selected && (\r\n <>\r\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\r\n <div className=\"ui-tabs-area\">\r\n <UIChildren {...props} scope={scope}>\r\n {selected.child}\r\n </UIChildren>\r\n </div>\r\n {element.layout === 'stepper' && (\r\n <div className=\"ui-tabs-actions\">\r\n <UI.Output space={6} layout=\"left\">\r\n <UI.Include\r\n {...props}\r\n transient\r\n name=\"left\"\r\n default={\r\n <UI.Button\r\n rendered={selectedIndex > 0}\r\n icon={<Ionicons />}\r\n click={previous}\r\n />\r\n }\r\n />\r\n </UI.Output>\r\n <UI.Output space={6} layout=\"right\">\r\n <UI.Include\r\n {...props}\r\n transient\r\n name=\"right\"\r\n default={\r\n <UI.Button\r\n rendered={selectedIndex < tabs.length - 1}\r\n icon={<Ionicons />}\r\n click={next}\r\n />\r\n }\r\n />\r\n </UI.Output>\r\n </div>\r\n )}\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n","import React from \"react\";\r\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\r\n\r\nexport default function ElChart(props: ChildType) {\r\n let scope: Scope = props.scope;\r\n let items: any = scope.getItems();\r\n let columns = Utils.asList(scope.original.columns);\r\n\r\n return <div className=\"ui-chart-data\"></div>;\r\n}\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\r\nimport AutoComplete from './core/UIAutoComplete';\r\n\r\nexport default function UIComplete({\r\n defaultsInput,\r\n defaultsUI,\r\n scope,\r\n}: ChildType) {\r\n return (\r\n <>\r\n <AutoComplete {...defaultsInput} {...defaultsUI} />\r\n </>\r\n );\r\n}\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\r\n Ionicons,\r\n MaterialCommunityIcons,\r\n AntDesign,\r\n Entypo,\r\n EvilIcons,\r\n} from '@expo/vector-icons';\r\n\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIIcon({ scope }: ChildType) {\r\n let name = scope.getValue();\r\n let libs: any = {\r\n ion: Ionicons,\r\n ant: AntDesign,\r\n entypo: Entypo,\r\n evil: EvilIcons,\r\n material: MaterialCommunityIcons,\r\n };\r\n\r\n let library = Utils.nvl(scope.original.library, 'ion');\r\n let Aux = libs[library];\r\n\r\n return <Aux name={name} style={scope.getStyle('icon')} />;\r\n}\r\n","import { Ionicons } from '@expo/vector-icons';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Text, TouchableHighlight, View } from 'react-native';\r\n\r\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\r\n\r\nexport default function UIButton(props: ChildType) {\r\n let scope = props.scope;\r\n let element = scope.original;\r\n let size = Utils.nvl(element.size, 'default');\r\n let align = Utils.nvl(element.align, 'center');\r\n let variant = Utils.nvl(element.variant, 'default');\r\n\r\n let color = element.color;\r\n let label = scope.getLabel();\r\n let icon = scope.getPart('icon');\r\n\r\n //ajuste align v5\r\n if (!color) color = 'primaryLight';\r\n\r\n const styles: any = {\r\n buttonLabel: {\r\n color: '#ffffff',\r\n fontWeight: 400,\r\n fontSize: 15,\r\n },\r\n buttonInner: {\r\n flexDirection: 'row',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n height: 44,\r\n minWidth: 44,\r\n },\r\n buttonIcon: {\r\n color: '#fff',\r\n fontSize: 16,\r\n },\r\n button: {\r\n backgroundColor: color,\r\n borderRadius: 20,\r\n gap: 10,\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n flexDirection: 'row',\r\n },\r\n };\r\n\r\n const onClick = (e: any) => {\r\n scope.call('click', {});\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let css = { ...styles[part], ...extra };\r\n\r\n if (variant === 'text' || variant === 'outlined') {\r\n css.backgroundColor = 'transparent';\r\n css.color = Utils.nvl(color, 'text');\r\n }\r\n\r\n if (size === 'small') {\r\n css.fontSize = 12;\r\n css.fontWeight = 500;\r\n }\r\n\r\n if (size === 'medium') {\r\n css.fontSize = 14;\r\n css.fontWeight = 500;\r\n }\r\n\r\n if (align === 'left') {\r\n css.justifyContent = 'flex-start';\r\n }\r\n\r\n return scope.getStyle(part, css);\r\n };\r\n\r\n let extra: any = {};\r\n\r\n if (icon) {\r\n extra.button = { height: 40, padding: 0 };\r\n } else {\r\n extra.button = { height: 50 };\r\n }\r\n\r\n const buttonStyle = Utils.call(() => {\r\n let def: any = { ...extra?.button };\r\n\r\n if (variant === 'outlined') {\r\n def.borderWidth = 1;\r\n def.borderColor = Utils.nvl(color, 'text');\r\n }\r\n\r\n if (size) {\r\n def = { ...def, ...BUTTONS_SIZE[size] };\r\n }\r\n\r\n if (!label) {\r\n def = { ...def, borderRadius: 20 };\r\n }\r\n\r\n let css = style('button', def);\r\n\r\n if (!css.width) {\r\n let h = css.height;\r\n\r\n if (typeof h === 'number') {\r\n css.minWidth = h;\r\n }\r\n }\r\n\r\n return css;\r\n });\r\n\r\n const buttonLabel = style('buttonLabel');\r\n const iconStyle = Utils.call(() => {\r\n let css: any = style('buttonIcon', extra.icon);\r\n\r\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\r\n\r\n return css;\r\n });\r\n\r\n return (\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClick}\r\n style={buttonStyle}\r\n >\r\n <>\r\n {icon && (\r\n <>\r\n <Ionicons\r\n size={Utils.nvl(element.iconSize, 30)}\r\n style={iconStyle}\r\n name={icon}\r\n />\r\n </>\r\n )}\r\n {label && <Text style={buttonLabel}>{label}</Text>}\r\n </>\r\n </TouchableHighlight>\r\n );\r\n}\r\n","import { useRef, useState } from 'react';\r\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\r\nimport {\r\n Text,\r\n TouchableOpacity,\r\n StyleSheet,\r\n Modal,\r\n View,\r\n SafeAreaView,\r\n ScrollView,\r\n} from 'react-native';\r\nimport { Ionicons } from '@expo/vector-icons';\r\nimport UI from '../UI';\r\n\r\nexport default function UISelect(props: ChildType) {\r\n const [modalVisible, setModalVisible] = useState(false);\r\n const scope = props.scope;\r\n const original = scope.original;\r\n const items = Utils.nvl(scope.getOptions(), []);\r\n const placeholder = scope.attr('placeholder', 'Selecione...');\r\n const value = scope.getDisplayValue();\r\n const theme = scope.getTheme();\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const handlePress = () => {\r\n setModalVisible(!modalVisible);\r\n };\r\n\r\n const scrollRef = useRef(null);\r\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\r\n const modalColor = Utils.nvl(headerStyle.color, 'white');\r\n const defaults = { color: modalColor };\r\n const onClick = ({ crud, value }: MethodType) => {\r\n let val = value as any;\r\n\r\n if (original.isObject && val?.object) {\r\n scope.changeValue(val?.object);\r\n } else if (val?.value) {\r\n scope.changeValue(val?.value);\r\n } else {\r\n scope.changeValue(value);\r\n }\r\n\r\n setModalVisible(false);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let all = { ...styles[part], ...extra };\r\n\r\n return scope.getStyle(part, all);\r\n };\r\n\r\n const isModalVisible = () => {\r\n return modalVisible;\r\n };\r\n //v4\r\n\r\n return (\r\n <View\r\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\r\n style={style('selectRoot')}\r\n >\r\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\r\n <Text style={style('selectLabel')}>\r\n {Utils.nvl(value, placeholder)}\r\n </Text>\r\n <Ionicons\r\n name=\"chevron-down-outline\"\r\n size={scope.getPart('iconSize', null, 24)}\r\n color={scope.getPart('iconColor', null, iconColor)}\r\n style={style('iconStyle', {})}\r\n />\r\n </TouchableOpacity>\r\n <Modal\r\n animationType=\"slide\"\r\n transparent={true}\r\n visible={isModalVisible()}\r\n onRequestClose={() => setModalVisible(false)}\r\n >\r\n <SafeAreaView style={style('modalTop')} />\r\n <SafeAreaView style={style('modalSafe')}>\r\n <View style={scope.getStyle('header', headerStyle)}>\r\n <TouchableOpacity\r\n onPress={handlePress}\r\n style={style('modalCloseButton')}\r\n >\r\n <Ionicons\r\n name=\"close\"\r\n size={24}\r\n color={modalColor}\r\n style={style('modalCloseText', defaults)}\r\n />\r\n </TouchableOpacity>\r\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\r\n </View>\r\n <ScrollView\r\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\r\n style={style('modalContent')}\r\n nestedScrollEnabled={true}\r\n ref={scrollRef}\r\n >\r\n <View\r\n style={{\r\n flex: 1,\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n }}\r\n >\r\n <UI.List\r\n data={items}\r\n name={scope.getName('list')}\r\n layout=\"card\"\r\n search={original.search === true}\r\n click={onClick}\r\n rowStyle={{\r\n paddingLeft: 15,\r\n paddinRight: 15,\r\n ...original?.rowStyle,\r\n }}\r\n {...original?.listProps}\r\n >\r\n <UI.Value value=\"#{@this.label}\" />\r\n </UI.List>\r\n </View>\r\n </ScrollView>\r\n </SafeAreaView>\r\n </Modal>\r\n </View>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n selectRoot: {\r\n justifyContent: 'flex-start',\r\n alignItems: 'flex-start',\r\n flex: 1,\r\n },\r\n selectInput: {\r\n width: '100%',\r\n flexDirection: 'row',\r\n borderRadius: 5,\r\n paddingHorizontal: 15,\r\n borderWidth: 1,\r\n borderStyle: 'solid',\r\n borderColor: '#dedede',\r\n paddingVertical: 10,\r\n },\r\n selectLabel: { flex: 1 },\r\n modalTop: {\r\n backgroundColor: 'primary',\r\n width: '100%',\r\n },\r\n modalSafe: {\r\n flex: 1,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n },\r\n modalCloseButton: {\r\n padding: 10,\r\n },\r\n modalCloseText: {\r\n fontSize: 18,\r\n color: 'white',\r\n },\r\n modalTitle: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n marginLeft: 10,\r\n },\r\n modalContent: {\r\n flex: 1,\r\n backgroundColor: 'background',\r\n },\r\n});\r\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n 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';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, TextInput, View } from 'react-native';\r\nimport { Ionicons } from '@expo/vector-icons';\r\n\r\nexport default function UIInput(props: ChildType) {\r\n let scope = props.scope;\r\n let initial = Utils.call(() => {\r\n let val = Utils.nvl(scope.getValue(), '');\r\n\r\n if (val && val?.push) {\r\n return val.join(', ').trim();\r\n }\r\n return val;\r\n });\r\n\r\n let label = scope.getLabel();\r\n let placeholder = scope.getPart('placeholder', null, label);\r\n let el = scope.original;\r\n\r\n const element = scope.original;\r\n const [height, setHeight] = useState(40);\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n v = scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n return { ...scope.getStyle(part, styles[part]), ...extra };\r\n };\r\n\r\n const CustomIcon = () => {\r\n let icon = el.icon;\r\n\r\n if (icon) {\r\n if (typeof icon === 'string') {\r\n return (\r\n <>\r\n {el.icon && (\r\n <Ionicons\r\n name={el.icon}\r\n size={scope.attr('iconSize', 20)}\r\n color={scope.attr('iconColor', '#888')}\r\n />\r\n )}\r\n </>\r\n );\r\n }\r\n return <>{icon}</>;\r\n }\r\n return <></>;\r\n };\r\n\r\n let type = scope.getPart('type', 'text');\r\n let decode = {\r\n textarea: {\r\n multiline: true,\r\n textAlignVertical: 'top',\r\n numberOfLines: 5,\r\n style: { height: Math.max(40, height) },\r\n },\r\n };\r\n\r\n let defs = { ...Utils.nvl(decode[type], {}), ...element.inputProps };\r\n let inputStyle = { ...style('input', scope.getStyle(type)) };\r\n\r\n if (element.autoHeight) {\r\n defs.onContentSizeChange = event => {\r\n setHeight(event.nativeEvent.contentSize.height);\r\n };\r\n\r\n inputStyle = { ...inputStyle, ...defs.style };\r\n }\r\n\r\n return (\r\n <>\r\n <View style={style('base')}>\r\n {scope.getPart('left')}\r\n <TextInput\r\n style={inputStyle}\r\n onChangeText={onChange}\r\n value={value}\r\n placeholder={placeholder}\r\n {...defs}\r\n />\r\n <CustomIcon />\r\n </View>\r\n {scope.getPart('right')}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n base: {\r\n flex: 1,\r\n width: '100%',\r\n paddingBottom: 0,\r\n paddingTop: 0,\r\n alignItems: 'center',\r\n borderWidth: 1,\r\n borderColor: 'borderColor',\r\n borderRadius: 5,\r\n paddingHorizontal: 15,\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n },\r\n icon: {\r\n marginRight: 10, // Espaço entre ícone e input\r\n },\r\n input: {\r\n marginHorizontal: 0,\r\n marginVertical: 0,\r\n height: 40,\r\n flex: 1, // Para o input ocupar o espaço restante\r\n },\r\n});\r\n","import React, { useRef, useState } from 'react';\r\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport UIChildren from '../UIChildren';\r\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\r\nimport { useIsVisible } from '../../hooks/useIsVisible';\r\n\r\ninterface UIListRowType extends ChildType {\r\n item: any;\r\n index: number;\r\n}\r\n\r\nexport default function UIListRow(props: UIListRowType) {\r\n const scope = props.scope;\r\n const index = props.index;\r\n const original = scope.original;\r\n const item = props.item;\r\n const cols = scope.getPart('cols', undefined, -1);\r\n const rowWidth = Math.floor(100 / cols) + '%';\r\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\r\n const name = `${scope.key('row', index, '')}`;\r\n const [row] = useState(\r\n ScopeUtils.create({\r\n ...original,\r\n parent: scope,\r\n name,\r\n crud: scope.crud,\r\n index,\r\n type: 'row',\r\n data: item,\r\n })\r\n );\r\n\r\n //v5\r\n const targetRef = useRef(null);\r\n const isVisible = useIsVisible(targetRef, row);\r\n\r\n const onClick = (item: any) => {\r\n row.call('click', { value: item, item, edit: true, index });\r\n };\r\n\r\n const Child = () => {\r\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\r\n return <></>;\r\n }\r\n return (\r\n <>\r\n <UIChildren transient scope={row} crud={row.crud}>\r\n {props.children}\r\n </UIChildren>\r\n </>\r\n );\r\n };\r\n\r\n const ListItem = () => {\r\n let [updateIndex, setUpdateIndex] = useState(0);\r\n let key = scope.key('item');\r\n\r\n row.selected = row.getPart('isSelectedRow', undefined, false);\r\n\r\n const getRowStyle = () => {\r\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\r\n\r\n if (row.selected) {\r\n css = { ...css, ...row.getStyle('rowSelected', {}) };\r\n } else {\r\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\r\n }\r\n\r\n if (cols > 0) {\r\n css.width = rowWidth;\r\n }\r\n\r\n return css;\r\n };\r\n\r\n row.update = () => {\r\n scope.updateIndex = scope.updateIndex + 1;\r\n\r\n setUpdateIndex(++updateIndex);\r\n };\r\n\r\n let renderedRow = row.getPart('renderedItem', undefined, true);\r\n\r\n if (renderedRow === false) {\r\n return <></>;\r\n }\r\n\r\n if (!original.click) {\r\n return (\r\n <View key={key} style={getRowStyle()} ref={targetRef}>\r\n <Child />\r\n </View>\r\n );\r\n }\r\n return (\r\n <TouchableHighlight\r\n key={key}\r\n style={getRowStyle()}\r\n underlayColor={'transparent'}\r\n ref={targetRef}\r\n onPress={e => {\r\n e.stopPropagation();\r\n onClick(item);\r\n }}\r\n >\r\n <Child />\r\n </TouchableHighlight>\r\n );\r\n };\r\n\r\n return <ListItem />;\r\n}\r\n\r\nconst stylesList = StyleSheet.create({\r\n row: {\r\n padding: 5,\r\n margin: 0,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n gap: 10,\r\n borderRadius: 8,\r\n justifyContent: 'center',\r\n },\r\n});\r\n\r\nconst stylesRepeat = StyleSheet.create({\r\n row: {\r\n padding: 0,\r\n width: '100%',\r\n justifyContent: 'center',\r\n },\r\n});\r\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';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, View } from 'react-native';\r\nimport UIListRow from './UIListRow';\r\nimport UI from '../UI';\r\nimport { Ionicons } from '@expo/vector-icons';\r\n\r\nexport default function UIList(props: ChildType) {\r\n const scope = props.scope;\r\n const crud = scope.crud;\r\n const original = scope.original;\r\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\r\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\r\n const add = ComponentUtils.getDefine(props, 'add');\r\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\r\n const hideEmpty = original.hideEmpty;\r\n\r\n //v2\r\n const getStyle = (key: string, extra?: any) => {\r\n return scope.getStyle(key, { ...extra, ...styles[key] });\r\n };\r\n\r\n const getContainerStyle = (extra?: any) => {\r\n let row = getStyle('container', {});\r\n\r\n if (cols > 1) {\r\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\r\n }\r\n\r\n return row;\r\n };\r\n\r\n const LocalData = () => {\r\n let [index, setIndex] = useState(scope.updateIndex);\r\n let empty = scope.attr('empty', 'Sem registro');\r\n\r\n scope.update = () => {\r\n scope.updateIndex = ++index;\r\n\r\n setIndex(index);\r\n };\r\n\r\n const items = Utils.call(() => {\r\n let list = Utils.nvl(scope.getItems(), []);\r\n\r\n if (original.search !== false && !original.list?.url) {\r\n let query = crud\r\n .get('query', '')\r\n .toLowerCase()\r\n .trim() as string;\r\n\r\n if (query.length > 1) {\r\n let filters: any[] = [];\r\n let filterBy = Utils.nvl(original.filterBy, 'label');\r\n\r\n Utils.each(list, o => {\r\n let label = Utils.getValue(filterBy, 'none', o).toLowerCase();\r\n\r\n if (label) {\r\n if (label.includes(query)) {\r\n filters.push(o);\r\n }\r\n }\r\n });\r\n\r\n return filters;\r\n }\r\n }\r\n return list;\r\n });\r\n\r\n let isEmpty = Utils.isEmpty(items);\r\n\r\n const isShowAdd = () => {\r\n if (!isEmpty) {\r\n return true;\r\n }\r\n return hideAddWhenEmpty !== true;\r\n };\r\n\r\n let Empty = () => {\r\n if (!isEmpty) {\r\n return <></>;\r\n }\r\n\r\n if (!empty) {\r\n return <></>;\r\n }\r\n\r\n if (typeof empty === 'string') {\r\n return (\r\n <Text\r\n style={scope.getStyle('empty', {\r\n flex: 1,\r\n fontWeight: 400,\r\n fontSize: 18,\r\n padding: 10,\r\n textAlign: 'center',\r\n width: '100%',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n })}\r\n >\r\n {empty}\r\n </Text>\r\n );\r\n }\r\n\r\n return <>{empty}</>;\r\n };\r\n\r\n if (empty === false && isEmpty) {\r\n return <></>;\r\n }\r\n\r\n return (\r\n <View style={getContainerStyle()}>\r\n <Empty />\r\n {items.map((item: any, i: number) => (\r\n <UIListRow index={i} item={item} scope={scope}>\r\n {props.children}\r\n </UIListRow>\r\n ))}\r\n {isShowAdd() && <>{add}</>}\r\n </View>\r\n );\r\n };\r\n\r\n let items = Utils.nvl(scope.getItems(), []);\r\n\r\n if (hideEmpty && Utils.isEmpty(items)) {\r\n return <></>;\r\n }\r\n\r\n return (\r\n <>\r\n {original.search !== false && (\r\n <UI.Text\r\n placeholder=\"Pesquisar...\"\r\n field=\"query\"\r\n crud={crud}\r\n style={{ marginBottom: 10 }}\r\n change={{\r\n action: () => {\r\n scope.search();\r\n },\r\n }}\r\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\r\n />\r\n )}\r\n <LocalData />\r\n </>\r\n );\r\n}\r\n\r\nconst stylesList = StyleSheet.create({\r\n container: {\r\n display: 'flex',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n width: '100%',\r\n },\r\n text: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n },\r\n});\r\n\r\nconst stylesRepeat = StyleSheet.create({\r\n container: {\r\n display: 'flex',\r\n flexWrap: 'wrap',\r\n gap: 10,\r\n width: '100%',\r\n },\r\n text: {\r\n fontSize: 18,\r\n fontWeight: 'bold',\r\n },\r\n});\r\n","import React, { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\r\nimport UIListRow from './UIListRow';\r\n\r\nexport default function UIToggle(props: ChildType) {\r\n const scope = props.scope;\r\n const options = Utils.nvl(scope.getOptions(), []);\r\n const value = scope.getInputValue();\r\n\r\n let [index, setIndex] = useState(0);\r\n\r\n const isSelected = (item: any) => {\r\n return item?.value === value;\r\n };\r\n\r\n const onClick = (item: any) => {\r\n scope.changeValue(item.object);\r\n setIndex(++index);\r\n };\r\n\r\n const Item = ({ item, index }) => {\r\n let selected = isSelected(item);\r\n let style: any = { ...styles.text };\r\n\r\n if (selected) style.color = '#ffffff';\r\n\r\n if (Utils.isEmpty(props.children)) {\r\n return <Text style={style}>{item.label}</Text>;\r\n }\r\n\r\n return (\r\n <UIListRow scope={scope} item={item.object} index={index}>\r\n {props.children}\r\n </UIListRow>\r\n );\r\n };\r\n\r\n const getItemStyle = (item: any) => {\r\n let style = { ...styles.item, ...scope.getStyle('item') };\r\n\r\n let wPart = 100 / options.length;\r\n let width = Math.floor(wPart) + '%';\r\n\r\n if (isSelected(item)) {\r\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\r\n let st = scope.getStyle('selected', {\r\n backgroundColor: selectedColor,\r\n color: '#ffffff',\r\n });\r\n\r\n style = { ...style, ...st };\r\n\r\n if (!style.color) {\r\n style.color = '#ffffff';\r\n }\r\n }\r\n\r\n style.width = width;\r\n\r\n return style;\r\n };\r\n\r\n return (\r\n <>\r\n {options.map((item: any, i: number) => (\r\n <TouchableHighlight\r\n key={`k-${i}`}\r\n style={getItemStyle(item)}\r\n onPress={e => {\r\n onClick(item);\r\n }}\r\n >\r\n <Item item={item} index={i} />\r\n </TouchableHighlight>\r\n ))}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n container: {\r\n flex: 1,\r\n width: '100%',\r\n gap: 10,\r\n justifyContent: 'center',\r\n flexDirection: 'row',\r\n },\r\n item: {\r\n padding: 10,\r\n marginVertical: 8,\r\n backgroundColor: 'background',\r\n borderRadius: 8,\r\n justifyContent: 'center',\r\n width: 'auto',\r\n flexDirection: 'row',\r\n },\r\n text: {\r\n fontSize: 15,\r\n fontWeight: '500',\r\n },\r\n});\r\n","import { Ionicons } from '@expo/vector-icons';\r\nimport { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Text, TouchableHighlight, View } from 'react-native';\r\n\r\nexport default function UIQuantity(props: ChildType) {\r\n const scope = props.scope;\r\n const element = scope.original;\r\n\r\n let [index, setIndex] = useState(0);\r\n\r\n const value = scope.getValue(0);\r\n\r\n let color = element.color;\r\n\r\n if (!color) color = 'primary';\r\n\r\n const btn = {\r\n padding: 0,\r\n alignItems: 'center',\r\n height: 30,\r\n width: 30,\r\n textAlign: 'center',\r\n verticalAling: 'middle',\r\n borderRadius: 24,\r\n backgroundColor: color,\r\n color: '#ffffff',\r\n justifyContent: 'center',\r\n };\r\n\r\n const styles: any = {\r\n buttonLabel: {\r\n color: '#ffffff',\r\n fontWeight: '500',\r\n fontSize: 16,\r\n },\r\n value: {\r\n flex: 1,\r\n flexDirection: 'row',\r\n textAlign: 'center',\r\n fontWeight: '500',\r\n },\r\n buttonInner: {\r\n flexDirection: 'row',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n },\r\n buttonIcon: {\r\n color: '#fff',\r\n fontSize: 18,\r\n },\r\n button: btn,\r\n addButton: {\r\n ...btn,\r\n },\r\n delButton: {\r\n ...btn,\r\n },\r\n };\r\n\r\n const change = (val: number) => {\r\n scope.changeValue(value + val);\r\n setIndex(++index);\r\n };\r\n\r\n const onClickAdd = () => {\r\n change(1);\r\n };\r\n\r\n const onClickDel = () => {\r\n change(-1);\r\n };\r\n\r\n const style = (part: string, extra?: any) => {\r\n let s = { ...styles[part], ...extra };\r\n return scope.getStyle(part, s);\r\n };\r\n\r\n return (\r\n <>\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClickDel}\r\n style={style('delButton')}\r\n >\r\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\r\n </TouchableHighlight>\r\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\r\n <TouchableHighlight\r\n underlayColor={'transparent'}\r\n onPress={onClickAdd}\r\n style={style('addButton')}\r\n >\r\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\r\n </TouchableHighlight>\r\n </>\r\n );\r\n}\r\n","import { StyleSheet } from 'react-native';\r\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\r\n\r\nexport default function UIToast() {\r\n const toastConfig = {\r\n success: props => (\r\n <BaseToast\r\n {...props}\r\n style={styles.darkToast}\r\n contentContainerStyle={{ paddingHorizontal: 15 }}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n error: props => (\r\n <ErrorToast\r\n {...props}\r\n style={styles.darkToast}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n info: props => (\r\n <BaseToast\r\n {...props}\r\n style={styles.darkToast}\r\n text1Style={styles.text}\r\n text2Style={styles.text}\r\n />\r\n ),\r\n };\r\n\r\n const styles = StyleSheet.create({\r\n darkToast: {\r\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\r\n borderLeftColor: '#222', // borda mais escura\r\n },\r\n text: {\r\n color: '#fff', // letras brancas\r\n textAlign: 'center',\r\n },\r\n });\r\n return <Toast config={toastConfig} />;\r\n}\r\n","import { useRef, useState } from 'react';\r\nimport {\r\n ChildType,\r\n ComponentUtils,\r\n CrudUtils,\r\n MethodType,\r\n Utils,\r\n ViewUtils,\r\n} from 'react-crud-utils';\r\nimport {\r\n Text,\r\n TouchableOpacity,\r\n StyleSheet,\r\n Modal,\r\n View,\r\n SafeAreaView,\r\n ScrollView,\r\n} from 'react-native';\r\nimport UIChildren from '../UIChildren';\r\nimport Ionicons from '@expo/vector-icons/Ionicons';\r\nimport UIToast from './UIToast';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\n\r\ninterface UIModalType extends ChildType {\r\n open?: boolean;\r\n dialog?: any;\r\n}\r\n\r\nexport default function UIModal(props: UIModalType) {\r\n const scrollRef = useRef(null);\r\n\r\n let owner = props.scope;\r\n let [index, setIndex] = useState(0);\r\n let dialog = owner.currentDialog;\r\n //v2\r\n\r\n let curr = dialog?.crud;\r\n\r\n if (!dialog) {\r\n return <></>;\r\n }\r\n\r\n dialog.update = () => {\r\n setIndex(++index);\r\n };\r\n\r\n if (dialog.debug) console.log(dialog);\r\n\r\n //const modalVisible = curr.uuid === main.dialog?.crud?.uuid;\r\n const scope = dialog.scope;\r\n const label = scope.getLabel();\r\n const theme = scope.getTheme();\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\r\n const bottom = ComponentUtils.getDefine(props, 'bottom');\r\n\r\n const style = (part: string, extra?: any) => {\r\n let st = { ...styles[part], ...extra };\r\n\r\n return { ...scope.getStyle(part, st) };\r\n };\r\n\r\n const onClose = () => {\r\n scope.close({ scope, crud: dialog?.crud, event: {} });\r\n };\r\n\r\n scope.put('scrollRef', scrollRef);\r\n\r\n const original = owner.original;\r\n\r\n ComponentUtils.setViewScope(scope);\r\n\r\n let color = Utils.nvl(headerStyle.color, 'white');\r\n let defaults = { color };\r\n let key = `${curr.name}-${index}`;\r\n\r\n let ModalContent = ({ children }) => {\r\n let disableScroll = scope.part('disableScroll', false);\r\n let disableContent = scope.part('disableContent', false);\r\n\r\n if (disableContent) {\r\n return <>{children}</>;\r\n }\r\n\r\n if (disableScroll) {\r\n return <View style={style('modalContent')}>{children}</View>;\r\n }\r\n return (\r\n <ScrollView\r\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\r\n style={style('modalContent')}\r\n nestedScrollEnabled={true}\r\n ref={scrollRef}\r\n >\r\n {children}\r\n </ScrollView>\r\n );\r\n };\r\n\r\n const ModalView = ({ children }) => {\r\n if (original.gesture) {\r\n return (\r\n <GestureHandlerRootView\r\n style={{\r\n flex: 1,\r\n }}\r\n >\r\n {children}\r\n </GestureHandlerRootView>\r\n );\r\n }\r\n return <>{children}</>;\r\n };\r\n\r\n const ModalInner = () => {\r\n let Content = () => {\r\n if (dialog?.component) {\r\n let cprops = dialog.props;\r\n let Aux = dialog.component;\r\n\r\n return <Aux key={curr.uuid} crud={curr} {...cprops} />;\r\n }\r\n\r\n return (\r\n <UIChildren scope={scope} crud={curr}>\r\n {props.children}\r\n </UIChildren>\r\n );\r\n };\r\n\r\n let content = <Content />;\r\n\r\n if (original.transient) {\r\n return <View style={style('modalSafe')}>{content}</View>;\r\n }\r\n\r\n return (\r\n <>\r\n <SafeAreaView style={style('modalTop')} />\r\n <SafeAreaView style={style('modalSafe')}>\r\n <View style={scope.getStyle('header', headerStyle)}>\r\n <TouchableOpacity\r\n onPress={onClose}\r\n style={style('modalCloseButton')}\r\n >\r\n <Ionicons\r\n name=\"chevron-back-outline\"\r\n size={24}\r\n color={color}\r\n style={style('modalCloseText', defaults)}\r\n />\r\n </TouchableOpacity>\r\n <Text style={style('modalTitle', defaults)}>{label}</Text>\r\n {!Utils.isEmpty(headerRight) && (\r\n <UIChildren scope={scope} crud={curr} transient>\r\n {headerRight}\r\n </UIChildren>\r\n )}\r\n </View>\r\n <ModalContent>{content}</ModalContent>\r\n {bottom}\r\n </SafeAreaView>\r\n <UIToast />\r\n </>\r\n );\r\n };\r\n return (\r\n <ModalView>\r\n <Modal\r\n key={key}\r\n animationType=\"slide\"\r\n transparent={true}\r\n visible={true}\r\n onRequestClose={onClose}\r\n >\r\n <ModalInner />\r\n </Modal>\r\n </ModalView>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n modalTop: {\r\n backgroundColor: 'primary',\r\n width: '100%',\r\n },\r\n modalSafe: {\r\n flex: 1,\r\n width: '100%',\r\n backgroundColor: 'background',\r\n },\r\n modalCloseButton: {\r\n padding: 10,\r\n },\r\n modalCloseText: {\r\n fontSize: 18,\r\n color: 'white',\r\n },\r\n modalTitle: {\r\n fontSize: 22,\r\n fontWeight: 600,\r\n marginLeft: 10,\r\n },\r\n modalContent: {\r\n flex: 1,\r\n backgroundColor: 'background',\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n },\r\n});\r\n","import { Text, View } from 'react-native';\r\n\r\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIHeader({ scope }: ChildType) {\r\n const theme = scope.getTheme();\r\n const header = scope.getPart('header', null, []);\r\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\r\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\r\n\r\n let headerStyleFull = Utils.call(() => {\r\n let css = scope.getStyle('header', headerStyle);\r\n let bg = css.backgroundColor;\r\n\r\n if (bg) {\r\n css.color = HtmlUtils.getTextColor(bg);\r\n }\r\n return css;\r\n });\r\n\r\n let hasHeader = !Utils.isEmpty(header);\r\n let AuxHeader = () => {\r\n if (typeof header === 'string') {\r\n return <Text style={headerTextStyle}>{header}</Text>;\r\n }\r\n return <>{header}</>;\r\n };\r\n\r\n return (\r\n <>\r\n {hasHeader && (\r\n <View style={headerStyleFull}>\r\n <AuxHeader />\r\n </View>\r\n )}\r\n </>\r\n );\r\n}\r\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\r\n\r\nimport UIChildren from '../UIChildren';\r\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\r\nimport { useRef } from 'react';\r\nimport UIToast from './UIToast';\r\nimport UIHeader from './UIHeader';\r\n\r\nexport default function UIView({ scope, children }: ChildType) {\r\n const scrollRef = useRef(null);\r\n const original = scope.original;\r\n\r\n const onScroll = () => {\r\n const crud = ViewUtils.getCrud();\r\n\r\n Utils.each(crud.scroll, s => {\r\n if (s.onScroll) {\r\n s.onScroll.call(s);\r\n }\r\n });\r\n };\r\n\r\n //v3\r\n scope.put('scrollRef', scrollRef);\r\n\r\n ComponentUtils.setViewScope(scope);\r\n\r\n let Container = () => {\r\n if (original.scroll === false) {\r\n return <UIChildren scope={scope}>{children}</UIChildren>;\r\n }\r\n\r\n return (\r\n <View style={scope.getStyle('container', styles.container)}>\r\n <ScrollView\r\n onScroll={onScroll}\r\n scrollEventThrottle={16}\r\n ref={scrollRef}\r\n nestedScrollEnabled={true}\r\n keyboardShouldPersistTaps=\"handled\"\r\n contentContainerStyle={scope.getStyle('contentContainer', {\r\n paddingBottom: 50,\r\n })}\r\n style={scope.getStyle('scroll', styles.scroll)}\r\n >\r\n <UIChildren scope={scope}>{children}</UIChildren>\r\n </ScrollView>\r\n </View>\r\n );\r\n };\r\n return (\r\n <>\r\n <UIHeader scope={scope} />\r\n <Container />\r\n <UIToast /> {/* <- este componente precisa estar aqui */}\r\n </>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n scroll: {\r\n paddingTop: 10,\r\n paddingBottom: 10,\r\n paddingLeft: 15,\r\n paddingRight: 15,\r\n },\r\n container: {},\r\n view: {},\r\n});\r\n","import React, { useState } from 'react';\r\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\r\nimport { StyleSheet, Text, TouchableOpacity, View } from 'react-native';\r\nimport UI from '../UI';\r\nimport { Ionicons, MaterialCommunityIcons } from '@expo/vector-icons';\r\nimport DraggableFlatList, {\r\n ScaleDecorator,\r\n} from 'react-native-draggable-flatlist';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\nimport UIHeader from './UIHeader';\r\nimport UIChildren from '../UIChildren';\r\n\r\nexport default function UIOrder(props: ChildType) {\r\n const scope = props.scope;\r\n const crud = scope.crud;\r\n const original = scope.original;\r\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\r\n\r\n const getStyle = (key: string, extra?: any) => {\r\n return scope.getStyle(key, { ...extra, ...styles[key] });\r\n };\r\n\r\n const getContainerStyle = (extra?: any) => {\r\n let row = getStyle('container', {});\r\n\r\n if (cols > 1) {\r\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\r\n }\r\n\r\n return row;\r\n };\r\n\r\n const items = Utils.call(() => {\r\n let list = Utils.nvl(scope.getItems(), []);\r\n\r\n if (original.search && !original.list?.url) {\r\n let query = crud\r\n .get('query', '')\r\n .toLowerCase()\r\n .trim() as string;\r\n\r\n if (query.length > 1) {\r\n let filters: any[] = [];\r\n let filterBy = Utils.nvl(original.filterBy, 'label');\r\n\r\n Utils.each(list, o => {\r\n let label = o[filterBy];\r\n\r\n if (label) {\r\n if (label.includes(query)) {\r\n filters.push(o);\r\n }\r\n }\r\n });\r\n\r\n return filters;\r\n }\r\n }\r\n return list;\r\n });\r\n\r\n //v2\r\n\r\n const renderItem = ({ item, drag, isActive, getIndex }) => {\r\n const index = getIndex();\r\n const name = `${scope.key('row', index, '')}`;\r\n const [row] = useState(\r\n ScopeUtils.create({\r\n ...original,\r\n parent: scope,\r\n name,\r\n crud: scope.crud,\r\n index,\r\n type: 'row',\r\n data: item,\r\n })\r\n );\r\n\r\n let css = { ...scope.getStyle('row') };\r\n\r\n if (isActive) {\r\n css = { ...css, ...scope.getStyle('active') };\r\n }\r\n\r\n if (isActive) {\r\n css = { ...css, ...row.getStyle('rowSelected', {}) };\r\n } else {\r\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\r\n }\r\n const Child = () => {\r\n if (Utils.isEmpty(props.children)) {\r\n return (\r\n <>\r\n <MaterialCommunityIcons name=\"drag\" size={24} color=\"black\" />\r\n <Text style={styles.text}>{scope.getItemLabel(item)}</Text>\r\n </>\r\n );\r\n }\r\n\r\n return (\r\n <>\r\n <UIChildren transient scope={row} crud={row.crud}>\r\n {props.children}\r\n </UIChildren>\r\n </>\r\n );\r\n };\r\n return (\r\n <ScaleDecorator>\r\n <TouchableOpacity\r\n style={[\r\n styles.row,\r\n { backgroundColor: isActive ? 'lightblue' : 'white' },\r\n { ...css },\r\n ]}\r\n delayLongPress={100}\r\n onLongPress={drag} // Initiate drag on long press\r\n >\r\n <Child />\r\n </TouchableOpacity>\r\n </ScaleDecorator>\r\n );\r\n };\r\n\r\n const OrderView = ({ children }) => {\r\n if (original.gesture !== false) {\r\n return (\r\n <GestureHandlerRootView\r\n style={{\r\n flex: 1,\r\n width: '100%',\r\n ...scope.getStyle('order', { justifyContent: 'flex-start' }),\r\n }}\r\n >\r\n {children}\r\n </GestureHandlerRootView>\r\n );\r\n }\r\n return <>{children}</>;\r\n };\r\n\r\n const Header = ({ pos }) => {\r\n const hPos = Utils.nvl(original.headerPos, 'outer');\r\n\r\n if (hPos !== pos) return <></>;\r\n\r\n return <UIHeader scope={scope} />;\r\n };\r\n\r\n let OrderData = () => {\r\n const [data, setData] = useState(items);\r\n\r\n return (\r\n <DraggableFlatList\r\n data={data}\r\n ListHeaderComponent={<Header pos=\"inner\" />}\r\n ListFooterComponent={<>{scope.getPart('footer')}</>}\r\n renderItem={renderItem}\r\n containerStyle={{ ...scope.getStyle('list') }}\r\n keyExtractor={item => {\r\n let key = scope.getItemValue(item);\r\n\r\n if (original?.debug) {\r\n console.log(key);\r\n }\r\n return key;\r\n }}\r\n onDragEnd={({ data }) => {\r\n setData(data);\r\n scope.changeValue(data);\r\n }}\r\n />\r\n );\r\n };\r\n return (\r\n <OrderView>\r\n <Header pos=\"outer\" />\r\n <OrderData />\r\n </OrderView>\r\n );\r\n}\r\n\r\nconst styles = StyleSheet.create({\r\n row: {\r\n flexDirection: 'row',\r\n gap: 10,\r\n padding: 15,\r\n borderBottomWidth: 1,\r\n borderBottomColor: '#ccc',\r\n },\r\n text: {\r\n fontSize: 18,\r\n },\r\n});\r\n","import React, {\r\n createContext,\r\n useContext,\r\n useEffect,\r\n useLayoutEffect,\r\n useRef,\r\n useState,\r\n} from 'react';\r\nimport UIChildren from './UIChildren';\r\nimport ElTabs from './tabs/ElTabs';\r\nimport ElChart from './charts/ElChart';\r\nimport UIComplete from './UIComplete';\r\nimport {\r\n Crud,\r\n HtmlUtils,\r\n ScopeUtils,\r\n Utils,\r\n ElementType,\r\n MethodType,\r\n ActionType,\r\n ComponentUtils,\r\n CrudUtils,\r\n ViewUtils,\r\n Scope,\r\n} from 'react-crud-utils';\r\nimport UILink from './core/UILink';\r\nimport UIIcon from './core/UIIcon';\r\nimport UIButton from './core/UIButton';\r\nimport UISelect from './core/UISelect';\r\nimport UISwitch from './core/UISwitch';\r\nimport UISlider from './core/UISlider';\r\nimport UIOption from './core/UIOption';\r\nimport UIRadio from './core/UIRadio';\r\nimport UIInput from './core/UIInput';\r\nimport {\r\n Alert,\r\n Image,\r\n Linking,\r\n StyleSheet,\r\n Text,\r\n TouchableHighlight,\r\n View,\r\n} from 'react-native';\r\nimport UIList from './core/UIList';\r\nimport UIToggle from './core/UIToggle';\r\nimport UIQuantity from './core/UIQuantity';\r\nimport UIModal from './core/UIModal';\r\nimport { Ionicons } from '@expo/vector-icons';\r\nimport UIView from './core/UIView';\r\nimport Toast from 'react-native-toast-message';\r\nimport UIOrder from './core/UIOrder';\r\n\r\nconst CrudContext = createContext<any>({});\r\n\r\nexport default function UIElement(props: ElementType) {\r\n const ctx = useContext(CrudContext);\r\n const theme = Utils.nvl(props.theme, ctx?.theme);\r\n\r\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\r\n let [scope] = useState<Scope>(ScopeUtils.create({ crud, ...props, theme }));\r\n let [index, setIndex] = useState(0);\r\n let [error, setError]: string | any = useState(null);\r\n\r\n scope.compile(props);\r\n\r\n crud = scope.crud;\r\n\r\n let options: any = scope.getOptions();\r\n\r\n let original = scope.original;\r\n let ref = useRef(null);\r\n\r\n scope.update = () => {\r\n setIndex(++index);\r\n };\r\n\r\n scope.updateElement = () => {\r\n setIndex(++index);\r\n };\r\n\r\n scope.toast = (message: string, type = 'info', args?: any) => {\r\n Toast.show({\r\n type, // 'success' | 'error' | 'info'\r\n text1: message,\r\n position: 'bottom', // 'top' é outra opção\r\n visibilityTime: 3000, // tempo que fica visível em ms\r\n ...args,\r\n });\r\n };\r\n\r\n scope.prompt = (args: MethodType) => {\r\n let event = args.event as ActionType;\r\n\r\n if (event) {\r\n let message = 'Você tem certeza que deseja continuar?';\r\n let title = 'Atenção';\r\n let prompt = event.prompt;\r\n\r\n if (typeof prompt === 'string') {\r\n message = prompt;\r\n }\r\n\r\n if (typeof prompt === 'object') {\r\n message = Utils.nvl(prompt.message, message);\r\n title = Utils.nvl(prompt.title, title);\r\n }\r\n\r\n Alert.alert(\r\n title,\r\n message,\r\n [\r\n {\r\n text: 'Cancelar',\r\n style: 'cancel',\r\n },\r\n {\r\n text: 'Confirmar',\r\n onPress: () => scope.execute(args),\r\n },\r\n ],\r\n { cancelable: false }\r\n );\r\n }\r\n };\r\n const Custom = () => {\r\n let c: any = original.custom;\r\n\r\n if (c) {\r\n if (typeof c === 'string') {\r\n return (\r\n <UIElement\r\n element={{ value: c, type: 'dummy' }}\r\n crud={crud}\r\n ></UIElement>\r\n );\r\n }\r\n\r\n return (\r\n <UIElement\r\n type={c.type}\r\n tag={c.type}\r\n {...c.props}\r\n crud={crud}\r\n ></UIElement>\r\n );\r\n }\r\n\r\n return <></>;\r\n };\r\n\r\n if (scope.is('type', 'dummy')) {\r\n return <>{scope.getDisplayValue()}</>;\r\n }\r\n\r\n let onCheck = () => {\r\n let v = scope.getValue();\r\n let check = !(v === true);\r\n\r\n onChange({ target: { value: check } });\r\n };\r\n\r\n let onChange = (e: any) => {\r\n let val = e.target.value;\r\n\r\n if (scope.isType('integer', 'int', 'number')) {\r\n val = parseInt(val);\r\n } else if (scope.isType('decimal')) {\r\n val = parseFloat(val);\r\n }\r\n\r\n if (scope.isType('select', 'complete')) {\r\n val = scope.getSelectedItem(val);\r\n }\r\n\r\n scope.changeValue(val);\r\n scope.update();\r\n };\r\n\r\n let onClick = (e: any) => {\r\n if (scope.currentDialog?.component) return;\r\n\r\n scope.call('click');\r\n };\r\n\r\n let defaultsInput: any = {\r\n scope,\r\n crud,\r\n onChange: onChange,\r\n };\r\n\r\n if (scope.isType('password')) {\r\n defaultsInput.type = 'password';\r\n }\r\n\r\n let isChecked = () => {\r\n let v = scope.getValue();\r\n\r\n return v === true;\r\n };\r\n\r\n let hasChildren = () => {\r\n if (scope.isInput()) {\r\n return false;\r\n }\r\n\r\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\r\n };\r\n\r\n let isInput = scope.is(\r\n 'type',\r\n 'text',\r\n 'textarea',\r\n 'number',\r\n 'integer',\r\n 'int',\r\n 'phone',\r\n 'postalCode',\r\n 'money',\r\n 'password',\r\n 'email'\r\n );\r\n\r\n const getStyle = (part?: string, extra?: any) => {\r\n let type = Utils.nvl(original.type, 'none');\r\n let key = Utils.nvl(part, 'root');\r\n let def = { ...styles[key] };\r\n let hasChild = hasChildren();\r\n\r\n type = Utils.nvl(original.layout, type);\r\n\r\n if (!part && !hasChild) {\r\n def = { ...def };\r\n }\r\n\r\n if (scope.isInput()) {\r\n def = { ...def, ...elementStyle.input[key] };\r\n }\r\n\r\n def = { ...def, ...elementStyle?.[type]?.[key] };\r\n\r\n if (hasChild && part) {\r\n def = { ...def, ...withChildStyles[part] };\r\n }\r\n\r\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\r\n };\r\n\r\n let elStyle = getStyle('element');\r\n\r\n let defaultsUI: any = {\r\n required: scope.isRequired(),\r\n size: 'small',\r\n scope,\r\n crud,\r\n style: elStyle,\r\n placeholder: scope.attr('placeholder', 'Digite aqui'),\r\n };\r\n\r\n scope.error = (msg: string) => {\r\n error = msg;\r\n setError(msg);\r\n };\r\n\r\n if (!original.list?.url && !original.load?.url) {\r\n scope.start();\r\n }\r\n\r\n useEffect(() => {\r\n scope.start();\r\n });\r\n\r\n const CustomIcon = () => {\r\n if (typeof original.icon === 'string') {\r\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\r\n }\r\n return <>{original.icon}</>;\r\n };\r\n\r\n scope.open = (args: any) => {\r\n Linking.openURL(args.url);\r\n };\r\n\r\n useLayoutEffect(() => {\r\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\r\n let el: any = ref?.current;\r\n\r\n if (el?.classList) {\r\n let bg = HtmlUtils.getBGColor(el);\r\n\r\n if (bg === 'rgb(255, 255, 255)') {\r\n el.classList.add('ui-dark');\r\n } else {\r\n el.classList.add('ui-light');\r\n }\r\n }\r\n }\r\n });\r\n\r\n const isShowLabel = () => {\r\n if (\r\n typeof original.label !== 'undefined' &&\r\n original.label !== false &&\r\n !scope.isType('button', 'dialog', 'modal')\r\n ) {\r\n return true;\r\n }\r\n\r\n return false;\r\n };\r\n\r\n const isShowInner = () => {\r\n if (hasChildren()) {\r\n return false;\r\n }\r\n return true;\r\n };\r\n\r\n if (!scope.isRendered() || scope.is('type', 'define')) {\r\n return <></>;\r\n }\r\n\r\n const isShowChild = () => {\r\n if (\r\n scope.isType(\r\n 'tabs',\r\n 'view',\r\n 'grid',\r\n 'list',\r\n 'define',\r\n 'repeat',\r\n 'modal',\r\n 'dialog',\r\n 'chart'\r\n )\r\n ) {\r\n return false;\r\n }\r\n\r\n return true;\r\n };\r\n\r\n let isTouch =\r\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\r\n let custom: any = {};\r\n\r\n if (isTouch) {\r\n custom.underlayColor = 'transparent';\r\n custom.onPress = onClick;\r\n }\r\n\r\n let Tag = (props: any) => {\r\n let Aux: any = View;\r\n\r\n if (isTouch) {\r\n Aux = TouchableHighlight;\r\n }\r\n\r\n if (scope.isType('dialog', 'order') || original.transient) {\r\n return <>{props.children}</>;\r\n }\r\n\r\n return <Aux {...props} />;\r\n };\r\n\r\n let Inner = () => {\r\n return (\r\n <>\r\n {scope.getPart('render', null, <></>)}\r\n {scope.is('type', 'button') && (\r\n <UIButton\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {original.icon && <CustomIcon />}\r\n {original.label && (\r\n <Text style={scope.getPart('label', 'button')}>\r\n {scope.getLabel()}\r\n </Text>\r\n )}\r\n </UIButton>\r\n )}\r\n {scope.is('type', 'icon') && (\r\n <UIIcon\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {scope.getDisplayValue()}\r\n </UIIcon>\r\n )}\r\n {scope.is('type', 'link') && (\r\n <UILink\r\n {...defaultsUI}\r\n onClick={onClick}\r\n variant={scope.attr('variant', 'outlined')}\r\n >\r\n {original.icon && <CustomIcon />}\r\n {original.label && (\r\n <Text style={scope.getPart('label', 'link')}>\r\n {scope.getLabel()}\r\n </Text>\r\n )}\r\n </UILink>\r\n )}\r\n {isInput && (\r\n <UIInput\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n InputProps={{ ...original.inputProps }}\r\n />\r\n )}\r\n {scope.is('type', 'complete', 'autocomplete') && (\r\n <UIComplete\r\n scope={scope}\r\n defaultsInput={defaultsInput}\r\n defaultsUI={defaultsUI}\r\n />\r\n )}\r\n {scope.is('type', 'quantity') && (\r\n <UIQuantity\r\n scope={scope}\r\n defaultsInput={defaultsInput}\r\n defaultsUI={defaultsUI}\r\n />\r\n )}\r\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\r\n <UISwitch\r\n checked={isChecked()}\r\n {...defaultsInput}\r\n onChange={onCheck}\r\n />\r\n )}\r\n {scope.isType('slider') && (\r\n <UISlider {...defaultsInput} onChange={onCheck} />\r\n )}\r\n {scope.is('type', 'select') && (\r\n <UISelect\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n value={scope.getSelectedValue()}\r\n />\r\n )}\r\n {scope.is('type', 'toggle') && (\r\n <UIToggle\r\n {...defaultsInput}\r\n {...defaultsUI}\r\n value={scope.getSelectedValue()}\r\n />\r\n )}\r\n {scope.is('type', 'radio') && (\r\n <UIRadio {...defaultsInput} {...defaultsUI} row>\r\n {options.map((row: any, i: number) => (\r\n <UIOption\r\n key={'i' + i}\r\n control={<UIRadio {...defaultsUI} />}\r\n label={row.label}\r\n value={row.value}\r\n />\r\n ))}\r\n </UIRadio>\r\n )}\r\n {scope.is('type', 'custom') && <Custom />}\r\n {scope.is('type', 'column') && (\r\n <>\r\n {scope.is('format', 'img') && (\r\n <Image source={scope.getDisplayValue()} />\r\n )}\r\n {scope.is('format', 'icon') && <UIIcon scope={scope} crud={crud} />}\r\n {!scope.is('format', 'icon', 'img') && (\r\n <Text>{scope.getDisplayValue()}</Text>\r\n )}\r\n </>\r\n )}\r\n {scope.is('type', 'output', 'value') && (\r\n <Text style={getStyle('value')}>{scope.getDisplayValue()}</Text>\r\n )}\r\n </>\r\n );\r\n };\r\n\r\n let Include = ({ name, style }: any) => {\r\n if (props[name]) {\r\n let define = ComponentUtils.getDefine(props, name);\r\n\r\n if (!Utils.isEmpty(define)) {\r\n return (\r\n <UIChildren\r\n {...props}\r\n scope={scope}\r\n crud={crud}\r\n style={getStyle(name, style)}\r\n >\r\n {define}\r\n </UIChildren>\r\n );\r\n }\r\n }\r\n return <></>;\r\n };\r\n\r\n let Container = () => {\r\n return (\r\n <>\r\n {isShowLabel() && (\r\n <View\r\n style={getStyle('outerLabel', {\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n display: 'flex',\r\n justifyContent: 'space-between',\r\n alignItems: 'center',\r\n width: '100%',\r\n })}\r\n >\r\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\r\n <Include name=\"actions\" style={{ width: 'auto' }} />\r\n </View>\r\n )}\r\n {isShowInner() && (\r\n <>\r\n <View style={getStyle('inner')}>\r\n <Inner />\r\n </View>\r\n {error && (\r\n <View\r\n style={getStyle('error', {\r\n fontSize: 12,\r\n paddingTop: 4,\r\n color: '#e55b5b',\r\n })}\r\n >\r\n {error}\r\n </View>\r\n )}\r\n </>\r\n )}\r\n {scope.isType('list', 'repeat') && (\r\n <UIList {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('order') && (\r\n <UIOrder {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {scope.isType('chart') && (\r\n <ElChart {...props} scope={scope} crud={crud} />\r\n )}\r\n {scope.isType('tabs') && (\r\n <ElTabs {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {scope.isType('view') && (\r\n <UIView {...props} scope={scope} crud={crud} />\r\n )}\r\n\r\n {isShowChild() && (\r\n <UIChildren\r\n {...props}\r\n scope={scope}\r\n crud={crud}\r\n style={getStyle('inner')}\r\n />\r\n )}\r\n <UIModal {...props} scope={scope} crud={crud} />\r\n </>\r\n );\r\n };\r\n\r\n let Card = (props: any) => {\r\n let isCard = scope.is('type|layout', 'card');\r\n\r\n if (scope.isType('list')) {\r\n let empty = scope.getPart('empty', null, undefined);\r\n let items = scope.getItems();\r\n\r\n if (empty === false && Utils.isEmpty(items)) {\r\n isCard = false;\r\n }\r\n }\r\n\r\n if (isCard) {\r\n let box = {\r\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\r\n };\r\n\r\n return (\r\n <View style={getStyle('card', { ...box })}>\r\n <View\r\n style={getStyle('boxInner', {\r\n paddingHorizontal: 15,\r\n paddingVertical: 10,\r\n })}\r\n >\r\n {props.children}\r\n </View>\r\n </View>\r\n );\r\n }\r\n\r\n if (scope.isInput() || original.container) {\r\n return (\r\n <View\r\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\r\n >\r\n {props.children}\r\n </View>\r\n );\r\n }\r\n return <>{props.children}</>;\r\n };\r\n\r\n scope.dialogShow = (args?: MethodType) => {\r\n let event = Utils.nvl(args?.event, {});\r\n\r\n if (event?.debug) console.log(args);\r\n\r\n let caller = args.caller;\r\n let main = ViewUtils.getCrud('view');\r\n let parent = main.dialog;\r\n let { crud } = args;\r\n let name = scope.getName('modal');\r\n let edit = args.edit === true;\r\n let def: any = {};\r\n let rowItem = null;\r\n let component = event?.component;\r\n let elo = Utils.nvl(caller?.original, original);\r\n\r\n if (crud.is('row')) {\r\n def.parent = crud.parent.parent;\r\n def.search = crud.parent;\r\n\r\n rowItem = crud.data;\r\n } else if (crud.is('search')) {\r\n def.parent = crud.parent;\r\n def.search = crud;\r\n }\r\n\r\n let crudData = crud.data;\r\n let eventData = Utils.nvl(event.data, event.send);\r\n\r\n if (typeof eventData === 'function') {\r\n eventData = eventData.call(this, args);\r\n }\r\n\r\n if (event.send === false || event.data === false) {\r\n crudData = {};\r\n }\r\n\r\n let data = Utils.nvl(eventData, args.item, rowItem, crudData, {});\r\n\r\n let d = CrudUtils.create('dialog', {\r\n parent: crud,\r\n root: crud,\r\n name,\r\n data,\r\n edit,\r\n scope,\r\n ...def,\r\n });\r\n\r\n let el: any = {\r\n label: elo.label,\r\n icon: elo.icon,\r\n type: 'dialog',\r\n };\r\n\r\n let close = event.dialog?.close;\r\n\r\n if (typeof event.dialog === 'object') {\r\n el = { ...el, ...event.dialog };\r\n }\r\n\r\n if (event.header) el.header = event.header;\r\n if (event.label) el.label = event.label;\r\n if (event.title) el.title = event.title;\r\n\r\n let label = Utils.nvl(el.title, el.label);\r\n\r\n el.label = label;\r\n\r\n let dialogScope = ScopeUtils.create({\r\n parent: scope,\r\n crud: d,\r\n ...el,\r\n owner: scope,\r\n });\r\n\r\n let dialog = {\r\n crud: d,\r\n label,\r\n parent,\r\n component,\r\n scope: dialogScope,\r\n close,\r\n props: event.props,\r\n debug: event.debug,\r\n };\r\n\r\n main.dialog = dialog;\r\n scope.currentDialog = dialog;\r\n\r\n if (parent) parent.update?.();\r\n scope.update();\r\n };\r\n\r\n scope.dialogHide = (args?: MethodType) => {\r\n let main = ViewUtils.getCrud('view');\r\n let current = main.dialog;\r\n let next = Utils.nvl(current.parent, null);\r\n\r\n main.dialog = next;\r\n scope.currentDialog = next;\r\n\r\n let nextScope = next?.scope?.parent;\r\n let currScope = current?.scope?.parent;\r\n\r\n if (currScope) {\r\n const close = current.close;\r\n\r\n currScope.update();\r\n\r\n if (close) {\r\n if (close?.debug) console.log('Fechando');\r\n current.scope.call('close', { close });\r\n }\r\n }\r\n\r\n if (nextScope) {\r\n nextScope.update();\r\n }\r\n };\r\n\r\n return (\r\n <CrudContext.Provider value={{ crud, theme }}>\r\n <Tag ref={ref} style={getStyle()} {...custom}>\r\n <Card>\r\n <Container />\r\n </Card>\r\n </Tag>\r\n </CrudContext.Provider>\r\n );\r\n}\r\n\r\nlet boxStyle = StyleSheet.create({\r\n box: {\r\n borderWidth: 0,\r\n borderColor: '#dedede',\r\n borderStyle: 'solid',\r\n backgroundColor: 'white',\r\n borderRadius: 12,\r\n width: '100%',\r\n shadowColor: '#000',\r\n shadowOpacity: 0.1,\r\n shadowRadius: 4,\r\n },\r\n});\r\n\r\nconst box: any = {\r\n ...boxStyle.box,\r\n};\r\n//v4\r\nconst elementStyle: any = {};\r\n\r\nelementStyle.view = {\r\n inner: {\r\n width: '100%',\r\n alignItems: 'normal',\r\n flex: 1,\r\n },\r\n container: {\r\n width: '100%',\r\n backgroundColor: 'background',\r\n flex: 1,\r\n gap: 10,\r\n },\r\n root: {\r\n width: '100%',\r\n flex: 1,\r\n alignItems: 'normal',\r\n padding: 0,\r\n },\r\n};\r\n\r\nelementStyle.input = StyleSheet.create({\r\n label: {\r\n paddingLeft: 0,\r\n },\r\n inner: {\r\n flex: 1,\r\n width: '100%',\r\n padding: 0,\r\n gap: 10,\r\n alignSelf: 'flex-start',\r\n flexDirection: 'row',\r\n flexWrap: 'wrap',\r\n },\r\n});\r\n\r\nelementStyle.quantity = {\r\n inner: {\r\n ...box,\r\n backgroundColor: 'primarySoft',\r\n fontWeight: 600,\r\n fontSize: 16,\r\n borderRadius: 25,\r\n borderWidth: 0,\r\n paddingHorizontal: 5,\r\n paddingVertical: 5,\r\n flexWrap: 'nowrap',\r\n flex: 1,\r\n flexDirection: 'row',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n },\r\n};\r\n\r\nelementStyle.toggle = StyleSheet.create({\r\n inner: {\r\n ...box,\r\n flex: 1,\r\n width: '100%',\r\n gap: 10,\r\n justifyContent: 'center',\r\n flexDirection: 'row',\r\n paddingHorizontal: 10,\r\n paddingVertical: 0,\r\n alignSelf: 'flex-start',\r\n flexWrap: 'nowrap',\r\n },\r\n});\r\n\r\nconst styles = StyleSheet.create({\r\n root: {\r\n gap: 5,\r\n flexDirection: 'column',\r\n flexWrap: 'wrap',\r\n width: '100%',\r\n alignItems: 'flex-start',\r\n },\r\n label: {\r\n fontWeight: 400,\r\n fontSize: 12,\r\n paddingVertical: 3,\r\n color: 'labelColor',\r\n },\r\n inner: { width: '100%' },\r\n});\r\n\r\nconst withChildStyles = StyleSheet.create({\r\n root: {\r\n gap: 10,\r\n },\r\n label: {\r\n width: '100%',\r\n fontWeight: 500,\r\n fontSize: 24,\r\n },\r\n});\r\n","import UIChildren from '../UIChildren';\r\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\r\n\r\nexport default function UIInclude(props: DefineType) {\r\n if (props.rendered === false) {\r\n return <></>;\r\n }\r\n\r\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\r\n\r\n if (Utils.isEmpty(includes)) {\r\n includes = props.default;\r\n }\r\n\r\n if (!Utils.isEmpty(includes)) {\r\n let Aux = (tagProp: any) => {\r\n let Tag: any = props.tag;\r\n\r\n if (!Utils.isEmpty(Tag)) {\r\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\r\n }\r\n return <>{tagProp.children}</>;\r\n };\r\n\r\n return (\r\n <Aux {...props.tagProps}>\r\n <UIChildren\r\n transient\r\n {...props}\r\n scope={props.scope}\r\n crud={props.crud}\r\n part={props.name}\r\n >\r\n {includes}\r\n </UIChildren>\r\n </Aux>\r\n );\r\n }\r\n return <>{includes}</>;\r\n}\r\n","import {\r\n ListType,\r\n UserType,\r\n InputType,\r\n ChartType,\r\n ContainerType,\r\n ListInputType,\r\n TabsType,\r\n DefineType,\r\n ButtonType,\r\n IconType,\r\n LinkType,\r\n SliderType,\r\n} from 'react-crud-utils';\r\nimport UIElement from './UIElement';\r\n\r\nimport UIInclude from './core/UIInclude';\r\nimport SafeView from './core/SafeView';\r\nimport GestureView from './core/GestureView';\r\n\r\nconst UI = {\r\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\r\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\r\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\r\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\r\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\r\n Repeat: (props: ListType) => (\r\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\r\n ),\r\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\r\n Include: (props: DefineType) => <UIInclude {...props} />,\r\n Column: ({ type = 'column', ...props }: UserType) => (\r\n <UIElement {...props} type=\"column\" />\r\n ),\r\n Input: (props: InputType) => <UIElement {...props} />,\r\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\r\n Textarea: (props: InputType) => <UIElement {...props} type=\"textarea\" />,\r\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\r\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\r\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\r\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\r\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\r\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\r\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\r\n View: (props: ContainerType) => (\r\n <UIElement {...props} type=\"view\" transient />\r\n ),\r\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\r\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\r\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\r\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\r\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\r\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\r\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\r\n Step: (props: ContainerType) => (\r\n <UIElement {...props} type=\"tab\" layout=\"step\" />\r\n ),\r\n Stepper: (props: TabsType) => (\r\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\r\n ),\r\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\r\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\r\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\r\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\r\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\r\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\r\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\r\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\r\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\r\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\r\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\r\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\r\n Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\r\n SafeView: SafeView,\r\n GestureView: GestureView,\r\n};\r\nexport default UI;\r\n","import {\r\n Keyboard,\r\n KeyboardAvoidingView,\r\n Platform,\r\n StatusBar,\r\n StyleProp,\r\n TouchableWithoutFeedback,\r\n ViewStyle,\r\n} from 'react-native';\r\nimport {\r\n SafeAreaProvider,\r\n SafeAreaView as SafeAreaContextView,\r\n} from 'react-native-safe-area-context';\r\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function SafeView(props: SafeViewType) {\r\n let theme = ThemeUtils.getCurrentTheme();\r\n //v2\r\n\r\n if (Utils.isEmpty(theme)) {\r\n theme = useTheme();\r\n }\r\n\r\n const dismissKeyboard = () => {\r\n if (Platform.OS !== 'web') {\r\n Keyboard.dismiss();\r\n }\r\n };\r\n\r\n return (\r\n <SafeAreaProvider>\r\n <SafeAreaContextView\r\n style={{\r\n backgroundColor: theme.colors?.theme,\r\n ...props.viewStyle,\r\n flex: 1,\r\n }}\r\n >\r\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\r\n <KeyboardAvoidingView\r\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\r\n style={{\r\n flex: 1, // 🔹 Ocupa 100% da tela\r\n justifyContent: 'flex-start',\r\n }}\r\n >\r\n <TouchableWithoutFeedback\r\n onPress={dismissKeyboard}\r\n accessible={false}\r\n >\r\n <>{props.children}</>\r\n </TouchableWithoutFeedback>\r\n </KeyboardAvoidingView>\r\n </SafeAreaContextView>\r\n </SafeAreaProvider>\r\n );\r\n}\r\n","import { StyleProp, ViewStyle } from 'react-native';\r\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\r\n\r\ninterface SafeViewType {\r\n safeStyle?: StyleProp<ViewStyle> | any;\r\n viewStyle?: StyleProp<ViewStyle> | any;\r\n children?: any;\r\n}\r\n\r\nexport default function GestureView(props: SafeViewType) {\r\n return (\r\n <GestureHandlerRootView style={{ flex: 1 }}>\r\n {props.children}\r\n </GestureHandlerRootView>\r\n );\r\n}\r\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","BUTTONS_SIZE","small","minWidth","height","UIButton","size","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","fontSize","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","iconSize","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","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","textAlignVertical","numberOfLines","Math","defs","inputProps","inputStyle","autoHeight","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","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","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","renderItem","drag","isActive","getIndex","getItemLabel","ScaleDecorator","delayLongPress","onLongPress","Header","_ref3","pos","headerPos","OrderData","setData","DraggableFlatList","ListHeaderComponent","ListFooterComponent","containerStyle","keyExtractor","getItemValue","onDragEnd","_ref4","borderBottomWidth","borderBottomColor","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","_scope$currentDialog","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","open","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Aux","Inner","InputProps","checked","getSelectedValue","control","Image","source","define","Card","isCard","box","boxStyle","dialogShow","caller","main","rowItem","elo","crudData","eventData","send","_this","d","root","_event$dialog","dialogHide","next","nextScope","_next$scope","currScope","_current$scope","Provider","shadowColor","shadowOpacity","shadowRadius","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Textarea","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","useTheme","SafeAreaProvider","SafeAreaContextView","viewStyle","StatusBar","barStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible","GestureView"],"mappings":"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"}