@codeleap/mobile 1.8.3 → 1.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. package/CodeLeap-Mobile-Packages.code-workspace +7 -7
  2. package/dist/components/ActivityIndicator.d.ts +13 -13
  3. package/dist/components/ActivityIndicator.js +54 -50
  4. package/dist/components/ActivityIndicator.js.map +1 -1
  5. package/dist/components/Animated.d.ts +15 -15
  6. package/dist/components/Animated.js +58 -54
  7. package/dist/components/Animated.js.map +1 -1
  8. package/dist/components/Button.d.ts +125 -125
  9. package/dist/components/Button.js +82 -78
  10. package/dist/components/Button.js.map +1 -1
  11. package/dist/components/Checkbox/index.d.ts +15 -14
  12. package/dist/components/Checkbox/index.js +77 -73
  13. package/dist/components/Checkbox/index.js.map +1 -1
  14. package/dist/components/Checkbox/styles.d.ts +55 -55
  15. package/dist/components/Checkbox/styles.js +48 -48
  16. package/dist/components/Checkbox/styles.js.map +0 -0
  17. package/dist/components/ContentView.d.ts +10 -10
  18. package/dist/components/ContentView.js +50 -50
  19. package/dist/components/ContentView.js.map +0 -0
  20. package/dist/components/FileInput.d.ts +27 -26
  21. package/dist/components/FileInput.js +178 -174
  22. package/dist/components/FileInput.js.map +1 -1
  23. package/dist/components/Icon.d.ts +12 -12
  24. package/dist/components/Icon.js +70 -66
  25. package/dist/components/Icon.js.map +1 -1
  26. package/dist/components/Image.d.ts +18 -18
  27. package/dist/components/Image.js +59 -55
  28. package/dist/components/Image.js.map +1 -1
  29. package/dist/components/List.d.ts +13 -13
  30. package/dist/components/List.js +82 -78
  31. package/dist/components/List.js.map +1 -1
  32. package/dist/components/Modal/index.d.ts +26 -26
  33. package/dist/components/Modal/index.js +112 -108
  34. package/dist/components/Modal/index.js.map +1 -1
  35. package/dist/components/Modal/styles.d.ts +69 -69
  36. package/dist/components/Modal/styles.js +64 -64
  37. package/dist/components/Modal/styles.js.map +0 -0
  38. package/dist/components/Navigation/Navigation.d.ts +3 -3
  39. package/dist/components/Navigation/Navigation.js +87 -83
  40. package/dist/components/Navigation/Navigation.js.map +1 -1
  41. package/dist/components/Navigation/constants.d.ts +5 -5
  42. package/dist/components/Navigation/constants.js +10 -10
  43. package/dist/components/Navigation/constants.js.map +0 -0
  44. package/dist/components/Navigation/index.d.ts +3 -3
  45. package/dist/components/Navigation/index.js +19 -15
  46. package/dist/components/Navigation/index.js.map +1 -1
  47. package/dist/components/Navigation/types.d.ts +26 -26
  48. package/dist/components/Navigation/types.js +7 -7
  49. package/dist/components/Navigation/types.js.map +0 -0
  50. package/dist/components/Navigation/utils.d.ts +3 -3
  51. package/dist/components/Navigation/utils.js +69 -69
  52. package/dist/components/Navigation/utils.js.map +0 -0
  53. package/dist/components/Overlay.d.ts +16 -16
  54. package/dist/components/Overlay.js +69 -65
  55. package/dist/components/Overlay.js.map +1 -1
  56. package/dist/components/Pager/index.d.ts +20 -20
  57. package/dist/components/Pager/index.js +167 -163
  58. package/dist/components/Pager/index.js.map +1 -1
  59. package/dist/components/Pager/styles.d.ts +54 -54
  60. package/dist/components/Pager/styles.js +43 -43
  61. package/dist/components/Pager/styles.js.map +0 -0
  62. package/dist/components/RadioInput/index.d.ts +26 -26
  63. package/dist/components/RadioInput/index.js +72 -68
  64. package/dist/components/RadioInput/index.js.map +1 -1
  65. package/dist/components/RadioInput/styles.d.ts +57 -57
  66. package/dist/components/RadioInput/styles.js +44 -44
  67. package/dist/components/RadioInput/styles.js.map +0 -0
  68. package/dist/components/Scroll.d.ts +12 -12
  69. package/dist/components/Scroll.js +80 -76
  70. package/dist/components/Scroll.js.map +1 -1
  71. package/dist/components/Sections.d.ts +11 -11
  72. package/dist/components/Sections.js +80 -76
  73. package/dist/components/Sections.js.map +1 -1
  74. package/dist/components/Select/index.d.ts +5 -5
  75. package/dist/components/Select/index.js +150 -146
  76. package/dist/components/Select/index.js.map +1 -1
  77. package/dist/components/Select/styles.d.ts +9 -9
  78. package/dist/components/Select/styles.js +56 -56
  79. package/dist/components/Select/styles.js.map +0 -0
  80. package/dist/components/Select/types.d.ts +39 -39
  81. package/dist/components/Select/types.js +2 -2
  82. package/dist/components/Select/types.js.map +0 -0
  83. package/dist/components/Slider/Mark.d.ts +3 -3
  84. package/dist/components/Slider/Mark.js +31 -31
  85. package/dist/components/Slider/Mark.js.map +0 -0
  86. package/dist/components/Slider/Thumb.d.ts +7 -7
  87. package/dist/components/Slider/Thumb.js +29 -29
  88. package/dist/components/Slider/Thumb.js.map +0 -0
  89. package/dist/components/Slider/index.d.ts +3 -3
  90. package/dist/components/Slider/index.js +97 -93
  91. package/dist/components/Slider/index.js.map +1 -1
  92. package/dist/components/Slider/types.d.ts +25 -25
  93. package/dist/components/Slider/types.js +2 -2
  94. package/dist/components/Slider/types.js.map +0 -0
  95. package/dist/components/Switch.d.ts +13 -13
  96. package/dist/components/Switch.js +75 -71
  97. package/dist/components/Switch.js.map +1 -1
  98. package/dist/components/Text.d.ts +12 -12
  99. package/dist/components/Text.js +52 -48
  100. package/dist/components/Text.js.map +1 -1
  101. package/dist/components/TextInput.d.ts +183 -171
  102. package/dist/components/TextInput.js +178 -157
  103. package/dist/components/TextInput.js.map +1 -1
  104. package/dist/components/Touchable.d.ts +14 -14
  105. package/dist/components/Touchable.js +61 -57
  106. package/dist/components/Touchable.js.map +1 -1
  107. package/dist/components/View.d.ts +120 -120
  108. package/dist/components/View.js +54 -50
  109. package/dist/components/View.js.map +1 -1
  110. package/dist/components/components.d.ts +25 -24
  111. package/dist/components/components.js +41 -36
  112. package/dist/components/components.js.map +1 -1
  113. package/dist/index.d.ts +5 -5
  114. package/dist/index.js +28 -24
  115. package/dist/index.js.map +1 -1
  116. package/dist/modules/documentPicker.d.ts +3 -3
  117. package/dist/modules/documentPicker.js +11 -11
  118. package/dist/modules/documentPicker.js.map +0 -0
  119. package/dist/modules/fastImage.d.ts +1 -1
  120. package/dist/modules/fastImage.js +9 -9
  121. package/dist/modules/fastImage.js.map +0 -0
  122. package/dist/modules/reactNavigation.d.ts +3 -3
  123. package/dist/modules/reactNavigation.js +10 -10
  124. package/dist/modules/reactNavigation.js.map +0 -0
  125. package/dist/modules/textInputMask.d.ts +7 -0
  126. package/dist/modules/textInputMask.js +10 -0
  127. package/dist/modules/textInputMask.js.map +1 -0
  128. package/dist/modules/types/fileTypes.d.ts +138 -138
  129. package/dist/modules/types/fileTypes.js +2 -2
  130. package/dist/modules/types/fileTypes.js.map +0 -0
  131. package/dist/modules/types/textInputMask.d.ts +9 -0
  132. package/dist/modules/types/textInputMask.js +3 -0
  133. package/dist/modules/types/textInputMask.js.map +1 -0
  134. package/dist/types/utility.d.ts +2 -2
  135. package/dist/types/utility.js +2 -2
  136. package/dist/types/utility.js.map +0 -0
  137. package/dist/utils/OSAlert.d.ts +31 -31
  138. package/dist/utils/OSAlert.js +141 -141
  139. package/dist/utils/OSAlert.js.map +1 -1
  140. package/dist/utils/misc.d.ts +2 -2
  141. package/dist/utils/misc.js +25 -25
  142. package/dist/utils/misc.js.map +0 -0
  143. package/dist/utils/styles.d.ts +1 -1
  144. package/dist/utils/styles.js +12 -12
  145. package/dist/utils/styles.js.map +0 -0
  146. package/package.json +39 -38
  147. package/src/components/ActivityIndicator.tsx +46 -46
  148. package/src/components/Animated.tsx +34 -34
  149. package/src/components/Button.tsx +95 -95
  150. package/src/components/Checkbox/index.tsx +83 -81
  151. package/src/components/Checkbox/styles.ts +72 -72
  152. package/src/components/ContentView.tsx +58 -58
  153. package/src/components/FileInput.tsx +181 -179
  154. package/src/components/Icon.tsx +58 -58
  155. package/src/components/Image.tsx +61 -61
  156. package/src/components/List.tsx +109 -109
  157. package/src/components/Modal/index.tsx +161 -161
  158. package/src/components/Modal/styles.ts +133 -133
  159. package/src/components/Navigation/Navigation.tsx +58 -58
  160. package/src/components/Navigation/constants.ts +8 -8
  161. package/src/components/Navigation/index.tsx +3 -3
  162. package/src/components/Navigation/types.ts +35 -35
  163. package/src/components/Navigation/utils.tsx +59 -59
  164. package/src/components/Overlay.tsx +77 -77
  165. package/src/components/Pager/index.tsx +242 -242
  166. package/src/components/Pager/styles.ts +51 -51
  167. package/src/components/RadioInput/index.tsx +101 -101
  168. package/src/components/RadioInput/styles.ts +67 -67
  169. package/src/components/Scroll.tsx +104 -104
  170. package/src/components/Sections.tsx +101 -101
  171. package/src/components/Select/index.tsx +195 -195
  172. package/src/components/Select/styles.ts +81 -81
  173. package/src/components/Select/types.ts +45 -45
  174. package/src/components/Slider/Mark.tsx +46 -46
  175. package/src/components/Slider/Thumb.tsx +29 -29
  176. package/src/components/Slider/index.tsx +123 -123
  177. package/src/components/Slider/types.ts +25 -25
  178. package/src/components/Switch.tsx +81 -81
  179. package/src/components/Text.tsx +30 -30
  180. package/src/components/TextInput.tsx +246 -218
  181. package/src/components/Touchable.tsx +64 -64
  182. package/src/components/View.tsx +46 -46
  183. package/src/components/components.ts +26 -26
  184. package/src/index.ts +6 -6
  185. package/src/modules/documentPicker.ts +7 -7
  186. package/src/modules/fastImage.ts +2 -2
  187. package/src/modules/index.d.ts +496 -496
  188. package/src/modules/reactNavigation.ts +4 -4
  189. package/src/modules/textInputMask.ts +7 -0
  190. package/src/modules/types/documentPicker.d.ts +215 -215
  191. package/src/modules/types/fileTypes.ts +138 -138
  192. package/src/modules/types/textInputMask.ts +9 -0
  193. package/src/types/utility.ts +3 -3
  194. package/src/utils/OSAlert.ts +180 -180
  195. package/src/utils/misc.ts +24 -24
  196. package/src/utils/styles.ts +14 -14
