bootstrap-rn 0.3.4 → 0.3.6

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 (172) hide show
  1. package/lib/commonjs/components/Image.js.map +1 -1
  2. package/lib/commonjs/components/ImageBackground.js.map +1 -1
  3. package/lib/commonjs/components/Text.js.map +1 -1
  4. package/lib/commonjs/components/dropdown/DropdownMenu.js.map +1 -1
  5. package/lib/commonjs/components/forms/RadioGroup.js.map +1 -1
  6. package/lib/commonjs/components/forms/internals/PickerNative.js.map +1 -1
  7. package/lib/commonjs/components/modal/Modal.js +1 -1
  8. package/lib/commonjs/components/modal/Modal.js.map +1 -1
  9. package/lib/commonjs/components/modal/ModalBody.js +1 -1
  10. package/lib/commonjs/components/modal/ModalBody.js.map +1 -1
  11. package/lib/commonjs/components/modal/ModalContext.js.map +1 -1
  12. package/lib/commonjs/components/nav/Nav.js.map +1 -1
  13. package/lib/commonjs/components/nav/NavContext.js.map +1 -1
  14. package/lib/commonjs/components/nav/TabContext.js.map +1 -1
  15. package/lib/commonjs/components/navbar/NavbarContext.js.map +1 -1
  16. package/lib/commonjs/components/offcanvas/OffcanvasBody.js.map +1 -1
  17. package/lib/commonjs/components/offcanvas/OffcanvasContext.js.map +1 -1
  18. package/lib/commonjs/components/popover/injectPopover.js.map +1 -1
  19. package/lib/commonjs/components/toasts/ToastContainer.js +3 -1
  20. package/lib/commonjs/components/toasts/ToastContainer.js.map +1 -1
  21. package/lib/commonjs/components/tooltip/injectTooltip.js +0 -3
  22. package/lib/commonjs/components/tooltip/injectTooltip.js.map +1 -1
  23. package/lib/commonjs/index.d.ts +47 -8
  24. package/lib/commonjs/index.js +0 -56
  25. package/lib/commonjs/index.js.map +1 -1
  26. package/lib/commonjs/style/StyleSheet.js +4 -2
  27. package/lib/commonjs/style/StyleSheet.js.map +1 -1
  28. package/lib/commonjs/style/makeUtilities.js.map +1 -1
  29. package/lib/commonjs/types.d.ts +6 -3
  30. package/lib/module/components/Image.js.map +1 -1
  31. package/lib/module/components/ImageBackground.js.map +1 -1
  32. package/lib/module/components/Text.js.map +1 -1
  33. package/lib/module/components/dropdown/DropdownMenu.js.map +1 -1
  34. package/lib/module/components/forms/RadioGroup.js.map +1 -1
  35. package/lib/module/components/forms/internals/PickerNative.js.map +1 -1
  36. package/lib/module/components/modal/Modal.js +1 -1
  37. package/lib/module/components/modal/Modal.js.map +1 -1
  38. package/lib/module/components/modal/ModalBody.js +1 -1
  39. package/lib/module/components/modal/ModalBody.js.map +1 -1
  40. package/lib/module/components/modal/ModalContext.js.map +1 -1
  41. package/lib/module/components/nav/Nav.js.map +1 -1
  42. package/lib/module/components/nav/NavContext.js.map +1 -1
  43. package/lib/module/components/nav/TabContext.js.map +1 -1
  44. package/lib/module/components/navbar/NavbarContext.js.map +1 -1
  45. package/lib/module/components/offcanvas/OffcanvasBody.js.map +1 -1
  46. package/lib/module/components/offcanvas/OffcanvasContext.js.map +1 -1
  47. package/lib/module/components/popover/injectPopover.js.map +1 -1
  48. package/lib/module/components/toasts/ToastContainer.js +3 -1
  49. package/lib/module/components/toasts/ToastContainer.js.map +1 -1
  50. package/lib/module/components/tooltip/injectTooltip.js +0 -3
  51. package/lib/module/components/tooltip/injectTooltip.js.map +1 -1
  52. package/lib/module/index.d.ts +47 -8
  53. package/lib/module/index.js +0 -7
  54. package/lib/module/index.js.map +1 -1
  55. package/lib/module/style/StyleSheet.js +4 -2
  56. package/lib/module/style/StyleSheet.js.map +1 -1
  57. package/lib/module/style/makeUtilities.js.map +1 -1
  58. package/lib/module/types.d.ts +6 -3
  59. package/lib/types/components/Image.d.ts.map +1 -1
  60. package/lib/types/components/ImageBackground.d.ts.map +1 -1
  61. package/lib/types/components/Text.d.ts +1 -1
  62. package/lib/types/components/Text.d.ts.map +1 -1
  63. package/lib/types/components/dropdown/Dropdown.d.ts +2 -11
  64. package/lib/types/components/dropdown/Dropdown.d.ts.map +1 -1
  65. package/lib/types/components/dropdown/DropdownContext.d.ts +2 -2
  66. package/lib/types/components/dropdown/DropdownContext.d.ts.map +1 -1
  67. package/lib/types/components/dropdown/DropdownMenu.d.ts +2 -2
  68. package/lib/types/components/dropdown/DropdownMenu.d.ts.map +1 -1
  69. package/lib/types/components/dropdown/DropdownToggle.d.ts +2 -2
  70. package/lib/types/components/dropdown/DropdownToggle.d.ts.map +1 -1
  71. package/lib/types/components/forms/Picker.d.ts +4 -4
  72. package/lib/types/components/forms/Picker.d.ts.map +1 -1
  73. package/lib/types/components/forms/PickerItem.d.ts +1 -1
  74. package/lib/types/components/forms/PickerItem.d.ts.map +1 -1
  75. package/lib/types/components/forms/Radio.d.ts +1 -1
  76. package/lib/types/components/forms/Radio.d.ts.map +1 -1
  77. package/lib/types/components/forms/RadioContext.d.ts +2 -2
  78. package/lib/types/components/forms/RadioContext.d.ts.map +1 -1
  79. package/lib/types/components/forms/RadioGroup.d.ts +2 -2
  80. package/lib/types/components/forms/RadioGroup.d.ts.map +1 -1
  81. package/lib/types/components/forms/internals/PickerNative.d.ts.map +1 -1
  82. package/lib/types/components/forms/internals/PickerNativeContext.d.ts +2 -2
  83. package/lib/types/components/forms/internals/PickerNativeContext.d.ts.map +1 -1
  84. package/lib/types/components/forms/internals/PickerNativeItem.d.ts +1 -1
  85. package/lib/types/components/forms/internals/PickerNativeItem.d.ts.map +1 -1
  86. package/lib/types/components/forms/internals/PickerWebItem.d.ts +1 -1
  87. package/lib/types/components/forms/internals/PickerWebItem.d.ts.map +1 -1
  88. package/lib/types/components/list-group/ListGroup.d.ts +1 -1
  89. package/lib/types/components/list-group/ListGroupItem.d.ts +13 -1
  90. package/lib/types/components/list-group/ListGroupItem.d.ts.map +1 -1
  91. package/lib/types/components/list-group/ListGroupItemAction.d.ts +2 -2
  92. package/lib/types/components/list-group/ListGroupItemAction.d.ts.map +1 -1
  93. package/lib/types/components/modal/Modal.d.ts +4 -7
  94. package/lib/types/components/modal/Modal.d.ts.map +1 -1
  95. package/lib/types/components/modal/ModalBody.d.ts +3 -6
  96. package/lib/types/components/modal/ModalBody.d.ts.map +1 -1
  97. package/lib/types/components/modal/ModalContext.d.ts +3 -3
  98. package/lib/types/components/modal/ModalContext.d.ts.map +1 -1
  99. package/lib/types/components/nav/Nav.d.ts +1 -3
  100. package/lib/types/components/nav/Nav.d.ts.map +1 -1
  101. package/lib/types/components/nav/NavContext.d.ts +3 -3
  102. package/lib/types/components/nav/NavContext.d.ts.map +1 -1
  103. package/lib/types/components/nav/Tab.d.ts +1 -1
  104. package/lib/types/components/nav/TabContext.d.ts +3 -3
  105. package/lib/types/components/nav/TabContext.d.ts.map +1 -1
  106. package/lib/types/components/navbar/Navbar.d.ts +1 -1
  107. package/lib/types/components/navbar/NavbarBrand.d.ts +2 -2
  108. package/lib/types/components/navbar/NavbarBrand.d.ts.map +1 -1
  109. package/lib/types/components/navbar/NavbarContext.d.ts +2 -2
  110. package/lib/types/components/navbar/NavbarContext.d.ts.map +1 -1
  111. package/lib/types/components/offcanvas/Offcanvas.d.ts +1 -3
  112. package/lib/types/components/offcanvas/Offcanvas.d.ts.map +1 -1
  113. package/lib/types/components/offcanvas/OffcanvasBody.d.ts +3 -4
  114. package/lib/types/components/offcanvas/OffcanvasBody.d.ts.map +1 -1
  115. package/lib/types/components/offcanvas/OffcanvasContext.d.ts +2 -2
  116. package/lib/types/components/offcanvas/OffcanvasContext.d.ts.map +1 -1
  117. package/lib/types/components/popover/injectPopover.d.ts +9 -12
  118. package/lib/types/components/popover/injectPopover.d.ts.map +1 -1
  119. package/lib/types/components/toasts/ToastContainer.d.ts +4 -2
  120. package/lib/types/components/toasts/ToastContainer.d.ts.map +1 -1
  121. package/lib/types/components/tooltip/injectTooltip.d.ts +8 -11
  122. package/lib/types/components/tooltip/injectTooltip.d.ts.map +1 -1
  123. package/lib/types/hooks/useBackground.native.d.ts +3 -1
  124. package/lib/types/hooks/useBackground.native.d.ts.map +1 -1
  125. package/lib/types/index.d.ts +47 -8
  126. package/lib/types/index.d.ts.map +1 -1
  127. package/lib/types/style/StyleSheet.d.ts +2 -3
  128. package/lib/types/style/StyleSheet.d.ts.map +1 -1
  129. package/lib/types/style/createStyle.d.ts +3 -1
  130. package/lib/types/style/createStyle.d.ts.map +1 -1
  131. package/lib/types/style/css.d.ts +3 -1
  132. package/lib/types/style/css.d.ts.map +1 -1
  133. package/lib/types/style/makeUtilities.d.ts +6 -2
  134. package/lib/types/style/makeUtilities.d.ts.map +1 -1
  135. package/lib/types/theme/variables.d.ts +3 -1
  136. package/lib/types/theme/variables.d.ts.map +1 -1
  137. package/lib/types/types.d.ts +6 -3
  138. package/lib/types/types.d.ts.map +1 -1
  139. package/package.json +80 -80
  140. package/src/components/Image.tsx +31 -27
  141. package/src/components/ImageBackground.tsx +48 -46
  142. package/src/components/Text.tsx +119 -117
  143. package/src/components/dropdown/DropdownContext.ts +2 -2
  144. package/src/components/dropdown/DropdownMenu.tsx +127 -125
  145. package/src/components/dropdown/DropdownToggle.ts +2 -2
  146. package/src/components/forms/Picker.tsx +191 -191
  147. package/src/components/forms/PickerItem.tsx +32 -32
  148. package/src/components/forms/Radio.tsx +37 -37
  149. package/src/components/forms/RadioContext.ts +13 -13
  150. package/src/components/forms/RadioGroup.tsx +42 -40
  151. package/src/components/forms/internals/PickerNative.tsx +193 -195
  152. package/src/components/forms/internals/PickerNativeContext.ts +14 -14
  153. package/src/components/forms/internals/PickerNativeItem.tsx +59 -59
  154. package/src/components/forms/internals/PickerWebItem.tsx +36 -36
  155. package/src/components/list-group/ListGroupItemAction.tsx +2 -2
  156. package/src/components/modal/Modal.tsx +234 -233
  157. package/src/components/modal/ModalBody.tsx +52 -56
  158. package/src/components/modal/ModalContext.ts +3 -3
  159. package/src/components/nav/Nav.tsx +4 -4
  160. package/src/components/nav/NavContext.ts +3 -3
  161. package/src/components/nav/TabContext.ts +3 -3
  162. package/src/components/navbar/NavbarBrand.tsx +2 -2
  163. package/src/components/navbar/NavbarContext.ts +2 -2
  164. package/src/components/offcanvas/OffcanvasBody.tsx +64 -66
  165. package/src/components/offcanvas/OffcanvasContext.ts +4 -2
  166. package/src/components/popover/injectPopover.tsx +97 -98
  167. package/src/components/toasts/ToastContainer.tsx +41 -39
  168. package/src/components/tooltip/injectTooltip.tsx +93 -96
  169. package/src/index.ts +242 -211
  170. package/src/style/StyleSheet.ts +149 -138
  171. package/src/style/makeUtilities.ts +79 -76
  172. package/src/types.ts +168 -162
