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