@codeleap/mobile 1.9.25 → 1.9.26

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 (202) 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 -54
  4. package/dist/components/ActivityIndicator.js.map +0 -0
  5. package/dist/components/Animated.d.ts +123 -15
  6. package/dist/components/Animated.js +58 -58
  7. package/dist/components/Animated.js.map +0 -0
  8. package/dist/components/Button.d.ts +125 -125
  9. package/dist/components/Button.js +82 -82
  10. package/dist/components/Button.js.map +0 -0
  11. package/dist/components/Checkbox/index.d.ts +15 -15
  12. package/dist/components/Checkbox/index.js +79 -79
  13. package/dist/components/Checkbox/index.js.map +0 -0
  14. package/dist/components/Checkbox/styles.d.ts +55 -55
  15. package/dist/components/Checkbox/styles.js +51 -51
  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 +31 -31
  21. package/dist/components/FileInput.js +230 -230
  22. package/dist/components/FileInput.js.map +0 -0
  23. package/dist/components/Icon.d.ts +12 -12
  24. package/dist/components/Icon.js +70 -70
  25. package/dist/components/Icon.js.map +0 -0
  26. package/dist/components/Image.d.ts +18 -18
  27. package/dist/components/Image.js +59 -59
  28. package/dist/components/Image.js.map +0 -0
  29. package/dist/components/List.d.ts +14 -14
  30. package/dist/components/List.js +83 -83
  31. package/dist/components/List.js.map +0 -0
  32. package/dist/components/Modal/index.d.ts +26 -26
  33. package/dist/components/Modal/index.js +112 -112
  34. package/dist/components/Modal/index.js.map +0 -0
  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 -87
  40. package/dist/components/Navigation/Navigation.js.map +0 -0
  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 -19
  46. package/dist/components/Navigation/index.js.map +0 -0
  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/NewPager/index.d.ts +26 -0
  54. package/dist/components/NewPager/index.js +92 -0
  55. package/dist/components/NewPager/index.js.map +1 -0
  56. package/dist/components/NewPager/styles.d.ts +87 -0
  57. package/dist/components/NewPager/styles.js +70 -0
  58. package/dist/components/NewPager/styles.js.map +1 -0
  59. package/dist/components/Overlay.d.ts +16 -16
  60. package/dist/components/Overlay.js +69 -69
  61. package/dist/components/Overlay.js.map +0 -0
  62. package/dist/components/Pager/index.d.ts +20 -20
  63. package/dist/components/Pager/index.js +167 -167
  64. package/dist/components/Pager/index.js.map +0 -0
  65. package/dist/components/Pager/styles.d.ts +54 -54
  66. package/dist/components/Pager/styles.js +43 -43
  67. package/dist/components/Pager/styles.js.map +0 -0
  68. package/dist/components/RadioInput/index.d.ts +26 -26
  69. package/dist/components/RadioInput/index.js +72 -72
  70. package/dist/components/RadioInput/index.js.map +0 -0
  71. package/dist/components/RadioInput/styles.d.ts +57 -57
  72. package/dist/components/RadioInput/styles.js +44 -44
  73. package/dist/components/RadioInput/styles.js.map +0 -0
  74. package/dist/components/Scroll.d.ts +13 -13
  75. package/dist/components/Scroll.js +81 -81
  76. package/dist/components/Scroll.js.map +0 -0
  77. package/dist/components/Sections.d.ts +11 -11
  78. package/dist/components/Sections.js +80 -80
  79. package/dist/components/Sections.js.map +0 -0
  80. package/dist/components/Select/index.d.ts +5 -5
  81. package/dist/components/Select/index.js +150 -150
  82. package/dist/components/Select/index.js.map +0 -0
  83. package/dist/components/Select/styles.d.ts +9 -9
  84. package/dist/components/Select/styles.js +56 -56
  85. package/dist/components/Select/styles.js.map +0 -0
  86. package/dist/components/Select/types.d.ts +40 -40
  87. package/dist/components/Select/types.js +2 -2
  88. package/dist/components/Select/types.js.map +0 -0
  89. package/dist/components/Slider/Mark.d.ts +3 -3
  90. package/dist/components/Slider/Mark.js +31 -31
  91. package/dist/components/Slider/Mark.js.map +0 -0
  92. package/dist/components/Slider/Thumb.d.ts +7 -7
  93. package/dist/components/Slider/Thumb.js +29 -29
  94. package/dist/components/Slider/Thumb.js.map +0 -0
  95. package/dist/components/Slider/index.d.ts +3 -3
  96. package/dist/components/Slider/index.js +97 -97
  97. package/dist/components/Slider/index.js.map +0 -0
  98. package/dist/components/Slider/types.d.ts +25 -25
  99. package/dist/components/Slider/types.js +2 -2
  100. package/dist/components/Slider/types.js.map +0 -0
  101. package/dist/components/Switch.d.ts +13 -13
  102. package/dist/components/Switch.js +75 -75
  103. package/dist/components/Switch.js.map +0 -0
  104. package/dist/components/Text.d.ts +12 -12
  105. package/dist/components/Text.js +52 -52
  106. package/dist/components/Text.js.map +0 -0
  107. package/dist/components/TextInput.d.ts +183 -183
  108. package/dist/components/TextInput.js +180 -180
  109. package/dist/components/TextInput.js.map +0 -0
  110. package/dist/components/Touchable.d.ts +14 -14
  111. package/dist/components/Touchable.js +75 -75
  112. package/dist/components/Touchable.js.map +0 -0
  113. package/dist/components/View.d.ts +123 -120
  114. package/dist/components/View.js +55 -54
  115. package/dist/components/View.js.map +1 -1
  116. package/dist/components/components.d.ts +26 -25
  117. package/dist/components/components.js +42 -41
  118. package/dist/components/components.js.map +1 -1
  119. package/dist/index.d.ts +5 -5
  120. package/dist/index.js +28 -28
  121. package/dist/index.js.map +0 -0
  122. package/dist/modules/documentPicker.d.ts +3 -3
  123. package/dist/modules/documentPicker.js +11 -11
  124. package/dist/modules/documentPicker.js.map +0 -0
  125. package/dist/modules/fastImage.d.ts +1 -1
  126. package/dist/modules/fastImage.js +9 -9
  127. package/dist/modules/fastImage.js.map +0 -0
  128. package/dist/modules/reactNavigation.d.ts +3 -3
  129. package/dist/modules/reactNavigation.js +10 -10
  130. package/dist/modules/reactNavigation.js.map +0 -0
  131. package/dist/modules/textInputMask.d.ts +12 -12
  132. package/dist/modules/textInputMask.js +7 -7
  133. package/dist/modules/types/fileTypes.d.ts +138 -138
  134. package/dist/modules/types/fileTypes.js +2 -2
  135. package/dist/modules/types/fileTypes.js.map +0 -0
  136. package/dist/modules/types/textInputMask.d.ts +12 -12
  137. package/dist/modules/types/textInputMask.js +2 -2
  138. package/dist/types/utility.d.ts +2 -2
  139. package/dist/types/utility.js +2 -2
  140. package/dist/types/utility.js.map +0 -0
  141. package/dist/utils/OSAlert.d.ts +31 -31
  142. package/dist/utils/OSAlert.js +141 -141
  143. package/dist/utils/OSAlert.js.map +0 -0
  144. package/dist/utils/misc.d.ts +2 -2
  145. package/dist/utils/misc.js +25 -25
  146. package/dist/utils/misc.js.map +0 -0
  147. package/dist/utils/styles.d.ts +1 -1
  148. package/dist/utils/styles.js +12 -12
  149. package/dist/utils/styles.js.map +0 -0
  150. package/package.json +42 -40
  151. package/src/components/ActivityIndicator.tsx +46 -46
  152. package/src/components/Animated.tsx +34 -34
  153. package/src/components/Button.tsx +95 -95
  154. package/src/components/Checkbox/index.tsx +85 -85
  155. package/src/components/Checkbox/styles.ts +76 -76
  156. package/src/components/ContentView.tsx +58 -58
  157. package/src/components/FileInput.tsx +230 -230
  158. package/src/components/Icon.tsx +58 -58
  159. package/src/components/Image.tsx +61 -61
  160. package/src/components/List.tsx +111 -111
  161. package/src/components/Modal/index.tsx +161 -161
  162. package/src/components/Modal/styles.ts +133 -133
  163. package/src/components/Navigation/Navigation.tsx +58 -58
  164. package/src/components/Navigation/constants.ts +8 -8
  165. package/src/components/Navigation/index.tsx +3 -3
  166. package/src/components/Navigation/types.ts +35 -35
  167. package/src/components/Navigation/utils.tsx +59 -59
  168. package/src/components/NewPager/index.tsx +123 -0
  169. package/src/components/NewPager/styles.ts +76 -0
  170. package/src/components/Overlay.tsx +77 -77
  171. package/src/components/Pager/index.tsx +242 -242
  172. package/src/components/Pager/styles.ts +52 -51
  173. package/src/components/RadioInput/index.tsx +101 -101
  174. package/src/components/RadioInput/styles.ts +67 -67
  175. package/src/components/Scroll.tsx +106 -106
  176. package/src/components/Sections.tsx +101 -101
  177. package/src/components/Select/index.tsx +195 -195
  178. package/src/components/Select/styles.ts +81 -81
  179. package/src/components/Select/types.ts +46 -46
  180. package/src/components/Slider/Mark.tsx +46 -46
  181. package/src/components/Slider/Thumb.tsx +29 -29
  182. package/src/components/Slider/index.tsx +123 -123
  183. package/src/components/Slider/types.ts +25 -25
  184. package/src/components/Switch.tsx +81 -81
  185. package/src/components/Text.tsx +30 -30
  186. package/src/components/TextInput.tsx +247 -247
  187. package/src/components/Touchable.tsx +78 -78
  188. package/src/components/View.tsx +48 -46
  189. package/src/components/components.ts +27 -26
  190. package/src/index.ts +6 -6
  191. package/src/modules/documentPicker.ts +7 -7
  192. package/src/modules/fastImage.ts +2 -2
  193. package/src/modules/index.d.ts +496 -496
  194. package/src/modules/reactNavigation.ts +4 -4
  195. package/src/modules/textInputMask.ts +9 -9
  196. package/src/modules/types/documentPicker.d.ts +215 -215
  197. package/src/modules/types/fileTypes.ts +138 -138
  198. package/src/modules/types/textInputMask.ts +13 -13
  199. package/src/types/utility.ts +3 -3
  200. package/src/utils/OSAlert.ts +180 -180
  201. package/src/utils/misc.ts +24 -24
  202. package/src/utils/styles.ts +14 -14