@@ -1,218 +1,246 @@
1
- import * as React from 'react'
2
- import {
3
- ComponentVariants,
4
- FormTypes,
5
- IconPlaceholder,
6
- TextInputComposition,
7
- TextInputStyles,
8
- useBooleanToggle,
9
- useDefaultComponentStyle,
10
- useValidate,
11
- } from '@codeleap/common'
12
- import { ComponentPropsWithoutRef, forwardRef, useImperativeHandle, useRef, useState } from 'react'
13
- import { Text } from './Text'
14
- import { View, ViewProps } from './View'
15
- import { Button } from './Button'
16
- import { StylesOf } from '../types/utility'
17
- import { Icon } from './Icon'
18
- import { NativeSyntheticEvent, StyleSheet, TextInput as NativeTextInput, TextInputChangeEventData } from 'react-native'
19
- import { Touchable, TouchableProps } from './Touchable'
20
-
21
- type IconProp = { name: IconPlaceholder; action?: () => void }
22
-
23
- type NativeProps = ComponentPropsWithoutRef<typeof NativeTextInput>
24
-
25
- export type TextInputProps =
26
- ComponentVariants<typeof TextInputStyles> &
27
- Omit<NativeProps, 'value'> &
28
- {
29
- multiline?: boolean
30
- onChangeText?: (text: string) => void
31
- disabled?: boolean
32
- edited?: boolean
33
- type?: string
34
- label?: React.ReactNode
35
- debugName: string
36
- leftIcon?: IconProp
37
- rightIcon?: IconProp
38
- styles?: StylesOf<TextInputComposition>
39
- validate?: FormTypes.ValidatorFunctionWithoutForm | string
40
- value?: string
41
- password?: boolean
42
- visibilityToggle?: boolean
43
- touchableWrapper?: boolean
44
- onPress?: () => void
45
- innerWrapperProps?: TouchableProps | ViewProps
46
- }
47
-
48
- export const TextInput = forwardRef<NativeTextInput, TextInputProps>((rawprops, inputRef) => {
49
- const {
50
- onChange,
51
- type,
52
- value,
53
- onChangeText,
54
- disabled,
55
- edited,
56
- onFocus,
57
- onBlur,
58
- variants,
59
- label,
60
- leftIcon,
61
- rightIcon,
62
- styles,
63
- validate,
64
- password,
65
- visibilityToggle,
66
- touchableWrapper,
67
- innerWrapperProps,
68
- debugName,
69
- ...props
70
- } = rawprops
71
-
72
- const [isFocused, setFocus] = useState(false)
73
- const [editedState, setEdited] = useState(edited)
74
-
75
- const input = useRef<any>(null)
76
- const [textIsVisible, setTextVisible] = useBooleanToggle(false)
77
- const variantStyles = useDefaultComponentStyle('TextInput', {
78
- variants,
79
- styles,
80
- })
81
- const InputElement = NativeTextInput
82
-
83
- const handleBlur: TextInputProps['onBlur'] = (e) => {
84
- if (!editedState && value) setEdited(true)
85
- setFocus(false)
86
-
87
- if (onBlur) {
88
- onBlur(e)
89
- }
90
- }
91
-
92
- const handleFocus: TextInputProps['onFocus'] = (e) => {
93
- setFocus(true)
94
- if (onFocus) {
95
- onFocus(e)
96
- }
97
- }
98
-
99
- const handleChange = (event: NativeSyntheticEvent<TextInputChangeEventData>) => {
100
- const text = event.nativeEvent.text
101
-
102
- if (onChange) onChange(event)
103
- if (onChangeText) onChangeText(text)
104
- }
105
-
106
- useImperativeHandle(inputRef, () => ({ ...input.current, focus: () => {
107
- input.current?.focus?.()
108
- }, isTextInput: true }))
109
-
110
- const { showError, error } = useValidate(value, validate)
111
-
112
- const leftIconStyle = {
113
- ...variantStyles.icon,
114
- ...(isFocused ? variantStyles['icon:focus'] : {}),
115
- ...(showError ? variantStyles['icon:error'] : {}),
116
- ...variantStyles.leftIcon,
117
- ...(isFocused ? variantStyles['leftIcon:focus'] : {}),
118
- ...(showError ? variantStyles['leftIcon:error'] : {}),
119
- }
120
-
121
- const rightIconStyle = {
122
- ...variantStyles.icon,
123
- ...(isFocused ? variantStyles['icon:focus'] : {}),
124
- ...(showError ? variantStyles['icon:error'] : {}),
125
- ...variantStyles.rightIcon,
126
- ...(isFocused ? variantStyles['rightIcon:focus'] : {}),
127
- ...(showError ? variantStyles['rightIcon:error'] : {}),
128
- }
129
-
130
- const buttonIconWrapperStyle = {
131
- ...variantStyles.buttonIconWrapper,
132
- ...(isFocused ? variantStyles['buttonIconWrapper:focus'] : {}),
133
- ...(showError ? variantStyles['buttonIconWrapper:error'] : {}),
134
- }
135
- function getStyles(key: TextInputComposition) {
136
- const requestedStyles = [
137
- variantStyles[key],
138
- isFocused ? variantStyles[key + ':focus'] : {},
139
- showError ? variantStyles[key + ':error'] : {},
140
- ]
141
- return requestedStyles
142
- }
143
-
144
- function handlePress() {
145
- if (props.onPress) {
146
- props.onPress()
147
- } else {
148
- input.current?.focus?.()
149
- }
150
- }
151
-
152
- return (
153
- <Touchable
154
- style={getStyles('wrapper')}
155
- debugName={debugName}
156
- onPress={handlePress}
157
- {...innerWrapperProps}
158
- >
159
- <InputLabel label={label} style={getStyles('label')} />
160
- <View style={getStyles('innerWrapper')} {...innerWrapperProps}>
161
- <InputIcon {...leftIcon} style={leftIconStyle} wrapperStyle={buttonIconWrapperStyle} />
162
- <InputElement
163
- ref={input}
164
- secureTextEntry={password && !textIsVisible}
165
- onChange={handleChange}
166
- value={value}
167
- editable={disabled}
168
- onFocus={handleFocus}
169
- onBlur={handleBlur}
170
- placeholderTextColor={StyleSheet.flatten(getStyles('placeholder'))?.color}
171
- selectionColor={StyleSheet.flatten(getStyles('selection'))?.color}
172
- {...props}
173
- style={getStyles('textField')}
174
- />
175
- {
176
- visibilityToggle ?
177
- <InputIcon name={
178
- (textIsVisible ? 'input-visiblity:visible' : 'input-visiblity:hidden') as IconPlaceholder
179
- } action={() => setTextVisible()} style={rightIconStyle} wrapperStyle={buttonIconWrapperStyle}/>
180
- :
181
- <InputIcon {...rightIcon} style={rightIconStyle} wrapperStyle={buttonIconWrapperStyle} />
182
- }
183
- </View>
184
- <FormError message={error.message} style={getStyles('error')} />
185
- </Touchable>
186
- )
187
- })
188
-
189
- export const FormError = ({ message, ...props }) => {
190
- if (['number', 'string', 'undefined'].includes(typeof message)) {
191
- const text = message ? `${message.charAt(0).toUpperCase() + message.slice(1)}` : ' '
192
- return <Text text={text} variants={['p2', 'marginTop:1']} {...props} />
193
- }
194
- return message
195
- }
196
-
197
- export const InputIcon: React.FC<{ style: any; wrapperStyle: any } & IconProp> = ({ name, style, action, wrapperStyle = {}}) => {
198
- if (!name) return null
199
- if (action) {
200
- return <Touchable debugName={`${name} icon button`} onPress={() => action()} style={wrapperStyle} >
201
- <Icon name={name} style={style}/>
202
- </Touchable>
203
- }
204
- return <Icon name={name} style={style} />
205
- }
206
-
207
- export const InputLabel = ({ label, style }) => {
208
- if (!label) return null
209
-
210
- switch (typeof label) {
211
- case 'string':
212
- return <Text style={style} text={label} />
213
- case 'object':
214
- return label
215
- default:
216
- return null
217
- }
218
- }
1
+ import * as React from 'react'
2
+ import {
3
+ ComponentVariants,
4
+ FormTypes,
5
+ IconPlaceholder,
6
+ TextInputComposition,
7
+ TextInputStyles,
8
+ useBooleanToggle,
9
+ useComponentStyle,
10
+ useDefaultComponentStyle,
11
+ useValidate,
12
+ } from '@codeleap/common'
13
+ import { ComponentPropsWithoutRef, forwardRef, useImperativeHandle, useRef, useState } from 'react'
14
+ import { Text } from './Text'
15
+ import { View, ViewProps } from './View'
16
+ import { Button } from './Button'
17
+ import { StylesOf } from '../types/utility'
18
+ import { Icon } from './Icon'
19
+ import { NativeSyntheticEvent, StyleSheet, TextInput as NativeTextInput, TextInputChangeEventData } from 'react-native'
20
+ import { Touchable, TouchableProps } from './Touchable'
21
+ import { MaskedTextInput } from '../modules/textInputMask'
22
+ import { TextInputMaskProps } from '../modules/types/textInputMask'
23
+
24
+ type IconProp = { name: IconPlaceholder; action?: () => void }
25
+
26
+ type NativeProps = ComponentPropsWithoutRef<typeof NativeTextInput>
27
+
28
+ export type TextInputProps =
29
+ ComponentVariants<typeof TextInputStyles> &
30
+ Omit<NativeProps, 'value'> &
31
+ {
32
+ multiline?: boolean
33
+ onChangeText?: (text: string) => void
34
+ disabled?: boolean
35
+ edited?: boolean
36
+ type?: string
37
+ label?: React.ReactNode
38
+ debugName: string
39
+ leftIcon?: IconProp
40
+ rightIcon?: IconProp
41
+ styles?: StylesOf<TextInputComposition>
42
+ validate?: FormTypes.ValidatorFunctionWithoutForm | string
43
+ value?: string
44
+ password?: boolean
45
+ visibilityToggle?: boolean
46
+ touchableWrapper?: boolean
47
+ onPress?: () => void
48
+ masking?: FormTypes.TextField['masking']
49
+ innerWrapperProps?: TouchableProps | ViewProps
50
+ onChangeMask?: TextInputMaskProps['onChangeText']
51
+ required?:boolean
52
+ }
53
+
54
+ export const TextInput = forwardRef<NativeTextInput, TextInputProps>((rawprops, inputRef) => {
55
+ const {
56
+ onChange,
57
+ type,
58
+ value,
59
+ onChangeText,
60
+ disabled,
61
+ edited,
62
+ onFocus,
63
+ onBlur,
64
+ variants,
65
+ label,
66
+ leftIcon,
67
+ rightIcon,
68
+ styles,
69
+ validate,
70
+ password,
71
+ visibilityToggle,
72
+ touchableWrapper,
73
+ innerWrapperProps,
74
+ masking = null,
75
+ onChangeMask,
76
+ debugName,
77
+ required = false,
78
+ ...props
79
+ } = rawprops
80
+
81
+ const [isFocused, setFocus] = useState(false)
82
+ const [editedState, setEdited] = useState(edited)
83
+
84
+ const input = useRef<any>(null)
85
+ const [textIsVisible, setTextVisible] = useBooleanToggle(false)
86
+ const variantStyles = useDefaultComponentStyle('TextInput', {
87
+ variants,
88
+ styles,
89
+ })
90
+ const InputElement = masking ? MaskedTextInput : NativeTextInput
91
+
92
+ const handleBlur: TextInputProps['onBlur'] = (e) => {
93
+ if (!editedState && value) setEdited(true)
94
+ setFocus(false)
95
+
96
+ if (onBlur) {
97
+ onBlur(e)
98
+ }
99
+ }
100
+
101
+ const handleFocus: TextInputProps['onFocus'] = (e) => {
102
+ setFocus(true)
103
+ if (onFocus) {
104
+ onFocus(e)
105
+ }
106
+ }
107
+ const handleMaskChange = (masked, unmasked, obfuscated) => {
108
+ if (onChangeText) onChangeText(masking.saveFormatted ? masked : unmasked)
109
+ if (onChangeMask) onChangeMask(masked, unmasked, obfuscated)
110
+ }
111
+ const handleChange = (event: NativeSyntheticEvent<TextInputChangeEventData>) => {
112
+ const text = event.nativeEvent.text
113
+
114
+ if (onChange) onChange(event)
115
+ if (onChangeText) onChangeText(text)
116
+ }
117
+
118
+ useImperativeHandle(inputRef, () => ({ ...input.current, focus: () => {
119
+ input.current?.focus?.()
120
+ }, isTextInput: true }))
121
+
122
+ const { showError, error } = useValidate(value, validate)
123
+
124
+ const leftIconStyle = {
125
+ ...variantStyles.icon,
126
+ ...(isFocused ? variantStyles['icon:focus'] : {}),
127
+ ...(showError ? variantStyles['icon:error'] : {}),
128
+ ...variantStyles.leftIcon,
129
+ ...(isFocused ? variantStyles['leftIcon:focus'] : {}),
130
+ ...(showError ? variantStyles['leftIcon:error'] : {}),
131
+ }
132
+
133
+ const rightIconStyle = {
134
+ ...variantStyles.icon,
135
+ ...(isFocused ? variantStyles['icon:focus'] : {}),
136
+ ...(showError ? variantStyles['icon:error'] : {}),
137
+ ...variantStyles.rightIcon,
138
+ ...(isFocused ? variantStyles['rightIcon:focus'] : {}),
139
+ ...(showError ? variantStyles['rightIcon:error'] : {}),
140
+ }
141
+
142
+ const buttonIconWrapperStyle = {
143
+ ...variantStyles.buttonIconWrapper,
144
+ ...(isFocused ? variantStyles['buttonIconWrapper:focus'] : {}),
145
+ ...(showError ? variantStyles['buttonIconWrapper:error'] : {}),
146
+ }
147
+ function getStyles(key: TextInputComposition) {
148
+ const requestedStyles = [
149
+ variantStyles[key],
150
+ isFocused ? variantStyles[key + ':focus'] : {},
151
+ showError ? variantStyles[key + ':error'] : {},
152
+ ]
153
+ return requestedStyles
154
+ }
155
+
156
+ function handlePress() {
157
+ if (props.onPress) {
158
+ props.onPress()
159
+ } else {
160
+ input.current?.focus?.()
161
+ }
162
+ }
163
+
164
+ return (
165
+ <Touchable
166
+ style={getStyles('wrapper')}
167
+ debugName={debugName}
168
+ onPress={handlePress}
169
+ {...innerWrapperProps}
170
+ >
171
+ <InputLabel
172
+ label={label}
173
+ style={getStyles('label')}
174
+ asteriskStyle={getStyles('requiredAsterisk')}
175
+ wrapperStyle={getStyles('labelWrapper')}
176
+ required={required}
177
+ />
178
+ <View style={getStyles('innerWrapper')} {...innerWrapperProps}>
179
+ <InputIcon {...leftIcon} style={leftIconStyle} wrapperStyle={buttonIconWrapperStyle} />
180
+ {/* @ts-ignore */}
181
+ <InputElement
182
+ ref={input}
183
+ secureTextEntry={password && !textIsVisible}
184
+ onChange={(e) => masking ? onChange?.(e) : handleChange(e)}
185
+ value={value}
186
+ editable={disabled}
187
+ onFocus={handleFocus}
188
+ onBlur={handleBlur}
189
+ placeholderTextColor={StyleSheet.flatten(getStyles('placeholder'))?.color}
190
+ selectionColor={StyleSheet.flatten(getStyles('selection'))?.color}
191
+ mask={masking?.mask}
192
+ {...props}
193
+ {...(masking ? { onChangeText: handleMaskChange } : {})}
194
+ style={getStyles('textField')}
195
+ />
196
+ {
197
+ visibilityToggle ?
198
+ <InputIcon name={
199
+ (textIsVisible ? 'input-visiblity:visible' : 'input-visiblity:hidden') as IconPlaceholder
200
+ } action={() => setTextVisible()} style={rightIconStyle} wrapperStyle={buttonIconWrapperStyle}/>
201
+ :
202
+ <InputIcon {...rightIcon} style={rightIconStyle} wrapperStyle={buttonIconWrapperStyle} />
203
+ }
204
+ </View>
205
+ <FormError message={error.message} style={getStyles('error')} />
206
+ </Touchable>
207
+ )
208
+ })
209
+
210
+ export const FormError = ({ message, ...props }) => {
211
+ if (['number', 'string', 'undefined'].includes(typeof message)) {
212
+ const text = message ? `${message.charAt(0).toUpperCase() + message.slice(1)}` : ' '
213
+ return <Text text={text} variants={['p2', 'marginTop:1']} {...props} />
214
+ }
215
+ return message
216
+ }
217
+
218
+ export const InputIcon: React.FC<{ style: any; wrapperStyle: any } & IconProp> = ({ name, style, action, wrapperStyle = {}}) => {
219
+ if (!name) return null
220
+ if (action) {
221
+ return <Touchable debugName={`${name} icon button`} onPress={() => action()} style={wrapperStyle} >
222
+ <Icon name={name} style={style}/>
223
+ </Touchable>
224
+ }
225
+ return <Icon name={name} style={style} />
226
+ }
227
+
228
+ export const InputLabel = ({ label, variants = [], styles = {}, style, asteriskStyle = null, required = false, wrapperStyle = null }) => {
229
+ const labelStyles = useDefaultComponentStyle('TextInput', {
230
+ variants, styles, transform: StyleSheet.flatten,
231
+ })
232
+
233
+ if (!label) return null
234
+
235
+ switch (typeof label) {
236
+ case 'string':
237
+ return <View style={ wrapperStyle || labelStyles.labelWrapper}>
238
+ <Text style={style || labelStyles.label} text={label} />
239
+ {required && <Text style={asteriskStyle || labelStyles.requiredAsterisk} text={' *'} />}
240
+ </View>
241
+ case 'object':
242
+ return label
243
+ default:
244
+ return null
245
+ }
246
+ }
@@ -1,64 +1,64 @@
1
- import * as React from 'react'
2
- import { ComponentPropsWithoutRef, forwardRef } from 'react'
3
- import {
4
- ComponentVariants,
5
- useDefaultComponentStyle,
6
- BaseViewProps,
7
- ViewStyles,
8
- useCodeleapContext,
9
- AnyFunction,
10
- } from '@codeleap/common'
11
- import { TouchableOpacity as NativeTouchable } from 'react-native'
12
-
13
- import { createAnimatableComponent } from 'react-native-animatable'
14
- export type TouchableProps = Omit<
15
- ComponentPropsWithoutRef<typeof NativeTouchable>,
16
- 'onPress'
17
- > & {
18
- variants?: ComponentVariants<typeof ViewStyles>['variants']
19
- component?: any
20
- ref?: React.Ref<NativeTouchable>
21
- debugName: string
22
- debugComponent?: string
23
- onPress?: AnyFunction
24
- } & BaseViewProps
25
-
26
- export const Touchable: React.FC<TouchableProps> = forwardRef<
27
- NativeTouchable,
28
- TouchableProps
29
- >((touchableProps, ref) => {
30
- const {
31
- variants = [],
32
- children,
33
- onPress,
34
- style,
35
- debugName,
36
- debugComponent,
37
- ...props
38
- } = touchableProps
39
-
40
- const variantStyles = useDefaultComponentStyle('View', {
41
- variants,
42
- })
43
-
44
- const { logger } = useCodeleapContext()
45
- const press = () => {
46
- if (!onPress) { throw { message: 'No onPress passed to touchable', touchableProps } }
47
- logger.log(
48
- `<${debugComponent || 'Touchable'}/> pressed`,
49
- { debugName, style, variants },
50
- 'User interaction',
51
- )
52
- onPress && onPress()
53
- }
54
-
55
- const styles = [variantStyles.wrapper, style]
56
-
57
- return (
58
- <NativeTouchable onPress={press} style={styles} {...props} ref={ref}>
59
- {children}
60
- </NativeTouchable>
61
- )
62
- })
63
-
64
- export const AnimatedTouchable = createAnimatableComponent(Touchable) as unknown as typeof Touchable
1
+ import * as React from 'react'
2
+ import { ComponentPropsWithoutRef, forwardRef } from 'react'
3
+ import {
4
+ ComponentVariants,
5
+ useDefaultComponentStyle,
6
+ BaseViewProps,
7
+ ViewStyles,
8
+ useCodeleapContext,
9
+ AnyFunction,
10
+ } from '@codeleap/common'
11
+ import { TouchableOpacity as NativeTouchable } from 'react-native'
12
+
13
+ import { createAnimatableComponent } from 'react-native-animatable'
14
+ export type TouchableProps = Omit<
15
+ ComponentPropsWithoutRef<typeof NativeTouchable>,
16
+ 'onPress'
17
+ > & {
18
+ variants?: ComponentVariants<typeof ViewStyles>['variants']
19
+ component?: any
20
+ ref?: React.Ref<NativeTouchable>
21
+ debugName: string
22
+ debugComponent?: string
23
+ onPress?: AnyFunction
24
+ } & BaseViewProps
25
+
26
+ export const Touchable: React.FC<TouchableProps> = forwardRef<
27
+ NativeTouchable,
28
+ TouchableProps
29
+ >((touchableProps, ref) => {
30
+ const {
31
+ variants = [],
32
+ children,
33
+ onPress,
34
+ style,
35
+ debugName,
36
+ debugComponent,
37
+ ...props
38
+ } = touchableProps
39
+
40
+ const variantStyles = useDefaultComponentStyle('View', {
41
+ variants,
42
+ })
43
+
44
+ const { logger } = useCodeleapContext()
45
+ const press = () => {
46
+ if (!onPress) { throw { message: 'No onPress passed to touchable', touchableProps } }
47
+ logger.log(
48
+ `<${debugComponent || 'Touchable'}/> pressed`,
49
+ { debugName, style, variants },
50
+ 'User interaction',
51
+ )
52
+ onPress && onPress()
53
+ }
54
+
55
+ const styles = [variantStyles.wrapper, style]
56
+
57
+ return (
58
+ <NativeTouchable onPress={press} style={styles} {...props} ref={ref}>
59
+ {children}
60
+ </NativeTouchable>
61
+ )
62
+ })
63
+
64
+ export const AnimatedTouchable = createAnimatableComponent(Touchable) as unknown as typeof Touchable