react-crud-mobile 1.3.183 → 1.3.185
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/react-crud-mobile.cjs.development.js +49 -17
- package/dist/react-crud-mobile.cjs.development.js.map +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js +1 -1
- package/dist/react-crud-mobile.cjs.production.min.js.map +1 -1
- package/dist/react-crud-mobile.esm.js +49 -17
- package/dist/react-crud-mobile.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/elements/core/UIOrder.tsx +44 -7
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UISlider.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/hooks/useIsVisible.ts","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIToast.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIHeader.tsx","../src/elements/core/UIView.tsx","../src/elements/core/UIOrder.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx","../src/elements/core/GestureView.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props?.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...scope.getStyle(part) };\n };\n\n if (props.transient) {\n return <Draw />;\n }\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n let size = Utils.nvl(element.size, 'default');\n let align = Utils.nvl(element.align, 'center');\n let variant = Utils.nvl(element.variant, 'default');\n\n let color = element.color;\n let label = scope.getLabel();\n let icon = scope.getPart('icon');\n\n //ajuste align v3\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\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 backgroundColor: color,\n borderRadius: 12,\n gap: 10,\n justifyContent: 'center',\n alignItems: 'center',\n flexDirection: 'row',\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let css = { ...styles[part], ...extra };\n\n if (variant === 'text' || variant === 'outlined') {\n css.backgroundColor = 'transparent';\n css.color = Utils.nvl(color, 'text');\n }\n\n if (size === 'small') {\n css.fontSize = 12;\n css.fontWeight = 500;\n }\n\n if (size === 'medium') {\n css.fontSize = 14;\n css.fontWeight = 500;\n }\n\n if (align === 'left') {\n css.justifyContent = 'flex-start';\n }\n\n return scope.getStyle(part, css);\n };\n\n let extra: any = {};\n\n if (icon) {\n extra.button = { height: 40, padding: 0 };\n } else {\n extra.button = { height: 50 };\n }\n\n const buttonStyle = Utils.call(() => {\n let def: any = { ...extra?.button };\n\n if (variant === 'outlined') {\n def.borderWidth = 1;\n def.borderColor = Utils.nvl(color, 'text');\n }\n\n if (size) {\n def = { ...def, ...BUTTONS_SIZE[size] };\n }\n\n if (!label) {\n def = { ...def, borderRadius: 20 };\n }\n\n let css = style('button', def);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\n }\n\n return css;\n });\n\n const buttonLabel = style('buttonLabel');\n const iconStyle = Utils.call(() => {\n let css: any = style('buttonIcon', extra.icon);\n\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\n\n return css;\n });\n\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={buttonStyle}\n >\n <>\n {icon && (\n <>\n <Ionicons\n size={Utils.nvl(element.iconSize, 30)}\n style={iconStyle}\n name={icon}\n />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useRef, useState } from 'react';\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const element = scope.original;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const scrollRef = useRef(null);\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\n const modalColor = Utils.nvl(headerStyle.color, 'white');\n const defaults = { color: modalColor };\n const onClick = ({ crud, value }: MethodType) => {\n let val = value as any;\n\n if (element.isObject && val?.object) {\n scope.changeValue(val?.object);\n } else if (val?.value) {\n scope.changeValue(val?.value);\n } else {\n scope.changeValue(value);\n }\n\n setModalVisible(false);\n };\n\n const style = (part: string, extra?: any) => {\n let all = { ...styles[part], ...extra };\n\n return scope.getStyle(part, all);\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n //v4\n\n return (\n <View\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\n style={style('selectRoot')}\n >\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Ionicons\n name=\"chevron-down-outline\"\n size={scope.getPart('iconSize', null, 24)}\n color={scope.getPart('iconColor', null, iconColor)}\n style={style('iconStyle', {})}\n />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={handlePress}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"close\"\n size={24}\n color={modalColor}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n <View\n style={{\n flex: 1,\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n }}\n >\n <UI.List\n data={items}\n name={scope.getName('list')}\n layout=\"card\"\n click={onClick}\n rowStyle={{\n paddingLeft: 15,\n paddinRight: 15,\n ...scope.original?.rowStyle,\n }}\n {...scope.original?.listProps}\n >\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 5,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n style={scope.getStyle('element')}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\nimport Slider from '@react-native-community/slider';\r\n\r\nexport default function UISlider(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), 0);\r\n const [value, setValue] = useState(initial);\r\n\r\n //redeploy 0\r\n\r\n let onChange = v => {\r\n v = Utils.nvl(v, 0);\r\n\r\n console.log(v);\r\n\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n let step = scope.attr('step', 1);\r\n let min = scope.attr('min', 0);\r\n let max = scope.attr('min', 100);\r\n\r\n let onSlideScroll = (scrollEnabled: boolean) => {\r\n let viewScope = ComponentUtils.getViewScope();\r\n\r\n if (scope.original.debug) {\r\n console.log(viewScope);\r\n }\r\n\r\n if (viewScope) {\r\n let scrollRef = viewScope.get('scrollRef');\r\n\r\n if (scrollRef) scrollRef.current?.setNativeProps?.({ scrollEnabled });\r\n }\r\n };\r\n return (\r\n <>\r\n <Slider\r\n minimumValue={min}\r\n maximumValue={max}\r\n step={step}\r\n minimumTrackTintColor=\"#1EB1FC\"\r\n maximumTrackTintColor=\"#d3d3d3\"\r\n thumbTintColor=\"#1EB1FC\"\r\n value={value}\r\n onSlidingStart={() => onSlideScroll(false)}\r\n onSlidingComplete={() => onSlideScroll(true)}\r\n style={{ width: '100%', height: 40, ...scope.getStyle('element') }}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n </>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.call(() => {\n let val = Utils.nvl(scope.getValue(), '');\n\n if (val && val?.push) {\n return val.join(', ').trim();\n }\n return val;\n });\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n v = scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n const CustomIcon = () => {\n let icon = el.icon;\n\n if (icon) {\n if (typeof icon === 'string') {\n return (\n <>\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n </>\n );\n }\n return <>{icon}</>;\n }\n return <></>;\n };\n return (\n <>\n <View style={style('base')}>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n <CustomIcon />\n </View>\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 5,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = scope.getPart('cols', undefined, -1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n //v4\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren transient scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n row.selected = row.getPart('isSelectedRow', undefined, false);\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (row.selected) {\n css = { ...css, ...row.getStyle('rowSelected', {}) };\n } else {\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\n }\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n let renderedRow = row.getPart('renderedItem', undefined, true);\n\n if (renderedRow === false) {\n return <></>;\n }\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: 'background',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n const LocalData = () => {\n let [index, setIndex] = useState(scope.updateIndex);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n let keyData = scope.key('data');\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search !== false && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = Utils.getValue(filterBy, 'none', o).toLowerCase();\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\n });\n\n 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 <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n );\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n style={{ marginBottom: 10 }}\n change={{\n action: () => {\n scope.search();\n },\n }}\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n <LocalData />\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\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: 10,\n marginVertical: 8,\n backgroundColor: 'background',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 15,\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: 0,\n alignItems: 'center',\n height: 30,\n width: 30,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n fontWeight: '500',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { StyleSheet } from 'react-native';\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\n\nexport default function UIToast() {\n const toastConfig = {\n success: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n contentContainerStyle={{ paddingHorizontal: 15 }}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n error: props => (\n <ErrorToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n info: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n };\n\n const styles = StyleSheet.create({\n darkToast: {\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\n borderLeftColor: '#222', // borda mais escura\n },\n text: {\n color: '#fff', // letras brancas\n textAlign: 'center',\n },\n });\n return <Toast config={toastConfig} />;\n}\n","import { useRef, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface UIModalType extends ChildType {\n open?: boolean;\n dialog?: any;\n}\n\nexport default function UIModal({\n scope,\n open,\n dialog,\n ...props\n}: UIModalType) {\n let [modalVisible, setModalVisible] = useState(open === true);\n let [index, setIndex] = useState(0);\n //v1\n\n const label = scope.getLabel();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const scrollRef = useRef(null);\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?.crud, event: {} });\n };\n\n scope.toggleDialog = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.update = () => {\n setIndex(++index);\n };\n\n let curr = scope.currentDialog?.crud;\n let main = ViewUtils.getCrud('view');\n\n if (!curr) {\n return <></>;\n }\n\n if (curr.uuid !== main.dialog?.crud?.uuid) {\n return <></>;\n }\n\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n const bottom = ComponentUtils.getDefine(props, 'bottom');\n\n scope.put('scrollRef', scrollRef);\n\n const original = scope.original;\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n let key = `${curr.name}-${index}`;\n\n let Content = () => {\n if (dialog?.component) {\n let Aux = dialog?.component;\n\n return <Aux key={curr.uuid} crud={curr} />;\n }\n\n return (\n <UIChildren scope={scope} crud={curr}>\n {props.children}\n </UIChildren>\n );\n };\n\n let ModalContent = ({ children }) => {\n let disableScroll = scope.part('disableScroll', false);\n let disableContent = scope.part('disableContent', false);\n\n if (disableContent) {\n return <>{children}</>;\n }\n\n if (disableScroll) {\n return <View style={style('modalContent')}>{children}</View>;\n }\n return (\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n {children}\n </ScrollView>\n );\n };\n\n const ModalView = ({ children }) => {\n if (original.gesture) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const ModalInner = () => {\n if (original.transient) {\n return (\n <View style={style('modalSafe')}>\n <Content />\n </View>\n );\n }\n\n return (\n <>\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={onClose}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"chevron-back-outline\"\n size={24}\n color={color}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={curr} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ModalContent>\n <Content />\n </ModalContent>\n {bottom}\n </SafeAreaView>\n <UIToast />\n </>\n );\n };\n return (\n <ModalView>\n <Modal\n key={key}\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <ModalInner />\n </Modal>\n </ModalView>\n );\n}\n\nconst styles = StyleSheet.create({\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 22,\n fontWeight: 600,\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n },\n});\n","import { Text, View } from 'react-native';\n\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\n\nexport default function UIHeader({ scope }: ChildType) {\n const theme = scope.getTheme();\n const header = scope.getPart('header', null, []);\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\n\n let headerStyleFull = Utils.call(() => {\n let css = scope.getStyle('header', headerStyle);\n let bg = css.backgroundColor;\n\n if (bg) {\n css.color = HtmlUtils.getTextColor(bg);\n }\n return css;\n });\n\n let hasHeader = !Utils.isEmpty(header);\n let AuxHeader = () => {\n if (typeof header === 'string') {\n return <Text style={headerTextStyle}>{header}</Text>;\n }\n return <>{header}</>;\n };\n\n return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n </>\n );\n}\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\nimport { useRef } from 'react';\nimport UIToast from './UIToast';\nimport UIHeader from './UIHeader';\n\nexport default function UIView({ scope, children }: ChildType) {\n const scrollRef = useRef(null);\n const original = scope.original;\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n //v3\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let Container = () => {\n if (original.scroll === false) {\n return <UIChildren scope={scope}>{children}</UIChildren>;\n }\n\n return (\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n ref={scrollRef}\n nestedScrollEnabled={true}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {\n paddingBottom: 50,\n })}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n );\n };\n return (\n <>\n <UIHeader scope={scope} />\n <Container />\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n paddingTop: 10,\n paddingBottom: 10,\n paddingLeft: 15,\n paddingRight: 15,\n },\n container: {},\n view: {},\n});\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableOpacity, View } from 'react-native';\nimport UI from '../UI';\nimport { Ionicons, MaterialCommunityIcons } from '@expo/vector-icons';\nimport DraggableFlatList, {\n ScaleDecorator,\n} from 'react-native-draggable-flatlist';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\nimport UIHeader from './UIHeader';\n\nexport default function UIOrder(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\n\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 items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = o[filterBy];\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\n });\n\n //v2\n\n const renderItem = ({ item, drag, isActive }) => {\n let state = { ...scope.getStyle('row') };\n\n if (isActive) {\n state = { ...state, ...scope.getStyle('active') };\n }\n\n return (\n <ScaleDecorator>\n <TouchableOpacity\n style={[\n styles.row,\n { backgroundColor: isActive ? 'lightblue' : 'white' },\n { ...state },\n ]}\n delayLongPress={100}\n onLongPress={drag} // Initiate drag on long press\n >\n <MaterialCommunityIcons name=\"drag\" size={24} color=\"black\" />\n <Text style={styles.text}>{scope.getItemLabel(item)}</Text>\n </TouchableOpacity>\n </ScaleDecorator>\n );\n };\n\n const OrderView = ({ children }) => {\n if (original.gesture !== false) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n width: '100%',\n ...scope.getStyle('order', { justifyContent: 'flex-start' }),\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const Header = ({ pos }) => {\n const hPos = Utils.nvl(original.headerPos, 'inner');\n\n if (hPos !== pos) return <></>;\n\n return <UIHeader scope={scope} />;\n };\n\n let OrderData = () => {\n const [data, setData] = useState(items);\n\n return (\n <DraggableFlatList\n data={data}\n ListHeaderComponent={<Header pos=\"inner\" />}\n ListFooterComponent={<>{scope.getPart('footer')}</>}\n renderItem={renderItem}\n containerStyle={{ ...scope.getStyle('list') }}\n keyExtractor={item => {\n let key = scope.getItemValue(item);\n\n if (original?.debug) {\n console.log(key);\n }\n return key;\n }}\n onDragEnd={({ data }) => {\n setData(data);\n scope.changeValue(data);\n }}\n />\n );\n };\n return (\n <OrderView>\n <Header pos=\"outer\" />\n <OrderData />\n </OrderView>\n );\n}\n\nconst styles = StyleSheet.create({\n row: {\n flexDirection: 'row',\n gap: 10,\n padding: 15,\n borderBottomWidth: 1,\n borderBottomColor: '#ccc',\n },\n text: {\n fontSize: 18,\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n MethodType,\n ActionType,\n ComponentUtils,\n CrudUtils,\n ViewUtils,\n Scope,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UISlider from './core/UISlider';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\nimport Toast from 'react-native-toast-message';\nimport UIOrder from './core/UIOrder';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n scope.compile(props);\n\n crud = scope.crud;\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n scope.toast = (message: string, type = 'info', args?: any) => {\n Toast.show({\n type, // 'success' | 'error' | 'info'\n text1: message,\n position: 'bottom', // 'top' é outra opção\n visibilityTime: 3000, // tempo que fica visível em ms\n ...args,\n });\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\n }\n };\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n if (scope.currentDialog?.component) return;\n\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'integer',\n 'int',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string, extra?: any) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n type = Utils.nvl(original.layout, type);\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n let isTouch =\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\n let custom: any = {};\n\n if (isTouch) {\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Tag = (props: any) => {\n let Aux: any = View;\n\n if (isTouch) {\n Aux = TouchableHighlight;\n }\n\n if (scope.isType('dialog', 'order') || original.transient) {\n return <>{props.children}</>;\n }\n\n return <Aux {...props} />;\n };\n\n let Inner = () => {\n return (\n <>\n {scope.getPart('render', null, <></>)}\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', '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.isType('slider') && (\n <UISlider {...defaultsInput} onChange={onCheck} />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && <UIIcon scope={scope} crud={crud} />}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>{scope.getDisplayValue()}</Text>\n )}\n </>\n );\n };\n\n let Include = ({ name, style }: any) => {\n if (props[name]) {\n let define = ComponentUtils.getDefine(props, name);\n\n if (!Utils.isEmpty(define)) {\n return (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle(name, style)}\n >\n {define}\n </UIChildren>\n );\n }\n }\n return <></>;\n };\n\n let Container = () => {\n return (\n <>\n {isShowLabel() && (\n <View\n style={getStyle('outerLabel', {\n alignSelf: 'flex-start',\n flexDirection: 'row',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n width: '100%',\n })}\n >\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n <Include name=\"actions\" style={{ width: 'auto' }} />\n </View>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n <Inner />\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('order') && (\n <UIOrder {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n\n {scope.currentDialog?.component && (\n <UIModal\n scope={scope.currentDialog?.scope}\n crud={scope.currentDialog?.crud}\n open\n dialog={scope.currentDialog}\n />\n )}\n\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n return (\n <View style={getStyle('card', { ...box })}>\n <View\n style={getStyle('boxInner', {\n paddingHorizontal: 15,\n paddingVertical: 10,\n })}\n >\n {props.children}\n </View>\n </View>\n );\n }\n\n if (scope.isInput() || original.container) {\n return (\n <View\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\n >\n {props.children}\n </View>\n );\n }\n return <>{props.children}</>;\n };\n\n scope.dialogShow = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let parent = main.dialog;\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n let event = Utils.nvl(args?.event, {});\n let component = event?.component;\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 data,\n edit,\n scope,\n ...def,\n });\n\n let el: any = {\n label: original.label,\n icon: original.icon,\n type: 'dialog',\n };\n\n let close = event.dialog?.close;\n\n if (typeof event.dialog === 'object') {\n el = { ...el, ...event.dialog };\n }\n\n if (event.header) el.header = event.header;\n if (event.label) el.label = event.label;\n if (event.title) el.title = event.title;\n\n el.label = Utils.nvl(el.title, el.label);\n\n let dialogScope = ScopeUtils.create({\n parent: scope,\n crud: d,\n ...el,\n owner: scope,\n });\n let dialog = { crud: d, parent, component, scope: dialogScope, close };\n\n main.dialog = dialog;\n scope.toggleDialog(true);\n scope.currentDialog = dialog;\n\n dialogScope.currentDialog = dialog;\n dialogScope.toggleDialog(true);\n\n scope.update();\n };\n\n scope.dialogHide = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let old = scope.currentDialog;\n let parentScope = old.scope.parent as Scope;\n\n main.dialog = Utils.nvl(old.parent, null);\n scope.currentDialog = null;\n\n if (main.dialog?.crud?.scope) {\n main.dialog?.crud.scope.update();\n }\n scope.toggleDialog(false);\n scope.update();\n\n const close = old.close;\n\n if (parentScope && close) {\n if (close?.debug) console.log('Fechando');\n parentScope.call('close', { close });\n }\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <Card>\n <Container />\n </Card>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nlet boxStyle = StyleSheet.create({\n box: {\n borderWidth: 0,\n borderColor: '#dedede',\n borderStyle: 'solid',\n backgroundColor: 'white',\n borderRadius: 12,\n width: '100%',\n shadowColor: '#000',\n shadowOpacity: 0.1,\n shadowRadius: 4,\n },\n});\n\nconst box: any = {\n ...boxStyle.box,\n};\n//v4\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: 'background',\n flex: 1,\n gap: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 0,\n },\n inner: {\n flex: 1,\n width: '100%',\n padding: 0,\n gap: 10,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n paddingHorizontal: 5,\n paddingVertical: 5,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n 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 fontWeight: 400,\n fontSize: 12,\n paddingVertical: 3,\n color: 'labelColor',\n },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n SliderType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\nimport UIInclude from './core/UIInclude';\nimport SafeView from './core/SafeView';\nimport GestureView from './core/GestureView';\n\nconst UI = {\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\n SafeView: SafeView,\n GestureView: GestureView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n //v2\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n return (\n <SafeAreaProvider>\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'flex-start',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n","import { StyleProp, ViewStyle } from 'react-native';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function GestureView(props: SafeViewType) {\n return (\n <GestureHandlerRootView style={{ flex: 1 }}>\n {props.children}\n </GestureHandlerRootView>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","BUTTONS_SIZE","small","minWidth","height","UIButton","size","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","fontSize","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","iconSize","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","Modal","animationType","transparent","visible","onRequestClose","SafeAreaView","ScrollView","contentContainerStyle","flexGrow","paddingBottom","nestedScrollEnabled","ref","flex","paddingLeft","paddingRight","paddingTop","List","getName","isObject","object","rowStyle","paddinRight","_scope$original","_scope$original2","listProps","Value","selectRoot","selectInput","paddingHorizontal","paddingVertical","selectLabel","modalTop","modalSafe","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","el","CustomIcon","TextInput","onChangeText","base","alignSelf","flexWrap","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","isVisible","setIsVisible","useEffect","interval","setInterval","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","LocalData","setIndex","keyData","search","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","empty","textAlign","field","marginBottom","change","container","display","UIToggle","options","getInputValue","isSelected","Item","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","UIModal","open","dialog","_objectWithoutPropertiesLoose","_excluded","st","onClose","close","_scope$currentDialog","currentDialog","toggleDialog","vis","curr","_scope$currentDialog2","main","ViewUtils","getCrud","uuid","_main$dialog","headerRight","put","setViewScope","Content","component","ModalContent","_ref2","disableScroll","_ref3","gesture","GestureHandlerRootView","UIHeader","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","UIView","onScroll","scroll","Container","scrollEventThrottle","keyboardShouldPersistTaps","view","UIOrder","renderItem","drag","isActive","state","ScaleDecorator","delayLongPress","onLongPress","getItemLabel","Header","pos","headerPos","OrderData","setData","DraggableFlatList","ListHeaderComponent","ListFooterComponent","containerStyle","keyExtractor","getItemValue","onDragEnd","_ref4","borderBottomWidth","borderBottomColor","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Aux","Inner","InputProps","inputProps","checked","getSelectedValue","control","Image","source","define","_scope$currentDialog3","_scope$currentDialog4","Card","box","boxStyle","dialogShow","rowItem","d","root","_event$dialog","dialogScope","owner","dialogHide","_main$dialog2","old","parentScope","Provider","borderStyle","shadowColor","shadowOpacity","shadowRadius","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","useTheme","SafeAreaProvider","SafeAreaContextView","viewStyle","StatusBar","barStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible","GestureView"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"react-crud-mobile.cjs.production.min.js","sources":["../src/elements/UIChildren.tsx","../src/elements/tabs/ElTabs.tsx","../src/elements/charts/ElChart.tsx","../src/elements/core/UIAutoComplete.tsx","../src/elements/UIComplete.tsx","../src/elements/core/UILink.tsx","../src/elements/core/UIIcon.tsx","../src/elements/core/UIButton.tsx","../src/elements/core/UISelect.tsx","../src/elements/core/UISwitch.tsx","../src/elements/core/UISlider.tsx","../src/elements/core/UIOption.tsx","../src/elements/core/UIRadio.tsx","../src/elements/core/UIInput.tsx","../src/elements/core/UIListRow.tsx","../src/hooks/useIsVisible.ts","../src/elements/core/UIList.tsx","../src/elements/core/UIToggle.tsx","../src/elements/core/UIQuantity.tsx","../src/elements/core/UIToast.tsx","../src/elements/core/UIModal.tsx","../src/elements/core/UIHeader.tsx","../src/elements/core/UIView.tsx","../src/elements/core/UIOrder.tsx","../src/elements/UIElement.tsx","../src/elements/core/UIInclude.tsx","../src/elements/UI.tsx","../src/elements/core/SafeView.tsx","../src/elements/core/GestureView.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport UIElement from './UIElement';\nimport { Crud, Scope, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, View } from 'react-native';\n\ninterface UIChildrenType {\n scope: Scope;\n crud?: Crud;\n validateScope?: String;\n children?: any;\n elements?: any;\n transient?: boolean;\n part?: string;\n style?: any;\n childProps?: any;\n}\n\nexport default function UIChildren(props: UIChildrenType) {\n let [scope] = useState(Utils.nvl(props.scope, ScopeUtils.create(props)));\n let crud = Utils.nvl(props.crud, scope.crud);\n let validateScope = Utils.nvl(props.validateScope, 'global');\n let name = Utils.nvl(props.part, 'child');\n\n if (scope.isInput()) {\n return <></>;\n }\n\n let Paint = ({ child }: any) => {\n if (!child) {\n return <></>;\n }\n if (typeof child === 'string') {\n return <>{child}</>;\n }\n\n let Custom = child.type;\n let pps = { ...child.props };\n\n delete pps.children;\n\n if (typeof Custom === 'string') {\n if (Utils.isEmpty(child.props.children)) {\n return <Custom {...pps} />;\n }\n return (\n <Custom {...pps}>\n <UIChildren\n transient\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n ></UIChildren>\n </Custom>\n );\n } else if (typeof Custom === 'function') {\n return (\n <Custom\n validateScope={validateScope}\n {...child.props}\n parent={scope}\n crud={crud}\n ></Custom>\n );\n }\n\n if (!Utils.isEmpty(child.props?.children)) {\n return (\n <UIChildren\n validateScope={validateScope}\n {...child.props}\n scope={scope}\n crud={crud}\n transient\n ></UIChildren>\n );\n }\n return <></>;\n };\n\n const Draw = () => {\n if (props.elements) {\n return (\n <>\n {Object.entries(props.elements).map((t: any, k) => {\n return <UIElement crud={crud} {...t[1]} />;\n })}\n </>\n );\n }\n return (\n <>\n {React.Children.map(props.children, child => {\n return <Paint child={child}></Paint>;\n })}\n </>\n );\n };\n\n if (props.transient) {\n return <Draw />;\n }\n\n if (Utils.isEmpty(props.children) && Utils.isEmpty(props.elements)) {\n return <></>;\n }\n\n const getStyle = (part?: string) => {\n let key = Utils.nvl(part, 'root');\n let def = styles[key];\n let css = {};\n\n if (!Utils.isEmpty(props.style)) {\n if (props.style?.push) {\n Utils.each(props.style, s => {\n if (s) {\n css = { ...css, ...s };\n }\n });\n } else {\n css = { ...props.style };\n }\n }\n return { ...def, ...css, ...scope.getStyle(part) };\n };\n\n if (props.transient) {\n return <Draw />;\n }\n return (\n <>\n <View style={getStyle(name)}>\n <Draw />\n </View>\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n child: { width: '100%' },\n inner: { width: '100%' },\n});\n","import React, { useState, useEffect } from 'react';\nimport UIChildren from '../UIChildren';\nimport UI from '../UI';\n\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport { ChildType, CrudUtils, Utils } from 'react-crud-utils';\n\nexport default function ElTabs(props: ChildType) {\n let scope = props.scope;\n let [selectedIndex, setSelectedIndex]: any = useState(0);\n let element = scope.original;\n let items = scope.getItems();\n let counter = 0;\n\n let tabs: any = [];\n let [selected, setSelected]: any = useState(null);\n\n const onChangeTab = (tab: any, validate = true) => {\n if (tab) {\n scope.execute({\n event: {\n validate,\n validateScope: element.validateScope,\n action: () => {\n scope.changeValue(tab.data);\n\n selected = tab;\n selectedIndex = tab.index;\n\n setSelectedIndex(selectedIndex);\n setSelected(tab);\n },\n },\n });\n }\n };\n\n const getStyleClass = (t: any) => {\n let s = 'ui-tabs-item ui-click';\n\n if (selected?.index === t.index) {\n s = s + ' ui-tab-selected';\n }\n return s;\n };\n\n const addTab = (child: any, item: any) => {\n let original = { ...child.props };\n\n if (!item) {\n item = scope.crud.data;\n }\n\n let crudTab = CrudUtils.create('tabs', {\n data: item,\n changed: item,\n parent: scope.crud,\n });\n\n let element = Utils.resolve(original, crudTab);\n\n if (element.rendered === false) {\n return;\n }\n\n tabs.push({\n ...element,\n child,\n element,\n original,\n index: counter++,\n data: item,\n });\n };\n\n React.Children.map(props.children, (child, index) => {\n if (Utils.isEmpty(items)) {\n addTab(child, {});\n } else {\n for (const i in items) {\n let o = items[i];\n\n addTab(child, o);\n }\n }\n });\n\n if (!selected) {\n onChangeTab(tabs[selectedIndex], false);\n }\n\n const nav = (i: any) => {\n let t = tabs[selectedIndex + i];\n\n onChangeTab(t);\n };\n\n const previous = () => {\n nav(-1);\n };\n\n const next = () => {\n nav(1);\n };\n\n let isStepper = element.layout === 'stepper';\n\n return (\n <div\n className={scope.getStyleClass('inner')}\n style={scope.getStyle('inner')}\n >\n <div className=\"ui-tabs-content\">\n <div className=\"ui-tabs-items\">\n {tabs.map((t: any, i: number) => (\n <div\n key={Utils.key(element.id, 'tab', i)}\n className={getStyleClass(t)}\n onClick={() => {\n onChangeTab(t);\n }}\n >\n {isStepper && <div className=\"ui-tab-item-divisor\" />}\n <div className=\"ui-tab-item-inner\">\n {isStepper && <div className=\"ui-step-line\" />}\n <div className=\"ui-tab-item-label\">\n {isStepper ? t.index + 1 : t.label}\n </div>\n </div>\n </div>\n ))}\n </div>\n {selected && (\n <>\n {isStepper && <div className=\"ui-tabs-label\">{selected.label}</div>}\n <div className=\"ui-tabs-area\">\n <UIChildren {...props} scope={scope}>\n {selected.child}\n </UIChildren>\n </div>\n {element.layout === 'stepper' && (\n <div className=\"ui-tabs-actions\">\n <UI.Output space={6} layout=\"left\">\n <UI.Include\n {...props}\n transient\n name=\"left\"\n default={\n <UI.Button\n rendered={selectedIndex > 0}\n icon={<Ionicons />}\n click={previous}\n />\n }\n />\n </UI.Output>\n <UI.Output space={6} layout=\"right\">\n <UI.Include\n {...props}\n transient\n name=\"right\"\n default={\n <UI.Button\n rendered={selectedIndex < tabs.length - 1}\n icon={<Ionicons />}\n click={next}\n />\n }\n />\n </UI.Output>\n </div>\n )}\n </>\n )}\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { ChildType, Scope, Utils } from \"react-crud-utils\";\n\nexport default function ElChart(props: ChildType) {\n let scope: Scope = props.scope;\n let items: any = scope.getItems();\n let columns = Utils.asList(scope.original.columns);\n\n return <div className=\"ui-chart-data\"></div>;\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIAutoComplete(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { ChildType } from 'react-crud-utils';\nimport AutoComplete from './core/UIAutoComplete';\n\nexport default function UIComplete({\n defaultsInput,\n defaultsUI,\n scope,\n}: ChildType) {\n return (\n <>\n <AutoComplete {...defaultsInput} {...defaultsUI} />\n </>\n );\n}\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UILink(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import {\n Ionicons,\n MaterialCommunityIcons,\n AntDesign,\n Entypo,\n EvilIcons,\n} from '@expo/vector-icons';\n\nimport { ChildType, Utils } from 'react-crud-utils';\n\nexport default function UIIcon({ scope }: ChildType) {\n let name = scope.getValue();\n let libs: any = {\n ion: Ionicons,\n ant: AntDesign,\n entypo: Entypo,\n evil: EvilIcons,\n material: MaterialCommunityIcons,\n };\n\n let library = Utils.nvl(scope.original.library, 'ion');\n let Aux = libs[library];\n\n return <Aux name={name} style={scope.getStyle('icon')} />;\n}\n","import { Ionicons } from '@expo/vector-icons';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { Text, TouchableHighlight, View } from 'react-native';\n\nconst BUTTONS_SIZE: any = { small: { minWidth: 30, height: 30 } };\n\nexport default function UIButton(props: ChildType) {\n let scope = props.scope;\n let element = scope.original;\n let size = Utils.nvl(element.size, 'default');\n let align = Utils.nvl(element.align, 'center');\n let variant = Utils.nvl(element.variant, 'default');\n\n let color = element.color;\n let label = scope.getLabel();\n let icon = scope.getPart('icon');\n\n //ajuste align v3\n if (!color) color = 'primaryLight';\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\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 backgroundColor: color,\n borderRadius: 12,\n gap: 10,\n justifyContent: 'center',\n alignItems: 'center',\n flexDirection: 'row',\n },\n };\n\n const onClick = (e: any) => {\n scope.call('click', {});\n };\n\n const style = (part: string, extra?: any) => {\n let css = { ...styles[part], ...extra };\n\n if (variant === 'text' || variant === 'outlined') {\n css.backgroundColor = 'transparent';\n css.color = Utils.nvl(color, 'text');\n }\n\n if (size === 'small') {\n css.fontSize = 12;\n css.fontWeight = 500;\n }\n\n if (size === 'medium') {\n css.fontSize = 14;\n css.fontWeight = 500;\n }\n\n if (align === 'left') {\n css.justifyContent = 'flex-start';\n }\n\n return scope.getStyle(part, css);\n };\n\n let extra: any = {};\n\n if (icon) {\n extra.button = { height: 40, padding: 0 };\n } else {\n extra.button = { height: 50 };\n }\n\n const buttonStyle = Utils.call(() => {\n let def: any = { ...extra?.button };\n\n if (variant === 'outlined') {\n def.borderWidth = 1;\n def.borderColor = Utils.nvl(color, 'text');\n }\n\n if (size) {\n def = { ...def, ...BUTTONS_SIZE[size] };\n }\n\n if (!label) {\n def = { ...def, borderRadius: 20 };\n }\n\n let css = style('button', def);\n\n if (!css.width) {\n let h = css.height;\n\n if (typeof h === 'number') {\n css.minWidth = h;\n }\n }\n\n return css;\n });\n\n const buttonLabel = style('buttonLabel');\n const iconStyle = Utils.call(() => {\n let css: any = style('buttonIcon', extra.icon);\n\n css.fontSize = Utils.nvl(buttonLabel.fontSize, css.fontSize);\n\n return css;\n });\n\n return (\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClick}\n style={buttonStyle}\n >\n <>\n {icon && (\n <>\n <Ionicons\n size={Utils.nvl(element.iconSize, 30)}\n style={iconStyle}\n name={icon}\n />\n </>\n )}\n {label && <Text style={buttonLabel}>{label}</Text>}\n </>\n </TouchableHighlight>\n );\n}\n","import { useRef, useState } from 'react';\nimport { ChildType, MethodType, Utils, ViewUtils } from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport UI from '../UI';\n\nexport default function UISelect(props: ChildType) {\n const [modalVisible, setModalVisible] = useState(false);\n const scope = props.scope;\n const element = scope.original;\n const items = Utils.nvl(scope.getOptions(), []);\n const placeholder = scope.attr('placeholder', 'Selecione...');\n const value = scope.getDisplayValue();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const handlePress = () => {\n setModalVisible(!modalVisible);\n };\n\n const scrollRef = useRef(null);\n const iconColor = Utils.nvl(theme.colors?.text, '#100e0e');\n const modalColor = Utils.nvl(headerStyle.color, 'white');\n const defaults = { color: modalColor };\n const onClick = ({ crud, value }: MethodType) => {\n let val = value as any;\n\n if (element.isObject && val?.object) {\n scope.changeValue(val?.object);\n } else if (val?.value) {\n scope.changeValue(val?.value);\n } else {\n scope.changeValue(value);\n }\n\n setModalVisible(false);\n };\n\n const style = (part: string, extra?: any) => {\n let all = { ...styles[part], ...extra };\n\n return scope.getStyle(part, all);\n };\n\n const isModalVisible = () => {\n return modalVisible;\n };\n //v4\n\n return (\n <View\n key={scope.getName(`${scope.getPart('modal')}_${modalVisible}`)}\n style={style('selectRoot')}\n >\n <TouchableOpacity onPress={handlePress} style={style('selectInput')}>\n <Text style={style('selectLabel')}>\n {Utils.nvl(value, placeholder)}\n </Text>\n <Ionicons\n name=\"chevron-down-outline\"\n size={scope.getPart('iconSize', null, 24)}\n color={scope.getPart('iconColor', null, iconColor)}\n style={style('iconStyle', {})}\n />\n </TouchableOpacity>\n <Modal\n animationType=\"slide\"\n transparent={true}\n visible={isModalVisible()}\n onRequestClose={() => setModalVisible(false)}\n >\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={handlePress}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"close\"\n size={24}\n color={modalColor}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{placeholder}</Text>\n </View>\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n <View\n style={{\n flex: 1,\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n }}\n >\n <UI.List\n data={items}\n name={scope.getName('list')}\n layout=\"card\"\n click={onClick}\n rowStyle={{\n paddingLeft: 15,\n paddinRight: 15,\n ...scope.original?.rowStyle,\n }}\n {...scope.original?.listProps}\n >\n <UI.Value value=\"#{@this.label}\" />\n </UI.List>\n </View>\n </ScrollView>\n </SafeAreaView>\n </Modal>\n </View>\n );\n}\n\nconst styles = StyleSheet.create({\n selectRoot: {\n justifyContent: 'flex-start',\n alignItems: 'flex-start',\n flex: 1,\n },\n selectInput: {\n width: '100%',\n flexDirection: 'row',\n borderRadius: 5,\n paddingHorizontal: 15,\n paddingVertical: 10,\n },\n selectLabel: { flex: 1 },\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 18,\n fontWeight: 'bold',\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n },\n});\n","import { useState } from 'react';\r\nimport { ChildType, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\n\r\nexport default function UISwitch(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), false) as boolean;\r\n const [value, setValue] = useState(initial);\r\n\r\n let onChange = v => {\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n return (\r\n <Switch\r\n value={value}\r\n style={scope.getStyle('element')}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\r\nimport { ChildType, ComponentUtils, Utils } from 'react-crud-utils';\r\nimport { Switch } from 'react-native';\r\nimport Slider from '@react-native-community/slider';\r\n\r\nexport default function UISlider(props: ChildType) {\r\n const scope = props.scope;\r\n const initial = Utils.nvl(scope.getValue(), 0);\r\n const [value, setValue] = useState(initial);\r\n\r\n //redeploy 0\r\n\r\n let onChange = v => {\r\n v = Utils.nvl(v, 0);\r\n\r\n console.log(v);\r\n\r\n scope.changeValue(v);\r\n\r\n setValue(v);\r\n };\r\n\r\n let step = scope.attr('step', 1);\r\n let min = scope.attr('min', 0);\r\n let max = scope.attr('min', 100);\r\n\r\n let onSlideScroll = (scrollEnabled: boolean) => {\r\n let viewScope = ComponentUtils.getViewScope();\r\n\r\n if (scope.original.debug) {\r\n console.log(viewScope);\r\n }\r\n\r\n if (viewScope) {\r\n let scrollRef = viewScope.get('scrollRef');\r\n\r\n if (scrollRef) scrollRef.current?.setNativeProps?.({ scrollEnabled });\r\n }\r\n };\r\n return (\r\n <>\r\n <Slider\r\n minimumValue={min}\r\n maximumValue={max}\r\n step={step}\r\n minimumTrackTintColor=\"#1EB1FC\"\r\n maximumTrackTintColor=\"#d3d3d3\"\r\n thumbTintColor=\"#1EB1FC\"\r\n value={value}\r\n onSlidingStart={() => onSlideScroll(false)}\r\n onSlidingComplete={() => onSlideScroll(true)}\r\n style={{ width: '100%', height: 40, ...scope.getStyle('element') }}\r\n onValueChange={onChange} // Alterna o estado\r\n />\r\n </>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIOption(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { Text, TouchableOpacity, Linking, StyleSheet } from 'react-native';\r\n\r\nexport default function UIRadio(props: any) {\r\n const handlePress = () => {\r\n Linking.openURL('https://reactnative.dev/');\r\n };\r\n\r\n return (\r\n <TouchableOpacity onPress={handlePress}>\r\n <Text style={styles.link}>Clique aqui para acessar o React Native</Text>\r\n </TouchableOpacity>\r\n );\r\n}\r\n\r\nconst styles = {\r\n link: {},\r\n};\r\n","import { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, TextInput, View } from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIInput(props: ChildType) {\n let scope = props.scope;\n let initial = Utils.call(() => {\n let val = Utils.nvl(scope.getValue(), '');\n\n if (val && val?.push) {\n return val.join(', ').trim();\n }\n return val;\n });\n\n let label = scope.getLabel();\n let placeholder = scope.getPart('placeholder', null, label);\n let el = scope.original;\n\n const [value, setValue] = useState(initial);\n\n let onChange = v => {\n v = scope.changeValue(v);\n\n setValue(v);\n };\n\n const style = (part: string, extra?: any) => {\n return { ...scope.getStyle(part, styles[part]), ...extra };\n };\n\n const CustomIcon = () => {\n let icon = el.icon;\n\n if (icon) {\n if (typeof icon === 'string') {\n return (\n <>\n {el.icon && (\n <Ionicons\n name={el.icon}\n size={scope.attr('iconSize', 20)}\n color={scope.attr('iconColor', '#888')}\n />\n )}\n </>\n );\n }\n return <>{icon}</>;\n }\n return <></>;\n };\n return (\n <>\n <View style={style('base')}>\n {scope.getPart('left')}\n <TextInput\n style={style('input')}\n onChangeText={onChange}\n value={value}\n placeholder={placeholder}\n />\n <CustomIcon />\n </View>\n {scope.getPart('right')}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n base: {\n flex: 1,\n width: '100%',\n paddingBottom: 0,\n paddingTop: 0,\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'borderColor',\n borderRadius: 5,\n paddingHorizontal: 15,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n gap: 10,\n },\n icon: {\n marginRight: 10, // Espaço entre ícone e input\n },\n input: {\n marginHorizontal: 0,\n marginVertical: 0,\n height: 40,\n flex: 1, // Para o input ocupar o espaço restante\n },\n});\n","import React, { useRef, useState } from 'react';\nimport { ChildType, ScopeUtils, Utils } from 'react-crud-utils';\nimport UIChildren from '../UIChildren';\nimport { StyleSheet, TouchableHighlight, View } from 'react-native';\nimport { useIsVisible } from '../../hooks/useIsVisible';\n\ninterface UIListRowType extends ChildType {\n item: any;\n index: number;\n}\n\nexport default function UIListRow(props: UIListRowType) {\n const scope = props.scope;\n const index = props.index;\n const original = scope.original;\n const item = props.item;\n const cols = scope.getPart('cols', undefined, -1);\n const rowWidth = Math.floor(100 / cols) + '%';\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n //v4\n const targetRef = useRef(null);\n const isVisible = useIsVisible(targetRef, row);\n\n const onClick = (item: any) => {\n row.call('click', { value: item, item, edit: true, index });\n };\n\n const Child = () => {\n if (!isVisible && original.useIsInView && !row.visible && index > 20) {\n return <></>;\n }\n return (\n <>\n <UIChildren transient scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n\n const ListItem = () => {\n let [updateIndex, setUpdateIndex] = useState(0);\n let key = scope.key('item');\n\n row.selected = row.getPart('isSelectedRow', undefined, false);\n\n const getRowStyle = () => {\n let css = row.getStyle('row', { ...styles.row, minHeight: 40 });\n\n if (row.selected) {\n css = { ...css, ...row.getStyle('rowSelected', {}) };\n } else {\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\n }\n\n if (cols > 0) {\n css.width = rowWidth;\n }\n\n return css;\n };\n\n row.update = () => {\n scope.updateIndex = scope.updateIndex + 1;\n\n setUpdateIndex(++updateIndex);\n };\n\n let renderedRow = row.getPart('renderedItem', undefined, true);\n\n if (renderedRow === false) {\n return <></>;\n }\n\n if (!original.click) {\n return (\n <View key={key} style={getRowStyle()} ref={targetRef}>\n <Child />\n </View>\n );\n }\n return (\n <TouchableHighlight\n key={key}\n style={getRowStyle()}\n underlayColor={'transparent'}\n ref={targetRef}\n onPress={e => {\n e.stopPropagation();\n onClick(item);\n }}\n >\n <Child />\n </TouchableHighlight>\n );\n };\n\n return <ListItem />;\n}\n\nconst stylesList = StyleSheet.create({\n row: {\n padding: 5,\n margin: 0,\n width: '100%',\n backgroundColor: 'background',\n gap: 10,\n borderRadius: 8,\n justifyContent: 'center',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n row: {\n padding: 0,\n width: '100%',\n justifyContent: 'center',\n },\n});\n","import { useEffect, useState } from 'react';\r\nimport { Scope } from 'react-crud-utils';\r\nimport { Dimensions, Platform } from 'react-native';\r\n\r\nexport function useIsVisible(ref: any, scope: Scope) {\r\n const [isVisible, setIsVisible] = useState(scope.visible === true);\r\n\r\n useEffect(() => {\r\n const checkVisibility = () => {\r\n if (!ref.current || isVisible || !scope.original?.useIsInView) return;\r\n\r\n if (Platform.OS === 'web') {\r\n const rect = ref.current.getBoundingClientRect?.();\r\n\r\n if (rect && typeof window !== 'undefined') {\r\n const windowHeight = window.innerHeight;\r\n const visible = rect.top < windowHeight && rect.bottom > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n\r\n setIsVisible(visible);\r\n }\r\n } else {\r\n ref.current.measureInWindow?.((x, y, width, height) => {\r\n const windowHeight = Dimensions.get('window').height;\r\n const visible = y < windowHeight && y + height > 0;\r\n\r\n if (visible) scope.visible = visible;\r\n setIsVisible(visible);\r\n });\r\n }\r\n };\r\n\r\n const interval = setInterval(checkVisibility, 300); // roda a cada 300ms\r\n return () => clearInterval(interval);\r\n }, [ref]);\r\n\r\n return isVisible;\r\n}\r\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\nimport UI from '../UI';\nimport { Ionicons } from '@expo/vector-icons';\n\nexport default function UIList(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\n const styles = { repeat: stylesRepeat, list: stylesList }?.[original.type];\n const add = ComponentUtils.getDefine(props, 'add');\n const hideAddWhenEmpty = original.hideAddWhenEmpty;\n\n const getStyle = (key: string, extra?: any) => {\n return scope.getStyle(key, { ...extra, ...styles[key] });\n };\n\n const getContainerStyle = (extra?: any) => {\n let row = getStyle('container', {});\n\n if (cols > 1) {\n row = { ...row, flexDirection: 'row', flexWrap: 'wrap' };\n }\n\n return row;\n };\n\n const LocalData = () => {\n let [index, setIndex] = useState(scope.updateIndex);\n\n scope.update = () => {\n scope.updateIndex = ++index;\n\n setIndex(index);\n };\n\n let keyData = scope.key('data');\n\n const items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search !== false && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = Utils.getValue(filterBy, 'none', o).toLowerCase();\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\n });\n\n 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 <View key={keyData} style={getContainerStyle()}>\n <Empty />\n {items.map((item: any, i: number) => (\n <UIListRow index={i} item={item} scope={scope}>\n {props.children}\n </UIListRow>\n ))}\n {isShowAdd() && <>{add}</>}\n </View>\n );\n };\n\n return (\n <>\n {original.search !== false && (\n <UI.Text\n placeholder=\"Pesquisar...\"\n field=\"query\"\n crud={crud}\n style={{ marginBottom: 10 }}\n change={{\n action: () => {\n scope.search();\n },\n }}\n icon={<Ionicons name=\"search\" size={20} color=\"#888\" />}\n />\n )}\n <LocalData />\n </>\n );\n}\n\nconst stylesList = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n\nconst stylesRepeat = StyleSheet.create({\n container: {\n display: 'flex',\n flexWrap: 'wrap',\n gap: 10,\n width: '100%',\n },\n text: {\n fontSize: 18,\n fontWeight: 'bold',\n },\n});\n","import React, { useState } from 'react';\nimport { ChildType, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport UIListRow from './UIListRow';\n\nexport default function UIToggle(props: ChildType) {\n const scope = props.scope;\n const options = Utils.nvl(scope.getOptions(), []);\n const value = scope.getInputValue();\n\n let [index, setIndex] = useState(0);\n\n const isSelected = (item: any) => {\n return item?.value === value;\n };\n\n const onClick = (item: any) => {\n scope.changeValue(item.object);\n setIndex(++index);\n };\n\n const Item = ({ item, index }) => {\n let selected = isSelected(item);\n let style: any = { ...styles.text };\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: 10,\n marginVertical: 8,\n backgroundColor: 'background',\n borderRadius: 8,\n justifyContent: 'center',\n width: 'auto',\n flexDirection: 'row',\n },\n text: {\n fontSize: 15,\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: 0,\n alignItems: 'center',\n height: 30,\n width: 30,\n textAlign: 'center',\n verticalAling: 'middle',\n borderRadius: 24,\n backgroundColor: color,\n color: '#ffffff',\n justifyContent: 'center',\n };\n\n const styles: any = {\n buttonLabel: {\n color: '#ffffff',\n fontWeight: '500',\n fontSize: 16,\n },\n value: {\n flex: 1,\n flexDirection: 'row',\n textAlign: 'center',\n fontWeight: '500',\n },\n buttonInner: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n },\n buttonIcon: {\n color: '#fff',\n fontSize: 18,\n },\n button: btn,\n addButton: {\n ...btn,\n },\n delButton: {\n ...btn,\n },\n };\n\n const change = (val: number) => {\n scope.changeValue(value + val);\n setIndex(++index);\n };\n\n const onClickAdd = () => {\n change(1);\n };\n\n const onClickDel = () => {\n change(-1);\n };\n\n const style = (part: string, extra?: any) => {\n let s = { ...styles[part], ...extra };\n return scope.getStyle(part, s);\n };\n\n return (\n <>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickDel}\n style={style('delButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"remove\" />\n </TouchableHighlight>\n <Text style={style('value')}>{Utils.nvl(value, 0)}</Text>\n <TouchableHighlight\n underlayColor={'transparent'}\n onPress={onClickAdd}\n style={style('addButton')}\n >\n <Ionicons size={30} style={style('buttonIcon')} name=\"add\" />\n </TouchableHighlight>\n </>\n );\n}\n","import { StyleSheet } from 'react-native';\nimport Toast, { BaseToast, ErrorToast } from 'react-native-toast-message';\n\nexport default function UIToast() {\n const toastConfig = {\n success: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n contentContainerStyle={{ paddingHorizontal: 15 }}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n error: props => (\n <ErrorToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n info: props => (\n <BaseToast\n {...props}\n style={styles.darkToast}\n text1Style={styles.text}\n text2Style={styles.text}\n />\n ),\n };\n\n const styles = StyleSheet.create({\n darkToast: {\n backgroundColor: 'rgba(34, 34, 34, 0.85)',\n borderLeftColor: '#222', // borda mais escura\n },\n text: {\n color: '#fff', // letras brancas\n textAlign: 'center',\n },\n });\n return <Toast config={toastConfig} />;\n}\n","import { useRef, useState } from 'react';\nimport {\n ChildType,\n ComponentUtils,\n CrudUtils,\n MethodType,\n Utils,\n ViewUtils,\n} from 'react-crud-utils';\nimport {\n Text,\n TouchableOpacity,\n StyleSheet,\n Modal,\n View,\n SafeAreaView,\n ScrollView,\n} from 'react-native';\nimport UIChildren from '../UIChildren';\nimport Ionicons from '@expo/vector-icons/Ionicons';\nimport UIToast from './UIToast';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface UIModalType extends ChildType {\n open?: boolean;\n dialog?: any;\n}\n\nexport default function UIModal({\n scope,\n open,\n dialog,\n ...props\n}: UIModalType) {\n let [modalVisible, setModalVisible] = useState(open === true);\n let [index, setIndex] = useState(0);\n //v1\n\n const label = scope.getLabel();\n const theme = scope.getTheme();\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const scrollRef = useRef(null);\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?.crud, event: {} });\n };\n\n scope.toggleDialog = vis => {\n modalVisible = vis;\n setModalVisible(modalVisible);\n };\n\n scope.update = () => {\n setIndex(++index);\n };\n\n let curr = scope.currentDialog?.crud;\n let main = ViewUtils.getCrud('view');\n\n if (!curr) {\n return <></>;\n }\n\n if (curr.uuid !== main.dialog?.crud?.uuid) {\n return <></>;\n }\n\n const headerRight = ComponentUtils.getDefine(props, 'header', 'right');\n const bottom = ComponentUtils.getDefine(props, 'bottom');\n\n scope.put('scrollRef', scrollRef);\n\n const original = scope.original;\n\n ComponentUtils.setViewScope(scope);\n\n let color = Utils.nvl(headerStyle.color, 'white');\n let defaults = { color };\n let key = `${curr.name}-${index}`;\n\n let Content = () => {\n if (dialog?.component) {\n let Aux = dialog?.component;\n\n return <Aux key={curr.uuid} crud={curr} />;\n }\n\n return (\n <UIChildren scope={scope} crud={curr}>\n {props.children}\n </UIChildren>\n );\n };\n\n let ModalContent = ({ children }) => {\n let disableScroll = scope.part('disableScroll', false);\n let disableContent = scope.part('disableContent', false);\n\n if (disableContent) {\n return <>{children}</>;\n }\n\n if (disableScroll) {\n return <View style={style('modalContent')}>{children}</View>;\n }\n return (\n <ScrollView\n contentContainerStyle={{ flexGrow: 1, paddingBottom: 50 }}\n style={style('modalContent')}\n nestedScrollEnabled={true}\n ref={scrollRef}\n >\n {children}\n </ScrollView>\n );\n };\n\n const ModalView = ({ children }) => {\n if (original.gesture) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const ModalInner = () => {\n if (original.transient) {\n return (\n <View style={style('modalSafe')}>\n <Content />\n </View>\n );\n }\n\n return (\n <>\n <SafeAreaView style={style('modalTop')} />\n <SafeAreaView style={style('modalSafe')}>\n <View style={scope.getStyle('header', headerStyle)}>\n <TouchableOpacity\n onPress={onClose}\n style={style('modalCloseButton')}\n >\n <Ionicons\n name=\"chevron-back-outline\"\n size={24}\n color={color}\n style={style('modalCloseText', defaults)}\n />\n </TouchableOpacity>\n <Text style={style('modalTitle', defaults)}>{label}</Text>\n {!Utils.isEmpty(headerRight) && (\n <UIChildren scope={scope} crud={curr} transient>\n {headerRight}\n </UIChildren>\n )}\n </View>\n <ModalContent>\n <Content />\n </ModalContent>\n {bottom}\n </SafeAreaView>\n <UIToast />\n </>\n );\n };\n return (\n <ModalView>\n <Modal\n key={key}\n animationType=\"slide\"\n transparent={true}\n visible={modalVisible}\n onRequestClose={onClose}\n >\n <ModalInner />\n </Modal>\n </ModalView>\n );\n}\n\nconst styles = StyleSheet.create({\n modalTop: {\n backgroundColor: 'primary',\n width: '100%',\n },\n modalSafe: {\n flex: 1,\n width: '100%',\n backgroundColor: 'background',\n },\n modalCloseButton: {\n padding: 10,\n },\n modalCloseText: {\n fontSize: 18,\n color: 'white',\n },\n modalTitle: {\n fontSize: 22,\n fontWeight: 600,\n marginLeft: 10,\n },\n modalContent: {\n flex: 1,\n backgroundColor: 'background',\n paddingLeft: 15,\n paddingRight: 15,\n paddingTop: 10,\n paddingBottom: 10,\n },\n});\n","import { Text, View } from 'react-native';\n\nimport { ChildType, HtmlUtils, Utils } from 'react-crud-utils';\n\nexport default function UIHeader({ scope }: ChildType) {\n const theme = scope.getTheme();\n const header = scope.getPart('header', null, []);\n const headerStyle = Utils.nvl(theme.styles?.defaults?.header, {});\n const headerTextStyle = Utils.nvl(theme.styles?.defaults?.headerText, {});\n\n let headerStyleFull = Utils.call(() => {\n let css = scope.getStyle('header', headerStyle);\n let bg = css.backgroundColor;\n\n if (bg) {\n css.color = HtmlUtils.getTextColor(bg);\n }\n return css;\n });\n\n let hasHeader = !Utils.isEmpty(header);\n let AuxHeader = () => {\n if (typeof header === 'string') {\n return <Text style={headerTextStyle}>{header}</Text>;\n }\n return <>{header}</>;\n };\n\n return (\n <>\n {hasHeader && (\n <View style={headerStyleFull}>\n <AuxHeader />\n </View>\n )}\n </>\n );\n}\n","import { ScrollView, StyleSheet, Text, View } from 'react-native';\n\nimport UIChildren from '../UIChildren';\nimport { ChildType, ComponentUtils, Utils, ViewUtils } from 'react-crud-utils';\nimport { useRef } from 'react';\nimport UIToast from './UIToast';\nimport UIHeader from './UIHeader';\n\nexport default function UIView({ scope, children }: ChildType) {\n const scrollRef = useRef(null);\n const original = scope.original;\n\n const onScroll = () => {\n const crud = ViewUtils.getCrud();\n\n Utils.each(crud.scroll, s => {\n if (s.onScroll) {\n s.onScroll.call(s);\n }\n });\n };\n\n //v3\n scope.put('scrollRef', scrollRef);\n\n ComponentUtils.setViewScope(scope);\n\n let Container = () => {\n if (original.scroll === false) {\n return <UIChildren scope={scope}>{children}</UIChildren>;\n }\n\n return (\n <View style={scope.getStyle('container', styles.container)}>\n <ScrollView\n onScroll={onScroll}\n scrollEventThrottle={16}\n ref={scrollRef}\n nestedScrollEnabled={true}\n keyboardShouldPersistTaps=\"handled\"\n contentContainerStyle={scope.getStyle('contentContainer', {\n paddingBottom: 50,\n })}\n style={scope.getStyle('scroll', styles.scroll)}\n >\n <UIChildren scope={scope}>{children}</UIChildren>\n </ScrollView>\n </View>\n );\n };\n return (\n <>\n <UIHeader scope={scope} />\n <Container />\n <UIToast /> {/* <- este componente precisa estar aqui */}\n </>\n );\n}\n\nconst styles = StyleSheet.create({\n scroll: {\n paddingTop: 10,\n paddingBottom: 10,\n paddingLeft: 15,\n paddingRight: 15,\n },\n container: {},\n view: {},\n});\n","import React, { useState } from 'react';\nimport { ChildType, ComponentUtils, ScopeUtils, Utils } from 'react-crud-utils';\nimport { StyleSheet, Text, TouchableOpacity, View } from 'react-native';\nimport UI from '../UI';\nimport { Ionicons, MaterialCommunityIcons } from '@expo/vector-icons';\nimport DraggableFlatList, {\n ScaleDecorator,\n} from 'react-native-draggable-flatlist';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\nimport UIHeader from './UIHeader';\nimport UIChildren from '../UIChildren';\n\nexport default function UIOrder(props: ChildType) {\n const scope = props.scope;\n const crud = scope.crud;\n const original = scope.original;\n const cols = Utils.nvl(scope.getPart('cols', undefined, 1));\n\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 items = Utils.call(() => {\n let list = Utils.nvl(scope.getItems(), []);\n\n if (original.search && !original.list?.url) {\n let query = crud\n .get('query', '')\n .toLowerCase()\n .trim() as string;\n\n if (query.length > 1) {\n let filters: any[] = [];\n let filterBy = Utils.nvl(original.filterBy, 'label');\n\n Utils.each(list, o => {\n let label = o[filterBy];\n\n if (label) {\n if (label.includes(query)) {\n filters.push(o);\n }\n }\n });\n\n return filters;\n }\n }\n return list;\n });\n\n //v2\n\n const renderItem = ({ item, drag, isActive, getIndex }) => {\n const index = getIndex();\n const name = `${scope.key('row', index, '')}`;\n const [row] = useState(\n ScopeUtils.create({\n ...original,\n parent: scope,\n name,\n crud: scope.crud,\n index,\n type: 'row',\n data: item,\n })\n );\n\n let css = { ...scope.getStyle('row') };\n\n if (isActive) {\n css = { ...css, ...scope.getStyle('active') };\n }\n\n if (isActive) {\n css = { ...css, ...row.getStyle('rowSelected', {}) };\n } else {\n css = { ...css, ...row.getStyle('rowUnSelected', {}) };\n }\n const Child = () => {\n if (Utils.isEmpty(props.children)) {\n return (\n <>\n <MaterialCommunityIcons name=\"drag\" size={24} color=\"black\" />\n <Text style={styles.text}>{scope.getItemLabel(item)}</Text>\n </>\n );\n }\n\n return (\n <>\n <UIChildren transient scope={row} crud={row.crud}>\n {props.children}\n </UIChildren>\n </>\n );\n };\n return (\n <ScaleDecorator>\n <TouchableOpacity\n style={[\n styles.row,\n { backgroundColor: isActive ? 'lightblue' : 'white' },\n { ...css },\n ]}\n delayLongPress={100}\n onLongPress={drag} // Initiate drag on long press\n >\n <Child />\n </TouchableOpacity>\n </ScaleDecorator>\n );\n };\n\n const OrderView = ({ children }) => {\n if (original.gesture !== false) {\n return (\n <GestureHandlerRootView\n style={{\n flex: 1,\n width: '100%',\n ...scope.getStyle('order', { justifyContent: 'flex-start' }),\n }}\n >\n {children}\n </GestureHandlerRootView>\n );\n }\n return <>{children}</>;\n };\n\n const Header = ({ pos }) => {\n const hPos = Utils.nvl(original.headerPos, 'outer');\n\n if (hPos !== pos) return <></>;\n\n return <UIHeader scope={scope} />;\n };\n\n let OrderData = () => {\n const [data, setData] = useState(items);\n\n return (\n <DraggableFlatList\n data={data}\n ListHeaderComponent={<Header pos=\"inner\" />}\n ListFooterComponent={<>{scope.getPart('footer')}</>}\n renderItem={renderItem}\n containerStyle={{ ...scope.getStyle('list') }}\n keyExtractor={item => {\n let key = scope.getItemValue(item);\n\n if (original?.debug) {\n console.log(key);\n }\n return key;\n }}\n onDragEnd={({ data }) => {\n setData(data);\n scope.changeValue(data);\n }}\n />\n );\n };\n return (\n <OrderView>\n <Header pos=\"outer\" />\n <OrderData />\n </OrderView>\n );\n}\n\nconst styles = StyleSheet.create({\n row: {\n flexDirection: 'row',\n gap: 10,\n padding: 15,\n borderBottomWidth: 1,\n borderBottomColor: '#ccc',\n },\n text: {\n fontSize: 18,\n },\n});\n","import React, {\n createContext,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\nimport UIChildren from './UIChildren';\nimport ElTabs from './tabs/ElTabs';\nimport ElChart from './charts/ElChart';\nimport UIComplete from './UIComplete';\nimport {\n Crud,\n HtmlUtils,\n ScopeUtils,\n Utils,\n ElementType,\n MethodType,\n ActionType,\n ComponentUtils,\n CrudUtils,\n ViewUtils,\n Scope,\n} from 'react-crud-utils';\nimport UILink from './core/UILink';\nimport UIIcon from './core/UIIcon';\nimport UIButton from './core/UIButton';\nimport UISelect from './core/UISelect';\nimport UISwitch from './core/UISwitch';\nimport UISlider from './core/UISlider';\nimport UIOption from './core/UIOption';\nimport UIRadio from './core/UIRadio';\nimport UIInput from './core/UIInput';\nimport {\n Alert,\n Image,\n Linking,\n StyleSheet,\n Text,\n TouchableHighlight,\n View,\n} from 'react-native';\nimport UIList from './core/UIList';\nimport UIToggle from './core/UIToggle';\nimport UIQuantity from './core/UIQuantity';\nimport UIModal from './core/UIModal';\nimport { Ionicons } from '@expo/vector-icons';\nimport UIView from './core/UIView';\nimport Toast from 'react-native-toast-message';\nimport UIOrder from './core/UIOrder';\n\nconst CrudContext = createContext<any>({});\n\nexport default function UIElement(props: ElementType) {\n const ctx = useContext(CrudContext);\n const theme = Utils.nvl(props.theme, ctx?.theme);\n\n let crud: Crud = Utils.nvl(props.crud, ctx?.crud);\n let [scope] = useState(ScopeUtils.create({ crud, ...props, theme }));\n let [index, setIndex] = useState(0);\n let [error, setError]: string | any = useState(null);\n\n scope.compile(props);\n\n crud = scope.crud;\n\n let options: any = scope.getOptions();\n\n let original = scope.original;\n let ref = useRef(null);\n\n scope.update = () => {\n setIndex(++index);\n };\n\n scope.updateElement = () => {\n setIndex(++index);\n };\n\n scope.toast = (message: string, type = 'info', args?: any) => {\n Toast.show({\n type, // 'success' | 'error' | 'info'\n text1: message,\n position: 'bottom', // 'top' é outra opção\n visibilityTime: 3000, // tempo que fica visível em ms\n ...args,\n });\n };\n\n scope.prompt = (args: MethodType) => {\n let event = args.event as ActionType;\n\n if (event) {\n let message = 'Você tem certeza que deseja continuar?';\n let title = 'Atenção';\n let prompt = event.prompt;\n\n if (typeof prompt === 'string') {\n message = prompt;\n }\n\n if (typeof prompt === 'object') {\n message = Utils.nvl(prompt.message, message);\n title = Utils.nvl(prompt.title, title);\n }\n\n Alert.alert(\n title,\n message,\n [\n {\n text: 'Cancelar',\n style: 'cancel',\n },\n {\n text: 'Confirmar',\n onPress: () => scope.execute(args),\n },\n ],\n { cancelable: false }\n );\n }\n };\n const Custom = () => {\n let c: any = original.custom;\n\n if (c) {\n if (typeof c === 'string') {\n return (\n <UIElement\n element={{ value: c, type: 'dummy' }}\n crud={crud}\n ></UIElement>\n );\n }\n\n return (\n <UIElement\n type={c.type}\n tag={c.type}\n {...c.props}\n crud={crud}\n ></UIElement>\n );\n }\n\n return <></>;\n };\n\n if (scope.is('type', 'dummy')) {\n return <>{scope.getDisplayValue()}</>;\n }\n\n let onCheck = () => {\n let v = scope.getValue();\n let check = !(v === true);\n\n onChange({ target: { value: check } });\n };\n\n let onChange = (e: any) => {\n let val = e.target.value;\n\n if (scope.isType('integer', 'int', 'number')) {\n val = parseInt(val);\n } else if (scope.isType('decimal')) {\n val = parseFloat(val);\n }\n\n if (scope.isType('select', 'complete')) {\n val = scope.getSelectedItem(val);\n }\n\n scope.changeValue(val);\n scope.update();\n };\n\n let onClick = (e: any) => {\n if (scope.currentDialog?.component) return;\n\n scope.call('click');\n };\n\n let defaultsInput: any = {\n scope,\n crud,\n onChange: onChange,\n };\n\n if (scope.isType('password')) {\n defaultsInput.type = 'password';\n }\n\n let isChecked = () => {\n let v = scope.getValue();\n\n return v === true;\n };\n\n let hasChildren = () => {\n if (scope.isInput()) {\n return false;\n }\n\n return !Utils.isEmpty(props.children) || !Utils.isEmpty(props.elements);\n };\n\n let isInput = scope.is(\n 'type',\n 'text',\n 'number',\n 'integer',\n 'int',\n 'phone',\n 'postalCode',\n 'money',\n 'password',\n 'email'\n );\n\n const getStyle = (part?: string, extra?: any) => {\n let type = Utils.nvl(original.type, 'none');\n let key = Utils.nvl(part, 'root');\n let def = { ...styles[key] };\n let hasChild = hasChildren();\n\n type = Utils.nvl(original.layout, type);\n\n if (!part && !hasChild) {\n def = { ...def };\n }\n\n if (scope.isInput()) {\n def = { ...def, ...elementStyle.input[key] };\n }\n\n def = { ...def, ...elementStyle?.[type]?.[key] };\n\n if (hasChild && part) {\n def = { ...def, ...withChildStyles[part] };\n }\n\n return { ...def, ...scope.getStyle(part, { ...def, ...extra }) };\n };\n\n let elStyle = getStyle('element');\n\n let defaultsUI: any = {\n required: scope.isRequired(),\n size: 'small',\n scope,\n crud,\n style: elStyle,\n placeholder: scope.attr('placeholder', 'Digite aqui'),\n };\n\n scope.error = (msg: string) => {\n error = msg;\n setError(msg);\n };\n\n if (!original.list?.url && !original.load?.url) {\n scope.start();\n }\n\n useEffect(() => {\n scope.start();\n });\n\n const CustomIcon = () => {\n if (typeof original.icon === 'string') {\n return <Ionicons name={original.icon} style={scope.getStyle('icon')} />;\n }\n return <>{original.icon}</>;\n };\n\n scope.open = (args: any) => {\n Linking.openURL(args.url);\n };\n\n useLayoutEffect(() => {\n if (ref?.current && scope.is('type', 'card', 'list', 'tabs', 'stepper')) {\n let el: any = ref?.current;\n\n if (el?.classList) {\n let bg = HtmlUtils.getBGColor(el);\n\n if (bg === 'rgb(255, 255, 255)') {\n el.classList.add('ui-dark');\n } else {\n el.classList.add('ui-light');\n }\n }\n }\n });\n\n const isShowLabel = () => {\n if (\n typeof original.label !== 'undefined' &&\n original.label !== false &&\n !scope.isType('button', 'dialog', 'modal')\n ) {\n return true;\n }\n\n return false;\n };\n\n const isShowInner = () => {\n if (hasChildren()) {\n return false;\n }\n return true;\n };\n\n if (!scope.isRendered() || scope.is('type', 'define')) {\n return <></>;\n }\n\n const isShowChild = () => {\n if (\n scope.isType(\n 'tabs',\n 'view',\n 'grid',\n 'list',\n 'define',\n 'repeat',\n 'modal',\n 'dialog',\n 'chart'\n )\n ) {\n return false;\n }\n\n return true;\n };\n\n let isTouch =\n !scope.isType('input', 'grid', 'list', 'order', 'repeat') && original.click;\n let custom: any = {};\n\n if (isTouch) {\n custom.underlayColor = 'transparent';\n custom.onPress = onClick;\n }\n\n let Tag = (props: any) => {\n let Aux: any = View;\n\n if (isTouch) {\n Aux = TouchableHighlight;\n }\n\n if (scope.isType('dialog', 'order') || original.transient) {\n return <>{props.children}</>;\n }\n\n return <Aux {...props} />;\n };\n\n let Inner = () => {\n return (\n <>\n {scope.getPart('render', null, <></>)}\n {scope.is('type', 'button') && (\n <UIButton\n {...defaultsUI}\n onClick={onClick}\n variant={scope.attr('variant', 'outlined')}\n >\n {original.icon && <CustomIcon />}\n {original.label && (\n <Text style={scope.getPart('label', 'button')}>\n {scope.getLabel()}\n </Text>\n )}\n </UIButton>\n )}\n {scope.is('type', '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.isType('slider') && (\n <UISlider {...defaultsInput} onChange={onCheck} />\n )}\n {scope.is('type', 'select') && (\n <UISelect\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'toggle') && (\n <UIToggle\n {...defaultsInput}\n {...defaultsUI}\n value={scope.getSelectedValue()}\n />\n )}\n {scope.is('type', 'radio') && (\n <UIRadio {...defaultsInput} {...defaultsUI} row>\n {options.map((row: any, i: number) => (\n <UIOption\n key={'i' + i}\n control={<UIRadio {...defaultsUI} />}\n label={row.label}\n value={row.value}\n />\n ))}\n </UIRadio>\n )}\n {scope.is('type', 'custom') && <Custom />}\n {scope.is('type', 'column') && (\n <>\n {scope.is('format', 'img') && (\n <Image source={scope.getDisplayValue()} />\n )}\n {scope.is('format', 'icon') && <UIIcon scope={scope} crud={crud} />}\n {!scope.is('format', 'icon', 'img') && (\n <Text>{scope.getDisplayValue()}</Text>\n )}\n </>\n )}\n {scope.is('type', 'output', 'value') && (\n <Text style={getStyle('value')}>{scope.getDisplayValue()}</Text>\n )}\n </>\n );\n };\n\n let Include = ({ name, style }: any) => {\n if (props[name]) {\n let define = ComponentUtils.getDefine(props, name);\n\n if (!Utils.isEmpty(define)) {\n return (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle(name, style)}\n >\n {define}\n </UIChildren>\n );\n }\n }\n return <></>;\n };\n\n let Container = () => {\n return (\n <>\n {isShowLabel() && (\n <View\n style={getStyle('outerLabel', {\n alignSelf: 'flex-start',\n flexDirection: 'row',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n width: '100%',\n })}\n >\n <Text style={getStyle('label')}>{scope.getLabel()}</Text>\n <Include name=\"actions\" style={{ width: 'auto' }} />\n </View>\n )}\n {isShowInner() && (\n <>\n <View style={getStyle('inner')}>\n <Inner />\n </View>\n {error && <View style={getStyle('error')}>{error}</View>}\n </>\n )}\n {scope.isType('list', 'repeat') && (\n <UIList {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('order') && (\n <UIOrder {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('dialog') && (\n <UIModal {...props} scope={scope} crud={crud} />\n )}\n\n {scope.currentDialog?.component && (\n <UIModal\n scope={scope.currentDialog?.scope}\n crud={scope.currentDialog?.crud}\n open\n dialog={scope.currentDialog}\n />\n )}\n\n {scope.isType('chart') && (\n <ElChart {...props} scope={scope} crud={crud} />\n )}\n {scope.isType('tabs') && (\n <ElTabs {...props} scope={scope} crud={crud} />\n )}\n\n {scope.isType('view') && (\n <UIView {...props} scope={scope} crud={crud} />\n )}\n\n {isShowChild() && (\n <UIChildren\n {...props}\n scope={scope}\n crud={crud}\n style={getStyle('inner')}\n />\n )}\n </>\n );\n };\n\n let Card = (props: any) => {\n let isCard = scope.is('type|layout', 'card');\n\n if (isCard) {\n let box = {\n ...getStyle('box', { ...boxStyle.box, alignSelf: 'stretch' }),\n };\n\n return (\n <View style={getStyle('card', { ...box })}>\n <View\n style={getStyle('boxInner', {\n paddingHorizontal: 15,\n paddingVertical: 10,\n })}\n >\n {props.children}\n </View>\n </View>\n );\n }\n\n if (scope.isInput() || original.container) {\n return (\n <View\n style={getStyle('container', { paddingVertical: 5, width: '100%' })}\n >\n {props.children}\n </View>\n );\n }\n return <>{props.children}</>;\n };\n\n scope.dialogShow = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let parent = main.dialog;\n let { crud } = args;\n let name = scope.getName('modal');\n let edit = args.edit === true;\n let def: any = {};\n let rowItem = null;\n let event = Utils.nvl(args?.event, {});\n let component = event?.component;\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 data,\n edit,\n scope,\n ...def,\n });\n\n let el: any = {\n label: original.label,\n icon: original.icon,\n type: 'dialog',\n };\n\n let close = event.dialog?.close;\n\n if (typeof event.dialog === 'object') {\n el = { ...el, ...event.dialog };\n }\n\n if (event.header) el.header = event.header;\n if (event.label) el.label = event.label;\n if (event.title) el.title = event.title;\n\n el.label = Utils.nvl(el.title, el.label);\n\n let dialogScope = ScopeUtils.create({\n parent: scope,\n crud: d,\n ...el,\n owner: scope,\n });\n let dialog = { crud: d, parent, component, scope: dialogScope, close };\n\n main.dialog = dialog;\n scope.toggleDialog(true);\n scope.currentDialog = dialog;\n\n dialogScope.currentDialog = dialog;\n dialogScope.toggleDialog(true);\n\n scope.update();\n };\n\n scope.dialogHide = (args?: MethodType) => {\n let main = ViewUtils.getCrud('view');\n let old = scope.currentDialog;\n let parentScope = old.scope.parent as Scope;\n\n main.dialog = Utils.nvl(old.parent, null);\n scope.currentDialog = null;\n\n if (main.dialog?.crud?.scope) {\n main.dialog?.crud.scope.update();\n }\n scope.toggleDialog(false);\n scope.update();\n\n const close = old.close;\n\n if (parentScope && close) {\n if (close?.debug) console.log('Fechando');\n parentScope.call('close', { close });\n }\n };\n\n return (\n <CrudContext.Provider value={{ crud, theme }}>\n <Tag ref={ref} style={getStyle()} {...custom}>\n <Card>\n <Container />\n </Card>\n </Tag>\n </CrudContext.Provider>\n );\n}\n\nlet boxStyle = StyleSheet.create({\n box: {\n borderWidth: 0,\n borderColor: '#dedede',\n borderStyle: 'solid',\n backgroundColor: 'white',\n borderRadius: 12,\n width: '100%',\n shadowColor: '#000',\n shadowOpacity: 0.1,\n shadowRadius: 4,\n },\n});\n\nconst box: any = {\n ...boxStyle.box,\n};\n//v4\nconst elementStyle: any = {};\n\nelementStyle.view = {\n inner: {\n width: '100%',\n alignItems: 'normal',\n flex: 1,\n },\n container: {\n width: '100%',\n backgroundColor: 'background',\n flex: 1,\n gap: 10,\n },\n root: {\n width: '100%',\n flex: 1,\n alignItems: 'normal',\n padding: 0,\n },\n};\n\nelementStyle.input = StyleSheet.create({\n label: {\n paddingLeft: 0,\n },\n inner: {\n flex: 1,\n width: '100%',\n padding: 0,\n gap: 10,\n alignSelf: 'flex-start',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n});\n\nelementStyle.quantity = {\n inner: {\n ...box,\n backgroundColor: 'primarySoft',\n fontWeight: 600,\n fontSize: 16,\n borderRadius: 25,\n borderWidth: 0,\n paddingHorizontal: 5,\n paddingVertical: 5,\n flexWrap: 'nowrap',\n flex: 1,\n flexDirection: 'row',\n justifyContent: 'center',\n alignItems: 'center',\n },\n};\n\nelementStyle.toggle = StyleSheet.create({\n 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 fontWeight: 400,\n fontSize: 12,\n paddingVertical: 3,\n color: 'labelColor',\n },\n inner: { width: '100%' },\n});\n\nconst withChildStyles = StyleSheet.create({\n root: {\n gap: 10,\n },\n label: {\n width: '100%',\n fontWeight: 500,\n fontSize: 24,\n },\n});\n","import UIChildren from '../UIChildren';\nimport { ComponentUtils, DefineType, Utils } from 'react-crud-utils';\n\nexport default function UIInclude(props: DefineType) {\n if (props.rendered === false) {\n return <></>;\n }\n\n let includes = ComponentUtils.getDefine(props, props.name, props.position);\n\n if (Utils.isEmpty(includes)) {\n includes = props.default;\n }\n\n if (!Utils.isEmpty(includes)) {\n let Aux = (tagProp: any) => {\n let Tag: any = props.tag;\n\n if (!Utils.isEmpty(Tag)) {\n return <Tag {...tagProp}>{tagProp.children}</Tag>;\n }\n return <>{tagProp.children}</>;\n };\n\n return (\n <Aux {...props.tagProps}>\n <UIChildren\n transient\n {...props}\n scope={props.scope}\n crud={props.crud}\n part={props.name}\n >\n {includes}\n </UIChildren>\n </Aux>\n );\n }\n return <>{includes}</>;\n}\n","import {\n ListType,\n UserType,\n InputType,\n ChartType,\n ContainerType,\n ListInputType,\n TabsType,\n DefineType,\n ButtonType,\n IconType,\n LinkType,\n SliderType,\n} from 'react-crud-utils';\nimport UIElement from './UIElement';\n\nimport UIInclude from './core/UIInclude';\nimport SafeView from './core/SafeView';\nimport GestureView from './core/GestureView';\n\nconst UI = {\n Order: (props: ListType) => <UIElement {...props} type=\"order\" />,\n List: (props: ListType) => <UIElement {...props} type=\"list\" />,\n Row: (props: UserType) => <UIElement {...props} type=\"row\" />,\n Value: (props: UserType) => <UIElement {...props} type=\"value\" />,\n Label: (props: UserType) => <UIElement {...props} type=\"label\" />,\n Repeat: (props: ListType) => (\n <UIElement {...props} type=\"repeat\" props={{ search: false }} />\n ),\n Define: (props: DefineType) => <UIElement {...props} type=\"define\" />,\n Include: (props: DefineType) => <UIInclude {...props} />,\n Column: ({ type = 'column', ...props }: UserType) => (\n <UIElement {...props} type=\"column\" />\n ),\n Input: (props: InputType) => <UIElement {...props} />,\n Text: (props: InputType) => <UIElement {...props} type=\"text\" />,\n Email: (props: InputType) => <UIElement {...props} type=\"email\" />,\n Button: (props: ButtonType) => <UIElement {...props} type=\"button\" />,\n Link: (props: LinkType) => <UIElement {...props} type=\"link\" />,\n Icon: (props: IconType) => <UIElement {...props} type=\"icon\" />,\n Output: (props: ContainerType) => <UIElement {...props} type=\"output\" />,\n Form: (props: ContainerType) => <UIElement {...props} type=\"form\" />,\n Crud: (props: ContainerType) => <UIElement {...props} type=\"crud\" />,\n View: (props: ContainerType) => (\n <UIElement {...props} type=\"view\" transient />\n ),\n Bottom: (props: ContainerType) => <UIElement {...props} type=\"bottom\" />,\n Dialog: (props: ContainerType) => <UIElement {...props} type=\"dialog\" />,\n Content: (props: ContainerType) => <UIElement {...props} type=\"content\" />,\n Top: (props: ContainerType) => <UIElement {...props} type=\"top\" />,\n Card: (props: ContainerType) => <UIElement {...props} type=\"card\" />,\n Tab: (props: ContainerType) => <UIElement {...props} type=\"tab\" />,\n Tabs: (props: TabsType) => <UIElement {...props} type=\"tabs\" />,\n Step: (props: ContainerType) => (\n <UIElement {...props} type=\"tab\" layout=\"step\" />\n ),\n Stepper: (props: TabsType) => (\n <UIElement {...props} type=\"tabs\" layout=\"stepper\" />\n ),\n Money: (props: InputType) => <UIElement {...props} type=\"money\" />,\n Chart: (props: ChartType) => <UIElement {...props} type=\"chart\" />,\n Password: (props: InputType) => <UIElement {...props} type=\"password\" />,\n Complete: (props: InputType) => <UIElement {...props} type=\"complete\" />,\n Checkbox: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Switch: (props: InputType) => <UIElement {...props} type=\"switch\" />,\n Radio: (props: ListInputType) => <UIElement {...props} type=\"radio\" />,\n Select: (props: ListInputType) => <UIElement {...props} type=\"select\" />,\n Toggle: (props: ListInputType) => <UIElement {...props} type=\"toggle\" />,\n Entity: (props: ListInputType) => <UIElement {...props} type=\"entity\" />,\n Element: (props: ListInputType) => <UIElement {...props} type=\"element\" />,\n Quantity: (props: ListInputType) => <UIElement {...props} type=\"quantity\" />,\n Slider: (props: SliderType) => <UIElement {...props} type=\"slider\" />,\n SafeView: SafeView,\n GestureView: GestureView,\n};\nexport default UI;\n","import {\n Keyboard,\n KeyboardAvoidingView,\n Platform,\n StatusBar,\n StyleProp,\n TouchableWithoutFeedback,\n ViewStyle,\n} from 'react-native';\nimport {\n SafeAreaProvider,\n SafeAreaView as SafeAreaContextView,\n} from 'react-native-safe-area-context';\nimport { ThemeUtils, useTheme, Utils } from 'react-crud-utils';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function SafeView(props: SafeViewType) {\n let theme = ThemeUtils.getCurrentTheme();\n //v2\n\n if (Utils.isEmpty(theme)) {\n theme = useTheme();\n }\n\n const dismissKeyboard = () => {\n if (Platform.OS !== 'web') {\n Keyboard.dismiss();\n }\n };\n\n return (\n <SafeAreaProvider>\n <SafeAreaContextView\n style={{\n backgroundColor: theme.colors?.theme,\n ...props.viewStyle,\n flex: 1,\n }}\n >\n <StatusBar barStyle=\"dark-content\" backgroundColor=\"#f5f5f5\" />\n <KeyboardAvoidingView\n behavior={Platform.OS === 'ios' ? 'padding' : 'height'}\n style={{\n flex: 1, // 🔹 Ocupa 100% da tela\n justifyContent: 'flex-start',\n }}\n >\n <TouchableWithoutFeedback\n onPress={dismissKeyboard}\n accessible={false}\n >\n <>{props.children}</>\n </TouchableWithoutFeedback>\n </KeyboardAvoidingView>\n </SafeAreaContextView>\n </SafeAreaProvider>\n );\n}\n","import { StyleProp, ViewStyle } from 'react-native';\nimport { GestureHandlerRootView } from 'react-native-gesture-handler';\n\ninterface SafeViewType {\n safeStyle?: StyleProp<ViewStyle> | any;\n viewStyle?: StyleProp<ViewStyle> | any;\n children?: any;\n}\n\nexport default function GestureView(props: SafeViewType) {\n return (\n <GestureHandlerRootView style={{ flex: 1 }}>\n {props.children}\n </GestureHandlerRootView>\n );\n}\n"],"names":["UIChildren","props","scope","useState","Utils","nvl","ScopeUtils","create","crud","validateScope","name","part","isInput","_jsx","_Fragment","_props$style","key","def","css","Paint","_ref","child","children","Custom","type","pps","_extends","isEmpty","transient","parent","_child$props","Draw","elements","Object","entries","map","t","k","UIElement","React","Children","View","style","styles","push","each","s","getStyle","StyleSheet","width","inner","ElTabs","_useState","selectedIndex","setSelectedIndex","element","original","items","getItems","counter","tabs","_useState2","selected","setSelected","onChangeTab","tab","validate","execute","event","action","changeValue","data","index","getStyleClass","_selected","addTab","item","crudTab","CrudUtils","changed","resolve","rendered","i","nav","isStepper","layout","className","_jsxs","onClick","label","id","UI","Output","space","Include","default","Button","icon","Ionicons","click","length","ElChart","asList","columns","UIAutoComplete","TouchableOpacity","onPress","Linking","openURL","Text","link","UIComplete","AutoComplete","defaultsInput","defaultsUI","UILink","UIIcon","getValue","libs","ion","ant","AntDesign","entypo","Entypo","evil","EvilIcons","material","MaterialCommunityIcons","library","BUTTONS_SIZE","small","minWidth","height","UIButton","size","align","variant","color","getLabel","getPart","buttonLabel","fontWeight","fontSize","buttonInner","flexDirection","alignItems","justifyContent","buttonIcon","button","backgroundColor","borderRadius","gap","extra","padding","buttonStyle","call","borderWidth","borderColor","h","iconStyle","TouchableHighlight","underlayColor","e","iconSize","UISelect","modalVisible","setModalVisible","getOptions","placeholder","attr","value","getDisplayValue","theme","getTheme","headerStyle","_theme$styles","defaults","header","handlePress","scrollRef","useRef","iconColor","_theme$colors","colors","text","modalColor","all","Modal","animationType","transparent","visible","onRequestClose","SafeAreaView","ScrollView","contentContainerStyle","flexGrow","paddingBottom","nestedScrollEnabled","ref","flex","paddingLeft","paddingRight","paddingTop","List","getName","isObject","object","rowStyle","paddinRight","_scope$original","_scope$original2","listProps","Value","selectRoot","selectInput","paddingHorizontal","paddingVertical","selectLabel","modalTop","modalSafe","modalCloseButton","modalCloseText","modalTitle","marginLeft","modalContent","UISwitch","initial","setValue","Switch","onValueChange","v","UISlider","step","min","max","onSlideScroll","scrollEnabled","viewScope","ComponentUtils","getViewScope","debug","console","log","_scrollRef$current","get","current","setNativeProps","Slider","minimumValue","maximumValue","minimumTrackTintColor","maximumTrackTintColor","thumbTintColor","onSlidingStart","onSlidingComplete","UIOption","UIRadio","UIInput","val","join","trim","el","CustomIcon","TextInput","onChangeText","base","alignSelf","flexWrap","marginRight","input","marginHorizontal","marginVertical","UIListRow","cols","undefined","rowWidth","Math","floor","_repeat$list","repeat","stylesRepeat","list","stylesList","row","targetRef","isVisible","setIsVisible","useEffect","interval","setInterval","useIsInView","Platform","OS","rect","getBoundingClientRect","window","windowHeight","innerHeight","top","bottom","measureInWindow","x","y","Dimensions","clearInterval","useIsVisible","Child","updateIndex","setUpdateIndex","getRowStyle","minHeight","update","stopPropagation","edit","margin","UIList","add","getDefine","hideAddWhenEmpty","LocalData","setIndex","keyData","search","_original$list","url","query","toLowerCase","filters","filterBy","o","includes","Empty","empty","textAlign","field","marginBottom","change","container","display","UIToggle","options","getInputValue","isSelected","Item","getItemStyle","selectedColor","UIQuantity","btn","verticalAling","addButton","delButton","UIToast","toastConfig","success","BaseToast","darkToast","text1Style","text2Style","error","ErrorToast","info","borderLeftColor","Toast","config","UIModal","open","dialog","_objectWithoutPropertiesLoose","_excluded","st","onClose","close","_scope$currentDialog","currentDialog","toggleDialog","vis","curr","_scope$currentDialog2","main","ViewUtils","getCrud","uuid","_main$dialog","headerRight","put","setViewScope","Content","component","ModalContent","_ref2","disableScroll","_ref3","gesture","GestureHandlerRootView","UIHeader","headerTextStyle","_theme$styles2","headerText","headerStyleFull","bg","HtmlUtils","getTextColor","hasHeader","UIView","onScroll","scroll","Container","scrollEventThrottle","keyboardShouldPersistTaps","view","UIOrder","renderItem","drag","isActive","getIndex","getItemLabel","ScaleDecorator","delayLongPress","onLongPress","Header","pos","headerPos","OrderData","setData","DraggableFlatList","ListHeaderComponent","ListFooterComponent","containerStyle","keyExtractor","getItemValue","onDragEnd","_ref4","borderBottomWidth","borderBottomColor","CrudContext","createContext","ctx","useContext","_useState3","setError","compile","updateElement","toast","message","args","show","text1","position","visibilityTime","prompt","title","Alert","alert","cancelable","c","custom","tag","is","onCheck","onChange","target","isType","parseInt","parseFloat","getSelectedItem","hasChildren","hasChild","elementStyle","_elementStyle$type","withChildStyles","elStyle","required","isRequired","msg","_original$load","load","start","useLayoutEffect","classList","getBGColor","isRendered","isTouch","Tag","Aux","Inner","InputProps","inputProps","checked","getSelectedValue","control","Image","source","define","_scope$currentDialog3","_scope$currentDialog4","Card","box","boxStyle","dialogShow","rowItem","d","root","_event$dialog","dialogScope","owner","dialogHide","_main$dialog2","old","parentScope","Provider","borderStyle","shadowColor","shadowOpacity","shadowRadius","quantity","toggle","UIInclude","tagProp","tagProps","Order","Row","Label","Repeat","Define","Column","Input","Email","Link","Icon","Form","Crud","Bottom","Dialog","Top","Tab","Tabs","Step","Stepper","Money","Chart","Password","Complete","Checkbox","Radio","Select","Toggle","Entity","Element","Quantity","SafeView","ThemeUtils","getCurrentTheme","useTheme","SafeAreaProvider","SafeAreaContextView","viewStyle","StatusBar","barStyle","KeyboardAvoidingView","behavior","TouchableWithoutFeedback","Keyboard","dismiss","accessible","GestureView"],"mappings":"g6BAiBwBA,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,SAAMC,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,eAAOG,EAACT,EAAMpB,cAAN6B,EAAaR,UAWzBT,MAAAC,eATHD,MAACb,EAAU0B,GACTjB,cAAeA,GACXY,EAAMpB,OACVC,MAAOA,EACPM,KAAMA,EACNoB,iBAOFG,EAAO,WACX,OAEIlB,MAAAC,WAFAb,EAAM+B,UAENV,SACGW,OAAOC,QAAQjC,EAAM+B,UAAUG,KAAI,SAACC,EAAQC,GAC3C,OAAOxB,MAACyB,GAASZ,GAAClB,KAAMA,GAAU4B,EAAE,UAM1Cd,SACGiB,EAAMC,SAASL,IAAIlC,EAAMqB,UAAU,SAAAD,GAClC,OAAOR,MAACM,GAAME,MAAOA,UAM7B,OAAIpB,YACKY,MAACkB,MAGN3B,QAAMuB,QAAQ1B,EAAMqB,WAAalB,QAAMuB,QAAQ1B,EAAM+B,UAChDnB,MAAAC,eAsBLb,YACKY,MAACkB,MAGRlB,MAAAC,YAAAQ,SACET,MAAC4B,QAAKC,OAxBQ/B,EAwBQD,EAvBpBM,EAAMZ,QAAMC,IAAIM,EAAM,QACtBM,EAAM0B,EAAO3B,GACbE,EAAM,GAELd,QAAMuB,QAAQ1B,EAAMyC,gBACvB3B,EAAId,EAAMyC,QAAN3B,EAAa6B,KACfxC,QAAMyC,KAAK5C,EAAMyC,OAAO,SAAAI,GAClBA,IACF5B,EAAGQ,KAAQR,EAAQ4B,OAIvB5B,EAAGQ,KAAQzB,EAAMyC,QAGrBhB,KAAYT,EAAQC,EAAQhB,EAAM6C,SAASpC,KAQbW,SAC1BT,MAACkB,UAMT,IAAMY,EAASK,aAAWzC,OAAO,CAC/Bc,MAAO,CAAE4B,MAAO,QAChBC,MAAO,CAAED,MAAO,mBCrIME,EAAOlD,GAC7B,IAAIC,EAAQD,EAAMC,MAClBkD,EAA6CjD,WAAS,GAAjDkD,EAAaD,KAAEE,EAAgBF,KAChCG,EAAUrD,EAAMsD,SAChBC,EAAQvD,EAAMwD,WACdC,EAAU,EAEVC,EAAY,GAChBC,EAAmC1D,WAAS,MAAvC2D,EAAQD,KAAEE,EAAWF,KAEpBG,EAAc,SAACC,EAAUC,YAAAA,IAAAA,GAAW,GACpCD,GACF/D,EAAMiE,QAAQ,CACZC,MAAO,CACLF,SAAAA,EACAzD,cAAe8C,EAAQ9C,cACvB4D,OAAQ,WACNnE,EAAMoE,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,SAACtD,EAAYuD,GAC1B,IAAIpB,EAAQ9B,KAAQL,EAAMpB,OAErB2E,IACHA,EAAO1E,EAAMM,KAAK+D,MAGpB,IAAIM,EAAUC,YAAUvE,OAAO,OAAQ,CACrCgE,KAAMK,EACNG,QAASH,EACT/C,OAAQ3B,EAAMM,OAGZ+C,EAAUnD,QAAM4E,QAAQxB,EAAUqB,IAEb,IAArBtB,EAAQ0B,UAIZrB,EAAKhB,KAAIlB,KACJ6B,GACHlC,MAAAA,EACAkC,QAAAA,EACAC,SAAAA,EACAgB,MAAOb,IACPY,KAAMK,MAIVrC,EAAMC,SAASL,IAAIlC,EAAMqB,UAAU,SAACD,EAAOmD,GACzC,GAAIpE,QAAMuB,QAAQ8B,GAChBkB,EAAOtD,EAAO,SAEd,IAAK,IAAM6D,KAAKzB,EAGdkB,EAAOtD,EAFCoC,EAAMyB,OAOfpB,GACHE,EAAYJ,EAAKP,IAAgB,GAGnC,IAAM8B,EAAM,SAACD,GAGXlB,EAFQJ,EAAKP,EAAgB6B,KAa3BE,EAA+B,YAAnB7B,EAAQ8B,OAExB,OACExE,aACEyE,UAAWpF,EAAMuE,cAAc,SAC/B/B,MAAOxC,EAAM6C,SAAS,SAASzB,SAE/BiE,cAAKD,UAAU,kBAAiBhE,UAC9BT,aAAKyE,UAAU,gBAAehE,SAC3BsC,EAAKzB,KAAI,SAACC,EAAQ8C,GAAS,OAC1BK,cAEED,UAAWb,EAAcrC,GACzBoD,QAAS,WACPxB,EAAY5B,IACZd,UAED8D,GAAavE,aAAKyE,UAAU,wBAC7BC,cAAKD,UAAU,oBAAmBhE,UAC/B8D,GAAavE,aAAKyE,UAAU,iBAC7BzE,aAAKyE,UAAU,oBAAmBhE,SAC/B8D,EAAYhD,EAAEoC,MAAQ,EAAIpC,EAAEqD,aAV5BrF,QAAMY,IAAIuC,EAAQmC,GAAI,MAAOR,SAgBvCpB,GACCyB,OAAAzE,YAAAQ,UACG8D,GAAavE,aAAKyE,UAAU,gBAAehE,SAAEwC,EAAS2B,QACvD5E,aAAKyE,UAAU,eAAchE,SAC3BT,MAACb,EAAU0B,KAAKzB,GAAOC,MAAOA,EAAMoB,SACjCwC,EAASzC,WAGM,YAAnBkC,EAAQ8B,QACPE,cAAKD,UAAU,kBAAiBhE,UAC9BT,MAAC8E,GAAGC,QAAOC,MAAO,EAAGR,OAAO,OAAM/D,SAChCT,MAAC8E,GAAGG,QAAOpE,KACLzB,GACJ2B,aACAlB,KAAK,OACLqF,QACElF,MAAC8E,GAAGK,QACFf,SAAU5B,EAAgB,EAC1B4C,KAAMpF,MAACqF,MACPC,MAtDL,WACfhB,GAAK,WA0DOtE,MAAC8E,GAAGC,QAAOC,MAAO,EAAGR,OAAO,QAAO/D,SACjCT,MAAC8E,GAAGG,QAAOpE,KACLzB,GACJ2B,aACAlB,KAAK,QACLqF,QACElF,MAAC8E,GAAGK,QACFf,SAAU5B,EAAgBO,EAAKwC,OAAS,EACxCH,KAAMpF,MAACqF,MACPC,MAhET,WACXhB,EAAI,+BCnGgBkB,EAAQpG,GAC9B,IAAIC,EAAeD,EAAMC,MAIzB,OAHiBA,EAAMwD,WACTtD,QAAMkG,OAAOpG,EAAMsD,SAAS+C,SAEnC1F,aAAKyE,UAAU,2BCNAkB,EAAevG,GAKrC,OACEY,MAAC4F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBtF,SACrCT,MAACgG,QAAKnE,MAAOC,EAAOmE,KAAKxF,SAAC,8CAKhC,IAAMqB,EAAS,CACbmE,KAAM,aCZgBC,EAAU3F,GAKhC,OACEP,MAAAC,YAAAQ,SACET,MAACmG,EAAYtF,KANJN,EAAb6F,cACU7F,EAAV8F,wBCHsBC,EAAOlH,GAK7B,OACEY,MAAC4F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBtF,SACrCT,MAACgG,QAAKnE,MAAOC,EAAOmE,KAAKxF,SAAC,8CAKhC,IAAMqB,EAAS,CACbmE,KAAM,aCLgBM,EAAMhG,OAAGlB,EAAKkB,EAALlB,MAC3BQ,EAAOR,EAAMmH,WACbC,EAAY,CACdC,IAAKrB,WACLsB,IAAKC,YACLC,OAAQC,SACRC,KAAMC,YACNC,SAAUC,0BAGRC,EAAU5H,QAAMC,IAAIH,EAAMsD,SAASwE,QAAS,OAGhD,OAAOnH,MAFGyG,EAAKU,IAEHtH,KAAMA,EAAMgC,MAAOxC,EAAM6C,SAAS,cCnB1CkF,EAAoB,CAAEC,MAAO,CAAEC,SAAU,GAAIC,OAAQ,cAEnCC,EAASpI,GAC/B,IAAIC,EAAQD,EAAMC,MACdqD,EAAUrD,EAAMsD,SAChB8E,EAAOlI,QAAMC,IAAIkD,EAAQ+E,KAAM,WAC/BC,EAAQnI,QAAMC,IAAIkD,EAAQgF,MAAO,UACjCC,EAAUpI,QAAMC,IAAIkD,EAAQiF,QAAS,WAErCC,EAAQlF,EAAQkF,MAChBhD,EAAQvF,EAAMwI,WACdzC,EAAO/F,EAAMyI,QAAQ,QAGpBF,IAAOA,EAAQ,gBAEpB,IAAM9F,EAAc,CAClBiG,YAAa,CACXH,MAAO,UACPI,WAAY,MACZC,SAAU,IAEZC,YAAa,CACXC,cAAe,MACfC,WAAY,SACZC,eAAgB,SAChBd,OAAQ,GACRD,SAAU,IAEZgB,WAAY,CACVV,MAAO,OACPK,SAAU,IAEZM,OAAQ,CACNC,gBAAiBZ,EACjBa,aAAc,GACdC,IAAK,GACLL,eAAgB,SAChBD,WAAY,SACZD,cAAe,QAQbtG,EAAQ,SAAC/B,EAAc6I,GAC3B,IAAItI,EAAGQ,KAAQiB,EAAOhC,GAAU6I,GAqBhC,MAnBgB,SAAZhB,GAAkC,aAAZA,IACxBtH,EAAImI,gBAAkB,cACtBnI,EAAIuH,MAAQrI,QAAMC,IAAIoI,EAAO,SAGlB,UAATH,IACFpH,EAAI4H,SAAW,GACf5H,EAAI2H,WAAa,KAGN,WAATP,IACFpH,EAAI4H,SAAW,GACf5H,EAAI2H,WAAa,KAGL,SAAVN,IACFrH,EAAIgI,eAAiB,cAGhBhJ,EAAM6C,SAASpC,EAAMO,IAG1BsI,EAAa,GAGfA,EAAMJ,OADJnD,EACa,CAAEmC,OAAQ,GAAIqB,QAAS,GAEvB,CAAErB,OAAQ,IAG3B,IAAMsB,EAActJ,QAAMuJ,MAAK,WAC7B,IAAI1I,EAAGS,WAAa8H,SAAAA,EAAOJ,QAEX,aAAZZ,IACFvH,EAAI2I,YAAc,EAClB3I,EAAI4I,YAAczJ,QAAMC,IAAIoI,EAAO,SAGjCH,IACFrH,EAAGS,KAAQT,EAAQgH,EAAaK,KAG7B7C,IACHxE,EAAGS,KAAQT,GAAKqI,aAAc,MAGhC,IAAIpI,EAAMwB,EAAM,SAAUzB,GAE1B,IAAKC,EAAI+B,MAAO,CACd,IAAI6G,EAAI5I,EAAIkH,OAEK,iBAAN0B,IACT5I,EAAIiH,SAAW2B,GAInB,OAAO5I,KAGH0H,EAAclG,EAAM,eACpBqH,EAAY3J,QAAMuJ,MAAK,WAC3B,IAAIzI,EAAWwB,EAAM,aAAc8G,EAAMvD,MAIzC,OAFA/E,EAAI4H,SAAW1I,QAAMC,IAAIuI,EAAYE,SAAU5H,EAAI4H,UAE5C5H,KAGT,OACEL,MAACmJ,sBACCC,cAAe,cACfvD,QA9EY,SAACwD,GACfhK,EAAMyJ,KAAK,QAAS,KA8ElBjH,MAAOgH,EAAYpI,SAEnBiE,OAAAzE,YAAAQ,UACG2E,GACCpF,MAAAC,YAAAQ,SACET,MAACqF,YACCoC,KAAMlI,QAAMC,IAAIkD,EAAQ4G,SAAU,IAClCzH,MAAOqH,EACPrJ,KAAMuF,MAIXR,GAAS5E,MAACgG,QAAKnE,MAAOkG,EAAYtH,SAAEmE,kBC5HrB2E,EAASnK,eAC/BmD,EAAwCjD,YAAS,GAA1CkK,EAAYjH,KAAEkH,EAAelH,KAC9BlD,EAAQD,EAAMC,MACdqD,EAAUrD,EAAMsD,SAChBC,EAAQrD,QAAMC,IAAIH,EAAMqK,aAAc,IACtCC,EAActK,EAAMuK,KAAK,cAAe,gBACxCC,EAAQxK,EAAMyK,kBACdC,EAAQ1K,EAAM2K,WACdC,EAAc1K,QAAMC,WAAG0K,EAACH,EAAMjI,gBAAMoI,EAAZA,EAAcC,iBAAdD,EAAwBE,OAAQ,IACxDC,EAAc,WAClBZ,GAAiBD,IAGbc,EAAYC,SAAO,MACnBC,EAAYjL,QAAMC,WAAGiL,EAACV,EAAMW,eAAND,EAAcE,KAAM,WAC1CC,EAAarL,QAAMC,IAAIyK,EAAYrC,MAAO,SAC1CuC,EAAW,CAAEvC,MAAOgD,GAepB/I,EAAQ,SAAC/B,EAAc6I,GAC3B,IAAIkC,EAAGhK,KAAQiB,EAAOhC,GAAU6I,GAEhC,OAAOtJ,EAAM6C,SAASpC,EAAM+K,IAQ9B,OACEnG,OAAC9C,QAECC,MAAOA,EAAM,cAAcpB,UAE3BiE,OAACkB,oBAAiBC,QAASwE,EAAaxI,MAAOA,EAAM,eAAepB,UAClET,MAACgG,QAAKnE,MAAOA,EAAM,eAAepB,SAC/BlB,QAAMC,IAAIqK,EAAOF,KAEpB3J,MAACqF,YACCxF,KAAK,uBACL4H,KAAMpI,EAAMyI,QAAQ,WAAY,KAAM,IACtCF,MAAOvI,EAAMyI,QAAQ,YAAa,KAAM0C,GACxC3I,MAAOA,EAAM,YAAa,SAG9B6C,OAACoG,SACCC,cAAc,QACdC,aAAa,EACbC,QAvBGzB,EAwBH0B,eAAgB,WAAF,OAAQzB,GAAgB,IAAOhJ,UAE7CT,MAACmL,gBAAatJ,MAAOA,EAAM,cAC3B6C,OAACyG,gBAAatJ,MAAOA,EAAM,aAAapB,UACtCiE,OAAC9C,QAAKC,MAAOxC,EAAM6C,SAAS,SAAU+H,GAAaxJ,UACjDT,MAAC4F,oBACCC,QAASwE,EACTxI,MAAOA,EAAM,oBAAoBpB,SAEjCT,MAACqF,YACCxF,KAAK,QACL4H,KAAM,GACNG,MAAOgD,EACP/I,MAAOA,EAAM,iBAAkBsI,OAGnCnK,MAACgG,QAAKnE,MAAOA,EAAM,aAAcsI,GAAU1J,SAAEkJ,OAE/C3J,MAACoL,cACCC,sBAAuB,CAAEC,SAAU,EAAGC,cAAe,IACrD1J,MAAOA,EAAM,gBACb2J,qBAAqB,EACrBC,IAAKnB,EAAU7J,SAEfT,MAAC4B,QACCC,MAAO,CACL6J,KAAM,EACNC,YAAa,GACbC,aAAc,GACdC,WAAY,GACZN,cAAe,IACf9K,SAEFT,MAAC8E,GAAGgH,KAAIjL,GACN6C,KAAMd,EACN/C,KAAMR,EAAM0M,QAAQ,QACpBvH,OAAO,OACPc,MAlFE,SAAH/E,OAAYsJ,EAAKtJ,EAALsJ,MAIrBxK,EAAMoE,YADJf,EAAQsJ,gBAFFnC,GAAAA,EAEmBoC,aAFnBpC,SAAAA,EAGeoC,aAHfpC,GAAAA,EAIMA,YAJNA,SAAAA,EAKeA,MAELA,GAGpBJ,GAAgB,IAwEJyC,SAAQrL,GACN8K,YAAa,GACbQ,YAAa,WAAEC,EACZ/M,EAAMsD,iBAANyJ,EAAgBF,kBACnBG,EACEhN,EAAMsD,iBAAN0J,EAAgBC,WAAS7L,SAE7BT,MAAC8E,GAAGyH,OAAM1C,MAAM,kCA/DrBxK,EAAM0M,QAAW1M,EAAMyI,QAAQ,aAAY0B,IAyEtD,IAAM1H,EAASK,aAAWzC,OAAO,CAC/B8M,WAAY,CACVnE,eAAgB,aAChBD,WAAY,aACZsD,KAAM,GAERe,YAAa,CACXrK,MAAO,OACP+F,cAAe,MACfM,aAAc,EACdiE,kBAAmB,GACnBC,gBAAiB,IAEnBC,YAAa,CAAElB,KAAM,GACrBmB,SAAU,CACRrE,gBAAiB,UACjBpG,MAAO,QAET0K,UAAW,CACTpB,KAAM,EACNtJ,MAAO,OACPoG,gBAAiB,cAEnBuE,iBAAkB,CAChBnE,QAAS,IAEXoE,eAAgB,CACd/E,SAAU,GACVL,MAAO,SAETqF,WAAY,CACVhF,SAAU,GACVD,WAAY,OACZkF,WAAY,IAEdC,aAAc,CACZzB,KAAM,EACNlD,gBAAiB,yBCpKG4E,EAAShO,GAC/B,IAAMC,EAAQD,EAAMC,MACdgO,EAAU9N,QAAMC,IAAIH,EAAMmH,YAAY,GAC5CjE,EAA0BjD,WAAS+N,GAArBC,EAAQ/K,KAQtB,OACEvC,MAACuN,UACC1D,MAVQtH,KAWRV,MAAOxC,EAAM6C,SAAS,WACtBsL,cAVW,SAAAC,GACbpO,EAAMoE,YAAYgK,GAElBH,EAASG,eCPWC,EAAStO,GAC/B,IAAMC,EAAQD,EAAMC,MACdgO,EAAU9N,QAAMC,IAAIH,EAAMmH,WAAY,GAC5CjE,EAA0BjD,WAAS+N,GAA5BxD,EAAKtH,KAAE+K,EAAQ/K,KAclBoL,EAAOtO,EAAMuK,KAAK,OAAQ,GAC1BgE,EAAMvO,EAAMuK,KAAK,MAAO,GACxBiE,EAAMxO,EAAMuK,KAAK,MAAO,KAExBkE,EAAgB,SAACC,GACnB,IAAIC,EAAYC,iBAAeC,eAM/B,GAJI7O,EAAMsD,SAASwL,OACjBC,QAAQC,IAAIL,GAGVA,EAAW,CAAA,IAAAM,EACThE,EAAY0D,EAAUO,IAAI,aAE1BjE,WAAWgE,EAAAhE,EAAUkE,gBAAVF,EAAmBG,gBAAnBH,EAAmBG,eAAiB,CAAEV,cAAAA,OAGzD,OACE/N,MAAAC,YAAAQ,SACET,MAAC0O,GACCC,aAAcf,EACdgB,aAAcf,EACdF,KAAMA,EACNkB,sBAAsB,UACtBC,sBAAsB,UACtBC,eAAe,UACflF,MAAOA,EACPmF,eAAgB,WAAF,OAAQlB,GAAc,IACpCmB,kBAAmB,WAAF,OAAQnB,GAAc,IACvCjM,MAAKhB,GAAIuB,MAAO,OAAQmF,OAAQ,IAAOlI,EAAM6C,SAAS,YACtDsL,cAxCS,SAAAC,GACbA,EAAIlO,QAAMC,IAAIiO,EAAG,GAEjBW,QAAQC,IAAIZ,GAEZpO,EAAMoE,YAAYgK,GAElBH,EAASG,iBCjBWyB,EAAS9P,GAK/B,OACEY,MAAC4F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBtF,SACrCT,MAACgG,QAAKnE,MAAOC,EAAOmE,KAAKxF,SAAC,8CAKhC,IAAMqB,EAAS,CACbmE,KAAM,aCbgBkJ,EAAQ/P,GAK9B,OACEY,MAAC4F,oBAAiBC,QALA,WAClBC,UAAQC,QAAQ,6BAIuBtF,SACrCT,MAACgG,QAAKnE,MAAOC,EAAOmE,KAAKxF,SAAC,8CAKhC,IAAMqB,EAAS,CACbmE,KAAM,aCVgBmJ,EAAQhQ,GAC9B,IAAIC,EAAQD,EAAMC,MACdgO,EAAU9N,QAAMuJ,MAAK,WACvB,IAAIuG,EAAM9P,QAAMC,IAAIH,EAAMmH,WAAY,IAEtC,OAAI6I,SAAOA,GAAAA,EAAKtN,KACPsN,EAAIC,KAAK,MAAMC,OAEjBF,KAGLzK,EAAQvF,EAAMwI,WACd8B,EAActK,EAAMyI,QAAQ,cAAe,KAAMlD,GACjD4K,EAAKnQ,EAAMsD,SAEfJ,EAA0BjD,WAAS+N,GAA5BxD,EAAKtH,KAAE+K,EAAQ/K,KAQhBV,EAAQ,SAAC/B,EAAc6I,GAC3B,OAAA9H,KAAYxB,EAAM6C,SAASpC,EAAMgC,EAAOhC,IAAW6I,IAG/C8G,EAAa,WACjB,IAAIrK,EAAOoK,EAAGpK,KAEd,OAGMpF,MAAAC,WAHFmF,EACkB,iBAATA,GAEP3E,SACG+O,EAAGpK,MACFpF,MAACqF,YACCxF,KAAM2P,EAAGpK,KACTqC,KAAMpI,EAAMuK,KAAK,WAAY,IAC7BhC,MAAOvI,EAAMuK,KAAK,YAAa,YAMlCnJ,SAAG2E,QAId,OACEV,OAAAzE,YAAAQ,UACEiE,OAAC9C,QAAKC,MAAOA,EAAM,QAAQpB,UACxBpB,EAAMyI,QAAQ,QACf9H,MAAC0P,aACC7N,MAAOA,EAAM,SACb8N,aArCO,SAAAlC,GACbA,EAAIpO,EAAMoE,YAAYgK,GAEtBH,EAASG,IAmCH5D,MAAOA,EACPF,YAAaA,IAEf3J,MAACyP,SAEFpQ,EAAMyI,QAAQ,YAKrB,IAAMhG,EAASK,aAAWzC,OAAO,CAC/BkQ,KAAM,CACJlE,KAAM,EACNtJ,MAAO,OACPmJ,cAAe,EACfM,WAAY,EACZzD,WAAY,SACZW,YAAa,EACbC,YAAa,cACbP,aAAc,EACdiE,kBAAmB,GACnBmD,UAAW,aACX1H,cAAe,MACf2H,SAAU,OACVpH,IAAK,IAEPtD,KAAM,CACJ2K,YAAa,IAEfC,MAAO,CACLC,iBAAkB,EAClBC,eAAgB,EAChB3I,OAAQ,GACRmE,KAAM,cClFcyE,EAAU/Q,SAC1BC,EAAQD,EAAMC,MACdsE,EAAQvE,EAAMuE,MACdhB,EAAWtD,EAAMsD,SACjBoB,EAAO3E,EAAM2E,KACbqM,EAAO/Q,EAAMyI,QAAQ,YAAQuI,GAAY,GACzCC,EAAWC,KAAKC,MAAM,IAAMJ,GAAQ,IACpCtO,SAAM2O,EAAG,CAAEC,OAAQC,EAAcC,KAAMC,WAA9BJ,EAA6C9N,EAAShC,MAC/Dd,KAAUR,EAAMc,IAAI,MAAOwD,EAAO,IACjCmN,EAAOxR,WACZG,aAAWC,OAAMmB,KACZ8B,GACH3B,OAAQ3B,EACRQ,KAAAA,EACAF,KAAMN,EAAMM,KACZgE,MAAAA,EACAhD,KAAM,MACN+C,KAAMK,SAKJgN,EAAYxG,SAAO,MACnByG,WC9BqBvF,EAAUpM,GACrC,IAAAkD,EAAkCjD,YAA2B,IAAlBD,EAAM4L,SAA1C+F,EAASzO,KAAE0O,EAAY1O,KAgC9B,OA9BA2O,aAAU,WACR,IAyBMC,EAAWC,aAzBO,iBACtB,GAAK3F,EAAI+C,UAAWwC,UAAa5E,EAAC/M,EAAMsD,WAANyJ,EAAgBiF,YAElD,GAAoB,QAAhBC,WAASC,GAAc,CACzB,IAAMC,QAAO/F,EAAI+C,QAAQiD,6BAAZhG,EAAI+C,QAAQiD,wBAEzB,GAAID,GAA0B,oBAAXE,OAAwB,CACzC,IAAMC,EAAeD,OAAOE,YACtB3G,EAAUuG,EAAKK,IAAMF,GAAgBH,EAAKM,OAAS,EAErD7G,IAAS5L,EAAM4L,QAAUA,GAE7BgG,EAAahG,eAGfQ,EAAI+C,QAAQuD,iBAAZtG,EAAI+C,QAAQuD,iBAAkB,SAACC,EAAGC,EAAG7P,EAAOmF,GAC1C,IACM0D,EAAUgH,EADKC,aAAW3D,IAAI,UAAUhH,QACV0K,EAAI1K,EAAS,EAE7C0D,IAAS5L,EAAM4L,QAAUA,GAC7BgG,EAAahG,QAK2B,KAC9C,OAAO,WAAA,OAAMkH,cAAchB,MAC1B,CAAC1F,IAEGuF,EDHWoB,CAAarB,EAAWD,GAMpCuB,EAAQ,WACZ,OACSrS,MAAAC,YADJ+Q,GAAarO,EAAS0O,cAAgBP,EAAI7F,SAAWtH,EAAQ,OAIhElD,SACET,MAACb,GAAW4B,aAAU1B,MAAOyR,EAAKnR,KAAMmR,EAAInR,KAAKc,SAC9CrB,EAAMqB,cA+Df,OAAOT,OAzDU,WACf,IAAAgD,EAAoC1D,WAAS,GAAxCgT,EAAWtP,KAAEuP,EAAcvP,KAC5B7C,EAAMd,EAAMc,IAAI,QAEpB2Q,EAAI7N,SAAW6N,EAAIhJ,QAAQ,qBAAiBuI,GAAW,GAEvD,IAAMmC,EAAc,WAClB,IAAInS,EAAMyQ,EAAI5O,SAAS,MAAKrB,KAAOiB,EAAOgP,KAAK2B,UAAW,MAY1D,OATEpS,EAAGQ,KAAQR,EAAQyQ,EAAI5O,SADrB4O,EAAI7N,SAC0B,cAEA,gBAFe,KAK7CmN,EAAO,IACT/P,EAAI+B,MAAQkO,GAGPjQ,GAWT,OARAyQ,EAAI4B,OAAS,WACXrT,EAAMiT,YAAcjT,EAAMiT,YAAc,EAExCC,IAAiBD,KAKC,IAFFxB,EAAIhJ,QAAQ,oBAAgBuI,GAAW,GAGhDrQ,MAAAC,eAGJ0C,EAAS2C,MAQZtF,MAACmJ,sBAECtH,MAAO2Q,IACPpJ,cAAe,cACfqC,IAAKsF,EACLlL,QAAS,SAAAwD,GACPA,EAAEsJ,kBAjEM,SAAC5O,GACf+M,EAAIhI,KAAK,QAAS,CAAEe,MAAO9F,EAAMA,KAAAA,EAAM6O,MAAM,EAAMjP,MAAAA,IAiE7CgB,CAAQZ,IACRtD,SAEFT,MAACqS,OATIlS,GAPLH,MAAC4B,QAAeC,MAAO2Q,IAAe/G,IAAKsF,EAAUtQ,SACnDT,MAACqS,OADQlS,SAwBnB,IAAM0Q,EAAa1O,aAAWzC,OAAO,CACnCoR,IAAK,CACHlI,QAAS,EACTiK,OAAQ,EACRzQ,MAAO,OACPoG,gBAAiB,aACjBE,IAAK,GACLD,aAAc,EACdJ,eAAgB,YAIdsI,EAAexO,aAAWzC,OAAO,CACrCoR,IAAK,CACHlI,QAAS,EACTxG,MAAO,OACPiG,eAAgB,qBE1HIyK,EAAO1T,SACvBC,EAAQD,EAAMC,MACdM,EAAON,EAAMM,KACbgD,EAAWtD,EAAMsD,SACjByN,EAAO7Q,QAAMC,IAAIH,EAAMyI,QAAQ,YAAQuI,EAAW,IAClDvO,SAAM2O,EAAG,CAAEC,OAAQC,EAAcC,KAAMC,WAA9BJ,EAA6C9N,EAAShC,MAC/DoS,EAAM9E,iBAAe+E,UAAU5T,EAAO,OACtC6T,EAAmBtQ,EAASsQ,iBAgB5BC,EAAY,WAChB,IAAA3Q,EAAwBjD,WAASD,EAAMiT,aAAlC3O,EAAKpB,KAAE4Q,EAAQ5Q,KAEpBlD,EAAMqT,OAAS,WACbrT,EAAMiT,cAAgB3O,EAEtBwP,EAASxP,IAGX,IAlBImN,EAkBAsC,EAAU/T,EAAMc,IAAI,QAElByC,EAAQrD,QAAMuJ,MAAK,iBACnB8H,EAAOrR,QAAMC,IAAIH,EAAMwD,WAAY,IAEvC,IAAwB,IAApBF,EAAS0Q,gBAAoBC,EAAC3Q,EAASiO,QAAT0C,EAAeC,KAAK,CACpD,IAAIC,EAAQ7T,EACT4O,IAAI,QAAS,IACbkF,cACAlE,OAEH,GAAIiE,EAAMjO,OAAS,EAAG,CACpB,IAAImO,EAAiB,GACjBC,EAAWpU,QAAMC,IAAImD,EAASgR,SAAU,SAY5C,OAVApU,QAAMyC,KAAK4O,GAAM,SAAAgD,GACf,IAAIhP,EAAQrF,QAAMiH,SAASmN,EAAU,OAAQC,GAAGH,cAE5C7O,GACEA,EAAMiP,SAASL,IACjBE,EAAQ3R,KAAK6R,MAKZF,GAGX,OAAO9C,KAULkD,EAAQ,WACV,IAAKvU,QAAMuB,QAAQ8B,GACjB,OAAO5C,MAAAC,eAGT,IAAI8T,EAAQ1U,EAAMuK,KAAK,QAAS,gBAEhC,OAAKmK,EAIgB,iBAAVA,EAEP/T,MAACgG,QACCnE,MAAOxC,EAAM6C,SAAS,QAAS,CAC7BwJ,KAAM,EACN1D,WAAY,IACZC,SAAU,GACVW,QAAS,GACToL,UAAW,SACX3L,eAAgB,SAChBD,WAAY,WACX3H,SAEFsT,IAKA/T,MAAAC,YAAAQ,SAAGsT,IArBD/T,MAAAC,gBAwBX,OACEyE,OAAC9C,QAAmBC,OAzFlBiP,EAJGzR,EAAM6C,SAIM,YAJMrB,KAIO,GAJUiB,EAAU,YAMhDsO,EAAO,IACTU,EAAGjQ,KAAQiQ,GAAK3I,cAAe,MAAO2H,SAAU,UAG3CgB,GAmF0CrQ,UAC7CT,MAAC8T,MACAlR,EAAMtB,KAAI,SAACyC,EAAWM,GAAS,OAC9BrE,MAACmQ,GAAUxM,MAAOU,EAAGN,KAAMA,EAAM1E,MAAOA,EAAMoB,SAC3CrB,EAAMqB,gBA3CRlB,QAAMuB,QAAQ8B,KAGS,IAArBqQ,IA2CWjT,MAAAC,YAAAQ,SAAGsS,MAPVK,IAYf,OACE1O,OAAAzE,YAAAQ,WACuB,IAApBkC,EAAS0Q,QACRrT,MAAC8E,GAAGkB,MACF2D,YAAY,eACZsK,MAAM,QACNtU,KAAMA,EACNkC,MAAO,CAAEqS,aAAc,IACvBC,OAAQ,CACN3Q,OAAQ,WACNnE,EAAMgU,WAGVjO,KAAMpF,MAACqF,YAASxF,KAAK,SAAS4H,KAAM,GAAIG,MAAM,WAGlD5H,MAACkT,SAKP,IAAMrC,EAAa1O,aAAWzC,OAAO,CACnC0U,UAAW,CACTC,QAAS,OACTvE,SAAU,OACVpH,IAAK,GACLtG,MAAO,QAETuI,KAAM,CACJ1C,SAAU,GACVD,WAAY,UAIV2I,EAAexO,aAAWzC,OAAO,CACrC0U,UAAW,CACTC,QAAS,OACTvE,SAAU,OACVpH,IAAK,GACLtG,MAAO,QAETuI,KAAM,CACJ1C,SAAU,GACVD,WAAY,mBChKQsM,EAASlV,GAC/B,IAAMC,EAAQD,EAAMC,MACdkV,EAAUhV,QAAMC,IAAIH,EAAMqK,aAAc,IACxCG,EAAQxK,EAAMmV,gBAEpBjS,EAAwBjD,WAAS,GAA5BqE,EAAKpB,KAAE4Q,EAAQ5Q,KAEdkS,EAAa,SAAC1Q,GAClB,aAAOA,SAAAA,EAAM8F,SAAUA,GAQnB6K,EAAO,SAAHnU,OAAMwD,EAAIxD,EAAJwD,KAAMJ,EAAKpD,EAALoD,MAChBV,EAAWwR,EAAW1Q,GACtBlC,EAAKhB,KAAaiB,EAAO6I,MAI7B,OAFI1H,IAAUpB,EAAM+F,MAAQ,WAExBrI,QAAMuB,QAAQ1B,EAAMqB,UACfT,MAACgG,QAAKnE,MAAOA,EAAMpB,SAAEsD,EAAKa,QAIjC5E,MAACmQ,GAAU9Q,MAAOA,EAAO0E,KAAMA,EAAKkI,OAAQtI,MAAOA,EAAMlD,SACtDrB,EAAMqB,YAKPkU,EAAe,SAAC5Q,GACpB,IAAIlC,EAAKhB,KAAQiB,EAAOiC,KAAS1E,EAAM6C,SAAS,SAG5CE,EAAQmO,KAAKC,MADL,IAAM+D,EAAQhP,QACM,IAEhC,GAAIkP,EAAW1Q,GAAO,CACpB,IAAI6Q,EAAgBvV,EAAMyI,QAAQ,qBAAiBuI,EAAW,YAM9DxO,EAAKhB,KAAQgB,EALJxC,EAAM6C,SAAS,WAAY,CAClCsG,gBAAiBoM,EACjBhN,MAAO,cAKEA,QACT/F,EAAM+F,MAAQ,WAMlB,OAFA/F,EAAMO,MAAQA,EAEPP,GAGT,OACE7B,MAAAC,YAAAQ,SACG8T,EAAQjT,KAAI,SAACyC,EAAWM,GAAS,OAChCrE,MAACmJ,sBAECtH,MAAO8S,EAAa5Q,GACpB8B,QAAS,SAAAwD,IArDD,SAACtF,GACf1E,EAAMoE,YAAYM,EAAKkI,QACvBkH,IAAWxP,GAoDHgB,CAAQZ,IACRtD,SAEFT,MAAC0U,GAAK3Q,KAAMA,EAAMJ,MAAOU,UANfA,QAapB,IAAMvC,EAASK,aAAWzC,OAAO,CAC/B0U,UAAW,CACT1I,KAAM,EACNtJ,MAAO,OACPsG,IAAK,GACLL,eAAgB,SAChBF,cAAe,OAEjBpE,KAAM,CACJ6E,QAAS,GACTsH,eAAgB,EAChB1H,gBAAiB,aACjBC,aAAc,EACdJ,eAAgB,SAChBjG,MAAO,OACP+F,cAAe,OAEjBwC,KAAM,CACJ1C,SAAU,GACVD,WAAY,kBC9FQ6M,EAAWzV,GACjC,IAAMC,EAAQD,EAAMC,MACdqD,EAAUrD,EAAMsD,SAEtBJ,EAAwBjD,WAAS,GAA5BqE,EAAKpB,KAAE4Q,EAAQ5Q,KAEdsH,EAAQxK,EAAMmH,SAAS,GAEzBoB,EAAQlF,EAAQkF,MAEfA,IAAOA,EAAQ,WAEpB,IAAMkN,EAAM,CACVlM,QAAS,EACTR,WAAY,SACZb,OAAQ,GACRnF,MAAO,GACP4R,UAAW,SACXe,cAAe,SACftM,aAAc,GACdD,gBAAiBZ,EACjBA,MAAO,UACPS,eAAgB,UAGZvG,EAAc,CAClBiG,YAAa,CACXH,MAAO,UACPI,WAAY,MACZC,SAAU,IAEZ4B,MAAO,CACL6B,KAAM,EACNvD,cAAe,MACf6L,UAAW,SACXhM,WAAY,OAEdE,YAAa,CACXC,cAAe,MACfC,WAAY,SACZC,eAAgB,UAElBC,WAAY,CACVV,MAAO,OACPK,SAAU,IAEZM,OAAQuM,EACRE,UAASnU,KACJiU,GAELG,UAASpU,KACJiU,IAIDX,EAAS,SAAC9E,GACdhQ,EAAMoE,YAAYoG,EAAQwF,GAC1B8D,IAAWxP,IAWP9B,EAAQ,SAAC/B,EAAc6I,GAC3B,IAAI1G,EAACpB,KAAQiB,EAAOhC,GAAU6I,GAC9B,OAAOtJ,EAAM6C,SAASpC,EAAMmC,IAG9B,OACEyC,OAAAzE,YAAAQ,UACET,MAACmJ,sBACCC,cAAe,cACfvD,QAba,WACjBsO,GAAQ,IAaJtS,MAAOA,EAAM,aAAapB,SAE1BT,MAACqF,YAASoC,KAAM,GAAI5F,MAAOA,EAAM,cAAehC,KAAK,aAEvDG,MAACgG,QAAKnE,MAAOA,EAAM,SAASpB,SAAElB,QAAMC,IAAIqK,EAAO,KAC/C7J,MAACmJ,sBACCC,cAAe,cACfvD,QAzBa,WACjBsO,EAAO,IAyBHtS,MAAOA,EAAM,aAAapB,SAE1BT,MAACqF,YAASoC,KAAM,GAAI5F,MAAOA,EAAM,cAAehC,KAAK,sBC1FrCqV,IACtB,IAAMC,EAAc,CAClBC,QAAS,SAAAhW,GAAK,OACZY,MAACqV,YAASxU,KACJzB,GACJyC,MAAOC,EAAOwT,UACdjK,sBAAuB,CAAEqB,kBAAmB,IAC5C6I,WAAYzT,EAAO6I,KACnB6K,WAAY1T,EAAO6I,SAGvB8K,MAAO,SAAArW,GAAK,OACVY,MAAC0V,aAAU7U,KACLzB,GACJyC,MAAOC,EAAOwT,UACdC,WAAYzT,EAAO6I,KACnB6K,WAAY1T,EAAO6I,SAGvBgL,KAAM,SAAAvW,GAAK,OACTY,MAACqV,YAASxU,KACJzB,GACJyC,MAAOC,EAAOwT,UACdC,WAAYzT,EAAO6I,KACnB6K,WAAY1T,EAAO6I,UAKnB7I,EAASK,aAAWzC,OAAO,CAC/B4V,UAAW,CACT9M,gBAAiB,yBACjBoN,gBAAiB,QAEnBjL,KAAM,CACJ/C,MAAO,OACPoM,UAAW,YAGf,OAAOhU,MAAC6V,GAAMC,OAAQX,6CCdAY,EAAOxV,aAC7BlB,EAAKkB,EAALlB,MACA2W,EAAIzV,EAAJyV,KACAC,EAAM1V,EAAN0V,OACG7W,EAAK8W,EAAA3V,EAAA4V,GAER5T,EAAsCjD,YAAkB,IAAT0W,GAA1CxM,EAAYjH,KAAEkH,EAAelH,KAClCS,EAAwB1D,WAAS,GAA5BqE,EAAKX,KAAEmQ,EAAQnQ,KAGd4B,EAAQvF,EAAMwI,WACdkC,EAAQ1K,EAAM2K,WACdC,EAAc1K,QAAMC,WAAG0K,EAACH,EAAMjI,gBAAMoI,EAAZA,EAAcC,iBAAdD,EAAwBE,OAAQ,IACxDE,EAAYC,SAAO,MAEnB1I,EAAQ,SAAC/B,EAAc6I,GAC3B,IAAIyN,EAAEvV,KAAQiB,EAAOhC,GAAU6I,GAE/B,OAAA9H,KAAYxB,EAAM6C,SAASpC,EAAMsW,KAG7BC,EAAU,iBACdhX,EAAMiX,MAAM,CAAEjX,MAAAA,EAAOM,YAAI4W,EAAElX,EAAMmX,sBAAND,EAAqB5W,KAAM4D,MAAO,MAG/DlE,EAAMoX,aAAe,SAAAC,GAEnBjN,EADAD,EAAekN,IAIjBrX,EAAMqT,OAAS,WACbS,IAAWxP,IAGb,IAAIgT,SAAIC,EAAGvX,EAAMmX,sBAANI,EAAqBjX,KAC5BkX,EAAOC,YAAUC,QAAQ,QAE7B,IAAKJ,EACH,OAAO3W,MAAAC,eAGT,GAAI0W,EAAKK,eAAIC,EAAKJ,EAAKZ,gBAAMgB,EAAXA,EAAatX,aAAbsX,EAAmBD,MACnC,OAAOhX,MAAAC,eAGT,IAAMiX,EAAcjJ,iBAAe+E,UAAU5T,EAAO,SAAU,SACxD0S,EAAS7D,iBAAe+E,UAAU5T,EAAO,UAE/CC,EAAM8X,IAAI,YAAa7M,GAEvB,IAAM3H,EAAWtD,EAAMsD,SAEvBsL,iBAAemJ,aAAa/X,GAE5B,IAAIuI,EAAQrI,QAAMC,IAAIyK,EAAYrC,MAAO,SACrCuC,EAAW,CAAEvC,MAAAA,GACbzH,EAASwW,EAAK9W,SAAQ8D,EAEtB0T,EAAU,WACZ,aAAIpB,GAAAA,EAAQqB,UAGHtX,YAFGiW,SAAAA,EAAQqB,WAEU3X,KAAMgX,GAAjBA,EAAKK,MAItBhX,MAACb,GAAWE,MAAOA,EAAOM,KAAMgX,EAAKlW,SAClCrB,EAAMqB,YAKT8W,EAAe,SAAHC,OAAM/W,EAAQ+W,EAAR/W,SAChBgX,EAAgBpY,EAAMS,KAAK,iBAAiB,GAGhD,OAFqBT,EAAMS,KAAK,kBAAkB,GAGzCE,MAAAC,YAAAQ,SAAGA,IAGRgX,EACKzX,MAAC4B,QAAKC,MAAOA,EAAM,gBAAgBpB,SAAEA,IAG5CT,MAACoL,cACCC,sBAAuB,CAAEC,SAAU,EAAGC,cAAe,IACrD1J,MAAOA,EAAM,gBACb2J,qBAAqB,EACrBC,IAAKnB,EAAU7J,SAEdA,KA6DP,OACET,OAzDgB,SAAH0X,OAAMjX,EAAQiX,EAARjX,SACnB,OAAIkC,EAASgV,QAET3X,MAAC4X,0BACC/V,MAAO,CACL6J,KAAM,GACNjL,SAEDA,IAIAT,MAAAC,YAAAQ,SAAGA,OA6CAA,SACRT,MAAC8K,SAECC,cAAc,QACdC,aAAa,EACbC,QAASzB,EACT0B,eAAgBmL,EAAQ5V,SAExBT,OAlDa,WACjB,OAAI2C,YAEA3C,MAAC4B,QAAKC,MAAOA,EAAM,aAAapB,SAC9BT,MAACqX,QAML3S,OAAAzE,YAAAQ,UACET,MAACmL,gBAAatJ,MAAOA,EAAM,cAC3B6C,OAACyG,gBAAatJ,MAAOA,EAAM,aAAapB,UACtCiE,OAAC9C,QAAKC,MAAOxC,EAAM6C,SAAS,SAAU+H,GAAaxJ,UACjDT,MAAC4F,oBACCC,QAASwQ,EACTxU,MAAOA,EAAM,oBAAoBpB,SAEjCT,MAACqF,GACCxF,KAAK,uBACL4H,KAAM,GACNG,MAAOA,EACP/F,MAAOA,EAAM,iBAAkBsI,OAGnCnK,MAACgG,QAAKnE,MAAOA,EAAM,aAAcsI,GAAU1J,SAAEmE,KAC3CrF,QAAMuB,QAAQoW,IACdlX,MAACb,GAAWE,MAAOA,EAAOM,KAAMgX,EAAM5V,aAASN,SAC5CyW,OAIPlX,MAACuX,GAAY9W,SACXT,MAACqX,QAEFvF,KAEH9R,MAACkV,gBAOI/U,KAYb,IAAM2B,EAASK,aAAWzC,OAAO,CAC/BmN,SAAU,CACRrE,gBAAiB,UACjBpG,MAAO,QAET0K,UAAW,CACTpB,KAAM,EACNtJ,MAAO,OACPoG,gBAAiB,cAEnBuE,iBAAkB,CAChBnE,QAAS,IAEXoE,eAAgB,CACd/E,SAAU,GACVL,MAAO,SAETqF,WAAY,CACVhF,SAAU,GACVD,WAAY,IACZkF,WAAY,IAEdC,aAAc,CACZzB,KAAM,EACNlD,gBAAiB,aACjBmD,YAAa,GACbC,aAAc,GACdC,WAAY,GACZN,cAAe,eC1NKsM,EAAQtX,WAAGlB,EAAKkB,EAALlB,MAC3B0K,EAAQ1K,EAAM2K,WACdI,EAAS/K,EAAMyI,QAAQ,SAAU,KAAM,IACvCmC,EAAc1K,QAAMC,WAAG0K,EAACH,EAAMjI,gBAAMoI,EAAZA,EAAcC,iBAAdD,EAAwBE,OAAQ,IACxD0N,EAAkBvY,QAAMC,WAAGuY,EAAChO,EAAMjI,gBAAMiW,EAAZA,EAAc5N,iBAAd4N,EAAwBC,WAAY,IAElEC,EAAkB1Y,QAAMuJ,MAAK,WAC/B,IAAIzI,EAAMhB,EAAM6C,SAAS,SAAU+H,GAC/BiO,EAAK7X,EAAImI,gBAKb,OAHI0P,IACF7X,EAAIuH,MAAQuQ,YAAUC,aAAaF,IAE9B7X,KAGLgY,GAAa9Y,QAAMuB,QAAQsJ,GAQ/B,OACEpK,MAAAC,YAAAQ,SACG4X,GACCrY,MAAC4B,QAAKC,MAAOoW,EAAgBxX,SAC3BT,OAXQ,WACd,MAAsB,iBAAXoK,EACFpK,MAACgG,QAAKnE,MAAOiW,EAAgBrX,SAAE2J,IAEjCpK,MAAAC,YAAAQ,SAAG2J,uBCjBUkO,EAAM/X,OAAGlB,EAAKkB,EAALlB,MAAOoB,EAAQF,EAARE,SAChC6J,EAAYC,SAAO,MACnB5H,EAAWtD,EAAMsD,SAEjB4V,EAAW,WACf,IAAM5Y,EAAOmX,YAAUC,UAEvBxX,QAAMyC,KAAKrC,EAAK6Y,QAAQ,SAAAvW,GAClBA,EAAEsW,UACJtW,EAAEsW,SAASzP,KAAK7G,OAMtB5C,EAAM8X,IAAI,YAAa7M,GAEvB2D,iBAAemJ,aAAa/X,GAE5B,IAAIoZ,EAAY,WACd,OAAwB,IAApB9V,EAAS6V,OACJxY,MAACb,GAAWE,MAAOA,EAAMoB,SAAEA,IAIlCT,MAAC4B,QAAKC,MAAOxC,EAAM6C,SAAS,YAAaJ,GAAOsS,WAAW3T,SACzDT,MAACoL,cACCmN,SAAUA,EACVG,oBAAqB,GACrBjN,IAAKnB,EACLkB,qBAAqB,EACrBmN,0BAA0B,UAC1BtN,sBAAuBhM,EAAM6C,SAAS,mBAAoB,CACxDqJ,cAAe,KAEjB1J,MAAOxC,EAAM6C,SAAS,SAAUJ,GAAO0W,QAAQ/X,SAE/CT,MAACb,GAAWE,MAAOA,EAAMoB,SAAEA,SAKnC,OACEiE,OAAAzE,YAAAQ,UACET,MAAC6X,GAASxY,MAAOA,IACjBW,MAACyY,MACDzY,MAACkV,SAKP,IAAMpT,GAASK,aAAWzC,OAAO,CAC/B8Y,OAAQ,CACN3M,WAAY,GACZN,cAAe,GACfI,YAAa,GACbC,aAAc,IAEhBwI,UAAW,GACXwE,KAAM,cCvDgBC,GAAQzZ,GAC9B,IAAMC,EAAQD,EAAMC,MACdM,EAAON,EAAMM,KACbgD,EAAWtD,EAAMsD,SAiBjBC,GAhBOrD,QAAMC,IAAIH,EAAMyI,QAAQ,YAAQuI,EAAW,IAgB1C9Q,QAAMuJ,MAAK,iBACnB8H,EAAOrR,QAAMC,IAAIH,EAAMwD,WAAY,IAEvC,GAAIF,EAAS0Q,gBAAUC,EAAC3Q,EAASiO,QAAT0C,EAAeC,KAAK,CAC1C,IAAIC,EAAQ7T,EACT4O,IAAI,QAAS,IACbkF,cACAlE,OAEH,GAAIiE,EAAMjO,OAAS,EAAG,CACpB,IAAImO,EAAiB,GACjBC,EAAWpU,QAAMC,IAAImD,EAASgR,SAAU,SAY5C,OAVApU,QAAMyC,KAAK4O,GAAM,SAAAgD,GACf,IAAIhP,EAAQgP,EAAED,GAEV/O,GACEA,EAAMiP,SAASL,IACjBE,EAAQ3R,KAAK6R,MAKZF,GAGX,OAAO9C,MAKHkI,EAAa,SAAHvY,OAAMwD,EAAIxD,EAAJwD,KAAMgV,EAAIxY,EAAJwY,KAAMC,EAAQzY,EAARyY,SAC1BrV,GAAQsV,EADoC1Y,EAAR0Y,YAEpCpZ,KAAUR,EAAMc,IAAI,MAAOwD,EAAO,IACjCmN,EAAOxR,WACZG,aAAWC,OAAMmB,KACZ8B,GACH3B,OAAQ3B,EACRQ,KAAAA,EACAF,KAAMN,EAAMM,KACZgE,MAAAA,EACAhD,KAAM,MACN+C,KAAMK,SAIN1D,EAAGQ,KAAQxB,EAAM6C,SAAS,QAE1B8W,IACF3Y,EAAGQ,KAAQR,EAAQhB,EAAM6C,SAAS,YAIlC7B,EAAGQ,KAAQR,EAAQyQ,EAAI5O,SADrB8W,EAC8B,cAEA,gBAFe,KAIjD,IAAM3G,EAAQ,WACZ,OAAI9S,QAAMuB,QAAQ1B,EAAMqB,UAEpBiE,OAAAzE,YAAAQ,UACET,MAACkH,0BAAuBrH,KAAK,OAAO4H,KAAM,GAAIG,MAAM,UACpD5H,MAACgG,QAAKnE,MAAOC,GAAO6I,KAAKlK,SAAEpB,EAAM6Z,aAAanV,QAMlD/D,MAAAC,YAAAQ,SACET,MAACb,GAAW4B,aAAU1B,MAAOyR,EAAKnR,KAAMmR,EAAInR,KAAKc,SAC9CrB,EAAMqB,cAKf,OACET,MAACmZ,kBAAc1Y,SACbT,MAAC4F,oBACC/D,MAAO,CACLC,GAAOgP,IACP,CAAEtI,gBAAiBwQ,EAAW,YAAc,SAASnY,KAChDR,IAEP+Y,eAAgB,IAChBC,YAAaN,EAAMtY,SAEnBT,MAACqS,WAuBHiH,EAAS,SAAH5B,OAAM6B,EAAG7B,EAAH6B,IAGhB,OAFaha,QAAMC,IAAImD,EAAS6W,UAAW,WAE9BD,EAAYvZ,MAAAC,eAElBD,MAAC6X,GAASxY,MAAOA,KAGtBoa,EAAY,WACd,IAAAzW,EAAwB1D,WAASsD,GAApB8W,EAAO1W,KAEpB,OACEhD,MAAC2Z,GACCjW,KAJOV,KAKP4W,oBAAqB5Z,MAACsZ,GAAOC,IAAI,UACjCM,oBAAqB7Z,MAAAC,YAAAQ,SAAGpB,EAAMyI,QAAQ,YACtCgR,WAAYA,EACZgB,eAAcjZ,KAAOxB,EAAM6C,SAAS,SACpC6X,aAAc,SAAAhW,GACZ,IAAI5D,EAAMd,EAAM2a,aAAajW,GAK7B,aAHIpB,GAAAA,EAAUwL,OACZC,QAAQC,IAAIlO,GAEPA,GAET8Z,UAAW,SAAFC,OAAKxW,EAAIwW,EAAJxW,KACZgW,EAAQhW,GACRrE,EAAMoE,YAAYC,OAK1B,OACEgB,QAnDgB,SAAH8S,OAAM/W,EAAQ+W,EAAR/W,SACnB,OAAyB,IAArBkC,EAASgV,QAET3X,MAAC4X,0BACC/V,MAAKhB,GACH6K,KAAM,EACNtJ,MAAO,QACJ/C,EAAM6C,SAAS,QAAS,CAAEmG,eAAgB,gBAC7C5H,SAEDA,IAIAT,MAAAC,YAAAQ,SAAGA,OAqCAA,UACRT,MAACsZ,GAAOC,IAAI,UACZvZ,MAACyZ,SAKP,IAAM3X,GAASK,aAAWzC,OAAO,CAC/BoR,IAAK,CACH3I,cAAe,MACfO,IAAK,GACLE,QAAS,GACTuR,kBAAmB,EACnBC,kBAAmB,QAErBzP,KAAM,CACJ1C,SAAU,MC3IRoS,GAAcC,gBAAmB,aAEf7Y,GAAUrC,WAC1Bmb,EAAMC,aAAWH,IACjBtQ,EAAQxK,QAAMC,IAAIJ,EAAM2K,YAAOwQ,SAAAA,EAAKxQ,OAEtCpK,EAAaJ,QAAMC,IAAIJ,EAAMO,WAAM4a,SAAAA,EAAK5a,MACvCN,EAASC,WAASG,aAAWC,OAAMmB,GAAGlB,KAAAA,GAASP,GAAO2K,MAAAA,SAC3D/G,EAAwB1D,WAAS,GAA5BqE,EAAKX,KAAEmQ,EAAQnQ,KACpByX,EAAsCnb,WAAS,MAA1CmW,EAAKgF,KAAEC,EAAQD,KAEpBpb,EAAMsb,QAAQvb,GAEdO,EAAON,EAAMM,KAEb,IAAI4U,EAAelV,EAAMqK,aAErB/G,EAAWtD,EAAMsD,SACjB8I,EAAMlB,SAAO,MAEjBlL,EAAMqT,OAAS,WACbS,IAAWxP,IAGbtE,EAAMub,cAAgB,WACpBzH,IAAWxP,IAGbtE,EAAMwb,MAAQ,SAACC,EAAiBna,EAAeoa,YAAfpa,IAAAA,EAAO,QACrCkV,EAAMmF,KAAIna,GACRF,KAAAA,EACAsa,MAAOH,EACPI,SAAU,SACVC,eAAgB,KACbJ,KAIP1b,EAAM+b,OAAS,SAACL,GACd,IAAIxX,EAAQwX,EAAKxX,MAEjB,GAAIA,EAAO,CACT,IAAIuX,EAAU,yCACVO,EAAQ,UACRD,EAAS7X,EAAM6X,OAEG,iBAAXA,IACTN,EAAUM,GAGU,iBAAXA,IACTN,EAAUvb,QAAMC,IAAI4b,EAAON,QAASA,GACpCO,EAAQ9b,QAAMC,IAAI4b,EAAOC,MAAOA,IAGlCC,QAAMC,MACJF,EACAP,EACA,CACE,CACEnQ,KAAM,WACN9I,MAAO,UAET,CACE8I,KAAM,YACN9E,QAAS,WAAF,OAAQxG,EAAMiE,QAAQyX,MAGjC,CAAES,YAAY,MAIpB,IAAM9a,EAAS,WACb,IAAI+a,EAAS9Y,EAAS+Y,OAEtB,OAAID,EAGEzb,MAACyB,GAFY,iBAANga,GAGL/Y,QAAS,CAAEmH,MAAO4R,EAAG9a,KAAM,SAC3BhB,KAAMA,GAMAkB,GACRF,KAAM8a,EAAE9a,KACRgb,IAAKF,EAAE9a,MACH8a,EAAErc,OACNO,KAAMA,KAKLK,MAAAC,gBAGT,GAAIZ,EAAMuc,GAAG,OAAQ,SACnB,OAAO5b,MAAAC,YAAAQ,SAAGpB,EAAMyK,oBAGlB,IAAI+R,EAAU,WACZ,IAAIpO,EAAIpO,EAAMmH,WAGdsV,EAAS,CAAEC,OAAQ,CAAElS,SAFD,IAAN4D,OAKZqO,EAAW,SAACzS,GACd,IAAIgG,EAAMhG,EAAE0S,OAAOlS,MAEfxK,EAAM2c,OAAO,UAAW,MAAO,UACjC3M,EAAM4M,SAAS5M,GACNhQ,EAAM2c,OAAO,aACtB3M,EAAM6M,WAAW7M,IAGfhQ,EAAM2c,OAAO,SAAU,cACzB3M,EAAMhQ,EAAM8c,gBAAgB9M,IAG9BhQ,EAAMoE,YAAY4L,GAClBhQ,EAAMqT,UAGJ/N,EAAU,SAAC0E,gBACbkN,EAAIlX,EAAMmX,gBAAND,EAAqBe,WAEzBjY,EAAMyJ,KAAK,UAGT1C,EAAqB,CACvB/G,MAAAA,EACAM,KAAAA,EACAmc,SAAUA,GAGRzc,EAAM2c,OAAO,cACf5V,EAAczF,KAAO,YAGvB,IAMIyb,EAAc,WAChB,QAAI/c,EAAMU,WAIFR,QAAMuB,QAAQ1B,EAAMqB,WAAclB,QAAMuB,QAAQ1B,EAAM+B,YAG5DpB,EAAUV,EAAMuc,GAClB,OACA,OACA,SACA,UACA,MACA,QACA,aACA,QACA,WACA,SAGI1Z,EAAW,SAACpC,EAAe6I,SAC3BhI,EAAOpB,QAAMC,IAAImD,EAAShC,KAAM,QAChCR,EAAMZ,QAAMC,IAAIM,EAAM,QACtBM,EAAGS,KAAQiB,GAAO3B,IAClBkc,EAAWD,IAkBf,OAhBAzb,EAAOpB,QAAMC,IAAImD,EAAS6B,OAAQ7D,GAE7Bb,GAASuc,IACZjc,EAAGS,KAAQT,IAGTf,EAAMU,YACRK,EAAGS,KAAQT,EAAQkc,GAAatM,MAAM7P,KAGxCC,EAAGS,KAAQT,QAAQkc,WAAYC,EAAZD,GAAe3b,WAAf4b,EAAuBpc,IAEtCkc,GAAYvc,IACdM,EAAGS,KAAQT,EAAQoc,GAAgB1c,KAGrCe,KAAYT,EAAQf,EAAM6C,SAASpC,EAAIe,KAAOT,EAAQuI,MAGpD8T,EAAUva,EAAS,WAEnBmE,EAAkB,CACpBqW,SAAUrd,EAAMsd,aAChBlV,KAAM,QACNpI,MAAAA,EACAM,KAAAA,EACAkC,MAAO4a,EACP9S,YAAatK,EAAMuK,KAAK,cAAe,gBAGzCvK,EAAMoW,MAAQ,SAACmH,GACbnH,EAAQmH,EACRlC,EAASkC,WAGPtJ,EAAC3Q,EAASiO,OAAT0C,EAAeC,YAAOsJ,EAACla,EAASma,OAATD,EAAetJ,KACzClU,EAAM0d,QAGR7L,aAAU,WACR7R,EAAM0d,WAGR,IAAMtN,EAAa,WACjB,MAA6B,iBAAlB9M,EAASyC,KACXpF,MAACqF,YAASxF,KAAM8C,EAASyC,KAAMvD,MAAOxC,EAAM6C,SAAS,UAEvDlC,MAAAC,YAAAQ,SAAGkC,EAASyC,QA0CrB,GAvCA/F,EAAM2W,KAAO,SAAC+E,GACZjV,UAAQC,QAAQgV,EAAKxH,MAGvByJ,mBAAgB,WACd,SAAIvR,GAAAA,EAAK+C,SAAWnP,EAAMuc,GAAG,OAAQ,OAAQ,OAAQ,OAAQ,WAAY,CACvE,IAAIpM,QAAU/D,SAAAA,EAAK+C,QAEnB,SAAIgB,GAAAA,EAAIyN,UAAW,CACjB,IAAI/E,EAAKC,YAAU+E,WAAW1N,GAG5BA,EAAGyN,UAAUlK,IADJ,uBAAPmF,EACe,UAEA,kBAyBpB7Y,EAAM8d,cAAgB9d,EAAMuc,GAAG,OAAQ,UAC1C,OAAO5b,MAAAC,eAGT,IAoBImd,GACD/d,EAAM2c,OAAO,QAAS,OAAQ,OAAQ,QAAS,WAAarZ,EAAS2C,MACpEoW,EAAc,GAEd0B,IACF1B,EAAOtS,cAAgB,cACvBsS,EAAO7V,QAAUlB,GAGnB,IAAI0Y,GAAM,SAACje,GACT,IAAIke,EAAW1b,OAMf,OAJIwb,IACFE,EAAMnU,sBAGJ9J,EAAM2c,OAAO,SAAU,UAAYrZ,YAC9B3C,MAAAC,YAAAQ,SAAGrB,EAAMqB,WAGXT,MAACsd,EAAGzc,KAAKzB,KAGdme,GAAQ,WACV,OACE7Y,OAAAzE,YAAAQ,UACGpB,EAAMyI,QAAQ,SAAU,KAAM9H,MAAAC,gBAC9BZ,EAAMuc,GAAG,OAAQ,WAChBlX,OAAC8C,EAAQ3G,KACHwF,GACJ1B,QAASA,EACTgD,QAAStI,EAAMuK,KAAK,UAAW,YAAYnJ,UAE1CkC,EAASyC,MAAQpF,MAACyP,MAClB9M,EAASiC,OACR5E,MAACgG,QAAKnE,MAAOxC,EAAMyI,QAAQ,QAAS,UAAUrH,SAC3CpB,EAAMwI,iBAKdxI,EAAMuc,GAAG,OAAQ,SAChB5b,MAACuG,EAAM1F,KACDwF,GACJ1B,QAASA,EACTgD,QAAStI,EAAMuK,KAAK,UAAW,YAAYnJ,SAE1CpB,EAAMyK,qBAGVzK,EAAMuc,GAAG,OAAQ,SAChBlX,OAAC4B,EAAMzF,KACDwF,GACJ1B,QAASA,EACTgD,QAAStI,EAAMuK,KAAK,UAAW,YAAYnJ,UAE1CkC,EAASyC,MAAQpF,MAACyP,MAClB9M,EAASiC,OACR5E,MAACgG,QAAKnE,MAAOxC,EAAMyI,QAAQ,QAAS,QAAQrH,SACzCpB,EAAMwI,iBAKd9H,GACCC,MAACoP,EAAOvO,KACFuF,EACAC,GACJmX,WAAU3c,KAAO8B,EAAS8a,eAG7Bpe,EAAMuc,GAAG,OAAQ,WAAY,iBAC5B5b,MAACkG,GACC7G,MAAOA,EACP+G,cAAeA,EACfC,WAAYA,IAGfhH,EAAMuc,GAAG,OAAQ,aAChB5b,MAAC6U,GACCxV,MAAOA,EACP+G,cAAeA,EACfC,WAAYA,IAGfhH,EAAMuc,GAAG,OAAQ,WAAY,UAAW,WACvC5b,MAACoN,EAAQvM,GACP6c,SAtOK,IAFLre,EAAMmH,YAyOFJ,GACJ0V,SAAUD,KAGbxc,EAAM2c,OAAO,WACZhc,MAAC0N,EAAQ7M,KAAKuF,GAAe0V,SAAUD,KAExCxc,EAAMuc,GAAG,OAAQ,WAChB5b,MAACuJ,EAAQ1I,KACHuF,EACAC,GACJwD,MAAOxK,EAAMse,sBAGhBte,EAAMuc,GAAG,OAAQ,WAChB5b,MAACsU,EAAQzT,KACHuF,EACAC,GACJwD,MAAOxK,EAAMse,sBAGhBte,EAAMuc,GAAG,OAAQ,UAChB5b,MAACmP,EAAOtO,KAAKuF,EAAmBC,GAAYyK,OAAGrQ,SAC5C8T,EAAQjT,KAAI,SAACwP,EAAUzM,GAAS,OAC/BrE,MAACkP,GAEC0O,QAAS5d,MAACmP,EAAOtO,KAAKwF,IACtBzB,MAAOkM,EAAIlM,MACXiF,MAAOiH,EAAIjH,OAHN,IAAMxF,SAQlBhF,EAAMuc,GAAG,OAAQ,WAAa5b,MAACU,MAC/BrB,EAAMuc,GAAG,OAAQ,WAChBlX,OAAAzE,YAAAQ,UACGpB,EAAMuc,GAAG,SAAU,QAClB5b,MAAC6d,SAAMC,OAAQze,EAAMyK,oBAEtBzK,EAAMuc,GAAG,SAAU,SAAW5b,MAACuG,GAAOlH,MAAOA,EAAOM,KAAMA,KACzDN,EAAMuc,GAAG,SAAU,OAAQ,QAC3B5b,MAACgG,QAAIvF,SAAEpB,EAAMyK,uBAIlBzK,EAAMuc,GAAG,OAAQ,SAAU,UAC1B5b,MAACgG,QAAKnE,MAAOK,EAAS,SAASzB,SAAEpB,EAAMyK,wBAM3C7E,GAAU,SAAH1E,OAAMV,EAAIU,EAAJV,KAAMgC,EAAKtB,EAALsB,MACrB,GAAIzC,EAAMS,GAAO,CACf,IAAIke,EAAS9P,iBAAe+E,UAAU5T,EAAOS,GAE7C,IAAKN,QAAMuB,QAAQid,GACjB,OACE/d,MAACb,EAAU0B,KACLzB,GACJC,MAAOA,EACPM,KAAMA,EACNkC,MAAOK,EAASrC,EAAMgC,GAAOpB,SAE5Bsd,KAKT,OAAO/d,MAAAC,gBAGLwY,GAAY,qBACd,OACE/T,OAAAzE,YAAAQ,eA3M0B,IAAnBkC,EAASiC,QACG,IAAnBjC,EAASiC,QACRvF,EAAM2c,OAAO,SAAU,SAAU,UA2M9BtX,OAAC9C,QACCC,MAAOK,EAAS,aAAc,CAC5B2N,UAAW,aACX1H,cAAe,MACfkM,QAAS,OACThM,eAAgB,gBAChBD,WAAY,SACZhG,MAAO,SACN3B,UAEHT,MAACgG,QAAKnE,MAAOK,EAAS,SAASzB,SAAEpB,EAAMwI,aACvC7H,MAACiF,IAAQpF,KAAK,UAAUgC,MAAO,CAAEO,MAAO,cA7M5Cga,KAiNE1X,OAAAzE,YAAAQ,UACET,MAAC4B,QAAKC,MAAOK,EAAS,SAASzB,SAC7BT,MAACud,SAEF9H,GAASzV,MAAC4B,QAAKC,MAAOK,EAAS,SAASzB,SAAEgV,OAG9CpW,EAAM2c,OAAO,OAAQ,WACpBhc,MAAC8S,EAAMjS,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAExCN,EAAM2c,OAAO,UACZhc,MAAC6Y,GAAOhY,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAGzCN,EAAM2c,OAAO,WACZhc,MAAC+V,EAAOlV,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,aAGzCiX,EAAAvX,EAAMmX,sBAANI,EAAqBU,YACpBtX,MAAC+V,GACC1W,aAAK2e,EAAE3e,EAAMmX,sBAANwH,EAAqB3e,MAC5BM,YAAIse,EAAE5e,EAAMmX,sBAANyH,EAAqBte,KAC3BqW,QACAC,OAAQ5W,EAAMmX,gBAIjBnX,EAAM2c,OAAO,UACZhc,MAACwF,EAAO3E,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAEzCN,EAAM2c,OAAO,SACZhc,MAACsC,EAAMzB,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,KAGxCN,EAAM2c,OAAO,SACZhc,MAACsY,EAAMzX,KAAKzB,GAAOC,MAAOA,EAAOM,KAAMA,MAxO3CN,EAAM2c,OACJ,OACA,OACA,OACA,OACA,SACA,SACA,QACA,SACA,UAmOEhc,MAACb,EAAU0B,KACLzB,GACJC,MAAOA,EACPM,KAAMA,EACNkC,MAAOK,EAAS,gBAOtBgc,GAAO,SAAC9e,GAGV,GAFaC,EAAMuc,GAAG,cAAe,QAEzB,CACV,IAAIuC,EAAGtd,KACFqB,EAAS,MAAKrB,KAAOud,GAASD,KAAKtO,UAAW,cAGnD,OACE7P,MAAC4B,QAAKC,MAAOK,EAAS,OAAMrB,KAAOsd,IAAO1d,SACxCT,MAAC4B,QACCC,MAAOK,EAAS,WAAY,CAC1BwK,kBAAmB,GACnBC,gBAAiB,KAChBlM,SAEFrB,EAAMqB,aAMf,OAAIpB,EAAMU,WAAa4C,EAASyR,UAE5BpU,MAAC4B,QACCC,MAAOK,EAAS,YAAa,CAAEyK,gBAAiB,EAAGvK,MAAO,SAAU3B,SAEnErB,EAAMqB,WAINT,MAAAC,YAAAQ,SAAGrB,EAAMqB,YA8FlB,OA3FApB,EAAMgf,WAAa,SAACtD,SACdlE,EAAOC,YAAUC,QAAQ,QACzB/V,EAAS6V,EAAKZ,OACZtW,EAASob,EAATpb,KACFE,EAAOR,EAAM0M,QAAQ,SACrB6G,GAAqB,IAAdmI,EAAKnI,KACZxS,EAAW,GACXke,EAAU,KACV/a,EAAQhE,QAAMC,UAAIub,SAAAA,EAAMxX,MAAO,IAC/B+T,QAAY/T,SAAAA,EAAO+T,UAEnB3X,EAAKic,GAAG,QACVxb,EAAIY,OAASrB,EAAKqB,OAAOA,OACzBZ,EAAIiT,OAAS1T,EAAKqB,OAElBsd,EAAU3e,EAAK+D,MACN/D,EAAKic,GAAG,YACjBxb,EAAIY,OAASrB,EAAKqB,OAClBZ,EAAIiT,OAAS1T,GAGf,IAAI+D,EAAOnE,QAAMC,IAAIub,EAAKhX,KAAMua,EAAS,IAErCC,EAAIta,YAAUvE,OAAO,SAAQmB,GAC/BG,OAAQrB,EACR6e,KAAM7e,EACNE,KAAAA,EACA6D,KAAAA,EACAkP,KAAAA,EACAvT,MAAAA,GACGe,IAGDoP,EAAU,CACZ5K,MAAOjC,EAASiC,MAChBQ,KAAMzC,EAASyC,KACfzE,KAAM,UAGJ2V,SAAKmI,EAAGlb,EAAM0S,eAANwI,EAAcnI,MAEE,iBAAjB/S,EAAM0S,SACfzG,EAAE3O,KAAQ2O,EAAOjM,EAAM0S,SAGrB1S,EAAM6G,SAAQoF,EAAGpF,OAAS7G,EAAM6G,QAChC7G,EAAMqB,QAAO4K,EAAG5K,MAAQrB,EAAMqB,OAC9BrB,EAAM8X,QAAO7L,EAAG6L,MAAQ9X,EAAM8X,OAElC7L,EAAG5K,MAAQrF,QAAMC,IAAIgQ,EAAG6L,MAAO7L,EAAG5K,OAElC,IAAI8Z,EAAcjf,aAAWC,OAAMmB,GACjCG,OAAQ3B,EACRM,KAAM4e,GACH/O,GACHmP,MAAOtf,KAEL4W,EAAS,CAAEtW,KAAM4e,EAAGvd,OAAAA,EAAQsW,UAAAA,EAAWjY,MAAOqf,EAAapI,MAAAA,GAE/DO,EAAKZ,OAASA,EACd5W,EAAMoX,cAAa,GACnBpX,EAAMmX,cAAgBP,EAEtByI,EAAYlI,cAAgBP,EAC5ByI,EAAYjI,cAAa,GAEzBpX,EAAMqT,UAGRrT,EAAMuf,WAAa,SAAC7D,SAQY8D,EAP1BhI,EAAOC,YAAUC,QAAQ,QACzB+H,EAAMzf,EAAMmX,cACZuI,EAAcD,EAAIzf,MAAM2B,OAE5B6V,EAAKZ,OAAS1W,QAAMC,IAAIsf,EAAI9d,OAAQ,MACpC3B,EAAMmX,cAAgB,YAEtBS,EAAIJ,EAAKZ,gBAAMgB,EAAXA,EAAatX,OAAbsX,EAAmB5X,eACrBwf,EAAAhI,EAAKZ,SAAL4I,EAAalf,KAAKN,MAAMqT,UAE1BrT,EAAMoX,cAAa,GACnBpX,EAAMqT,SAEN,IAAM4D,EAAQwI,EAAIxI,MAEdyI,GAAezI,UACbA,GAAAA,EAAOnI,OAAOC,QAAQC,IAAI,YAC9B0Q,EAAYjW,KAAK,QAAS,CAAEwN,MAAAA,MAK9BtW,MAACqa,GAAY2E,UAASnV,MAAO,CAAElK,KAAAA,EAAMoK,MAAAA,GAAQtJ,SAC3CT,MAACqd,GAAGxc,GAAC4K,IAAKA,EAAK5J,MAAOK,KAAgBwZ,GAAMjb,SAC1CT,MAACke,IAAIzd,SACHT,MAACyY,cAOX,IAAI2F,GAAWjc,aAAWzC,OAAO,CAC/Bye,IAAK,CACHpV,YAAa,EACbC,YAAa,UACbiW,YAAa,QACbzW,gBAAiB,QACjBC,aAAc,GACdrG,MAAO,OACP8c,YAAa,OACbC,cAAe,GACfC,aAAc,KAIZjB,GAAGtd,KACJud,GAASD,KAGR7B,GAAoB,CAE1BA,KAAoB,CAClBja,MAAO,CACLD,MAAO,OACPgG,WAAY,SACZsD,KAAM,GAER0I,UAAW,CACThS,MAAO,OACPoG,gBAAiB,aACjBkD,KAAM,EACNhD,IAAK,IAEP8V,KAAM,CACJpc,MAAO,OACPsJ,KAAM,EACNtD,WAAY,SACZQ,QAAS,KAIb0T,GAAatM,MAAQ7N,aAAWzC,OAAO,CACrCkF,MAAO,CACL+G,YAAa,GAEftJ,MAAO,CACLqJ,KAAM,EACNtJ,MAAO,OACPwG,QAAS,EACTF,IAAK,GACLmH,UAAW,aACX1H,cAAe,MACf2H,SAAU,UAIdwM,GAAa+C,SAAW,CACtBhd,MAAKxB,KACAsd,IACH3V,gBAAiB,cACjBR,WAAY,IACZC,SAAU,GACVQ,aAAc,GACdM,YAAa,EACb2D,kBAAmB,EACnBC,gBAAiB,EACjBmD,SAAU,SACVpE,KAAM,EACNvD,cAAe,MACfE,eAAgB,SAChBD,WAAY,YAIhBkU,GAAagD,OAASnd,aAAWzC,OAAO,CACtC2C,MAAKxB,KACAsd,IACHzS,KAAM,EACNtJ,MAAO,OACPsG,IAAK,GACLL,eAAgB,SAChBF,cAAe,MACfuE,kBAAmB,GACnBC,gBAAiB,EACjBkD,UAAW,aACXC,SAAU,aAId,IAAMhO,GAASK,aAAWzC,OAAO,CAC/B8e,KAAM,CACJ9V,IAAK,EACLP,cAAe,SACf2H,SAAU,OACV1N,MAAO,OACPgG,WAAY,cAEdxD,MAAO,CACLoD,WAAY,IACZC,SAAU,GACV0E,gBAAiB,EACjB/E,MAAO,cAETvF,MAAO,CAAED,MAAO,UAGZoa,GAAkBra,aAAWzC,OAAO,CACxC8e,KAAM,CACJ9V,IAAK,IAEP9D,MAAO,CACLxC,MAAO,OACP4F,WAAY,IACZC,SAAU,eC9yBUsX,GAAUngB,GAChC,IAAuB,IAAnBA,EAAMgF,SACR,OAAOpE,MAAAC,eAGT,IAAI4T,EAAW5F,iBAAe+E,UAAU5T,EAAOA,EAAMS,KAAMT,EAAM8b,UAMjE,OAJI3b,QAAMuB,QAAQ+S,KAChBA,EAAWzU,WAGRG,QAAMuB,QAAQ+S,GAwBZ7T,MAAAC,YAAAQ,SAAGoT,IAbN7T,OAVQ,SAACwf,GACT,IAAInC,EAAWje,EAAMuc,IAErB,OAAKpc,QAAMuB,QAAQuc,GAGZrd,MAAAC,YAAAQ,SAAG+e,EAAQ/e,WAFTT,MAACqd,EAAGxc,KAAK2e,GAAO/e,SAAG+e,EAAQ/e,cAMhCI,KAAKzB,EAAMqgB,UAAQhf,SACrBT,MAACb,EAAU0B,GACTE,cACI3B,GACJC,MAAOD,EAAMC,MACbM,KAAMP,EAAMO,KACZG,KAAMV,EAAMS,KAAKY,SAEhBoT,wBCbL/O,GAAK,CACT4a,MAAO,SAACtgB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACvDmL,KAAM,SAAC1M,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WACtDgf,IAAK,SAACvgB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,UACrD4L,MAAO,SAACnN,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACvDif,MAAO,SAACxgB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACvDkf,OAAQ,SAACzgB,GAAe,OACtBY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,SAASvB,MAAO,CAAEiU,QAAQ,OAEvDyM,OAAQ,SAAC1gB,GAAiB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC1DsE,QAAS,SAAC7F,GAAiB,OAAKY,MAACuf,GAAS1e,KAAKzB,KAC/C2gB,OAAQ,SAAFxf,OAAyBnB,EAAK8W,EAAA3V,EAAA4V,IAAA,OAClCnW,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAE7Bqf,MAAO,SAAC5gB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,KAC5C4G,KAAM,SAAC5G,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WACvDsf,MAAO,SAAC7gB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACxDwE,OAAQ,SAAC/F,GAAiB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC1Duf,KAAM,SAAC9gB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WACtDwf,KAAM,SAAC/gB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WACtDoE,OAAQ,SAAC3F,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7Dyf,KAAM,SAAChhB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WAC3D0f,KAAM,SAACjhB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WAC3DiB,KAAM,SAACxC,GAAoB,OACzBY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,OAAOI,iBAEpCuf,OAAQ,SAAClhB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7D4f,OAAQ,SAACnhB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7D0W,QAAS,SAACjY,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,cAC9D6f,IAAK,SAACphB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,UAC1Dud,KAAM,SAAC9e,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WAC3D8f,IAAK,SAACrhB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,UAC1D+f,KAAM,SAACthB,GAAe,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,WACtDggB,KAAM,SAACvhB,GAAoB,OACzBY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,MAAM6D,OAAO,WAE1Coc,QAAS,SAACxhB,GAAe,OACvBY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,OAAO6D,OAAO,cAE3Cqc,MAAO,SAACzhB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACxDmgB,MAAO,SAAC1hB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YACxDogB,SAAU,SAAC3hB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,eAC3DqgB,SAAU,SAAC5hB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,eAC3DsgB,SAAU,SAAC7hB,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC3D4M,OAAQ,SAACnO,GAAgB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aACzDugB,MAAO,SAAC9hB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,YAC5DwgB,OAAQ,SAAC/hB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7DygB,OAAQ,SAAChiB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7D0gB,OAAQ,SAACjiB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC7D2gB,QAAS,SAACliB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,cAC9D4gB,SAAU,SAACniB,GAAoB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,eAC/D+N,OAAQ,SAACtP,GAAiB,OAAKY,MAACyB,GAASZ,KAAKzB,GAAOuB,KAAK,aAC1D6gB,kBCnD+BpiB,SAC3B2K,EAAQ0X,aAAWC,kBAavB,OAVIniB,QAAMuB,QAAQiJ,KAChBA,EAAQ4X,cAUR3hB,MAAC4hB,oBAAgBnhB,SACfiE,OAACmd,gBACChgB,MAAKhB,GACH2H,uBAAeiC,EAAEV,EAAMW,eAAND,EAAcV,OAC5B3K,EAAM0iB,WACTpW,KAAM,IACNjL,UAEFT,MAAC+hB,aAAUC,SAAS,eAAexZ,gBAAgB,YACnDxI,MAACiiB,wBACCC,SAA0B,QAAhB5Q,WAASC,GAAe,UAAY,SAC9C1P,MAAO,CACL6J,KAAM,EACNrD,eAAgB,cAChB5H,SAEFT,MAACmiB,4BACCtc,QAxBc,WACF,QAAhByL,WAASC,IACX6Q,WAASC,WAuBHC,YAAY,EAAM7hB,SAElBT,MAAAC,YAAAQ,SAAGrB,EAAMqB,qBDiBnB8hB,qBEhEkCnjB,GAClC,OACEY,MAAC4X,0BAAuB/V,MAAO,CAAE6J,KAAM,GAAIjL,SACxCrB,EAAMqB"}
|