package/src/types.ts CHANGED
@@ -1,162 +1,168 @@
1
- import {
2
- ViewStyle as BaseViewStyle,
3
- ImageStyle as BaseImageStyle,
4
- TextStyle as BaseTextStyle,
5
- GestureResponderEvent,
6
- Role,
7
- NativeSyntheticEvent,
8
- TextInputKeyPressEventData,
9
- } from 'react-native';
10
- import type { Placement, Axis, PlacementAxis } from '@react-types/overlays';
11
- import { BOOTSTRAP_RN_STYLE } from './style/createStyle';
12
-
13
- // Media
14
-
15
- export type Viewport = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl';
16
-
17
- export type MediaHandler = {
18
- up: (point: Viewport) => boolean;
19
- down: (point: Viewport) => boolean;
20
- only: (point: Viewport) => boolean;
21
- between: (lower: Viewport, upper: Viewport) => boolean;
22
- };
23
-
24
- // Styles
25
-
26
- export type BaseStyle = BaseViewStyle | BaseImageStyle | BaseTextStyle;
27
-
28
- export type InteractionState = {
29
- interaction?: {
30
- hover?: boolean;
31
- focus: boolean;
32
- focusVisible: boolean;
33
- active?: boolean;
34
- };
35
- media: MediaHandler;
36
- };
37
-
38
- // Ref: https://github.com/facebook/react-native/blob/main/packages/react-native/Libraries/StyleSheet/StyleSheet.d.ts
39
- type Falsy = undefined | null | undefined | false | '';
40
- interface RecursiveArray<T>
41
- extends Array<T | ReadonlyArray<T> | RecursiveArray<T>> {}
42
- type RegisteredStyle<T> = number & { __registeredStyleBrand: T };
43
-
44
- export type SpecialInteractionStyle<T> = {
45
- (state: InteractionState): [T[], T[]];
46
- $$typeof: typeof BOOTSTRAP_RN_STYLE;
47
- };
48
-
49
- export type ExtendedStyleType<T> =
50
- | T
51
- | SpecialInteractionStyle<T>
52
- | ((state: InteractionState) => T);
53
-
54
- export type StyleProp<T> =
55
- | ExtendedStyleType<T>
56
- | RegisteredStyle<T>
57
- | RecursiveArray<ExtendedStyleType<T> | RegisteredStyle<T> | Falsy>
58
- | Falsy;
59
-
60
- export type ExtendedViewStyle = ExtendedStyleType<BaseViewStyle>;
61
-
62
- export type ExtendedImageStyle = ExtendedStyleType<BaseImageStyle>;
63
-
64
- export type ExtendedTextStyle = ExtendedStyleType<BaseTextStyle>;
65
-
66
- export type ExtendedStyle =
67
- | ExtendedViewStyle
68
- | ExtendedImageStyle
69
- | ExtendedTextStyle;
70
-
71
- export type StyleName = string;
72
-
73
- // Theme
74
-
75
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
76
- export type StyleValue = any;
77
-
78
- export type ThemeVariables = {
79
- [key: string]: StyleValue;
80
- };
81
-
82
- export type StyleUtility = {
83
- responsive?: boolean;
84
- print?: boolean;
85
- rfs?: boolean;
86
- property: string;
87
- class?: string;
88
- values: Record<string, string | ((t: ThemeVariables) => StyleValue)>;
89
- };
90
-
91
- export type FormValidationState = (t: ThemeVariables) => {
92
- color: string;
93
- icon: string;
94
- };
95
-
96
- // Overlay
97
-
98
- export type Trigger =
99
- | 'press'
100
- | 'hover'
101
- | 'focus'
102
- | 'manual'
103
- | 'press hover'
104
- | 'hover press'
105
- | 'hover focus'
106
- | 'focus hover'
107
- | 'press focus'
108
- | 'focus press';
109
-
110
- export { Placement, Axis, PlacementAxis };
111
-
112
- export type TransformedPlacementAxis =
113
- | 'top'
114
- | 'bottom'
115
- | 'end'
116
- | 'start'
117
- | 'center';
118
-
119
- // Modifiers
120
-
121
- // TODO: Modifiers can have different props based on the implementation. It would be better to define modifiers on the application.
122
-
123
- type To =
124
- | string
125
- | Partial<{
126
- pathname: string;
127
- search: string;
128
- hash: string;
129
- }>;
130
-
131
- type External =
132
- | boolean
133
- | {
134
- download: boolean;
135
- target: string;
136
- rel: string;
137
- };
138
-
139
- export type UseTabbableProps = {
140
- to?: To;
141
- external?: External;
142
- end?: boolean;
143
- caseSensitive?: boolean;
144
- active?: boolean;
145
- };
146
-
147
- export type UseActionableProps = {
148
- to?: To;
149
- external?: External;
150
- relative?: 'path' | 'route';
151
- replace?: boolean;
152
- preventScrollReset?: boolean;
153
- reloadDocument?: boolean;
154
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
155
- state?: any;
156
- onPress?: null | ((event: GestureResponderEvent) => void);
157
- role?: Role;
158
- };
159
-
160
- export type UseFormFieldProps = {
161
- onKeyPress?: (e: NativeSyntheticEvent<TextInputKeyPressEventData>) => void;
162
- };
1
+ import {
2
+ ViewStyle as BaseViewStyle,
3
+ ImageStyle as TempImageStyle,
4
+ TextStyle as BaseTextStyle,
5
+ GestureResponderEvent,
6
+ Role,
7
+ NativeSyntheticEvent,
8
+ TextInputKeyPressEventData,
9
+ } from 'react-native';
10
+ import type { Placement, Axis, PlacementAxis } from '@react-types/overlays';
11
+ import { BOOTSTRAP_RN_STYLE } from './style/createStyle';
12
+
13
+ // Media
14
+
15
+ export type Viewport = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl';
16
+
17
+ export type MediaHandler = {
18
+ up: (point: Viewport) => boolean;
19
+ down: (point: Viewport) => boolean;
20
+ only: (point: Viewport) => boolean;
21
+ between: (lower: Viewport, upper: Viewport) => boolean;
22
+ };
23
+
24
+ // Styles
25
+
26
+ // Workaround: Add scroll to possible overflow values of ImageStyle to resolve conflict between
27
+ // ImageStyle and ViewStyle.
28
+ type BaseImageStyle = Omit<TempImageStyle, 'overflow'> & {
29
+ overflow?: 'visible' | 'hidden' | 'scroll';
30
+ };
31
+
32
+ export type BaseStyle = BaseViewStyle | BaseImageStyle | BaseTextStyle;
33
+
34
+ export type InteractionState = {
35
+ interaction?: {
36
+ hover?: boolean;
37
+ focus: boolean;
38
+ focusVisible: boolean;
39
+ active?: boolean;
40
+ };
41
+ media: MediaHandler;
42
+ };
43
+
44
+ // Ref: https://github.com/facebook/react-native/blob/main/packages/react-native/Libraries/StyleSheet/StyleSheet.d.ts
45
+ type Falsy = undefined | null | undefined | false | '';
46
+ interface RecursiveArray<T>
47
+ extends Array<T | ReadonlyArray<T> | RecursiveArray<T>> {}
48
+ type RegisteredStyle<T> = number & { __registeredStyleBrand: T };
49
+
50
+ export type SpecialInteractionStyle<T> = {
51
+ (state: InteractionState): [T[], T[]];
52
+ $$typeof: typeof BOOTSTRAP_RN_STYLE;
53
+ };
54
+
55
+ export type ExtendedStyleType<T> =
56
+ | T
57
+ | SpecialInteractionStyle<T>
58
+ | ((state: InteractionState) => T);
59
+
60
+ export type StyleProp<T> =
61
+ | ExtendedStyleType<T>
62
+ | RegisteredStyle<T>
63
+ | RecursiveArray<ExtendedStyleType<T> | RegisteredStyle<T> | Falsy>
64
+ | Falsy;
65
+
66
+ export type ExtendedViewStyle = ExtendedStyleType<BaseViewStyle>;
67
+
68
+ export type ExtendedImageStyle = ExtendedStyleType<BaseImageStyle>;
69
+
70
+ export type ExtendedTextStyle = ExtendedStyleType<BaseTextStyle>;
71
+
72
+ export type ExtendedStyle =
73
+ | ExtendedViewStyle
74
+ | ExtendedImageStyle
75
+ | ExtendedTextStyle;
76
+
77
+ export type StyleName = string;
78
+
79
+ // Theme
80
+
81
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
82
+ export type StyleValue = any;
83
+
84
+ export type ThemeVariables = {
85
+ [key: string]: StyleValue;
86
+ };
87
+
88
+ export type StyleUtility = {
89
+ responsive?: boolean;
90
+ print?: boolean;
91
+ rfs?: boolean;
92
+ property: string;
93
+ class?: string;
94
+ values: Record<string, string | ((t: ThemeVariables) => StyleValue)>;
95
+ };
96
+
97
+ export type FormValidationState = (t: ThemeVariables) => {
98
+ color: string;
99
+ icon: string;
100
+ };
101
+
102
+ // Overlay
103
+
104
+ export type Trigger =
105
+ | 'press'
106
+ | 'hover'
107
+ | 'focus'
108
+ | 'manual'
109
+ | 'press hover'
110
+ | 'hover press'
111
+ | 'hover focus'
112
+ | 'focus hover'
113
+ | 'press focus'
114
+ | 'focus press';
115
+
116
+ export { Placement, Axis, PlacementAxis };
117
+
118
+ export type TransformedPlacementAxis =
119
+ | 'top'
120
+ | 'bottom'
121
+ | 'end'
122
+ | 'start'
123
+ | 'center';
124
+
125
+ // Modifiers
126
+
127
+ // TODO: Modifiers can have different props based on the implementation. It would be better to define modifiers on the application.
128
+
129
+ type To =
130
+ | string
131
+ | Partial<{
132
+ pathname: string;
133
+ search: string;
134
+ hash: string;
135
+ }>;
136
+
137
+ type External =
138
+ | boolean
139
+ | Partial<{
140
+ download: boolean;
141
+ target: string;
142
+ rel: string;
143
+ }>;
144
+
145
+ export type UseTabbableProps = {
146
+ to?: To;
147
+ external?: External;
148
+ end?: boolean;
149
+ caseSensitive?: boolean;
150
+ active?: boolean;
151
+ };
152
+
153
+ export type UseActionableProps = {
154
+ to?: To;
155
+ external?: External;
156
+ relative?: 'path' | 'route';
157
+ replace?: boolean;
158
+ preventScrollReset?: boolean;
159
+ reloadDocument?: boolean;
160
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
161
+ state?: any;
162
+ onPress?: null | ((event: GestureResponderEvent) => void);
163
+ role?: Role;
164
+ };
165
+
166
+ export type UseFormFieldProps = {
167
+ onKeyPress?: (e: NativeSyntheticEvent<TextInputKeyPressEventData>) => void;
168
+ };