@@ -1,95 +1,95 @@
1
- import * as React from 'react'
2
- import {
3
- useDefaultComponentStyle,
4
- ButtonStyles,
5
- ComponentVariants,
6
- ButtonComposition,
7
- ButtonParts,
8
- IconPlaceholder,
9
- } from '@codeleap/common'
10
- import { forwardRef } from 'react'
11
- import { StylesOf } from '../types/utility'
12
- import { Text } from './Text'
13
- import { Touchable, TouchableProps } from './Touchable'
14
- import { Icon } from './Icon'
15
- import { ActivityIndicator } from './ActivityIndicator'
16
- import { StyleSheet, TouchableOpacity } from 'react-native'
17
-
18
- export type ButtonProps = Omit<TouchableProps, 'variants'> &
19
- ComponentVariants<typeof ButtonStyles> & {
20
- text?: string
21
- rightIcon?: IconPlaceholder
22
- icon?: IconPlaceholder
23
- styles?: StylesOf<ButtonComposition>
24
- loading?: boolean
25
- debounce?: number
26
- debugName: string
27
- }
28
-
29
- export const Button = forwardRef<TouchableOpacity, ButtonProps>((buttonProps, ref) => {
30
- const {
31
- variants = [],
32
- children,
33
- icon,
34
- text,
35
- loading,
36
- styles = {},
37
- onPress,
38
- disabled,
39
- rightIcon,
40
- debounce = 600,
41
- style,
42
- ...props
43
- } = buttonProps
44
- const [pressed, setPressed] = React.useState(false)
45
-
46
- const variantStyles = useDefaultComponentStyle('Button', {
47
- variants,
48
- transform: StyleSheet.flatten,
49
- styles,
50
- })
51
-
52
- function handlePress() {
53
- if (!pressed) {
54
- setPressed(true)
55
-
56
- setTimeout(() => setPressed(false), debounce)
57
-
58
- onPress && onPress()
59
- }
60
- }
61
-
62
- function getStyles(key: ButtonParts) {
63
- return [
64
- variantStyles[key],
65
- key === 'wrapper' && style,
66
- disabled && variantStyles[key + ':disabled'],
67
- styles[key],
68
- disabled && styles[key + ':disabled'],
69
- ]
70
- }
71
-
72
- const iconStyle = getStyles('icon')
73
-
74
- const leftIconStyle = StyleSheet.flatten([iconStyle, getStyles('leftIcon')])
75
- const rightIconStyle = StyleSheet.flatten([iconStyle, getStyles('rightIcon')])
76
-
77
- const hasText = !!(text || children)
78
- return (
79
- <Touchable
80
- style={getStyles('wrapper')}
81
- onPress={handlePress}
82
- ref={ref}
83
- disabled={disabled}
84
- debugComponent={'Button'}
85
- {...props}
86
- >
87
-
88
- {loading && <ActivityIndicator style={getStyles('loader')} />}
89
- {!loading && <Icon name={icon} style={leftIconStyle} renderEmptySpace={hasText}/>}
90
- {text ? <Text text={text} style={getStyles('text')} /> : null}
91
- {children}
92
- <Icon name={rightIcon} style={rightIconStyle} renderEmptySpace={hasText} />
93
- </Touchable>
94
- )
95
- })
1
+ import * as React from 'react'
2
+ import {
3
+ useDefaultComponentStyle,
4
+ ButtonStyles,
5
+ ComponentVariants,
6
+ ButtonComposition,
7
+ ButtonParts,
8
+ IconPlaceholder,
9
+ } from '@codeleap/common'
10
+ import { forwardRef } from 'react'
11
+ import { StylesOf } from '../types/utility'
12
+ import { Text } from './Text'
13
+ import { Touchable, TouchableProps } from './Touchable'
14
+ import { Icon } from './Icon'
15
+ import { ActivityIndicator } from './ActivityIndicator'
16
+ import { StyleSheet, TouchableOpacity } from 'react-native'
17
+
18
+ export type ButtonProps = Omit<TouchableProps, 'variants'> &
19
+ ComponentVariants<typeof ButtonStyles> & {
20
+ text?: string
21
+ rightIcon?: IconPlaceholder
22
+ icon?: IconPlaceholder
23
+ styles?: StylesOf<ButtonComposition>
24
+ loading?: boolean
25
+ debounce?: number
26
+ debugName: string
27
+ }
28
+
29
+ export const Button = forwardRef<TouchableOpacity, ButtonProps>((buttonProps, ref) => {
30
+ const {
31
+ variants = [],
32
+ children,
33
+ icon,
34
+ text,
35
+ loading,
36
+ styles = {},
37
+ onPress,
38
+ disabled,
39
+ rightIcon,
40
+ debounce = 600,
41
+ style,
42
+ ...props
43
+ } = buttonProps
44
+ const [pressed, setPressed] = React.useState(false)
45
+
46
+ const variantStyles = useDefaultComponentStyle('Button', {
47
+ variants,
48
+ transform: StyleSheet.flatten,
49
+ styles,
50
+ })
51
+
52
+ function handlePress() {
53
+ if (!pressed) {
54
+ setPressed(true)
55
+
56
+ setTimeout(() => setPressed(false), debounce)
57
+
58
+ onPress && onPress()
59
+ }
60
+ }
61
+
62
+ function getStyles(key: ButtonParts) {
63
+ return [
64
+ variantStyles[key],
65
+ key === 'wrapper' && style,
66
+ disabled && variantStyles[key + ':disabled'],
67
+ styles[key],
68
+ disabled && styles[key + ':disabled'],
69
+ ]
70
+ }
71
+
72
+ const iconStyle = getStyles('icon')
73
+
74
+ const leftIconStyle = StyleSheet.flatten([iconStyle, getStyles('leftIcon')])
75
+ const rightIconStyle = StyleSheet.flatten([iconStyle, getStyles('rightIcon')])
76
+
77
+ const hasText = !!(text || children)
78
+ return (
79
+ <Touchable
80
+ style={getStyles('wrapper')}
81
+ onPress={handlePress}
82
+ ref={ref}
83
+ disabled={disabled}
84
+ debugComponent={'Button'}
85
+ {...props}
86
+ >
87
+
88
+ {loading && <ActivityIndicator style={getStyles('loader')} />}
89
+ {!loading && <Icon name={icon} style={leftIconStyle} renderEmptySpace={hasText}/>}
90
+ {text ? <Text text={text} style={getStyles('text')} /> : null}
91
+ {children}
92
+ <Icon name={rightIcon} style={rightIconStyle} renderEmptySpace={hasText} />
93
+ </Touchable>
94
+ )
95
+ })
@@ -1,85 +1,85 @@
1
- import * as React from 'react'
2
- import {
3
- ComponentVariants,
4
- useDefaultComponentStyle,
5
- StylesOf,
6
- Form,
7
- useValidate,
8
- } from '@codeleap/common'
9
- import { ComponentPropsWithRef, forwardRef, ReactNode } from 'react'
10
- import { Switch as NativeCheckbox } from 'react-native'
11
- import { InputLabel, FormError } from '../TextInput'
12
- import { View } from '../View'
13
- import { Touchable } from '../Touchable'
14
- import {
15
- MobileCheckboxStyles as CheckboxStyles,
16
- MobileCheckboxComposition as CheckboxComposition,
17
- } from './styles'
18
- export * from './styles'
19
-
20
- type NativeCheckboxProps = Omit<
21
- ComponentPropsWithRef<typeof NativeCheckbox>,
22
- 'thumbColor' | 'trackColor'
23
- >
24
- type CheckboxProps = NativeCheckboxProps & {
25
- variants?: ComponentVariants<typeof CheckboxStyles>['variants']
26
- label?: ReactNode
27
- styles?: StylesOf<CheckboxComposition>
28
- validate?: Form.ValidatorFunctionWithoutForm | string
29
- required?: boolean
30
- }
31
-
32
- export const Checkbox = forwardRef<NativeCheckbox, CheckboxProps>(
33
- (checkboxProps, ref) => {
34
- const {
35
- variants = [],
36
- style = {},
37
- styles = {},
38
- label,
39
- value,
40
- onValueChange,
41
- validate,
42
- required,
43
- ...props
44
- } = checkboxProps
45
-
46
- const variantStyles = useDefaultComponentStyle('Checkbox', {
47
- // @ts-ignore
48
- variants,
49
- })
50
-
51
- const { error, showError } = useValidate(value, validate)
52
-
53
- function getStyles(key: CheckboxComposition) {
54
- return [
55
- variantStyles[key],
56
- variantStyles[key],
57
- key === 'wrapper' ? style : {},
58
- value ? variantStyles[key + ':checked'] : {},
59
- value ? styles[key + ':checked'] : {},
60
- showError ? variantStyles[key + ':error'] : {},
61
- showError ? styles[key + ':error'] : {},
62
- checkboxProps.disabled ? variantStyles[key + ':disabled'] : {},
63
- checkboxProps.disabled ? styles[key + ':disabled'] : {},
64
- ]
65
- }
66
-
67
- return (
68
- <View style={getStyles('wrapper')} {...props}>
69
- <Touchable
70
- debugName={`Set checkbox value to ${!value}`}
71
- style={getStyles('input')}
72
- onPress={() => onValueChange(!value)}
73
- >
74
- <View style={getStyles('checkmarkWrapper')}>
75
- <View style={getStyles('checkmark')} />
76
- </View>
77
- <View style={getStyles('labelWrapper')}>
78
- <InputLabel label={label} style={getStyles('label')} required={required}/>
79
- </View>
80
- </Touchable>
81
- <FormError message={error.message} style={getStyles('error')} />
82
- </View>
83
- )
84
- },
85
- )
1
+ import * as React from 'react'
2
+ import {
3
+ ComponentVariants,
4
+ useDefaultComponentStyle,
5
+ StylesOf,
6
+ Form,
7
+ useValidate,
8
+ } from '@codeleap/common'
9
+ import { ComponentPropsWithRef, forwardRef, ReactNode } from 'react'
10
+ import { Switch as NativeCheckbox } from 'react-native'
11
+ import { InputLabel, FormError } from '../TextInput'
12
+ import { View } from '../View'
13
+ import { Touchable } from '../Touchable'
14
+ import {
15
+ MobileCheckboxStyles as CheckboxStyles,
16
+ MobileCheckboxComposition as CheckboxComposition,
17
+ } from './styles'
18
+ export * from './styles'
19
+
20
+ type NativeCheckboxProps = Omit<
21
+ ComponentPropsWithRef<typeof NativeCheckbox>,
22
+ 'thumbColor' | 'trackColor'
23
+ >
24
+ type CheckboxProps = NativeCheckboxProps & {
25
+ variants?: ComponentVariants<typeof CheckboxStyles>['variants']
26
+ label?: ReactNode
27
+ styles?: StylesOf<CheckboxComposition>
28
+ validate?: Form.ValidatorFunctionWithoutForm | string
29
+ required?: boolean
30
+ }
31
+
32
+ export const Checkbox = forwardRef<NativeCheckbox, CheckboxProps>(
33
+ (checkboxProps, ref) => {
34
+ const {
35
+ variants = [],
36
+ style = {},
37
+ styles = {},
38
+ label,
39
+ value,
40
+ onValueChange,
41
+ validate,
42
+ required,
43
+ ...props
44
+ } = checkboxProps
45
+
46
+ const variantStyles = useDefaultComponentStyle('Checkbox', {
47
+ // @ts-ignore
48
+ variants,
49
+ })
50
+
51
+ const { error, showError } = useValidate(value, validate)
52
+
53
+ function getStyles(key: CheckboxComposition) {
54
+ return [
55
+ variantStyles[key],
56
+ variantStyles[key],
57
+ key === 'wrapper' ? style : {},
58
+ value ? variantStyles[key + ':checked'] : {},
59
+ value ? styles[key + ':checked'] : {},
60
+ showError ? variantStyles[key + ':error'] : {},
61
+ showError ? styles[key + ':error'] : {},
62
+ checkboxProps.disabled ? variantStyles[key + ':disabled'] : {},
63
+ checkboxProps.disabled ? styles[key + ':disabled'] : {},
64
+ ]
65
+ }
66
+
67
+ return (
68
+ <View style={getStyles('wrapper')} {...props}>
69
+ <Touchable
70
+ debugName={`Set checkbox value to ${!value}`}
71
+ style={getStyles('input')}
72
+ onPress={() => onValueChange(!value)}
73
+ >
74
+ <View style={getStyles('checkmarkWrapper')}>
75
+ <View style={getStyles('checkmark')} />
76
+ </View>
77
+ <View style={getStyles('labelWrapper')}>
78
+ <InputLabel label={label} style={getStyles('label')} required={required}/>
79
+ </View>
80
+ </Touchable>
81
+ <FormError message={error.message} style={getStyles('error')} />
82
+ </View>
83
+ )
84
+ },
85
+ )
@@ -1,76 +1,76 @@
1
- import { createDefaultVariantFactory, includePresets } from '@codeleap/common'
2
-
3
- type CheckboxParts =
4
- | 'wrapper'
5
- | 'label'
6
- | 'labelWrapper'
7
- | 'input'
8
- | 'checkmark'
9
- | 'checkmarkWrapper'
10
- | 'error'
11
-
12
- export type MobileCheckboxComposition =
13
- | CheckboxParts
14
- | `${CheckboxParts}:checked`
15
- | `${CheckboxParts}:disabled`
16
- | `${CheckboxParts}:error`
17
- const createCheckboxStyle =
18
- createDefaultVariantFactory<MobileCheckboxComposition>()
19
-
20
- const presets = includePresets((styles) => createCheckboxStyle(() => ({ wrapper: styles })),
21
- )
22
-
23
- export const MobileCheckboxStyles = {
24
- ...presets,
25
- default: createCheckboxStyle((theme) => {
26
- const size = theme.typography.baseFontSize * 1.2
27
-
28
- const markHeight = size * 0.5
29
- const markWidth = size * 0.25
30
-
31
- const translateX = -(markWidth / 2)
32
- const translateY = -(markHeight / 2)
33
- return {
34
- wrapper: {},
35
- input: {
36
- flexDirection: 'row',
37
- ...theme.presets.alignCenter,
38
- borderRadius: theme.borderRadius.small,
39
- },
40
- labelWrapper: {
41
- flex: 1,
42
- },
43
- label: {
44
- ...theme.spacing.marginLeft(0.5),
45
- },
46
-
47
- checkmark: {
48
- position: 'absolute',
49
- top: '40%',
50
- left: '50%',
51
-
52
- height: markHeight,
53
- width: markWidth,
54
- transform: [{ translateX }, { translateY }, { rotate: '45deg' }],
55
- },
56
- 'checkmark:checked': {
57
- ...theme.border.white({
58
- width: 2,
59
- directions: ['right', 'bottom'],
60
- }),
61
- },
62
- checkmarkWrapper: {
63
- position: 'relative',
64
- width: size,
65
- height: size,
66
- ...theme.border.neutral(1),
67
- },
68
- 'checkmarkWrapper:checked': {
69
- backgroundColor: theme.colors.primary,
70
- },
71
- error: {
72
- color: theme.colors.negative,
73
- },
74
- }
75
- }),
76
- }
1
+ import { createDefaultVariantFactory, includePresets } from '@codeleap/common'
2
+
3
+ type CheckboxParts =
4
+ | 'wrapper'
5
+ | 'label'
6
+ | 'labelWrapper'
7
+ | 'input'
8
+ | 'checkmark'
9
+ | 'checkmarkWrapper'
10
+ | 'error'
11
+
12
+ export type MobileCheckboxComposition =
13
+ | CheckboxParts
14
+ | `${CheckboxParts}:checked`
15
+ | `${CheckboxParts}:disabled`
16
+ | `${CheckboxParts}:error`
17
+ const createCheckboxStyle =
18
+ createDefaultVariantFactory<MobileCheckboxComposition>()
19
+
20
+ const presets = includePresets((styles) => createCheckboxStyle(() => ({ wrapper: styles })),
21
+ )
22
+
23
+ export const MobileCheckboxStyles = {
24
+ ...presets,
25
+ default: createCheckboxStyle((theme) => {
26
+ const size = theme.typography.baseFontSize * 1.2
27
+
28
+ const markHeight = size * 0.5
29
+ const markWidth = size * 0.25
30
+
31
+ const translateX = -(markWidth / 2)
32
+ const translateY = -(markHeight / 2)
33
+ return {
34
+ wrapper: {},
35
+ input: {
36
+ flexDirection: 'row',
37
+ ...theme.presets.alignCenter,
38
+ borderRadius: theme.borderRadius.small,
39
+ },
40
+ labelWrapper: {
41
+ flex: 1,
42
+ },
43
+ label: {
44
+ ...theme.spacing.marginLeft(0.5),
45
+ },
46
+
47
+ checkmark: {
48
+ position: 'absolute',
49
+ top: '40%',
50
+ left: '50%',
51
+
52
+ height: markHeight,
53
+ width: markWidth,
54
+ transform: [{ translateX }, { translateY }, { rotate: '45deg' }],
55
+ },
56
+ 'checkmark:checked': {
57
+ ...theme.border.white({
58
+ width: 2,
59
+ directions: ['right', 'bottom'],
60
+ }),
61
+ },
62
+ checkmarkWrapper: {
63
+ position: 'relative',
64
+ width: size,
65
+ height: size,
66
+ ...theme.border.neutral(1),
67
+ },
68
+ 'checkmarkWrapper:checked': {
69
+ backgroundColor: theme.colors.primary,
70
+ },
71
+ error: {
72
+ color: theme.colors.negative,
73
+ },
74
+ }
75
+ }),
76
+ }
@@ -1,58 +1,58 @@
1
- import React from 'react'
2
- import {
3
- ComponentVariants,
4
- ContentViewStyles,
5
- useDefaultComponentStyle,
6
- ViewComposition,
7
- } from '@codeleap/common'
8
- import { ViewProps, View } from './View'
9
- import { Text } from './Text'
10
- import { StylesOf } from '../types/utility'
11
- import { ActivityIndicator } from './ActivityIndicator'
12
- import { StyleSheet } from 'react-native'
13
-
14
- export type ContentViewProps = Omit<
15
- ViewProps,
16
- 'variants' | 'responsiveVariants'
17
- > & {
18
- placeholderMsg: string
19
- loading?: boolean
20
- styles?: StylesOf<ViewComposition>
21
- } & ComponentVariants<typeof ContentViewStyles>
22
-
23
- const WrapContent = ({ children, ...props }) => (
24
- <View {...props}>{children}</View>
25
- )
26
-
27
- export const ContentView: React.FC<ContentViewProps> = (rawProps) => {
28
- const { children, placeholderMsg, loading, variants, styles, ...props } =
29
- rawProps
30
-
31
- const variantStyle = useDefaultComponentStyle('ContentView', {
32
- variants,
33
- transform: StyleSheet.flatten,
34
- styles,
35
- })
36
-
37
- if (loading) {
38
- return (
39
- <WrapContent {...props} style={variantStyle.wrapper}>
40
- <ActivityIndicator styles={{ wrapper: variantStyle.loader }} />
41
- </WrapContent>
42
- )
43
- }
44
- const hasChildren = Object.keys(children || {}).length > 0
45
- if (hasChildren) {
46
- return (
47
- <WrapContent {...props} style={variantStyle.wrapper}>
48
- {children}
49
- </WrapContent>
50
- )
51
- }
52
-
53
- return (
54
- <WrapContent {...props} style={styles}>
55
- <Text text={placeholderMsg} />
56
- </WrapContent>
57
- )
58
- }
1
+ import React from 'react'
2
+ import {
3
+ ComponentVariants,
4
+ ContentViewStyles,
5
+ useDefaultComponentStyle,
6
+ ViewComposition,
7
+ } from '@codeleap/common'
8
+ import { ViewProps, View } from './View'
9
+ import { Text } from './Text'
10
+ import { StylesOf } from '../types/utility'
11
+ import { ActivityIndicator } from './ActivityIndicator'
12
+ import { StyleSheet } from 'react-native'
13
+
14
+ export type ContentViewProps = Omit<
15
+ ViewProps,
16
+ 'variants' | 'responsiveVariants'
17
+ > & {
18
+ placeholderMsg: string
19
+ loading?: boolean
20
+ styles?: StylesOf<ViewComposition>
21
+ } & ComponentVariants<typeof ContentViewStyles>
22
+
23
+ const WrapContent = ({ children, ...props }) => (
24
+ <View {...props}>{children}</View>
25
+ )
26
+
27
+ export const ContentView: React.FC<ContentViewProps> = (rawProps) => {
28
+ const { children, placeholderMsg, loading, variants, styles, ...props } =
29
+ rawProps
30
+
31
+ const variantStyle = useDefaultComponentStyle('ContentView', {
32
+ variants,
33
+ transform: StyleSheet.flatten,
34
+ styles,
35
+ })
36
+
37
+ if (loading) {
38
+ return (
39
+ <WrapContent {...props} style={variantStyle.wrapper}>
40
+ <ActivityIndicator styles={{ wrapper: variantStyle.loader }} />
41
+ </WrapContent>
42
+ )
43
+ }
44
+ const hasChildren = Object.keys(children || {}).length > 0
45
+ if (hasChildren) {
46
+ return (
47
+ <WrapContent {...props} style={variantStyle.wrapper}>
48
+ {children}
49
+ </WrapContent>
50
+ )
51
+ }
52
+
53
+ return (
54
+ <WrapContent {...props} style={styles}>
55
+ <Text text={placeholderMsg} />
56
+ </WrapContent>
57
+ )
58
+ }