react-crud-mobile 1.0.684 → 1.0.686

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/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/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...scope.getStyle(part) };\n };\n\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n\n let color = element.color;\n let label = element.label;\n let icon = element.icon;\n\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n paddingRight: 10,\n paddingLeft: 10,\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n height: 44,\n minWidth: 44,\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: {\n alignItems: 'center',\n margin: 'auto',\n width: '100%',\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n flex: 1,\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n let extra: any = {};\n\n if (!label) {\n extra.button = { width: 'auto' };\n extra.icon = { padding: 5 };\n } else if (icon) {\n extra.button = { padding: 0, paddingHorizontal: 20 };\n }\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={style('button', extra.button)}\n >\n <View style={style('buttonInner')}>\n {icon && (\n <>\n <Ionicons\n size={30}\n style={style('buttonIcon', extra.icon)}\n name={icon}\n />\n </>\n )}\n {label && <Text style={style('buttonLabel')}>{label}</Text>}\n </View>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport {\n ChildType,\n MethodType,\n useTheme,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = useTheme();\n const main = ViewUtils.getCrud('view');\n\n const handlePress = () => {\n const _modalVisible = !modalVisible;\n\n main.data.selectIsOpen = _modalVisible;\n setModalVisible(_modalVisible);\n };\n\n const onClick = ({ crud, value }: MethodType) => {\n scope.changeValue(value);\n handlePress();\n };\n\n const style = (part: string, extra?: any) => {\n return { ...styles[part], ...scope.getStyle(part), ...extra };\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n\n return (\n <View style={style('selectRoot')}>\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Ionicons name=\"arrow-down\" size={20} color=\"#888\" />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <StatusBar\n barStyle=\"dark-content\"\n backgroundColor={theme.colors.primary}\n />\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{placeholder}</Text>\n </View>\n <View style={style('modalContent')}>\n <UI.List data={items} name={scope.getName('list')} click={onClick}>\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 20,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n paddingTop: StatusBar.currentHeight || 0, // Considera a altura da barra de status no Android\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: '#6200ea',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n width: '100%',\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 20,\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n 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 { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.nvl(scope.getValue(), '');\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n return (\n <>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flexDirection: 'row',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 10,\n paddingVertical: 5,\n padding: 10,\n paddingLeft: 5,\n paddingRight: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = Utils.nvl(original.cols, 1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(original.cols, 1);\n const items = Utils.nvl(scope.getItems(), []);\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n let [index, setIndex] = useState(0);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n const isShowAdd = () => {\n if (!Utils.isEmpty(items)) {\n return true;\n }\n return hideAddWhenEmpty !== true;\n };\n\n let Empty = () => {\n if (!Utils.isEmpty(items)) {\n return <></>;\n }\n\n let empty = scope.attr('empty', 'Sem registro');\n\n if (!empty) {\n return <></>;\n }\n\n if (typeof empty === 'string') {\n return (\n <Text\n style={scope.getStyle('empty', {\n flex: 1,\n fontWeight: 500,\n fontSize: 20,\n padding: 10,\n textAlign: 'center',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n let keyData = scope.key('data');\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n right={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n\n <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n alignItems: 'stretch',\n gap: 10,\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n alignItems: 'stretch',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 15,\n marginVertical: 8,\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 16,\n fontWeight: '500',\n },\n});\n","import { Ionicons } from '@expo/vector-icons';\nimport { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIQuantity(props: ChildType) {\n const scope = props.scope;\n const element = scope.original;\n\n let [index, setIndex] = useState(0);\n\n const value = scope.getValue(0);\n\n let color = element.color;\n\n if (!color) color = 'primary';\n\n const btn = {\n padding: 10,\n alignItems: 'center',\n height: 44,\n width: 44,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { useEffect, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n useTheme,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\n\nexport default function UIModal(props: ChildType) {\n let [modalVisible, setModalVisible] = useState(false);\n let [index, setIndex] = useState(0);\n let main = ViewUtils.getCrud('view');\n\n const scope = props.scope;\n const label = scope.getLabel();\n const theme = useTheme();\n\n const style = (part: string, extra?: any) => {\n let st = { ...styles[part], ...extra };\n\n return { ...scope.getStyle(part, st) };\n };\n\n const onClose = () => {\n scope.close({ scope, crud: scope.currentDialog, event: {} });\n };\n\n const toggle = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.update = () => {\n setIndex(++index);\n };\n scope.show = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n\n if (crud.is('row')) {\n def.parent = crud.parent.parent;\n def.search = crud.parent;\n\n rowItem = crud.data;\n } else if (crud.is('search')) {\n def.parent = crud.parent;\n def.search = crud;\n }\n\n let data = Utils.nvl(args.item, rowItem, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: crud,\n name,\n dialog: main.dialog,\n data,\n edit,\n scope,\n ...def,\n });\n\n main.dialog = d;\n\n scope.currentDialog = d;\n\n toggle(true);\n };\n\n scope.hide = (args?: MethodType) => {\n let old = scope.currentDialog;\n\n main.dialog = Utils.nvl(old.dialog, null);\n scope.currentDialog = null;\n\n toggle(false);\n\n if (main.dialog?.scope) {\n main.dialog.scope.update();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, [modalVisible]);\n\n let curr = scope.currentDialog;\n\n if (!curr) {\n return <></>;\n }\n\n if (curr.uuid !== main.dialog?.uuid) {\n return <></>;\n }\n\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={scope.currentDialog} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1 }}\n style={style('modalContent')}\n >\n <View style={{ flex: 1 }}>\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {props.children}\n </UIChildren>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalSafe: {\n flex: 1,\n backgroundColor: 'primary',\n width: '100%',\n },\n modalHeader: {\n height: 58,\n flexWrap: 'nowrap',\n flexDirection: 'row',\n alignContent: 'center',\n justifyContent: 'flex-start',\n alignItems: 'center',\n padding: 15,\n backgroundColor: 'primary',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n padding: 20,\n },\n});\n","import { ScrollView, StyleSheet, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, useTheme, Utils, ViewUtils } from 'react-crud-utils';\nimport { useEffect } from 'react';\nimport { StatusBar } from 'react-native';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = useTheme();\n const header = scope.getPart('header', null, []);\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n let hasHeader = !Utils.isEmpty(header);\n\n return (\n <>\n {hasHeader && (\n <View\n style={{\n padding: 20,\n height: 58,\n flexWrap: 'nowrap',\n flexDirection: 'row',\n alignContent: 'center',\n justifyContent: 'flex-start',\n alignItems: 'center',\n }}\n >\n {header}\n </View>\n )}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {})}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {\n backgroundColor: 'primary',\n },\n view: {\n backgroundColor: 'primary',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n ChildType,\n MethodType,\n ActionType,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n crud = scope.crud;\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\n }\n };\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, def) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n let Tag: any = View;\n let custom: any = {};\n\n if (!scope.isType('input', 'grid', 'list', 'repeat') && original.click) {\n Tag = TouchableHighlight;\n\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <>\n {isShowLabel() && (\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', 'icon') && (\n <UIIcon\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {scope.getDisplayValue()}\n </UIIcon>\n )}\n {scope.is('type', 'link') && (\n <UILink\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'link')}>\n {scope.getLabel()}\n </Text>\n )}\n </UILink>\n )}\n {isInput && (\n <UIInput\n {...defaultsInput}\n {...defaultsUI}\n InputProps={{ ...original.inputProps }}\n />\n )}\n {scope.is('type', 'complete', 'autocomplete') && (\n <UIComplete\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'quantity') && (\n <UIQuantity\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\n <UISwitch\n checked={isChecked()}\n {...defaultsInput}\n onChange={onCheck}\n />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && (\n <UIIcon scope={scope} crud={crud} />\n )}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>\n {scope.getDisplayValue()}\n </Text>\n )}\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nconst box: any = {\n backgroundColor: 'white',\n padding: 16,\n borderRadius: 10,\n width: '100%',\n shadowColor: '#888', // iOS\n shadowOffset: { width: 0, height: 1 }, // iOS\n shadowOpacity: 0.25, // iOS\n shadowRadius: 3.84, // iOS\n elevation: 3, // Android\n};\n\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: '#f5f5f5',\n flex: 1,\n gap: 10,\n },\n child: {\n width: '100%',\n flex: 1,\n gap: 10,\n padding: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\nelementStyle.card = StyleSheet.create({\n root: {\n ...box,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 10,\n paddingTop: 5,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n});\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 8,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.switch = {\n inner: {\n paddingBottom: 6,\n paddingTop: 6,\n paddingHorizontal: 25,\n },\n};\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n padding: 5,\n paddingHorizontal: 5,\n paddingVertical: 5,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n paddingHorizontal: 10,\n paddingVertical: 0,\n alignSelf: 'flex-start',\n flexWrap: 'nowrap',\n },\n});\n\nconst styles = StyleSheet.create({\n root: {\n gap: 5,\n flexDirection: 'column',\n flexWrap: 'wrap',\n width: '100%',\n alignItems: 'flex-start',\n },\n label: {\n width: '100%',\n fontWeight: 400,\n fontSize: 12,\n color: 'labelColor',\n },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\nimport UIInclude from './core/UIInclude';\nimport SafeView from './core/SafeView';\n\nconst UI = {\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n SafeView: SafeView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\nimport { useEffect } from 'react';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n\n return (\n <SafeAreaProvider>\n <StatusBar barStyle=\"light-content\" />\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.primary,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","UIButton","color","buttonLabel","fontWeight","fontSize","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","main","ViewUtils","getCrud","handlePress","_modalVisible","selectIsOpen","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","borderWidth","borderColor","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","useRef","isVisible","ref","setIsVisible","useEffect","interval","setInterval","current","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","get","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","gap","UIList","add","ComponentUtils","getDefine","hideAddWhenEmpty","setIndex","Empty","empty","keyData","search","field","right","container","text","UIToggle","options","getInputValue","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","st","onClose","close","currentDialog","toggle","vis","show","args","rowItem","is","d","root","dialog","hide","_main$dialog","setBarStyle","setBackgroundColor","curr","uuid","_main$dialog2","headerRight","ScrollView","contentContainerStyle","flexGrow","alignContent","UIView","header","hasHeader","onScroll","scroll","scrollEventThrottle","keyboardShouldPersistTaps","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","updateElement","prompt","message","title","Alert","alert","cancelable","c","custom","tag","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","classList","bg","HtmlUtils","getBGColor","isRendered","Tag","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","card","paddingBottom","quantity","UIInclude","includes","position","tagProp","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"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"}
1
+ {"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/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/UIModal.tsx","../src/elements/core/UIView.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...scope.getStyle(part) };\n };\n\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n\n let color = element.color;\n let label = element.label;\n let icon = element.icon;\n\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n paddingRight: 10,\n paddingLeft: 10,\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n height: 44,\n minWidth: 44,\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: {\n alignItems: 'center',\n margin: 'auto',\n width: '100%',\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n flex: 1,\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n let extra: any = {};\n\n if (!label) {\n extra.button = { width: 'auto' };\n extra.icon = { padding: 5 };\n } else if (icon) {\n extra.button = { padding: 0, paddingHorizontal: 20 };\n }\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={style('button', extra.button)}\n >\n <View style={style('buttonInner')}>\n {icon && (\n <>\n <Ionicons\n size={30}\n style={style('buttonIcon', extra.icon)}\n name={icon}\n />\n </>\n )}\n {label && <Text style={style('buttonLabel')}>{label}</Text>}\n </View>\n </TouchableHighlight>\n );\n}\n","import { useState } from 'react';\nimport {\n ChildType,\n MethodType,\n useTheme,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = useTheme();\n const main = ViewUtils.getCrud('view');\n\n const handlePress = () => {\n const _modalVisible = !modalVisible;\n\n main.data.selectIsOpen = _modalVisible;\n setModalVisible(_modalVisible);\n };\n\n const onClick = ({ crud, value }: MethodType) => {\n scope.changeValue(value);\n handlePress();\n };\n\n const style = (part: string, extra?: any) => {\n return { ...styles[part], ...scope.getStyle(part), ...extra };\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n\n return (\n <View style={style('selectRoot')}>\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Ionicons name=\"arrow-down\" size={20} color=\"#888\" />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <StatusBar\n barStyle=\"dark-content\"\n backgroundColor={theme.colors.primary}\n />\n <SafeAreaView style={style('modalSafe')}>\n <View style={style('modalHeader')}>\n <TouchableOpacity\n onPress={() => setModalVisible(false)}\n style={style('modalCloseButton')}\n >\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{placeholder}</Text>\n </View>\n <View style={style('modalContent')}>\n <UI.List data={items} name={scope.getName('list')} click={onClick}>\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 20,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalSafe: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n paddingTop: StatusBar.currentHeight || 0, // Considera a altura da barra de status no Android\n },\n modalHeader: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 15,\n backgroundColor: '#6200ea',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n width: '100%',\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n padding: 20,\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n 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 { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.nvl(scope.getValue(), '');\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n return (\n <>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flexDirection: 'row',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 10,\n paddingVertical: 5,\n padding: 10,\n paddingLeft: 5,\n paddingRight: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = Utils.nvl(original.cols, 1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(original.cols, 1);\n const items = Utils.nvl(scope.getItems(), []);\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n let [index, setIndex] = useState(0);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n const isShowAdd = () => {\n if (!Utils.isEmpty(items)) {\n return true;\n }\n return hideAddWhenEmpty !== true;\n };\n\n let Empty = () => {\n if (!Utils.isEmpty(items)) {\n return <></>;\n }\n\n let empty = scope.attr('empty', 'Sem registro');\n\n if (!empty) {\n return <></>;\n }\n\n if (typeof empty === 'string') {\n return (\n <Text\n style={scope.getStyle('empty', {\n flex: 1,\n fontWeight: 500,\n fontSize: 20,\n padding: 10,\n textAlign: 'center',\n justifyContent: 'center',\n alignItems: 'center',\n })}\n >\n {empty}\n </Text>\n );\n }\n\n return <>{empty}</>;\n };\n\n let keyData = scope.key('data');\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n right={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n\n <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n alignItems: 'stretch',\n gap: 10,\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n alignItems: 'stretch',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 15,\n marginVertical: 8,\n backgroundColor: '#f5f5f5',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 16,\n fontWeight: '500',\n },\n});\n","import { Ionicons } from '@expo/vector-icons';\nimport { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nexport default function UIQuantity(props: ChildType) {\n const scope = props.scope;\n const element = scope.original;\n\n let [index, setIndex] = useState(0);\n\n const value = scope.getValue(0);\n\n let color = element.color;\n\n if (!color) color = 'primary';\n\n const btn = {\n padding: 10,\n alignItems: 'center',\n height: 44,\n width: 44,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { useEffect, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n useTheme,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n StatusBar,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\n\nexport default function UIModal(props: ChildType) {\n let [modalVisible, setModalVisible] = useState(false);\n let [index, setIndex] = useState(0);\n let main = ViewUtils.getCrud('view');\n\n const scope = props.scope;\n const label = scope.getLabel();\n const theme = useTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n\n const style = (part: string, extra?: any) => {\n let st = { ...styles[part], ...extra };\n\n return { ...scope.getStyle(part, st) };\n };\n\n const onClose = () => {\n scope.close({ scope, crud: scope.currentDialog, event: {} });\n };\n\n const toggle = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.update = () => {\n setIndex(++index);\n };\n scope.show = (args?: MethodType) => {\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n\n if (crud.is('row')) {\n def.parent = crud.parent.parent;\n def.search = crud.parent;\n\n rowItem = crud.data;\n } else if (crud.is('search')) {\n def.parent = crud.parent;\n def.search = crud;\n }\n\n let data = Utils.nvl(args.item, rowItem, {});\n\n let d = CrudUtils.create('dialog', {\n parent: crud,\n root: crud,\n name,\n dialog: main.dialog,\n data,\n edit,\n scope,\n ...def,\n });\n\n main.dialog = d;\n\n scope.currentDialog = d;\n\n toggle(true);\n };\n\n scope.hide = (args?: MethodType) => {\n let old = scope.currentDialog;\n\n main.dialog = Utils.nvl(old.dialog, null);\n scope.currentDialog = null;\n\n toggle(false);\n\n if (main.dialog?.scope) {\n main.dialog.scope.update();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, [modalVisible]);\n\n let curr = scope.currentDialog;\n\n if (!curr) {\n return <></>;\n }\n\n if (curr.uuid !== main.dialog?.uuid) {\n return <></>;\n }\n\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n\n return (\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity onPress={onClose} style={style('modalCloseButton')}>\n <Text style={style('modalCloseText')}>X</Text>\n </TouchableOpacity>\n <Text style={style('modalTitle')}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={scope.currentDialog} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1 }}\n style={style('modalContent')}\n >\n <View style={{ flex: 1 }}>\n <UIChildren scope={scope} crud={scope.currentDialog}>\n {props.children}\n </UIChildren>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n );\n}\n\nconst styles = StyleSheet.create({\n modalSafe: {\n flex: 1,\n backgroundColor: 'primary',\n width: '100%',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n color: 'white',\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: '#f5f5f5',\n padding: 20,\n },\n});\n","import { ScrollView, StyleSheet, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, useTheme, Utils, ViewUtils } from 'react-crud-utils';\nimport { useEffect } from 'react';\nimport { StatusBar } from 'react-native';\n\nexport default function UIView({ scope, children }: ChildType) {\n const theme = useTheme();\n const header = scope.getPart('header', null, []);\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n let hasHeader = !Utils.isEmpty(header);\n\n return (\n <>\n {hasHeader && (\n <View style={scope.getStyle('header', headerStyle)}>{header}</View>\n )}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {})}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n padding: 10,\n },\n container: {\n backgroundColor: 'primary',\n },\n view: {\n backgroundColor: 'primary',\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n ChildType,\n MethodType,\n ActionType,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n crud = scope.crud;\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\n }\n };\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, def) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n let Tag: any = View;\n let custom: any = {};\n\n if (!scope.isType('input', 'grid', 'list', 'repeat') && original.click) {\n Tag = TouchableHighlight;\n\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <>\n {isShowLabel() && (\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', 'icon') && (\n <UIIcon\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {scope.getDisplayValue()}\n </UIIcon>\n )}\n {scope.is('type', 'link') && (\n <UILink\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'link')}>\n {scope.getLabel()}\n </Text>\n )}\n </UILink>\n )}\n {isInput && (\n <UIInput\n {...defaultsInput}\n {...defaultsUI}\n InputProps={{ ...original.inputProps }}\n />\n )}\n {scope.is('type', 'complete', 'autocomplete') && (\n <UIComplete\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'quantity') && (\n <UIQuantity\n scope={scope}\n defaultsInput={defaultsInput}\n defaultsUI={defaultsUI}\n />\n )}\n {scope.is('type', 'checkbox', 'boolean', 'switch') && (\n <UISwitch\n checked={isChecked()}\n {...defaultsInput}\n onChange={onCheck}\n />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && (\n <UIIcon scope={scope} crud={crud} />\n )}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>\n {scope.getDisplayValue()}\n </Text>\n )}\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nconst box: any = {\n backgroundColor: 'white',\n padding: 16,\n borderRadius: 10,\n width: '100%',\n shadowColor: '#888', // iOS\n shadowOffset: { width: 0, height: 1 }, // iOS\n shadowOpacity: 0.25, // iOS\n shadowRadius: 3.84, // iOS\n elevation: 3, // Android\n};\n\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: '#f5f5f5',\n flex: 1,\n gap: 10,\n },\n child: {\n width: '100%',\n flex: 1,\n gap: 10,\n padding: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\nelementStyle.card = StyleSheet.create({\n root: {\n ...box,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 10,\n paddingTop: 5,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n});\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 8,\n },\n inner: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 20,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.switch = {\n inner: {\n paddingBottom: 6,\n paddingTop: 6,\n paddingHorizontal: 25,\n },\n};\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n padding: 5,\n paddingHorizontal: 5,\n paddingVertical: 5,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n inner: {\n ...box,\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n paddingHorizontal: 10,\n paddingVertical: 0,\n alignSelf: 'flex-start',\n flexWrap: 'nowrap',\n },\n});\n\nconst styles = StyleSheet.create({\n root: {\n gap: 5,\n flexDirection: 'column',\n flexWrap: 'wrap',\n width: '100%',\n alignItems: 'flex-start',\n },\n label: {\n width: '100%',\n fontWeight: 400,\n fontSize: 12,\n color: 'labelColor',\n },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\nimport UIInclude from './core/UIInclude';\nimport SafeView from './core/SafeView';\n\nconst UI = {\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n SafeView: SafeView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\nimport { useEffect } from 'react';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n useEffect(() => {\n StatusBar.setBarStyle('light-content');\n StatusBar.setBackgroundColor?.(theme.colors.primary);\n }, []);\n\n return (\n <SafeAreaProvider>\n <StatusBar barStyle=\"light-content\" />\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.primary,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'center',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","UIButton","color","buttonLabel","fontWeight","fontSize","paddingRight","paddingLeft","buttonInner","flexDirection","alignItems","justifyContent","height","minWidth","buttonIcon","button","margin","textAlign","verticalAling","borderRadius","backgroundColor","flex","extra","padding","paddingHorizontal","TouchableHighlight","underlayColor","e","call","size","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","useTheme","main","ViewUtils","getCrud","handlePress","_modalVisible","selectIsOpen","Modal","animationType","transparent","visible","onRequestClose","StatusBar","barStyle","colors","primary","SafeAreaView","List","getName","Value","selectRoot","selectInput","paddingVertical","selectLabel","modalSafe","paddingTop","currentHeight","modalHeader","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","alignSelf","flexWrap","UISwitch","initial","setValue","Switch","onValueChange","v","UIOption","UIRadio","UIInput","getLabel","getPart","el","TextInput","onChangeText","base","borderWidth","borderColor","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","useRef","isVisible","ref","setIsVisible","useEffect","interval","setInterval","current","_scope$original","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","get","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","gap","UIList","add","ComponentUtils","getDefine","hideAddWhenEmpty","setIndex","Empty","empty","keyData","search","field","right","container","text","UIToggle","options","getInputValue","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","headerStyle","_theme$styles","defaults","header","st","onClose","close","currentDialog","toggle","vis","show","args","rowItem","is","d","root","dialog","hide","_main$dialog","setBarStyle","setBackgroundColor","curr","uuid","_main$dialog2","headerRight","ScrollView","contentContainerStyle","flexGrow","UIView","hasHeader","onScroll","scroll","scrollEventThrottle","keyboardShouldPersistTaps","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","updateElement","prompt","message","title","Alert","alert","cancelable","c","custom","tag","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$list","url","_original$load","load","start","CustomIcon","open","useLayoutEffect","classList","bg","HtmlUtils","getBGColor","isRendered","Tag","Provider","variant","InputProps","inputProps","checked","getSelectedValue","control","Image","source","box","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","card","paddingBottom","quantity","UIInclude","includes","position","tagProp","tagProps","Row","Label","Repeat","Define","Column","_objectWithoutPropertiesLoose","_excluded","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Content","Top","Card","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"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"}
@@ -1101,7 +1101,7 @@ function UIQuantity(props) {
1101
1101
  }
1102
1102
 
1103
1103
  function UIModal(props) {
1104
- var _main$dialog2;
1104
+ var _theme$styles, _main$dialog2;
1105
1105
  var _useState = useState(false),
1106
1106
  modalVisible = _useState[0],
1107
1107
  setModalVisible = _useState[1];
@@ -1112,6 +1112,7 @@ function UIModal(props) {
1112
1112
  var scope = props.scope;
1113
1113
  var label = scope.getLabel();
1114
1114
  var theme = useTheme();
1115
+ var headerStyle = Utils.nvl((_theme$styles = theme.styles) == null || (_theme$styles = _theme$styles.defaults) == null ? void 0 : _theme$styles.header, {});
1115
1116
  var style = function style(part, extra) {
1116
1117
  var st = _extends({}, styles$8[part], extra);
1117
1118
  return _extends({}, scope.getStyle(part, st));
@@ -1188,7 +1189,7 @@ function UIModal(props) {
1188
1189
  children: /*#__PURE__*/jsxs(SafeAreaView, {
1189
1190
  style: style('modalSafe'),
1190
1191
  children: [/*#__PURE__*/jsxs(View, {
1191
- style: style('modalHeader'),
1192
+ style: scope.getStyle('header', headerStyle),
1192
1193
  children: [/*#__PURE__*/jsx(TouchableOpacity, {
1193
1194
  onPress: onClose,
1194
1195
  style: style('modalCloseButton'),
@@ -1230,16 +1231,6 @@ var styles$8 = /*#__PURE__*/StyleSheet.create({
1230
1231
  backgroundColor: 'primary',
1231
1232
  width: '100%'
1232
1233
  },
1233
- modalHeader: {
1234
- height: 58,
1235
- flexWrap: 'nowrap',
1236
- flexDirection: 'row',
1237
- alignContent: 'center',
1238
- justifyContent: 'flex-start',
1239
- alignItems: 'center',
1240
- padding: 15,
1241
- backgroundColor: 'primary'
1242
- },
1243
1234
  modalCloseButton: {
1244
1235
  padding: 10
1245
1236
  },
@@ -1261,10 +1252,12 @@ var styles$8 = /*#__PURE__*/StyleSheet.create({
1261
1252
  });
1262
1253
 
1263
1254
  function UIView(_ref) {
1255
+ var _theme$styles;
1264
1256
  var scope = _ref.scope,
1265
1257
  children = _ref.children;
1266
1258
  var theme = useTheme();
1267
1259
  var header = scope.getPart('header', null, []);
1260
+ var headerStyle = Utils.nvl((_theme$styles = theme.styles) == null || (_theme$styles = _theme$styles.defaults) == null ? void 0 : _theme$styles.header, {});
1268
1261
  useEffect(function () {
1269
1262
  StatusBar.setBarStyle('light-content');
1270
1263
  StatusBar.setBackgroundColor == null || StatusBar.setBackgroundColor(theme.colors.primary);
@@ -1280,15 +1273,7 @@ function UIView(_ref) {
1280
1273
  var hasHeader = !Utils.isEmpty(header);
1281
1274
  return /*#__PURE__*/jsxs(Fragment, {
1282
1275
  children: [hasHeader && /*#__PURE__*/jsx(View, {
1283
- style: {
1284
- padding: 20,
1285
- height: 58,
1286
- flexWrap: 'nowrap',
1287
- flexDirection: 'row',
1288
- alignContent: 'center',
1289
- justifyContent: 'flex-start',
1290
- alignItems: 'center'
1291
- },
1276
+ style: scope.getStyle('header', headerStyle),
1292
1277
  children: header
1293
1278
  }), /*#__PURE__*/jsx(View, {
1294
1279
  style: scope.getStyle('container', styles$9.container),