react-crud-mobile 1.0.618 → 1.0.620

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/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\n if (!Utils.isEmpty(props.style)) {\n console.log(props.style);\n }\n return { ...def, ...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 { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n\n return <Ionicons 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 },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderWidth: 1,\n borderColor: '#a9a9a9',\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 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, { useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\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 = ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n });\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true });\n };\n\n if (!original.click) {\n return (\n <View key={`k-${index}`} style={getRowStyle()}>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={`k-${index}`}\n underlayColor={'transparent'}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </TouchableHighlight>\n );\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 3,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n },\n});\n","import React 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';\nimport UIChildren from '../UIChildren';\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 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 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 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 },\n row: {\n padding: 5,\n margin: 3,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 8,\n padding: 10,\n width: '100%',\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 row: {\n padding: 0,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n padding: 0,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 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 flexDirection: 'row',\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 } 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 return (\n <>\n {header}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\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} 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 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 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.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 { ListType } from 'react-crud-utils';\nimport { UserType } from 'react-crud-utils';\nimport { InputType } from 'react-crud-utils';\nimport { ChartType } from 'react-crud-utils';\nimport { ContainerType } from 'react-crud-utils';\nimport { ListInputType } from 'react-crud-utils';\nimport UIElement from './UIElement';\nimport { TabsType } from 'react-crud-utils';\nimport { DefineType } from 'react-crud-utils';\nimport { ButtonType } from 'react-crud-utils';\nimport { LinkType } from 'react-crud-utils';\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: ButtonType) => <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 {\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 { useTheme } 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 const theme = useTheme();\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 StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\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?.primary,\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","key","def","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","console","log","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","s","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","push","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","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","borderWidth","borderColor","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","marginRight","input","marginHorizontal","marginVertical","UIListRow","css","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","stopPropagation","edit","gap","UIList","add","ComponentUtils","getDefine","hideAddWhenEmpty","Empty","empty","search","field","right","container","rowInner","flexGrow","text","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","st","onClose","close","currentDialog","toggle","vis","update","show","args","rowItem","is","d","root","dialog","hide","_main$dialog","useEffect","setBarStyle","setBackgroundColor","curr","uuid","headerRight","ScrollView","contentContainerStyle","UIView","header","keyboardShouldPersistTaps","scroll","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","updateElement","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","current","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","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","Platform","OS","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/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 { Ionicons } from '@expo/vector-icons';\nimport { ChildType } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n\n return <Ionicons 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 },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderWidth: 1,\n borderColor: '#a9a9a9',\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 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, { useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\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 = ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n });\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row });\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true });\n };\n\n if (!original.click) {\n return (\n <View key={`k-${index}`} style={getRowStyle()}>\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={`k-${index}`}\n style={getRowStyle()}\n underlayColor={'transparent'}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <UIChildren scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </TouchableHighlight>\n );\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 3,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n },\n});\n","import React 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';\nimport UIChildren from '../UIChildren';\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 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 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 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 },\n row: {\n padding: 5,\n margin: 3,\n width: '100%',\n backgroundColor: '#f5f5f5',\n gap: 10,\n borderRadius: 8,\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 8,\n padding: 10,\n width: '100%',\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 row: {\n padding: 0,\n width: '100%',\n },\n rowInner: {\n flexGrow: 1, // ✅ cresce conforme o conteúdo\n justifyContent: 'center',\n alignItems: 'center',\n padding: 0,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\n\n if (selected) style.color = '#ffffff';\n\n if (Utils.isEmpty(props.children)) {\n return <Text style={style}>{item.label}</Text>;\n }\n\n return (\n <UIListRow scope={scope} item={item.object} index={index}>\n {props.children}\n </UIListRow>\n );\n };\n\n const getItemStyle = (item: any) => {\n let style = { ...styles.item, ...scope.getStyle('item') };\n\n let wPart = 100 / options.length;\n let width = Math.floor(wPart) + '%';\n\n if (isSelected(item)) {\n let selectedColor = scope.getPart('selectedColor', undefined, 'primary');\n let st = scope.getStyle('selected', {\n backgroundColor: selectedColor,\n color: '#ffffff',\n });\n\n style = { ...style, ...st };\n\n if (!style.color) {\n style.color = '#ffffff';\n }\n }\n\n style.width = width;\n\n return style;\n };\n\n return (\n <>\n {options.map((item: any, i: number) => (\n <TouchableHighlight\n key={`k-${i}`}\n style={getItemStyle(item)}\n onPress={e => {\n onClick(item);\n }}\n >\n <Item item={item} index={i} />\n </TouchableHighlight>\n ))}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n width: '100%',\n gap: 10,\n justifyContent: 'center',\n flexDirection: 'row',\n },\n item: {\n padding: 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 flexDirection: 'row',\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 } 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 return (\n <>\n {header}\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\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} 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 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 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.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 { ListType } from 'react-crud-utils';\nimport { UserType } from 'react-crud-utils';\nimport { InputType } from 'react-crud-utils';\nimport { ChartType } from 'react-crud-utils';\nimport { ContainerType } from 'react-crud-utils';\nimport { ListInputType } from 'react-crud-utils';\nimport UIElement from './UIElement';\nimport { TabsType } from 'react-crud-utils';\nimport { DefineType } from 'react-crud-utils';\nimport { ButtonType } from 'react-crud-utils';\nimport { LinkType } from 'react-crud-utils';\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: ButtonType) => <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 {\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 { useTheme } 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 const theme = useTheme();\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 StatusBar.setBarStyle('light-content');\r\n StatusBar.setBackgroundColor?.(theme.colors.primary);\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?.primary,\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","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","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","borderWidth","borderColor","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","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","getRowStyle","stopPropagation","edit","gap","UIList","add","ComponentUtils","getDefine","hideAddWhenEmpty","Empty","empty","search","field","right","container","rowInner","flexGrow","text","UIToggle","options","getInputValue","setIndex","isSelected","Item","object","getItemStyle","selectedColor","undefined","UIQuantity","btn","addButton","delButton","change","val","UIModal","st","onClose","close","currentDialog","toggle","vis","update","show","args","rowItem","is","d","root","dialog","hide","_main$dialog","useEffect","setBarStyle","setBackgroundColor","curr","uuid","headerRight","ScrollView","contentContainerStyle","UIView","header","keyboardShouldPersistTaps","scroll","view","CrudContext","createContext","ctx","useContext","_useState3","error","setError","ref","useRef","updateElement","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","current","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","SafeAreaProvider","SafeAreaContextView","_theme$colors","viewStyle","KeyboardAvoidingView","behavior","Platform","OS","TouchableWithoutFeedback","Keyboard","dismiss","accessible"],"mappings":"ulBAiBwBA,EAAWC,GACjC,IAAKC,EAASC,WAASC,QAAMC,IAAIJ,EAAMC,MAAOI,aAAWC,OAAON,QAC5DO,EAAOJ,QAAMC,IAAIJ,EAAMO,KAAMN,EAAMM,MACnCC,EAAgBL,QAAMC,IAAIJ,EAAMQ,cAAe,UAC/CC,EAAON,QAAMC,IAAIJ,EAAMU,KAAM,SAEjC,GAAIT,EAAMU,UACR,OAAOC,MAAAC,eAGT,IAgFkBH,EAKiBI,EAJ7BC,EACAC,EACAC,EAnFFC,EAAQ,SAAHC,OAAMC,EAAKD,EAALC,MACb,IAAKA,EACH,OAAOR,MAAAC,eAET,GAAqB,iBAAVO,EACT,OAAOR,MAAAC,YAAAQ,SAAGD,IAGZ,IAAIE,EAASF,EAAMG,KACfC,EAAGC,KAAQL,EAAMpB,OAIrB,cAFOwB,EAAIH,SAEW,iBAAXC,EACLnB,QAAMuB,QAAQN,EAAMpB,MAAMqB,UACrBT,MAACU,EAAMG,KAAKD,IAGnBZ,MAACU,EAAMG,KAAKD,GAAGH,SACbT,MAACb,EAAU0B,GACTE,aACAnB,cAAeA,GACXY,EAAMpB,OACVC,MAAOA,EACPM,KAAMA,QAIe,mBAAXe,EAEdV,MAACU,EAAMG,GACLjB,cAAeA,GACXY,EAAMpB,OACV4B,OAAQ3B,EACRM,KAAMA,KAKPJ,QAAMuB,QAAQN,EAAMpB,MAAMqB,UAWxBT,MAAAC,eATHD,MAACb,EAAU0B,GACTjB,cAAeA,GACXY,EAAMpB,OACVC,MAAOA,EACPM,KAAMA,EACNoB,iBAOFE,EAAO,WACX,OAEIjB,MAAAC,WAFAb,EAAM8B,UAENT,SACGU,OAAOC,QAAQhC,EAAM8B,UAAUG,KAAI,SAACC,EAAQC,GAC3C,OAAOvB,MAACwB,EAASX,GAAClB,KAAMA,GAAU2B,EAAE,UAM1Cb,SACGgB,EAAMC,SAASL,IAAIjC,EAAMqB,UAAU,SAAAD,GAClC,OAAOR,MAACM,GAAME,MAAOA,UAM7B,OAAIpB,YACKY,MAACiB,MAGN1B,QAAMuB,QAAQ1B,EAAMqB,WAAalB,QAAMuB,QAAQ1B,EAAM8B,UAChDlB,MAAAC,eAuBPD,MAAAC,YAAAQ,SACET,MAAC2B,QAAKC,OArBQ9B,EAqBQD,EApBpBM,EAAMZ,QAAMC,IAAIM,EAAM,QACtBM,EAAMyB,EAAO1B,GACbE,EAAM,GAELd,QAAMuB,QAAQ1B,EAAMwC,gBACvB1B,EAAId,EAAMwC,QAAN1B,EAAa4B,KACfvC,QAAMwC,KAAK3C,EAAMwC,OAAO,SAAAI,GAClBA,IACF3B,EAAGQ,KAAQR,EAAQ2B,OAIvB3B,EAAGQ,KAAQzB,EAAMwC,QAGrBf,KAAYT,EAAQC,EAAQhB,EAAM4C,SAASnC,KAKbW,SAC1BT,MAACiB,UAMT,IAAMY,EAASK,aAAWxC,OAAO,CAC/Bc,MAAO,CAAE2B,MAAO,QAChBC,MAAO,CAAED,MAAO,mBClIME,EAAOjD,GAC7B,IAAIC,EAAQD,EAAMC,MAClBiD,EAA6ChD,WAAS,GAAjDiD,EAAaD,KAAEE,EAAgBF,KAChCG,EAAUpD,EAAMqD,SAChBC,EAAQtD,EAAMuD,WACdC,EAAU,EAEVC,EAAY,GAChBC,EAAmCzD,WAAS,MAAvC0D,EAAQD,KAAEE,EAAWF,KAEpBG,EAAc,SAACC,EAAUC,YAAAA,IAAAA,GAAW,GACpCD,GACF9D,EAAMgE,QAAQ,CACZC,MAAO,CACLF,SAAAA,EACAxD,cAAe6C,EAAQ7C,cACvB2D,OAAQ,WACNlE,EAAMmE,YAAYL,EAAIM,MAEtBT,EAAWG,EAGXX,EAFAD,EAAgBY,EAAIO,OAGpBT,EAAYE,QAOhBQ,EAAgB,SAACrC,SACjBU,EAAI,wBAKR,cAHI4B,EAAAZ,UAAAY,EAAUF,SAAUpC,EAAEoC,QACxB1B,GAAQ,oBAEHA,GAGH6B,EAAS,SAACrD,EAAYsD,GAC1B,IAAIpB,EAAQ7B,KAAQL,EAAMpB,OAErB0E,IACHA,EAAOzE,EAAMM,KAAK8D,MAGpB,IAAIM,EAAUC,YAAUtE,OAAO,OAAQ,CACrC+D,KAAMK,EACNG,QAASH,EACT9C,OAAQ3B,EAAMM,OAGZ8C,EAAUlD,QAAM2E,QAAQxB,EAAUqB,IAEb,IAArBtB,EAAQ0B,UAIZrB,EAAKhB,KAAIjB,KACJ4B,GACHjC,MAAAA,EACAiC,QAAAA,EACAC,SAAAA,EACAgB,MAAOb,IACPY,KAAMK,MAIVrC,EAAMC,SAASL,IAAIjC,EAAMqB,UAAU,SAACD,EAAOkD,GACzC,GAAInE,QAAMuB,QAAQ6B,GAChBkB,EAAOrD,EAAO,SAEd,IAAK,IAAM4D,KAAKzB,EAGdkB,EAAOrD,EAFCmC,EAAMyB,OAOfpB,GACHE,EAAYJ,EAAKP,IAAgB,GAGnC,IAAM8B,EAAM,SAACD,GAGXlB,EAFQJ,EAAKP,EAAgB6B,KAa3BE,EAA+B,YAAnB7B,EAAQ8B,OAExB,OACEvE,aACEwE,UAAWnF,EAAMsE,cAAc,SAC/B/B,MAAOvC,EAAM4C,SAAS,SAASxB,SAE/BgE,cAAKD,UAAU,kBAAiB/D,UAC9BT,aAAKwE,UAAU,gBAAe/D,SAC3BqC,EAAKzB,KAAI,SAACC,EAAQ8C,GAAS,OAC1BK,cAEED,UAAWb,EAAcrC,GACzBoD,QAAS,WACPxB,EAAY5B,IACZb,UAED6D,GAAatE,aAAKwE,UAAU,wBAC7BC,cAAKD,UAAU,oBAAmB/D,UAC/B6D,GAAatE,aAAKwE,UAAU,iBAC7BxE,aAAKwE,UAAU,oBAAmB/D,SAC/B6D,EAAYhD,EAAEoC,MAAQ,EAAIpC,EAAEqD,aAV5BpF,QAAMY,IAAIsC,EAAQmC,GAAI,MAAOR,SAgBvCpB,GACCyB,OAAAxE,YAAAQ,UACG6D,GAAatE,aAAKwE,UAAU,gBAAe/D,SAAEuC,EAAS2B,QACvD3E,aAAKwE,UAAU,eAAc/D,SAC3BT,MAACb,EAAU0B,KAAKzB,GAAOC,MAAOA,EAAMoB,SACjCuC,EAASxC,WAGM,YAAnBiC,EAAQ8B,QACPE,cAAKD,UAAU,kBAAiB/D,UAC9BT,MAAC6E,EAAGC,QAAOC,MAAO,EAAGR,OAAO,OAAM9D,SAChCT,MAAC6E,EAAGG,QAAOnE,KACLzB,GACJ2B,aACAlB,KAAK,OACLoF,QACEjF,MAAC6E,EAAGK,QACFf,SAAU5B,EAAgB,EAC1B4C,KAAMnF,MAACoF,MACPC,MAtDL,WACfhB,GAAK,WA0DOrE,MAAC6E,EAAGC,QAAOC,MAAO,EAAGR,OAAO,QAAO9D,SACjCT,MAAC6E,EAAGG,QAAOnE,KACLzB,GACJ2B,aACAlB,KAAK,QACLoF,QACEjF,MAAC6E,EAAGK,QACFf,SAAU5B,EAAgBO,EAAKwC,OAAS,EACxCH,KAAMnF,MAACoF,MACPC,MAhET,WACXhB,EAAI,+BCnGgBkB,EAAQnG,GAC9B,IAAIC,EAAeD,EAAMC,MAIzB,OAHiBA,EAAMuD,WACTrD,QAAMiG,OAAOnG,EAAMqD,SAAS+C,SAEnCzF,aAAKwE,UAAU,2BCNAkB,EAAetG,GAKrC,OACEY,MAAC2F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBrF,SACrCT,MAAC+F,QAAKnE,MAAOC,EAAOmE,KAAKvF,SAAC,8CAKhC,IAAMoB,EAAS,CACbmE,KAAM,aCZgBC,EAAU1F,GAKhC,OACEP,MAAAC,YAAAQ,SACET,MAACkG,EAAYrF,KANJN,EAAb4F,cACU5F,EAAV6F,wBCHsBC,EAAOjH,GAK7B,OACEY,MAAC2F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBrF,SACrCT,MAAC+F,QAAKnE,MAAOC,EAAOmE,KAAKvF,SAAC,8CAKhC,IAAMoB,EAAS,CACbmE,KAAM,aCZgBM,EAAM/F,OAAGlB,EAAKkB,EAALlB,MAC3BQ,EAAOR,EAAMkH,WAEjB,OAAOvG,MAACoF,YAASvF,KAAMA,EAAM+B,MAAOvC,EAAM4C,SAAS,mBCF7BuE,EAASpH,GAC/B,IAAIC,EAAQD,EAAMC,MACdoD,EAAUpD,EAAMqD,SAEhB+D,EAAQhE,EAAQgE,MAChB9B,EAAQlC,EAAQkC,MAChBQ,EAAO1C,EAAQ0C,KAEdsB,IAAOA,EAAQ,gBAEpB,IAAM5E,EAAc,CAClB6E,YAAa,CACXD,MAAO,UACPE,WAAY,MACZC,SAAU,GACVC,aAAc,GACdC,YAAa,IAEfC,YAAa,CACXC,cAAe,MACfC,WAAY,SACZC,eAAgB,SAChBC,OAAQ,GACRC,SAAU,IAEZC,WAAY,CACVZ,MAAO,OACPG,SAAU,IAEZU,OAAQ,CACNL,WAAY,SACZM,OAAQ,OACRpF,MAAO,OACPqF,UAAW,SACXC,cAAe,SACfC,aAAc,GACdC,gBAAiBlB,EACjBA,MAAO,UACPS,eAAgB,SAChBU,KAAM,IAQJhG,EAAQ,SAAC9B,EAAc+H,GAC3B,IAAI7F,EAACnB,KAAQgB,EAAO/B,GAAU+H,GAC9B,OAAOxI,EAAM4C,SAASnC,EAAMkC,IAG1B6F,EAAa,GAQjB,OANKlD,EAGMQ,IACT0C,EAAMP,OAAS,CAAEQ,QAAS,EAAGC,kBAAmB,MAHhDF,EAAMP,OAAS,CAAEnF,MAAO,QACxB0F,EAAM1C,KAAO,CAAE2C,QAAS,IAKxB9H,MAACgI,sBACCC,cAAe,cACfrC,QApBY,SAACsC,GACf7I,EAAM8I,KAAK,QAAS,KAoBlBvG,MAAOA,EAAM,SAAUiG,EAAMP,QAAQ7G,SAErCgE,OAAC9C,QAAKC,MAAOA,EAAM,eAAenB,UAC/B0E,GACCnF,MAAAC,YAAAQ,SACET,MAACoF,YACCgD,KAAM,GACNxG,MAAOA,EAAM,aAAciG,EAAM1C,MACjCtF,KAAMsF,MAIXR,GAAS3E,MAAC+F,QAAKnE,MAAOA,EAAM,eAAenB,SAAEkE,kBC5D9B0D,EAASjJ,GAC/B,IAAAkD,EAAwChD,YAAS,GAA1CgJ,EAAYhG,KAAEiG,EAAejG,KAC9BjD,EAAQD,EAAMC,MACdsD,EAAQpD,QAAMC,IAAIH,EAAMmJ,aAAc,IACtCC,EAAcpJ,EAAMqJ,KAAK,cAAe,gBACxCC,EAAQtJ,EAAMuJ,kBACdC,EAAQC,aACRC,EAAOC,YAAUC,QAAQ,QAEzBC,EAAc,WAClB,IAAMC,GAAiBb,EAEvBS,EAAKtF,KAAK2F,aAAeD,EACzBZ,EAAgBY,IAQZvH,EAAQ,SAAC9B,EAAc+H,GAC3B,OAAAhH,KAAYgB,EAAO/B,GAAUT,EAAM4C,SAASnC,GAAU+H,IAOxD,OACEpD,OAAC9C,QAAKC,MAAOA,EAAM,cAAcnB,UAC/BgE,OAACkB,oBAAiBC,QAASsD,EAAatH,MAAOA,EAAM,eAAenB,UAClET,MAAC+F,QAAKnE,MAAOA,EAAM,eAAenB,SAC/BlB,QAAMC,IAAImJ,EAAOF,KAEpBzI,MAACoF,YAASvF,KAAK,aAAauI,KAAM,GAAI3B,MAAM,YAE9ChC,OAAC4E,SACCC,cAAc,QACdC,aAAa,EACbC,QAdGlB,EAeHmB,eAAgB,WAAF,OAAQlB,GAAgB,IAAO9H,UAE7CT,MAAC0J,aACCC,SAAS,eACThC,gBAAiBkB,EAAMe,OAAOC,UAEhCpF,OAACqF,gBAAalI,MAAOA,EAAM,aAAanB,UACtCgE,OAAC9C,QAAKC,MAAOA,EAAM,eAAenB,UAChCT,MAAC2F,oBACCC,QAAS,WAAF,OAAQ2C,GAAgB,IAC/B3G,MAAOA,EAAM,oBAAoBnB,SAEjCT,MAAC+F,QAAKnE,MAAOA,EAAM,kBAAkBnB,SAAC,QAExCT,MAAC+F,QAAKnE,MAAOA,EAAM,cAAcnB,SAAEgI,OAErCzI,MAAC2B,QAAKC,MAAOA,EAAM,gBAAgBnB,SACjCT,MAAC6E,EAAGkF,MAAKtG,KAAMd,EAAO9C,KAAMR,EAAM2K,QAAQ,QAAS3E,MA1C7C,SAAH9E,GACXlB,EAAMmE,YADsBjD,EAALoI,OAEvBO,KAwC0EzI,SAChET,MAAC6E,EAAGoF,OAAMtB,MAAM,gCAS9B,IAAM9G,EAASK,aAAWxC,OAAO,CAC/BwK,WAAY,CACVhD,eAAgB,aAChBD,WAAY,cAEdkD,YAAa,CACXhI,MAAO,OACP6E,cAAe,MACfoD,YAAa,EACbC,YAAa,UACb3C,aAAc,GACdK,kBAAmB,GACnBuC,gBAAiB,IAEnBC,YAAa,CAAE3C,KAAM,GACrB4C,UAAW,CACT5C,KAAM,EACND,gBAAiB,UACjB8C,WAAYf,YAAUgB,eAAiB,GAEzCC,YAAa,CACX3D,cAAe,MACfC,WAAY,SACZa,QAAS,GACTH,gBAAiB,WAEnBiD,iBAAkB,CAChB9C,QAAS,IAEX+C,eAAgB,CACdjE,SAAU,GACVH,MAAO,SAETqE,WAAY,CACVlE,SAAU,GACVH,MAAO,QACPE,WAAY,OACZoE,WAAY,IAEdC,aAAc,CACZpD,KAAM,EACNzF,MAAO,OACP8I,UAAW,aACXjE,cAAe,MACfkE,SAAU,OACVpD,QAAS,eCjIWqD,EAAS/L,GAC/B,IAAMC,EAAQD,EAAMC,MACd+L,EAAU7L,QAAMC,IAAIH,EAAMkH,YAAY,GAC5CjE,EAA0BhD,WAAS8L,GAArBC,EAAQ/I,KAQtB,OACEtC,MAACsL,UACC3C,MAVQrG,KAWRiJ,cATW,SAAAC,GACbnM,EAAMmE,YAAYgI,GAElBH,EAASG,eCVWC,EAASrM,GAK/B,OACEY,MAAC2F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBrF,SACrCT,MAAC+F,QAAKnE,MAAOC,EAAOmE,KAAKvF,SAAC,8CAKhC,IAAMoB,EAAS,CACbmE,KAAM,aCbgB0F,EAAQtM,GAK9B,OACEY,MAAC2F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBrF,SACrCT,MAAC+F,QAAKnE,MAAOC,EAAOmE,KAAKvF,SAAC,8CAKhC,IAAMoB,EAAS,CACbmE,KAAM,aCVgB2F,EAAQvM,GAC9B,IAAIC,EAAQD,EAAMC,MACd+L,EAAU7L,QAAMC,IAAIH,EAAMkH,WAAY,IAEtC5B,EAAQtF,EAAMuM,WACdnD,EAAcpJ,EAAMwM,QAAQ,cAAe,KAAMlH,GACjDmH,EAAKzM,EAAMqD,SAEfJ,EAA0BhD,WAAS8L,GAA5BzC,EAAKrG,KAAE+I,EAAQ/I,KAYtB,OACEmC,OAAAxE,YAAAQ,UACGpB,EAAMwM,QAAQ,QACf7L,MAAC+L,aACCnK,MAPJf,KAAYxB,EAAM4C,SAOD,QAPgBJ,EAAW,YADjBgG,GASvBmE,aAfS,SAAAR,GACbnM,EAAMmE,YAAYgI,GAElBH,EAASG,IAaL7C,MAAOA,EACPF,YAAaA,IAEdqD,EAAG3G,MACFnF,MAACoF,YACCvF,KAAMiM,EAAG3G,KACTiD,KAAM/I,EAAMqJ,KAAK,WAAY,IAC7BjC,MAAOpH,EAAMqJ,KAAK,YAAa,UAGlCrJ,EAAMwM,QAAQ,YAKrB,IAAMhK,EAASK,aAAWxC,OAAO,CAC/BuM,KAAM,CACJjF,cAAe,MACfC,WAAY,SACZmD,YAAa,EACbC,YAAa,cACb3C,aAAc,GACdK,kBAAmB,GACnBuC,gBAAiB,EACjBxC,QAAS,GACThB,YAAa,EACbD,aAAc,IAEhB1B,KAAM,CACJ+G,YAAa,IAEfC,MAAO,CACLC,iBAAkB,EAClBC,eAAgB,EAChBlF,OAAQ,GACRS,KAAM,cCxDc0E,EAAUlN,SAC1BC,EAAQD,EAAMC,MACdqE,EAAQtE,EAAMsE,MACdhB,EAAWrD,EAAMqD,SACjBoB,EAAO1E,EAAM0E,KACbyI,EAAOhN,QAAMC,IAAIkD,EAAS6J,KAAM,GAChCC,EAAWC,KAAKC,MAAM,IAAMH,GAAQ,IACpC1K,SAAM8K,EAAG,CAAEC,OAAQC,EAAcC,KAAMC,WAA9BJ,EAA6CjK,EAAS/B,MAC/Dd,KAAUR,EAAMc,IAAI,MAAOuD,EAAO,IAClCsJ,EAAMvN,aAAWC,OAAMmB,KACxB6B,GACH1B,OAAQ3B,EACRQ,KAAAA,EACAF,KAAMN,EAAMM,KACZ+D,MAAAA,EACA/C,KAAM,MACN8C,KAAMK,KAEFmJ,EAAc,WAClB,IAAI5M,EAAM2M,EAAI/K,SAAS,MAAKpB,KAAOgB,EAAOmL,MAM1C,OAJIT,EAAO,IACTlM,EAAI8B,MAAQqK,GAGPnM,GAOT,OAAKqC,EAAS2C,MAUZrF,MAACgI,sBAECpG,MAAOqL,IACPhF,cAAe,cACfrC,QAAS,SAAAsC,GACPA,EAAEgF,kBAnBQ,SAACpJ,GACfkJ,EAAI7E,KAAK,QAAS,CAAEQ,MAAO7E,EAAMA,KAAAA,EAAMqJ,MAAM,IAmBzCzI,CAAQZ,IACRrD,SAEFT,MAACb,GAAWE,MAAO2N,EAAKrN,KAAMqN,EAAIrN,KAAKc,SACpCrB,EAAMqB,iBATCiD,GATV1D,MAAC2B,QAAwBC,MAAOqL,IAAcxM,SAC5CT,MAACb,GAAWE,MAAO2N,EAAKrN,KAAMqN,EAAIrN,KAAKc,SACpCrB,EAAMqB,iBAFKiD,GAwBtB,IAAMqJ,EAAa7K,aAAWxC,OAAO,CACnCsN,IAAK,CACHlF,QAAS,EACTP,OAAQ,EACRpF,MAAO,OACPwF,gBAAiB,UACjByF,IAAK,GACL1F,aAAc,KAIZmF,EAAe3K,aAAWxC,OAAO,CACrCsN,IAAK,CACHlF,QAAS,EACT3F,MAAO,mBC1EakL,EAAOjO,SAUEyI,EAKzBmF,EAdA3N,EAAQD,EAAMC,MACdM,EAAON,EAAMM,KACb+C,EAAWrD,EAAMqD,SACjB6J,EAAOhN,QAAMC,IAAIkD,EAAS6J,KAAM,GAChC5J,EAAQpD,QAAMC,IAAIH,EAAMuD,WAAY,IACpCf,SAAM8K,EAAG,CAAEC,OAAQC,EAAcC,KAAMC,WAA9BJ,EAA6CjK,EAAS/B,MAC/D2M,EAAMC,iBAAeC,UAAUpO,EAAO,OACtCqO,EAAmB/K,EAAS+K,iBAuB9BC,EAAQ,WACV,IAAKnO,QAAMuB,QAAQ6B,GACjB,OAAO3C,MAAAC,eAGT,IAAI0N,EAAQtO,EAAMqJ,KAAK,QAAS,gBAEhC,OAAKiF,EAIgB,iBAAVA,EAEP3N,MAAC+F,QACCnE,MAAOvC,EAAM4C,SAAS,QAAS,CAC7B2F,KAAM,EACNjB,WAAY,IACZC,SAAU,GACVkB,QAAS,GACTN,UAAW,SACXN,eAAgB,SAChBD,WAAY,WACXxG,SAEFkN,IAKA3N,MAAAC,YAAAQ,SAAGkN,IArBD3N,MAAAC,gBAwBX,OACEwE,OAAAxE,YAAAQ,WACuB,IAApBiC,EAASkL,QACR5N,MAAC6E,EAAGkB,MACF0C,YAAY,eACZoF,MAAM,QACNlO,KAAMA,EACNmO,MAAO9N,MAACoF,YAASvF,KAAK,SAASuI,KAAM,GAAI3B,MAAM,WAInDhC,OAAC9C,QAAKC,OAhEqBiG,EAKG,GAA5BmF,EAJG3N,EAAM4C,SAIM,YAJMpB,KAAOgH,EAAUhG,EAAU,YAMhD0K,EAAO,IACTS,EAAGnM,KAAQmM,GAAKhG,cAAe,MAAOkE,SAAU,UAG3C8B,GAqD4BvM,UAC/BT,MAAC0N,MACA/K,EAAMtB,KAAI,SAACyC,EAAWM,GAAS,OAC9BpE,MAACsM,GAAU5I,MAAOU,EAAGN,KAAMA,EAAMzE,MAAOA,EAAMoB,SAC3CrB,EAAMqB,gBArDVlB,QAAMuB,QAAQ6B,KAGS,IAArB8K,IAqDazN,MAAAC,YAAAQ,SAAG6M,UAM3B,IAAMP,EAAa7K,aAAWxC,OAAO,CACnCqO,UAAW,CACTnG,KAAM,EACNzF,MAAO,OACP6E,cAAe,MACfkE,SAAU,OACVjE,WAAY,WAEd+F,IAAK,CACHlF,QAAS,EACTP,OAAQ,EACRpF,MAAO,OACPwF,gBAAiB,UACjByF,IAAK,GACL1F,aAAc,GAEhBsG,SAAU,CACRC,SAAU,EACV/G,eAAgB,SAChBD,WAAY,SACZS,aAAc,EACdI,QAAS,GACT3F,MAAO,QAET+L,KAAM,CACJtH,SAAU,GACVD,WAAY,UAIVkG,EAAe3K,aAAWxC,OAAO,CACrCqO,UAAW,CACTnG,KAAM,EACNzF,MAAO,OACP6E,cAAe,MACfkE,SAAU,OACVkC,IAAK,GACLnG,WAAY,WAEd+F,IAAK,CACHlF,QAAS,EACT3F,MAAO,QAET6L,SAAU,CACRC,SAAU,EACV/G,eAAgB,SAChBD,WAAY,SACZa,QAAS,EACT3F,MAAO,QAET+L,KAAM,CACJtH,SAAU,GACVD,WAAY,mBC9IQwH,EAAS/O,GAC/B,IAAMC,EAAQD,EAAMC,MACd+O,EAAU7O,QAAMC,IAAIH,EAAMmJ,aAAc,IACxCG,EAAQtJ,EAAMgP,gBAEpB/L,EAAwBhD,WAAS,GAA5BoE,EAAKpB,KAAEgM,EAAQhM,KAEdiM,EAAa,SAACzK,GAClB,aAAOA,SAAAA,EAAM6E,SAAUA,GAQnB6F,EAAO,SAAHjO,OAAMuD,EAAIvD,EAAJuD,KAAMJ,EAAKnD,EAALmD,MAChBV,EAAWuL,EAAWzK,GACtBlC,EAAKf,KAAagB,EAAOqM,MAI7B,OAFIlL,IAAUpB,EAAM6E,MAAQ,WAExBlH,QAAMuB,QAAQ1B,EAAMqB,UACfT,MAAC+F,QAAKnE,MAAOA,EAAMnB,SAAEqD,EAAKa,QAIjC3E,MAACsM,GAAUjN,MAAOA,EAAOyE,KAAMA,EAAK2K,OAAQ/K,MAAOA,EAAMjD,SACtDrB,EAAMqB,YAKPiO,EAAe,SAAC5K,GACpB,IAAIlC,EAAKf,KAAQgB,EAAOiC,KAASzE,EAAM4C,SAAS,SAG5CE,EAAQsK,KAAKC,MADL,IAAM0B,EAAQ9I,QACM,IAEhC,GAAIiJ,EAAWzK,GAAO,CACpB,IAAI6K,EAAgBtP,EAAMwM,QAAQ,qBAAiB+C,EAAW,YAM9DhN,EAAKf,KAAQe,EALJvC,EAAM4C,SAAS,WAAY,CAClC0F,gBAAiBgH,EACjBlI,MAAO,cAKEA,QACT7E,EAAM6E,MAAQ,WAMlB,OAFA7E,EAAMO,MAAQA,EAEPP,GAGT,OACE5B,MAAAC,YAAAQ,SACG2N,EAAQ/M,KAAI,SAACyC,EAAWM,GAAS,OAChCpE,MAACgI,sBAECpG,MAAO8M,EAAa5K,GACpB8B,QAAS,SAAAsC,IArDD,SAACpE,GACfzE,EAAMmE,YAAYM,EAAK2K,QACvBH,IAAW5K,GAoDHgB,CAAQZ,IACRrD,SAEFT,MAACwO,GAAK1K,KAAMA,EAAMJ,MAAOU,UANfA,QAapB,IAAMvC,EAASK,aAAWxC,OAAO,CAC/BqO,UAAW,CACTnG,KAAM,EACNzF,MAAO,OACPiL,IAAK,GACLlG,eAAgB,SAChBF,cAAe,OAEjBlD,KAAM,CACJgE,QAAS,GACTuE,eAAgB,EAChB1E,gBAAiB,UACjBD,aAAc,EACdR,eAAgB,SAChB/E,MAAO,OACP6E,cAAe,OAEjBkH,KAAM,CACJtH,SAAU,GACVD,WAAY,kBC9FQkI,EAAWzP,GACjC,IAAMC,EAAQD,EAAMC,MACdoD,EAAUpD,EAAMqD,SAEtBJ,EAAwBhD,WAAS,GAA5BoE,EAAKpB,KAAEgM,EAAQhM,KAEdqG,EAAQtJ,EAAMkH,SAAS,GAEzBE,EAAQhE,EAAQgE,MAEfA,IAAOA,EAAQ,WAEpB,IAAMqI,EAAM,CACVhH,QAAS,GACTb,WAAY,SACZE,OAAQ,GACRhF,MAAO,GACPqF,UAAW,SACXC,cAAe,SACfC,aAAc,GACdC,gBAAiBlB,EACjBA,MAAO,UACPS,eAAgB,UAGZrF,EAAc,CAClB6E,YAAa,CACXD,MAAO,UACPE,WAAY,MACZC,SAAU,IAEZ+B,MAAO,CACLf,KAAM,EACNZ,cAAe,MACfQ,UAAW,UAEbT,YAAa,CACXC,cAAe,MACfC,WAAY,SACZC,eAAgB,UAElBG,WAAY,CACVZ,MAAO,OACPG,SAAU,IAEZU,OAAQwH,EACRC,UAASlO,KACJiO,GAELE,UAASnO,KACJiO,IAIDG,EAAS,SAACC,GACd7P,EAAMmE,YAAYmF,EAAQuG,GAC1BZ,IAAW5K,IAWP9B,EAAQ,SAAC9B,EAAc+H,GAC3B,IAAI7F,EAACnB,KAAQgB,EAAO/B,GAAU+H,GAC9B,OAAOxI,EAAM4C,SAASnC,EAAMkC,IAG9B,OACEyC,OAAAxE,YAAAQ,UACET,MAACgI,sBACCC,cAAe,cACfrC,QAba,WACjBqJ,GAAQ,IAaJrN,MAAOA,EAAM,aAAanB,SAE1BT,MAACoF,YAASgD,KAAM,GAAIxG,MAAOA,EAAM,cAAe/B,KAAK,aAEvDG,MAAC+F,QAAKnE,MAAOA,EAAM,SAASnB,SAAElB,QAAMC,IAAImJ,EAAO,KAC/C3I,MAACgI,sBACCC,cAAe,cACfrC,QAzBa,WACjBqJ,EAAO,IAyBHrN,MAAOA,EAAM,aAAanB,SAE1BT,MAACoF,YAASgD,KAAM,GAAIxG,MAAOA,EAAM,cAAe/B,KAAK,sBCtErCsP,EAAQ/P,GAC9B,IAAAkD,EAAsChD,YAAS,GAA1CgJ,EAAYhG,KAAEiG,EAAejG,KAClCS,EAAwBzD,WAAS,GAA5BoE,EAAKX,KAAEuL,EAAQvL,KAChBgG,EAAOC,YAAUC,QAAQ,QAEvB5J,EAAQD,EAAMC,MACdsF,EAAQtF,EAAMuM,WACd/C,EAAQC,aAERlH,EAAQ,SAAC9B,EAAc+H,GAC3B,IAAIuH,EAAEvO,KAAQgB,EAAO/B,GAAU+H,GAE/B,OAAAhH,KAAYxB,EAAM4C,SAASnC,EAAMsP,KAG7BC,EAAU,WACdhQ,EAAMiQ,MAAM,CAAEjQ,MAAAA,EAAOM,KAAMN,EAAMkQ,cAAejM,MAAO,MAGnDkM,EAAS,SAAAC,GAEblH,EADAD,EAAemH,IAIjBpQ,EAAMqQ,OAAS,WACbpB,IAAW5K,IAEbrE,EAAMsQ,KAAO,SAACC,GACZ,IAAMjQ,EAASiQ,EAATjQ,KACFE,EAAOR,EAAM2K,QAAQ,SACrBmD,GAAqB,IAAdyC,EAAKzC,KACZ/M,EAAW,GACXyP,EAAU,KAEVlQ,EAAKmQ,GAAG,QACV1P,EAAIY,OAASrB,EAAKqB,OAAOA,OACzBZ,EAAIwN,OAASjO,EAAKqB,OAElB6O,EAAUlQ,EAAK8D,MACN9D,EAAKmQ,GAAG,YACjB1P,EAAIY,OAASrB,EAAKqB,OAClBZ,EAAIwN,OAASjO,GAGf,IAAI8D,EAAOlE,QAAMC,IAAIoQ,EAAK9L,KAAM+L,EAAS,IAErCE,EAAI/L,YAAUtE,OAAO,SAAQmB,GAC/BG,OAAQrB,EACRqQ,KAAMrQ,EACNE,KAAAA,EACAoQ,OAAQlH,EAAKkH,OACbxM,KAAAA,EACA0J,KAAAA,EACA9N,MAAAA,GACGe,IAGL2I,EAAKkH,OAASF,EAEd1Q,EAAMkQ,cAAgBQ,EAEtBP,GAAO,IAGTnQ,EAAM6Q,KAAO,SAACN,SAGZ7G,EAAKkH,OAAS1Q,QAAMC,IAFVH,EAAMkQ,cAEYU,OAAQ,MACpC5Q,EAAMkQ,cAAgB,KAEtBC,GAAO,UAEPW,EAAIpH,EAAKkH,SAALE,EAAa9Q,OACf0J,EAAKkH,OAAO5Q,MAAMqQ,UAItBU,aAAU,WACR1G,YAAU2G,YAAY,uBACtB3G,YAAU4G,oBAAV5G,YAAU4G,mBAAqBzH,EAAMe,OAAOC,WAC3C,CAACvB,IAEJ,IAAIiI,EAAOlR,EAAMkQ,cAEjB,IAAKgB,EACH,OAAOvQ,MAAAC,eAGT,GAAIsQ,EAAKC,OAASzH,EAAKkH,OAAOO,KAC5B,OAAOxQ,MAAAC,eAGT,IAAMwQ,EAAclD,iBAAeC,UAAUpO,EAAO,SAAU,SAE9D,OACEY,MAACqJ,SACCC,cAAc,QACdC,aAAa,EACbC,QAASlB,EACTmB,eAAgB4F,EAAQ5O,SAExBgE,OAACqF,gBAAalI,MAAOA,EAAM,aAAanB,UACtCgE,OAAC9C,QAAKC,MAAOA,EAAM,eAAenB,UAChCT,MAAC2F,oBAAiBC,QAASyJ,EAASzN,MAAOA,EAAM,oBAAoBnB,SACnET,MAAC+F,QAAKnE,MAAOA,EAAM,kBAAkBnB,SAAC,QAExCT,MAAC+F,QAAKnE,MAAOA,EAAM,cAAcnB,SAAEkE,KACjCpF,QAAMuB,QAAQ2P,IACdzQ,MAACb,GAAWE,MAAOA,EAAOM,KAAMN,EAAMkQ,cAAexO,aAASN,SAC3DgQ,OAIPzQ,MAAC0Q,cACCC,sBAAuB,CAAE1C,SAAU,GACnCrM,MAAOA,EAAM,gBAAgBnB,SAE7BT,MAAC2B,QAAKC,MAAO,CAAEgG,KAAM,GAAInH,SACvBT,MAACb,GAAWE,MAAOA,EAAOM,KAAMN,EAAMkQ,cAAc9O,SACjDrB,EAAMqB,oBASrB,IAAMoB,EAASK,aAAWxC,OAAO,CAC/B8K,UAAW,CACT5C,KAAM,EACND,gBAAiB,UACjBxF,MAAO,QAETwI,YAAa,CACX3D,cAAe,MACfC,WAAY,SACZa,QAAS,GACTH,gBAAiB,WAEnBiD,iBAAkB,CAChB9C,QAAS,IAEX+C,eAAgB,CACdjE,SAAU,GACVH,MAAO,SAETqE,WAAY,CACVlE,SAAU,GACVH,MAAO,QACPE,WAAY,OACZoE,WAAY,IAEdC,aAAc,CACZpD,KAAM,EACND,gBAAiB,UACjBG,QAAS,eC3KW8I,EAAMrQ,OAAGlB,EAAKkB,EAALlB,MAAOoB,EAAQF,EAARE,SAChCoI,EAAQC,aACR+H,EAASxR,EAAMwM,QAAQ,SAAU,KAAM,IAM7C,OAJAuE,aAAU,WACR1G,YAAU2G,YAAY,uBACtB3G,YAAU4G,oBAAV5G,YAAU4G,mBAAqBzH,EAAMe,OAAOC,WAC3C,IAEDpF,OAAAxE,YAAAQ,UACGoQ,EACD7Q,MAAC2B,QAAKC,MAAOvC,EAAM4C,SAAS,YAAaJ,EAAOkM,WAAWtN,SACzDT,MAAC0Q,cACCI,0BAA0B,UAC1BH,sBAAuBtR,EAAM4C,SAAS,mBAAoB,IAC1DL,MAAOvC,EAAM4C,SAAS,SAAUJ,EAAOkP,QAAQtQ,SAE/CT,MAACb,GAAWE,MAAOA,EAAMoB,SAAEA,WAOrC,IAAMoB,EAASK,aAAWxC,OAAO,CAC/BqR,OAAQ,CACNjJ,QAAS,IAEXiG,UAAW,CACTpG,gBAAiB,WAEnBqJ,KAAM,CACJrJ,gBAAiB,aCIfsJ,EAAcC,gBAAmB,aAEf1P,EAAUpC,WAC1B+R,EAAMC,aAAWH,GACjBpI,EAAQtJ,QAAMC,IAAIJ,EAAMyJ,YAAOsI,SAAAA,EAAKtI,OAEtClJ,EAAaJ,QAAMC,IAAIJ,EAAMO,WAAMwR,SAAAA,EAAKxR,MACvCN,EAASC,WAASG,aAAWC,OAAMmB,GAAGlB,KAAAA,GAASP,GAAOyJ,MAAAA,SAC3D9F,EAAwBzD,WAAS,GAA5BoE,EAAKX,KAAEuL,EAAQvL,KACpBsO,EAAsC/R,WAAS,MAA1CgS,EAAKD,KAAEE,EAAQF,KAEpB1R,EAAON,EAAMM,KAEb,IAAIyO,EAAe/O,EAAMmJ,aAErB9F,EAAWrD,EAAMqD,SACjB8O,EAAMC,SAAO,MAEjBpS,EAAMqQ,OAAS,WACbpB,IAAW5K,IAGbrE,EAAMqS,cAAgB,WACpBpD,IAAW5K,IAGb,IAAMhD,EAAS,WACb,IAAIiR,EAASjP,EAASkP,OAEtB,OAAID,EAGE3R,MAACwB,EAFY,iBAANmQ,GAGLlP,QAAS,CAAEkG,MAAOgJ,EAAGhR,KAAM,SAC3BhB,KAAMA,GAMAkB,GACRF,KAAMgR,EAAEhR,KACRkR,IAAKF,EAAEhR,MACHgR,EAAEvS,OACNO,KAAMA,KAKLK,MAAAC,gBAGT,GAAIZ,EAAMyQ,GAAG,OAAQ,SACnB,OAAO9P,MAAAC,YAAAQ,SAAGpB,EAAMuJ,oBAGlB,IAOIkJ,EAAW,SAAC5J,GACd,IAAIgH,EAAMhH,EAAE6J,OAAOpJ,MAEftJ,EAAM2S,OAAO,UAAW,MAAO,UACjC9C,EAAM+C,SAAS/C,GACN7P,EAAM2S,OAAO,aACtB9C,EAAMgD,WAAWhD,IAGf7P,EAAM2S,OAAO,SAAU,cACzB9C,EAAM7P,EAAM8S,gBAAgBjD,IAG9B7P,EAAMmE,YAAY0L,GAClB7P,EAAMqQ,UAGJhL,EAAU,SAACwD,GACb7I,EAAM8I,KAAK,UAGThC,EAAqB,CACvB9G,MAAAA,EACAM,KAAAA,EACAmS,SAAUA,GAGRzS,EAAM2S,OAAO,cACf7L,EAAcxF,KAAO,YAGvB,IAMIyR,EAAc,WAChB,QAAI/S,EAAMU,WAIFR,QAAMuB,QAAQ1B,EAAMqB,WAAclB,QAAMuB,QAAQ1B,EAAM8B,YAG5DnB,EAAUV,EAAMyQ,GAClB,OACA,OACA,SACA,QACA,aACA,QACA,WACA,SAGI7N,EAAW,SAACnC,SACZa,EAAOpB,QAAMC,IAAIkD,EAAS/B,KAAM,QAChCR,EAAMZ,QAAMC,IAAIM,EAAM,QACtBM,EAAGS,KAAQgB,EAAO1B,IAClBkS,EAAWD,IAgBf,OAdKtS,GAASuS,IACZjS,EAAGS,KAAQT,IAGTf,EAAMU,YACRK,EAAGS,KAAQT,EAAQkS,EAAanG,MAAMhM,KAGxCC,EAAGS,KAAQT,QAAQkS,UAAYC,EAAZD,EAAe3R,WAAf4R,EAAuBpS,IAEtCkS,GAAYvS,IACdM,EAAGS,KAAQT,EAAQoS,EAAgB1S,KAGrCe,KAAYT,EAAQf,EAAM4C,SAASnC,EAAMM,KAGvCqS,EAAUxQ,EAAS,WAEnBmE,EAAkB,CACpBsM,SAAUrT,EAAMsT,aAChBvK,KAAM,QACN/I,MAAAA,EACAM,KAAAA,EACAiC,MAAO6Q,EACPhK,YAAapJ,EAAMqJ,KAAK,cAAe,gBAGzCrJ,EAAMiS,MAAQ,SAACsB,GACbtB,EAAQsB,EACRrB,EAASqB,WAGPC,EAACnQ,EAASoK,OAAT+F,EAAeC,YAAOC,EAACrQ,EAASsQ,OAATD,EAAeD,KACzCzT,EAAM4T,QAGR7C,aAAU,WACR/Q,EAAM4T,WAGR,IAAMC,EAAa,WACjB,MAA6B,iBAAlBxQ,EAASyC,KACXnF,MAACoF,YAASvF,KAAM6C,EAASyC,KAAMvD,MAAOvC,EAAM4C,SAAS,UAEvDjC,MAAAC,YAAAQ,SAAGiC,EAASyC,QA0CrB,GAvCA9F,EAAM8T,KAAO,SAACvD,GACZ/J,UAAQC,QAAQ8J,EAAKkD,MAGvBM,mBAAgB,WACd,SAAI5B,GAAAA,EAAK6B,SAAWhU,EAAMyQ,GAAG,OAAQ,OAAQ,OAAQ,OAAQ,WAAY,CACvE,IAAIhE,QAAU0F,SAAAA,EAAK6B,QAEnB,SAAIvH,GAAAA,EAAIwH,UAAW,CACjB,IAAIC,EAAKC,YAAUC,WAAW3H,GAG5BA,EAAGwH,UAAUhG,IADJ,uBAAPiG,EACe,UAEA,kBAyBpBlU,EAAMqU,cAAgBrU,EAAMyQ,GAAG,OAAQ,UAC1C,OAAO9P,MAAAC,eAGT,IAoBI0T,GAAWhS,OACXiQ,GAAc,GASlB,OAPKvS,EAAM2S,OAAO,QAAS,OAAQ,OAAQ,WAAatP,EAAS2C,QAC/DsO,GAAM3L,qBAEN4J,GAAO3J,cAAgB,cACvB2J,GAAOhM,QAAUlB,GAIjB1E,MAACiR,EAAY2C,UAASjL,MAAO,CAAEhJ,KAAAA,EAAMkJ,MAAAA,GAAQpI,SAC3CT,MAAC2T,GAAG9S,GAAC2Q,IAAKA,EAAK5P,MAAOK,KAAgB2P,IAAMnR,SAC1CgE,OAAAxE,YAAAQ,eAtDwB,IAAnBiC,EAASiC,QACG,IAAnBjC,EAASiC,QACRtF,EAAM2S,OAAO,SAAU,SAAU,UAsD5BhS,MAAC+F,QAAKnE,MAAOK,EAAS,SAASxB,SAAEpB,EAAMuM,cA7C3CwG,KAgDI3N,OAAAxE,YAAAQ,UACEgE,OAAC9C,QAAKC,MAAOK,EAAS,SAASxB,UAC5BpB,EAAMyQ,GAAG,OAAQ,WAChBrL,OAAC+B,EAAQ3F,KACHuF,GACJ1B,QAASA,EACTmP,QAASxU,EAAMqJ,KAAK,UAAW,YAAYjI,UAE1CiC,EAASyC,MAAQnF,MAACkT,MAClBxQ,EAASiC,OACR3E,MAAC+F,QAAKnE,MAAOvC,EAAMwM,QAAQ,QAAS,UAAUpL,SAC3CpB,EAAMuM,iBAKdvM,EAAMyQ,GAAG,OAAQ,SAChB9P,MAACsG,EAAMzF,KACDuF,GACJ1B,QAASA,EACTmP,QAASxU,EAAMqJ,KAAK,UAAW,YAAYjI,SAE1CpB,EAAMuJ,qBAGVvJ,EAAMyQ,GAAG,OAAQ,SAChBrL,OAAC4B,EAAMxF,KACDuF,GACJ1B,QAASA,EACTmP,QAASxU,EAAMqJ,KAAK,UAAW,YAAYjI,UAE1CiC,EAASyC,MAAQnF,MAACkT,MAClBxQ,EAASiC,OACR3E,MAAC+F,QAAKnE,MAAOvC,EAAMwM,QAAQ,QAAS,QAAQpL,SACzCpB,EAAMuM,iBAKd7L,GACCC,MAAC2L,EAAO9K,KACFsF,EACAC,GACJ0N,WAAUjT,KAAO6B,EAASqR,eAG7B1U,EAAMyQ,GAAG,OAAQ,WAAY,iBAC5B9P,MAACiG,GACC5G,MAAOA,EACP8G,cAAeA,EACfC,WAAYA,IAGf/G,EAAMyQ,GAAG,OAAQ,aAChB9P,MAAC6O,GACCxP,MAAOA,EACP8G,cAAeA,EACfC,WAAYA,IAGf/G,EAAMyQ,GAAG,OAAQ,WAAY,UAAW,WACvC9P,MAACmL,EAAQtK,GACPmT,SA3NH,IAFL3U,EAAMkH,YA8NMJ,GACJ2L,SAtQJ,WACZ,IAAItG,EAAInM,EAAMkH,WAGduL,EAAS,CAAEC,OAAQ,CAAEpJ,SAFD,IAAN6C,UAuQDnM,EAAMyQ,GAAG,OAAQ,WAChB9P,MAACqI,EAAQxH,KACHsF,EACAC,GACJuC,MAAOtJ,EAAM4U,sBAGhB5U,EAAMyQ,GAAG,OAAQ,WAChB9P,MAACmO,EAAQtN,KACHsF,EACAC,GACJuC,MAAOtJ,EAAM4U,sBAGhB5U,EAAMyQ,GAAG,OAAQ,UAChB9P,MAAC0L,EAAO7K,KAAKsF,EAAmBC,GAAY4G,OAAGvM,SAC5C2N,EAAQ/M,KAAI,SAAC2L,EAAU5I,GAAS,OAC/BpE,MAACyL,GAECyI,QAASlU,MAAC0L,EAAO7K,KAAKuF,IACtBzB,MAAOqI,EAAIrI,MACXgE,MAAOqE,EAAIrE,OAHN,IAAMvE,SAQlB/E,EAAMyQ,GAAG,OAAQ,WAAa9P,MAACU,MAC/BrB,EAAMyQ,GAAG,OAAQ,WAChBrL,OAAAxE,YAAAQ,UACGpB,EAAMyQ,GAAG,SAAU,QAClB9P,MAACmU,SAAMC,OAAQ/U,EAAMuJ,oBAEtBvJ,EAAMyQ,GAAG,SAAU,SAClB9P,MAACsG,GAAOjH,MAAOA,EAAOM,KAAMA,KAE5BN,EAAMyQ,GAAG,SAAU,OAAQ,QAC3B9P,MAAC+F,QAAItF,SAAEpB,EAAMuJ,uBAIlBvJ,EAAMyQ,GAAG,OAAQ,SAAU,UAC1B9P,MAAC+F,QAAKnE,MAAOK,EAAS,SAASxB,SAC5BpB,EAAMuJ,uBAIZ0I,GAAStR,MAAC2B,QAAKC,MAAOK,EAAS,SAASxB,SAAE6Q,OAG9CjS,EAAM2S,OAAO,OAAQ,WACpBhS,MAACqN,EAAMxM,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAExCN,EAAM2S,OAAO,WACZhS,MAACmP,EAAOtO,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAEzCN,EAAM2S,OAAO,UACZhS,MAACuF,EAAO1E,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAEzCN,EAAM2S,OAAO,SACZhS,MAACqC,EAAMxB,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAGxCN,EAAM2S,OAAO,SACZhS,MAAC4Q,EAAM/P,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,MAtK7CN,EAAM2S,OACJ,OACA,OACA,OACA,OACA,SACA,SACA,QACA,SACA,UAiKIhS,MAACb,EAAU0B,KACLzB,GACJC,MAAOA,EACPM,KAAMA,EACNiC,MAAOK,EAAS,oBAS9B,IAAMoS,EAAW,CACf1M,gBAAiB,QACjBG,QAAS,GACTJ,aAAc,GACdvF,MAAO,OACPmS,YAAa,OACbC,aAAc,CAAEpS,MAAO,EAAGgF,OAAQ,GAClCqN,cAAe,IACfC,aAAc,KACdC,UAAW,GAGPpC,EAAoB,CAE1BA,KAAoB,CAClBlQ,MAAO,CACLD,MAAO,OACP8E,WAAY,SACZW,KAAM,GAERmG,UAAW,CACT5L,MAAO,OACPwF,gBAAiB,UACjBC,KAAM,EACNwF,IAAK,IAEP5M,MAAO,CACL2B,MAAO,OACPyF,KAAM,EACNwF,IAAK,GACLtF,QAAS,IAEXkI,KAAM,CACJ7N,MAAO,OACPyF,KAAM,EACNX,WAAY,SACZa,QAAS,KAGbwK,EAAaqC,KAAOzS,aAAWxC,OAAO,CACpCsQ,KAAInP,KACCwT,GAELjS,MAAO,CACLwF,KAAM,EACNzF,MAAO,OACPyS,cAAe,GACfnK,WAAY,EACZQ,UAAW,aACXjE,cAAe,MACfkE,SAAU,OACVkC,IAAK,MAITkF,EAAanG,MAAQjK,aAAWxC,OAAO,CACrCiF,MAAO,CACLmC,YAAa,GAEf1E,MAAO,CACLwF,KAAM,EACNzF,MAAO,OACPyS,cAAe,EACfnK,WAAY,EACZxD,WAAY,SACZmD,YAAa,EACbC,YAAa,cACb3C,aAAc,GACdK,kBAAmB,GACnBkD,UAAW,aACXjE,cAAe,MACfkE,SAAU,UAIdoH,EAAauC,SAAW,CACtBzS,MAAKvB,KACAwT,GACH1M,gBAAiB,cACjBhB,WAAY,IACZC,SAAU,GACVc,aAAc,GACd0C,YAAa,EACbtC,QAAS,EACTC,kBAAmB,EACnBuC,gBAAiB,EACjBY,SAAU,SACVtD,KAAM,EACNZ,cAAe,MACfE,eAAgB,SAChBD,WAAY,YAIhBqL,EAAa9C,OAAStN,aAAWxC,OAAO,CACtC0C,MAAKvB,KACAwT,GACHzM,KAAM,EACNzF,MAAO,OACPiL,IAAK,GACLlG,eAAgB,SAChBF,cAAe,MACfe,kBAAmB,GACnBuC,gBAAiB,EACjBW,UAAW,aACXC,SAAU,aAId,IAAMrJ,EAASK,aAAWxC,OAAO,CAC/BsQ,KAAM,CACJ5C,IAAK,EACLpG,cAAe,SACfkE,SAAU,OACV/I,MAAO,OACP8E,WAAY,cAEdtC,MAAO,CACLxC,MAAO,OACPwE,WAAY,IACZC,SAAU,GACVH,MAAO,cAETrE,MAAO,CAAED,MAAO,UAGZqQ,EAAkBtQ,aAAWxC,OAAO,CACxCsQ,KAAM,CACJ5C,IAAK,IAEPzI,MAAO,CACLxC,MAAO,OACPwE,WAAY,IACZC,SAAU,eC9jBUkO,EAAU1V,GAChC,IAAuB,IAAnBA,EAAM+E,SACR,OAAOnE,MAAAC,eAGT,IAAI8U,EAAWxH,iBAAeC,UAAUpO,EAAOA,EAAMS,KAAMT,EAAM4V,UAMjE,OAJIzV,QAAMuB,QAAQiU,KAChBA,EAAW3V,WAGRG,QAAMuB,QAAQiU,GAwBZ/U,MAAAC,YAAAQ,SAAGsU,IAbN/U,OAVQ,SAACiV,GACT,IAAItB,EAAWvU,EAAMyS,IAErB,OAAKtS,QAAMuB,QAAQ6S,GAGZ3T,MAAAC,YAAAQ,SAAGwU,EAAQxU,WAFTT,MAAC2T,EAAG9S,KAAKoU,GAAOxU,SAAGwU,EAAQxU,cAMhCI,KAAKzB,EAAM8V,UAAQzU,SACrBT,MAACb,EAAU0B,GACTE,cACI3B,GACJC,MAAOD,EAAMC,MACbM,KAAMP,EAAMO,KACZG,KAAMV,EAAMS,KAAKY,SAEhBsU,uBCnBLlQ,EAAK,CACTkF,KAAM,SAAC3K,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WACtDwU,IAAK,SAAC/V,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,UACrDsJ,MAAO,SAAC7K,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YACvDyU,MAAO,SAAChW,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YACvD0U,OAAQ,SAACjW,GAAe,OACtBY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,SAASvB,MAAO,CAAEwO,QAAQ,OAEvD0H,OAAQ,SAAClW,GAAiB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC1DqE,QAAS,SAAC5F,GAAiB,OAAKY,MAAC8U,EAASjU,KAAKzB,KAC/CmW,OAAQ,SAAFhV,OAAyBnB,6IAAKoW,CAAAjV,EAAAkV,GAAA,OAClCzV,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAE7B+U,MAAO,SAACtW,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,KAC5C2G,KAAM,SAAC3G,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WACvDgV,MAAO,SAACvW,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YACxDuE,OAAQ,SAAC9F,GAAiB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC1DiV,KAAM,SAACxW,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WACtDkV,KAAM,SAACzW,GAAiB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WACxDmE,OAAQ,SAAC1F,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DmV,KAAM,SAAC1W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WAC3DoV,KAAM,SAAC3W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WAC3DgB,KAAM,SAACvC,GAAoB,OACzBY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,OAAOI,iBAEpCiV,OAAQ,SAAC5W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DsV,OAAQ,SAAC7W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DuV,QAAS,SAAC9W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,cAC9DwV,IAAK,SAAC/W,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,UAC1DyV,KAAM,SAAChX,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WAC3D0V,IAAK,SAACjX,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,UAC1D2V,KAAM,SAAClX,GAAe,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,WACtD4V,KAAM,SAACnX,GAAoB,OACzBY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,MAAM4D,OAAO,WAE1CiS,QAAS,SAACpX,GAAe,OACvBY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,OAAO4D,OAAO,cAE3CkS,MAAO,SAACrX,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YACxD+V,MAAO,SAACtX,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YACxDgW,SAAU,SAACvX,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,eAC3DiW,SAAU,SAACxX,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,eAC3DkW,SAAU,SAACzX,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC3D2K,OAAQ,SAAClM,GAAgB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aACzDmW,MAAO,SAAC1X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,YAC5DoW,OAAQ,SAAC3X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DqW,OAAQ,SAAC5X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DsW,OAAQ,SAAC7X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,aAC7DuW,QAAS,SAAC9X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,cAC9DwW,SAAU,SAAC/X,GAAoB,OAAKY,MAACwB,EAASX,KAAKzB,GAAOuB,KAAK,eAC/DyW,kBC1C+BhY,SACzByJ,EAAQC,aAYd,OALAsH,aAAU,WACR1G,YAAU2G,YAAY,uBACtB3G,YAAU4G,oBAAV5G,YAAU4G,mBAAqBzH,EAAMe,OAAOC,WAC3C,IAGDpF,OAAC4S,oBAAgB5W,UACfT,MAAC0J,aAAUC,SAAS,kBACpB3J,MAACsX,gBACC1V,MAAKf,GACH8G,uBAAe4P,EAAE1O,EAAMe,eAAN2N,EAAc1N,SAC5BzK,EAAMoY,WACT5P,KAAM,IACNnH,SAEFT,MAACyX,wBACCC,SAA0B,QAAhBC,WAASC,GAAe,UAAY,SAC9ChW,MAAO,CACLgG,KAAM,EACNV,eAAgB,UAChBzG,SAEFT,MAAC6X,4BACCjS,QA7Bc,WACF,QAAhB+R,WAASC,IACXE,WAASC,WA4BHC,YAAY,EAAMvX,SAElBT,MAAAC,YAAAQ,SAAGrB,EAAMqB"}
@@ -106,10 +106,20 @@ function UIChildren(props) {
106
106
  var getStyle = function getStyle(part) {
107
107
  var key = Utils.nvl(part, 'root');
108
108
  var def = styles[key];
109
+ var css = {};
109
110
  if (!Utils.isEmpty(props.style)) {
110
- console.log(props.style);
111
+ var _props$style;
112
+ if ((_props$style = props.style) != null && _props$style.push) {
113
+ Utils.each(props.style, function (s) {
114
+ if (s) {
115
+ css = _extends({}, css, s);
116
+ }
117
+ });
118
+ } else {
119
+ css = _extends({}, props.style);
120
+ }
111
121
  }
112
- return _extends({}, def, scope.getStyle(part));
122
+ return _extends({}, def, css, scope.getStyle(part));
113
123
  };
114
124
  return /*#__PURE__*/jsx(Fragment, {
115
125
  children: /*#__PURE__*/jsx(View, {
@@ -699,6 +709,7 @@ function UIListRow(props) {
699
709
  }, "k-" + index);
700
710
  }
701
711
  return /*#__PURE__*/jsx(TouchableHighlight, {
712
+ style: getRowStyle(),
702
713
  underlayColor: 'transparent',
703
714
  onPress: function onPress(e) {
704
715
  e.stopPropagation();