react-native-richify 1.0.0 → 1.0.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 (159) hide show
  1. package/package.json +11 -10
  2. package/src/components/OverlayText.d.ts +1 -1
  3. package/src/components/OverlayText.tsx +3 -3
  4. package/src/components/RichTextInput.d.ts +1 -1
  5. package/src/components/RichTextInput.tsx +6 -6
  6. package/src/components/Toolbar.tsx +3 -3
  7. package/src/components/ToolbarButton.tsx +7 -7
  8. package/src/constants/defaultStyles.ts +1 -1
  9. package/src/context/RichTextContext.d.ts +2 -2
  10. package/src/context/RichTextContext.tsx +3 -3
  11. package/src/hooks/useFormatting.d.ts +2 -2
  12. package/src/hooks/useFormatting.ts +2 -2
  13. package/src/hooks/useRichText.d.ts +1 -1
  14. package/src/hooks/useRichText.ts +5 -5
  15. package/src/hooks/useSelection.d.ts +1 -1
  16. package/src/hooks/useSelection.ts +1 -1
  17. package/src/index.d.ts +15 -15
  18. package/src/index.ts +15 -15
  19. package/lib/commonjs/components/OverlayText.d.js +0 -6
  20. package/lib/commonjs/components/OverlayText.d.js.map +0 -1
  21. package/lib/commonjs/components/OverlayText.js +0 -45
  22. package/lib/commonjs/components/OverlayText.js.map +0 -1
  23. package/lib/commonjs/components/RichTextInput.d.js +0 -6
  24. package/lib/commonjs/components/RichTextInput.d.js.map +0 -1
  25. package/lib/commonjs/components/RichTextInput.js +0 -160
  26. package/lib/commonjs/components/RichTextInput.js.map +0 -1
  27. package/lib/commonjs/components/Toolbar.d.js +0 -6
  28. package/lib/commonjs/components/Toolbar.d.js.map +0 -1
  29. package/lib/commonjs/components/Toolbar.js +0 -99
  30. package/lib/commonjs/components/Toolbar.js.map +0 -1
  31. package/lib/commonjs/components/ToolbarButton.d.js +0 -6
  32. package/lib/commonjs/components/ToolbarButton.d.js.map +0 -1
  33. package/lib/commonjs/components/ToolbarButton.js +0 -63
  34. package/lib/commonjs/components/ToolbarButton.js.map +0 -1
  35. package/lib/commonjs/constants/defaultStyles.d.js +0 -6
  36. package/lib/commonjs/constants/defaultStyles.d.js.map +0 -1
  37. package/lib/commonjs/constants/defaultStyles.js +0 -172
  38. package/lib/commonjs/constants/defaultStyles.js.map +0 -1
  39. package/lib/commonjs/context/RichTextContext.d.js +0 -6
  40. package/lib/commonjs/context/RichTextContext.d.js.map +0 -1
  41. package/lib/commonjs/context/RichTextContext.js +0 -61
  42. package/lib/commonjs/context/RichTextContext.js.map +0 -1
  43. package/lib/commonjs/hooks/useFormatting.d.js +0 -6
  44. package/lib/commonjs/hooks/useFormatting.d.js.map +0 -1
  45. package/lib/commonjs/hooks/useFormatting.js +0 -82
  46. package/lib/commonjs/hooks/useFormatting.js.map +0 -1
  47. package/lib/commonjs/hooks/useRichText.d.js +0 -6
  48. package/lib/commonjs/hooks/useRichText.d.js.map +0 -1
  49. package/lib/commonjs/hooks/useRichText.js +0 -136
  50. package/lib/commonjs/hooks/useRichText.js.map +0 -1
  51. package/lib/commonjs/hooks/useSelection.d.js +0 -6
  52. package/lib/commonjs/hooks/useSelection.d.js.map +0 -1
  53. package/lib/commonjs/hooks/useSelection.js +0 -39
  54. package/lib/commonjs/hooks/useSelection.js.map +0 -1
  55. package/lib/commonjs/index.d.js +0 -186
  56. package/lib/commonjs/index.d.js.map +0 -1
  57. package/lib/commonjs/index.js +0 -186
  58. package/lib/commonjs/index.js.map +0 -1
  59. package/lib/commonjs/package.json +0 -1
  60. package/lib/commonjs/types/index.d.js +0 -6
  61. package/lib/commonjs/types/index.d.js.map +0 -1
  62. package/lib/commonjs/types/index.js +0 -6
  63. package/lib/commonjs/types/index.js.map +0 -1
  64. package/lib/commonjs/utils/formatter.d.js +0 -13
  65. package/lib/commonjs/utils/formatter.d.js.map +0 -1
  66. package/lib/commonjs/utils/formatter.js +0 -229
  67. package/lib/commonjs/utils/formatter.js.map +0 -1
  68. package/lib/commonjs/utils/parser.d.js +0 -6
  69. package/lib/commonjs/utils/parser.d.js.map +0 -1
  70. package/lib/commonjs/utils/parser.js +0 -221
  71. package/lib/commonjs/utils/parser.js.map +0 -1
  72. package/lib/commonjs/utils/styleMapper.d.js +0 -6
  73. package/lib/commonjs/utils/styleMapper.d.js.map +0 -1
  74. package/lib/commonjs/utils/styleMapper.js +0 -87
  75. package/lib/commonjs/utils/styleMapper.js.map +0 -1
  76. package/lib/module/components/OverlayText.d.js +0 -4
  77. package/lib/module/components/OverlayText.d.js.map +0 -1
  78. package/lib/module/components/OverlayText.js +0 -41
  79. package/lib/module/components/OverlayText.js.map +0 -1
  80. package/lib/module/components/RichTextInput.d.js +0 -4
  81. package/lib/module/components/RichTextInput.d.js.map +0 -1
  82. package/lib/module/components/RichTextInput.js +0 -155
  83. package/lib/module/components/RichTextInput.js.map +0 -1
  84. package/lib/module/components/Toolbar.d.js +0 -4
  85. package/lib/module/components/Toolbar.d.js.map +0 -1
  86. package/lib/module/components/Toolbar.js +0 -95
  87. package/lib/module/components/Toolbar.js.map +0 -1
  88. package/lib/module/components/ToolbarButton.d.js +0 -4
  89. package/lib/module/components/ToolbarButton.d.js.map +0 -1
  90. package/lib/module/components/ToolbarButton.js +0 -59
  91. package/lib/module/components/ToolbarButton.js.map +0 -1
  92. package/lib/module/constants/defaultStyles.d.js +0 -4
  93. package/lib/module/constants/defaultStyles.d.js.map +0 -1
  94. package/lib/module/constants/defaultStyles.js +0 -168
  95. package/lib/module/constants/defaultStyles.js.map +0 -1
  96. package/lib/module/context/RichTextContext.d.js +0 -4
  97. package/lib/module/context/RichTextContext.d.js.map +0 -1
  98. package/lib/module/context/RichTextContext.js +0 -55
  99. package/lib/module/context/RichTextContext.js.map +0 -1
  100. package/lib/module/hooks/useFormatting.d.js +0 -11
  101. package/lib/module/hooks/useFormatting.d.js.map +0 -1
  102. package/lib/module/hooks/useFormatting.js +0 -78
  103. package/lib/module/hooks/useFormatting.js.map +0 -1
  104. package/lib/module/hooks/useRichText.d.js +0 -4
  105. package/lib/module/hooks/useRichText.d.js.map +0 -1
  106. package/lib/module/hooks/useRichText.js +0 -132
  107. package/lib/module/hooks/useRichText.js.map +0 -1
  108. package/lib/module/hooks/useSelection.d.js +0 -4
  109. package/lib/module/hooks/useSelection.d.js.map +0 -1
  110. package/lib/module/hooks/useSelection.js +0 -35
  111. package/lib/module/hooks/useSelection.js.map +0 -1
  112. package/lib/module/index.d.js +0 -15
  113. package/lib/module/index.d.js.map +0 -1
  114. package/lib/module/index.js +0 -25
  115. package/lib/module/index.js.map +0 -1
  116. package/lib/module/types/index.d.js +0 -4
  117. package/lib/module/types/index.d.js.map +0 -1
  118. package/lib/module/types/index.js +0 -4
  119. package/lib/module/types/index.js.map +0 -1
  120. package/lib/module/utils/formatter.d.js +0 -30
  121. package/lib/module/utils/formatter.d.js.map +0 -1
  122. package/lib/module/utils/formatter.js +0 -217
  123. package/lib/module/utils/formatter.js.map +0 -1
  124. package/lib/module/utils/parser.d.js +0 -4
  125. package/lib/module/utils/parser.d.js.map +0 -1
  126. package/lib/module/utils/parser.js +0 -211
  127. package/lib/module/utils/parser.js.map +0 -1
  128. package/lib/module/utils/styleMapper.d.js +0 -4
  129. package/lib/module/utils/styleMapper.d.js.map +0 -1
  130. package/lib/module/utils/styleMapper.js +0 -82
  131. package/lib/module/utils/styleMapper.js.map +0 -1
  132. package/lib/typescript/src/components/OverlayText.d.ts +0 -11
  133. package/lib/typescript/src/components/OverlayText.d.ts.map +0 -1
  134. package/lib/typescript/src/components/RichTextInput.d.ts +0 -21
  135. package/lib/typescript/src/components/RichTextInput.d.ts.map +0 -1
  136. package/lib/typescript/src/components/Toolbar.d.ts +0 -13
  137. package/lib/typescript/src/components/Toolbar.d.ts.map +0 -1
  138. package/lib/typescript/src/components/ToolbarButton.d.ts +0 -8
  139. package/lib/typescript/src/components/ToolbarButton.d.ts.map +0 -1
  140. package/lib/typescript/src/constants/defaultStyles.d.ts +0 -46
  141. package/lib/typescript/src/constants/defaultStyles.d.ts.map +0 -1
  142. package/lib/typescript/src/context/RichTextContext.d.ts +0 -31
  143. package/lib/typescript/src/context/RichTextContext.d.ts.map +0 -1
  144. package/lib/typescript/src/hooks/useFormatting.d.ts +0 -26
  145. package/lib/typescript/src/hooks/useFormatting.d.ts.map +0 -1
  146. package/lib/typescript/src/hooks/useRichText.d.ts +0 -17
  147. package/lib/typescript/src/hooks/useRichText.d.ts.map +0 -1
  148. package/lib/typescript/src/hooks/useSelection.d.ts +0 -14
  149. package/lib/typescript/src/hooks/useSelection.d.ts.map +0 -1
  150. package/lib/typescript/src/index.d.ts +0 -16
  151. package/lib/typescript/src/index.d.ts.map +0 -1
  152. package/lib/typescript/src/types/index.d.ts +0 -245
  153. package/lib/typescript/src/types/index.d.ts.map +0 -1
  154. package/lib/typescript/src/utils/formatter.d.ts +0 -29
  155. package/lib/typescript/src/utils/formatter.d.ts.map +0 -1
  156. package/lib/typescript/src/utils/parser.d.ts +0 -46
  157. package/lib/typescript/src/utils/parser.d.ts.map +0 -1
  158. package/lib/typescript/src/utils/styleMapper.d.ts +0 -16
  159. package/lib/typescript/src/utils/styleMapper.d.ts.map +0 -1
@@ -1,155 +0,0 @@
1
- "use strict";
2
-
3
- import React, { useEffect, useCallback } from 'react';
4
- import { View, TextInput, StyleSheet } from 'react-native';
5
- import { DEFAULT_THEME } from '@/constants/defaultStyles';
6
- import { segmentsToPlainText } from '@/utils/parser';
7
- import { useRichText } from '@/hooks/useRichText';
8
- import { OverlayText } from '@/components/OverlayText';
9
- import { Toolbar } from '@/components/Toolbar';
10
-
11
- /**
12
- * RichTextInput — The main rich text editor component.
13
- *
14
- * Uses the Overlay Technique:
15
- * - A transparent `TextInput` on top captures user input and selection
16
- * - A styled `<Text>` layer behind it renders the formatted content
17
- * - Both share identical font metrics for pixel-perfect alignment
18
- *
19
- * @example
20
- * ```tsx
21
- * <RichTextInput
22
- * placeholder="Start typing..."
23
- * showToolbar
24
- * onChangeSegments={(segments) => console.log(segments)}
25
- * />
26
- * ```
27
- */
28
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
29
- export const RichTextInput = ({
30
- initialSegments,
31
- onChangeSegments,
32
- onChangeText,
33
- placeholder = 'Start typing...',
34
- editable = true,
35
- maxLength,
36
- showToolbar = true,
37
- toolbarPosition = 'top',
38
- toolbarItems,
39
- theme,
40
- multiline = true,
41
- minHeight = 120,
42
- maxHeight,
43
- autoFocus = false,
44
- textInputProps,
45
- renderToolbar,
46
- onReady
47
- }) => {
48
- const resolvedTheme = theme ?? DEFAULT_THEME;
49
- const {
50
- state,
51
- actions
52
- } = useRichText({
53
- initialSegments,
54
- onChangeSegments,
55
- onChangeText
56
- });
57
-
58
- // Expose actions via onReady callback
59
- useEffect(() => {
60
- onReady?.(actions);
61
- }, [onReady, actions]);
62
-
63
- // Build plain text for the TextInput value
64
- const plainText = segmentsToPlainText(state.segments);
65
-
66
- // Handle selection change from TextInput
67
- const onSelectionChange = useCallback(e => {
68
- const {
69
- start,
70
- end
71
- } = e.nativeEvent.selection;
72
- actions.handleSelectionChange({
73
- start,
74
- end
75
- });
76
- }, [actions]);
77
-
78
- // Container style
79
- const containerStyle = [resolvedTheme.containerStyle ?? DEFAULT_THEME.containerStyle];
80
-
81
- // Input area style
82
- const inputAreaStyle = [styles.inputArea, {
83
- minHeight
84
- }, maxHeight ? {
85
- maxHeight
86
- } : undefined];
87
-
88
- // Input style
89
- const inputStyle = [styles.textInput, resolvedTheme.inputStyle ?? DEFAULT_THEME.inputStyle];
90
-
91
- // Toolbar component
92
- const toolbarComponent = showToolbar ? /*#__PURE__*/_jsx(Toolbar, {
93
- actions: actions,
94
- state: state,
95
- items: toolbarItems,
96
- theme: resolvedTheme,
97
- renderToolbar: renderToolbar
98
- }) : null;
99
-
100
- // Toolbar border
101
- const toolbarBorderStyle = toolbarPosition === 'top' ? {
102
- borderBottomWidth: 1,
103
- borderBottomColor: resolvedTheme.colors?.toolbarBorder ?? DEFAULT_THEME.colors?.toolbarBorder
104
- } : {
105
- borderTopWidth: 1,
106
- borderTopColor: resolvedTheme.colors?.toolbarBorder ?? DEFAULT_THEME.colors?.toolbarBorder
107
- };
108
- return /*#__PURE__*/_jsxs(View, {
109
- style: containerStyle,
110
- children: [toolbarPosition === 'top' && toolbarComponent && /*#__PURE__*/_jsx(View, {
111
- style: toolbarBorderStyle,
112
- children: toolbarComponent
113
- }), /*#__PURE__*/_jsxs(View, {
114
- style: inputAreaStyle,
115
- children: [/*#__PURE__*/_jsx(OverlayText, {
116
- segments: state.segments,
117
- baseTextStyle: resolvedTheme.baseTextStyle,
118
- theme: resolvedTheme
119
- }), /*#__PURE__*/_jsx(TextInput, {
120
- ...textInputProps,
121
- style: inputStyle,
122
- value: plainText,
123
- onChangeText: actions.handleTextChange,
124
- onSelectionChange: onSelectionChange,
125
- multiline: multiline,
126
- placeholder: placeholder,
127
- placeholderTextColor: resolvedTheme.colors?.placeholder ?? DEFAULT_THEME.colors?.placeholder,
128
- editable: editable,
129
- maxLength: maxLength,
130
- autoFocus: autoFocus,
131
- selectionColor: resolvedTheme.colors?.cursor ?? DEFAULT_THEME.colors?.cursor,
132
- textAlignVertical: "top",
133
- scrollEnabled: true
134
- })]
135
- }), toolbarPosition === 'bottom' && toolbarComponent && /*#__PURE__*/_jsx(View, {
136
- style: toolbarBorderStyle,
137
- children: toolbarComponent
138
- })]
139
- });
140
- };
141
- RichTextInput.displayName = 'RichTextInput';
142
- const styles = StyleSheet.create({
143
- inputArea: {
144
- position: 'relative'
145
- },
146
- textInput: {
147
- // The TextInput must be transparent so the overlay text shows through.
148
- // Only the caret/cursor and selection highlight are visible.
149
- color: 'transparent',
150
- // Ensure it matches the overlay text positioning exactly.
151
- position: 'relative',
152
- zIndex: 1
153
- }
154
- });
155
- //# sourceMappingURL=RichTextInput.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","useEffect","useCallback","View","TextInput","StyleSheet","DEFAULT_THEME","segmentsToPlainText","useRichText","OverlayText","Toolbar","jsx","_jsx","jsxs","_jsxs","RichTextInput","initialSegments","onChangeSegments","onChangeText","placeholder","editable","maxLength","showToolbar","toolbarPosition","toolbarItems","theme","multiline","minHeight","maxHeight","autoFocus","textInputProps","renderToolbar","onReady","resolvedTheme","state","actions","plainText","segments","onSelectionChange","e","start","end","nativeEvent","selection","handleSelectionChange","containerStyle","inputAreaStyle","styles","inputArea","undefined","inputStyle","textInput","toolbarComponent","items","toolbarBorderStyle","borderBottomWidth","borderBottomColor","colors","toolbarBorder","borderTopWidth","borderTopColor","style","children","baseTextStyle","value","handleTextChange","placeholderTextColor","selectionColor","cursor","textAlignVertical","scrollEnabled","displayName","create","position","color","zIndex"],"sourceRoot":"..\\..\\..\\src","sources":["components/RichTextInput.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,SAAS,EAAEC,WAAW,QAAQ,OAAO;AACrD,SACEC,IAAI,EACJC,SAAS,EACTC,UAAU,QAGL,cAAc;AAErB,SAASC,aAAa,QAAQ,2BAA2B;AACzD,SAASC,mBAAmB,QAAQ,gBAAgB;AACpD,SAASC,WAAW,QAAQ,qBAAqB;AACjD,SAASC,WAAW,QAAQ,0BAA0B;AACtD,SAASC,OAAO,QAAQ,sBAAsB;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAhBA,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAiBA,OAAO,MAAMC,aAA2C,GAAGA,CAAC;EAC1DC,eAAe;EACfC,gBAAgB;EAChBC,YAAY;EACZC,WAAW,GAAG,iBAAiB;EAC/BC,QAAQ,GAAG,IAAI;EACfC,SAAS;EACTC,WAAW,GAAG,IAAI;EAClBC,eAAe,GAAG,KAAK;EACvBC,YAAY;EACZC,KAAK;EACLC,SAAS,GAAG,IAAI;EAChBC,SAAS,GAAG,GAAG;EACfC,SAAS;EACTC,SAAS,GAAG,KAAK;EACjBC,cAAc;EACdC,aAAa;EACbC;AACF,CAAC,KAAK;EACJ,MAAMC,aAAa,GAAGR,KAAK,IAAInB,aAAa;EAE5C,MAAM;IAAE4B,KAAK;IAAEC;EAAQ,CAAC,GAAG3B,WAAW,CAAC;IACrCQ,eAAe;IACfC,gBAAgB;IAChBC;EACF,CAAC,CAAC;;EAEF;EACAjB,SAAS,CAAC,MAAM;IACd+B,OAAO,GAAGG,OAAO,CAAC;EACpB,CAAC,EAAE,CAACH,OAAO,EAAEG,OAAO,CAAC,CAAC;;EAEtB;EACA,MAAMC,SAAS,GAAG7B,mBAAmB,CAAC2B,KAAK,CAACG,QAAQ,CAAC;;EAErD;EACA,MAAMC,iBAAiB,GAAGpC,WAAW,CAClCqC,CAA0D,IAAK;IAC9D,MAAM;MAAEC,KAAK;MAAEC;IAAI,CAAC,GAAGF,CAAC,CAACG,WAAW,CAACC,SAAS;IAC9CR,OAAO,CAACS,qBAAqB,CAAC;MAAEJ,KAAK;MAAEC;IAAI,CAAC,CAAC;EAC/C,CAAC,EACD,CAACN,OAAO,CACV,CAAC;;EAED;EACA,MAAMU,cAAc,GAAG,CACrBZ,aAAa,CAACY,cAAc,IAAIvC,aAAa,CAACuC,cAAc,CAC7D;;EAED;EACA,MAAMC,cAAc,GAAG,CACrBC,MAAM,CAACC,SAAS,EAChB;IAAErB;EAAU,CAAC,EACbC,SAAS,GAAG;IAAEA;EAAU,CAAC,GAAGqB,SAAS,CACtC;;EAED;EACA,MAAMC,UAAU,GAAG,CACjBH,MAAM,CAACI,SAAS,EAChBlB,aAAa,CAACiB,UAAU,IAAI5C,aAAa,CAAC4C,UAAU,CACrD;;EAED;EACA,MAAME,gBAAgB,GAAG9B,WAAW,gBAClCV,IAAA,CAACF,OAAO;IACNyB,OAAO,EAAEA,OAAQ;IACjBD,KAAK,EAAEA,KAAM;IACbmB,KAAK,EAAE7B,YAAa;IACpBC,KAAK,EAAEQ,aAAc;IACrBF,aAAa,EAAEA;EAAc,CAC9B,CAAC,GACA,IAAI;;EAER;EACA,MAAMuB,kBAAkB,GACtB/B,eAAe,KAAK,KAAK,GACrB;IAAEgC,iBAAiB,EAAE,CAAC;IAAEC,iBAAiB,EAAEvB,aAAa,CAACwB,MAAM,EAAEC,aAAa,IAAIpD,aAAa,CAACmD,MAAM,EAAEC;EAAc,CAAC,GACvH;IAAEC,cAAc,EAAE,CAAC;IAAEC,cAAc,EAAE3B,aAAa,CAACwB,MAAM,EAAEC,aAAa,IAAIpD,aAAa,CAACmD,MAAM,EAAEC;EAAc,CAAC;EAEvH,oBACE5C,KAAA,CAACX,IAAI;IAAC0D,KAAK,EAAEhB,cAAe;IAAAiB,QAAA,GAEzBvC,eAAe,KAAK,KAAK,IAAI6B,gBAAgB,iBAC5CxC,IAAA,CAACT,IAAI;MAAC0D,KAAK,EAAEP,kBAAmB;MAAAQ,QAAA,EAAEV;IAAgB,CAAO,CAC1D,eAGDtC,KAAA,CAACX,IAAI;MAAC0D,KAAK,EAAEf,cAAe;MAAAgB,QAAA,gBAE1BlD,IAAA,CAACH,WAAW;QACV4B,QAAQ,EAAEH,KAAK,CAACG,QAAS;QACzB0B,aAAa,EAAE9B,aAAa,CAAC8B,aAAc;QAC3CtC,KAAK,EAAEQ;MAAc,CACtB,CAAC,eAGFrB,IAAA,CAACR,SAAS;QAAA,GACJ0B,cAAc;QAClB+B,KAAK,EAAEX,UAAW;QAClBc,KAAK,EAAE5B,SAAU;QACjBlB,YAAY,EAAEiB,OAAO,CAAC8B,gBAAiB;QACvC3B,iBAAiB,EAAEA,iBAAkB;QACrCZ,SAAS,EAAEA,SAAU;QACrBP,WAAW,EAAEA,WAAY;QACzB+C,oBAAoB,EAClBjC,aAAa,CAACwB,MAAM,EAAEtC,WAAW,IACjCb,aAAa,CAACmD,MAAM,EAAEtC,WACvB;QACDC,QAAQ,EAAEA,QAAS;QACnBC,SAAS,EAAEA,SAAU;QACrBQ,SAAS,EAAEA,SAAU;QACrBsC,cAAc,EACZlC,aAAa,CAACwB,MAAM,EAAEW,MAAM,IAAI9D,aAAa,CAACmD,MAAM,EAAEW,MACvD;QACDC,iBAAiB,EAAC,KAAK;QACvBC,aAAa,EAAE;MAAK,CACrB,CAAC;IAAA,CACE,CAAC,EAGN/C,eAAe,KAAK,QAAQ,IAAI6B,gBAAgB,iBAC/CxC,IAAA,CAACT,IAAI;MAAC0D,KAAK,EAAEP,kBAAmB;MAAAQ,QAAA,EAAEV;IAAgB,CAAO,CAC1D;EAAA,CACG,CAAC;AAEX,CAAC;AAEDrC,aAAa,CAACwD,WAAW,GAAG,eAAe;AAE3C,MAAMxB,MAAM,GAAG1C,UAAU,CAACmE,MAAM,CAAC;EAC/BxB,SAAS,EAAE;IACTyB,QAAQ,EAAE;EACZ,CAAC;EACDtB,SAAS,EAAE;IACT;IACA;IACAuB,KAAK,EAAE,aAAa;IACpB;IACAD,QAAQ,EAAE,UAAU;IACpBE,MAAM,EAAE;EACV;AACF,CAAC,CAAC","ignoreList":[]}
@@ -1,4 +0,0 @@
1
- "use strict";
2
-
3
- export {};
4
- //# sourceMappingURL=Toolbar.d.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["components/Toolbar.d.ts"],"mappings":"","ignoreList":[]}
@@ -1,95 +0,0 @@
1
- "use strict";
2
-
3
- import React, { useMemo } from 'react';
4
- import { View, ScrollView, StyleSheet } from 'react-native';
5
- import { DEFAULT_THEME, DEFAULT_TOOLBAR_ITEMS } from '@/constants/defaultStyles';
6
- import { ToolbarButton } from '@/components/ToolbarButton';
7
-
8
- /**
9
- * Formatting toolbar for the rich text editor.
10
- *
11
- * Supports:
12
- * - Default toolbar items (bold, italic, underline, etc.)
13
- * - Custom toolbar items via the `items` prop
14
- * - Fully custom rendering via `renderToolbar`
15
- * - Horizontal scrolling for overflow
16
- */
17
- import { jsx as _jsx } from "react/jsx-runtime";
18
- export const Toolbar = /*#__PURE__*/React.memo(({
19
- actions,
20
- state,
21
- items,
22
- theme,
23
- visible = true,
24
- renderToolbar
25
- }) => {
26
- const resolvedTheme = theme ?? DEFAULT_THEME;
27
- const toolbarItems = items ?? DEFAULT_TOOLBAR_ITEMS;
28
-
29
- // Compute active state for each item
30
- const enrichedItems = useMemo(() => {
31
- return toolbarItems.map(item => {
32
- let isActive = false;
33
- if (item.format) {
34
- // Check if the format is currently active
35
- const {
36
- activeStyles
37
- } = state;
38
- isActive = !!activeStyles[item.format];
39
- }
40
- if (item.heading) {
41
- isActive = state.activeStyles.heading === item.heading;
42
- }
43
- return {
44
- ...item,
45
- active: item.active ?? isActive
46
- };
47
- });
48
- }, [toolbarItems, state]);
49
-
50
- // Custom render
51
- if (renderToolbar) {
52
- return renderToolbar({
53
- items: enrichedItems,
54
- state,
55
- actions
56
- });
57
- }
58
- if (!visible) {
59
- return null;
60
- }
61
- const toolbarStyle = [resolvedTheme.toolbarStyle ?? DEFAULT_THEME.toolbarStyle];
62
- return /*#__PURE__*/_jsx(View, {
63
- style: toolbarStyle,
64
- children: /*#__PURE__*/_jsx(ScrollView, {
65
- horizontal: true,
66
- showsHorizontalScrollIndicator: false,
67
- keyboardShouldPersistTaps: "always",
68
- contentContainerStyle: styles.scrollContent,
69
- children: enrichedItems.map(item => /*#__PURE__*/_jsx(ToolbarButton, {
70
- label: item.label,
71
- active: !!item.active,
72
- theme: resolvedTheme,
73
- renderButton: item.renderButton,
74
- onPress: () => {
75
- if (item.onPress) {
76
- item.onPress();
77
- } else if (item.format) {
78
- actions.toggleFormat(item.format);
79
- } else if (item.heading) {
80
- actions.setHeading(item.heading);
81
- }
82
- }
83
- }, item.id))
84
- })
85
- });
86
- });
87
- Toolbar.displayName = 'Toolbar';
88
- const styles = StyleSheet.create({
89
- scrollContent: {
90
- flexDirection: 'row',
91
- alignItems: 'center',
92
- gap: 2
93
- }
94
- });
95
- //# sourceMappingURL=Toolbar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","useMemo","View","ScrollView","StyleSheet","DEFAULT_THEME","DEFAULT_TOOLBAR_ITEMS","ToolbarButton","jsx","_jsx","Toolbar","memo","actions","state","items","theme","visible","renderToolbar","resolvedTheme","toolbarItems","enrichedItems","map","item","isActive","format","activeStyles","heading","active","toolbarStyle","style","children","horizontal","showsHorizontalScrollIndicator","keyboardShouldPersistTaps","contentContainerStyle","styles","scrollContent","label","renderButton","onPress","toggleFormat","setHeading","id","displayName","create","flexDirection","alignItems","gap"],"sourceRoot":"..\\..\\..\\src","sources":["components/Toolbar.tsx"],"mappings":"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","ignoreList":[]}
@@ -1,4 +0,0 @@
1
- "use strict";
2
-
3
- export {};
4
- //# sourceMappingURL=ToolbarButton.d.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["components/ToolbarButton.d.ts"],"mappings":"","ignoreList":[]}
@@ -1,59 +0,0 @@
1
- "use strict";
2
-
3
- import React from 'react';
4
- import { TouchableOpacity, Text, StyleSheet } from 'react-native';
5
- import { DEFAULT_THEME } from '@/constants/defaultStyles';
6
-
7
- /**
8
- * A single toolbar button that toggles a formatting option.
9
- * Supports custom rendering via the `renderButton` prop.
10
- */
11
- import { jsx as _jsx } from "react/jsx-runtime";
12
- export const ToolbarButton = /*#__PURE__*/React.memo(({
13
- label,
14
- active,
15
- onPress,
16
- theme,
17
- renderButton
18
- }) => {
19
- // Custom render
20
- if (renderButton) {
21
- return renderButton({
22
- active,
23
- onPress,
24
- label
25
- });
26
- }
27
- const resolvedTheme = theme ?? DEFAULT_THEME;
28
- const buttonStyle = [resolvedTheme.toolbarButtonStyle ?? DEFAULT_THEME.toolbarButtonStyle, active && (resolvedTheme.toolbarButtonActiveStyle ?? DEFAULT_THEME.toolbarButtonActiveStyle)];
29
- const textStyle = [resolvedTheme.toolbarButtonTextStyle ?? DEFAULT_THEME.toolbarButtonTextStyle, active && (resolvedTheme.toolbarButtonActiveTextStyle ?? DEFAULT_THEME.toolbarButtonActiveTextStyle),
30
- // Make italic button actually italic, bold button actually bold, etc.
31
- label === 'I' && styles.italicLabel, label === 'U' && styles.underlineLabel, label === 'S' && styles.strikethroughLabel];
32
- return /*#__PURE__*/_jsx(TouchableOpacity, {
33
- style: buttonStyle,
34
- onPress: onPress,
35
- activeOpacity: 0.7,
36
- accessibilityRole: "button",
37
- accessibilityLabel: `Format ${label}`,
38
- accessibilityState: {
39
- selected: active
40
- },
41
- children: /*#__PURE__*/_jsx(Text, {
42
- style: textStyle,
43
- children: label
44
- })
45
- });
46
- });
47
- ToolbarButton.displayName = 'ToolbarButton';
48
- const styles = StyleSheet.create({
49
- italicLabel: {
50
- fontStyle: 'italic'
51
- },
52
- underlineLabel: {
53
- textDecorationLine: 'underline'
54
- },
55
- strikethroughLabel: {
56
- textDecorationLine: 'line-through'
57
- }
58
- });
59
- //# sourceMappingURL=ToolbarButton.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","TouchableOpacity","Text","StyleSheet","DEFAULT_THEME","jsx","_jsx","ToolbarButton","memo","label","active","onPress","theme","renderButton","resolvedTheme","buttonStyle","toolbarButtonStyle","toolbarButtonActiveStyle","textStyle","toolbarButtonTextStyle","toolbarButtonActiveTextStyle","styles","italicLabel","underlineLabel","strikethroughLabel","style","activeOpacity","accessibilityRole","accessibilityLabel","accessibilityState","selected","children","displayName","create","fontStyle","textDecorationLine"],"sourceRoot":"..\\..\\..\\src","sources":["components/ToolbarButton.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,gBAAgB,EAAEC,IAAI,EAAEC,UAAU,QAAQ,cAAc;AAEjE,SAASC,aAAa,QAAQ,2BAA2B;;AAEzD;AACA;AACA;AACA;AAHA,SAAAC,GAAA,IAAAC,IAAA;AAIA,OAAO,MAAMC,aAA2C,gBAAGP,KAAK,CAACQ,IAAI,CACnE,CAAC;EAAEC,KAAK;EAAEC,MAAM;EAAEC,OAAO;EAAEC,KAAK;EAAEC;AAAa,CAAC,KAAK;EACnD;EACA,IAAIA,YAAY,EAAE;IAChB,OAAOA,YAAY,CAAC;MAAEH,MAAM;MAAEC,OAAO;MAAEF;IAAM,CAAC,CAAC;EACjD;EAEA,MAAMK,aAAa,GAAGF,KAAK,IAAIR,aAAa;EAE5C,MAAMW,WAAW,GAAG,CAClBD,aAAa,CAACE,kBAAkB,IAAIZ,aAAa,CAACY,kBAAkB,EACpEN,MAAM,KACHI,aAAa,CAACG,wBAAwB,IACrCb,aAAa,CAACa,wBAAwB,CAAC,CAC5C;EAED,MAAMC,SAAS,GAAG,CAChBJ,aAAa,CAACK,sBAAsB,IAClCf,aAAa,CAACe,sBAAsB,EACtCT,MAAM,KACHI,aAAa,CAACM,4BAA4B,IACzChB,aAAa,CAACgB,4BAA4B,CAAC;EAC/C;EACAX,KAAK,KAAK,GAAG,IAAIY,MAAM,CAACC,WAAW,EACnCb,KAAK,KAAK,GAAG,IAAIY,MAAM,CAACE,cAAc,EACtCd,KAAK,KAAK,GAAG,IAAIY,MAAM,CAACG,kBAAkB,CAC3C;EAED,oBACElB,IAAA,CAACL,gBAAgB;IACfwB,KAAK,EAAEV,WAAY;IACnBJ,OAAO,EAAEA,OAAQ;IACjBe,aAAa,EAAE,GAAI;IACnBC,iBAAiB,EAAC,QAAQ;IAC1BC,kBAAkB,EAAE,UAAUnB,KAAK,EAAG;IACtCoB,kBAAkB,EAAE;MAAEC,QAAQ,EAAEpB;IAAO,CAAE;IAAAqB,QAAA,eAEzCzB,IAAA,CAACJ,IAAI;MAACuB,KAAK,EAAEP,SAAU;MAAAa,QAAA,EAAEtB;IAAK,CAAO;EAAC,CACtB,CAAC;AAEvB,CACF,CAAC;AAEDF,aAAa,CAACyB,WAAW,GAAG,eAAe;AAE3C,MAAMX,MAAM,GAAGlB,UAAU,CAAC8B,MAAM,CAAC;EAC/BX,WAAW,EAAE;IACXY,SAAS,EAAE;EACb,CAAC;EACDX,cAAc,EAAE;IACdY,kBAAkB,EAAE;EACtB,CAAC;EACDX,kBAAkB,EAAE;IAClBW,kBAAkB,EAAE;EACtB;AACF,CAAC,CAAC","ignoreList":[]}
@@ -1,4 +0,0 @@
1
- "use strict";
2
-
3
- export {};
4
- //# sourceMappingURL=defaultStyles.d.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["constants/defaultStyles.d.ts"],"mappings":"","ignoreList":[]}
@@ -1,168 +0,0 @@
1
- "use strict";
2
-
3
- /**
4
- * Default color palette used throughout the editor.
5
- */
6
- export const DEFAULT_COLORS = {
7
- primary: '#6366F1',
8
- background: '#FFFFFF',
9
- text: '#1F2937',
10
- placeholder: '#9CA3AF',
11
- toolbarBackground: '#F9FAFB',
12
- toolbarBorder: '#E5E7EB',
13
- cursor: '#6366F1',
14
- activeButtonBg: '#EEF2FF',
15
- codeBackground: '#F3F4F6'
16
- };
17
-
18
- /**
19
- * Font size presets for heading levels.
20
- */
21
- export const HEADING_FONT_SIZES = {
22
- h1: 32,
23
- h2: 24,
24
- h3: 20,
25
- none: 16
26
- };
27
-
28
- /**
29
- * Default base text style applied to all segments.
30
- */
31
- export const DEFAULT_BASE_TEXT_STYLE = {
32
- fontSize: 16,
33
- lineHeight: 24,
34
- color: DEFAULT_COLORS.text,
35
- fontFamily: undefined // Uses system default
36
- };
37
-
38
- /**
39
- * Empty format style — no formatting applied.
40
- */
41
- export const EMPTY_FORMAT_STYLE = {
42
- bold: false,
43
- italic: false,
44
- underline: false,
45
- strikethrough: false,
46
- code: false,
47
- color: undefined,
48
- backgroundColor: undefined,
49
- fontSize: undefined,
50
- heading: undefined
51
- };
52
-
53
- /**
54
- * Default theme configuration.
55
- */
56
- export const DEFAULT_THEME = {
57
- containerStyle: {
58
- borderWidth: 1,
59
- borderColor: DEFAULT_COLORS.toolbarBorder,
60
- borderRadius: 12,
61
- backgroundColor: DEFAULT_COLORS.background,
62
- overflow: 'hidden'
63
- },
64
- inputStyle: {
65
- fontSize: DEFAULT_BASE_TEXT_STYLE.fontSize,
66
- lineHeight: DEFAULT_BASE_TEXT_STYLE.lineHeight,
67
- color: 'transparent',
68
- paddingHorizontal: 16,
69
- paddingVertical: 12,
70
- textAlignVertical: 'top'
71
- },
72
- overlayContainerStyle: {
73
- position: 'absolute',
74
- top: 0,
75
- left: 0,
76
- right: 0,
77
- bottom: 0,
78
- paddingHorizontal: 16,
79
- paddingVertical: 12
80
- },
81
- baseTextStyle: {
82
- fontSize: DEFAULT_BASE_TEXT_STYLE.fontSize,
83
- lineHeight: DEFAULT_BASE_TEXT_STYLE.lineHeight,
84
- color: DEFAULT_COLORS.text
85
- },
86
- toolbarStyle: {
87
- flexDirection: 'row',
88
- alignItems: 'center',
89
- paddingHorizontal: 8,
90
- paddingVertical: 6,
91
- backgroundColor: DEFAULT_COLORS.toolbarBackground,
92
- borderColor: DEFAULT_COLORS.toolbarBorder,
93
- gap: 2
94
- },
95
- toolbarButtonStyle: {
96
- paddingHorizontal: 10,
97
- paddingVertical: 6,
98
- borderRadius: 6,
99
- minWidth: 36,
100
- alignItems: 'center',
101
- justifyContent: 'center'
102
- },
103
- toolbarButtonActiveStyle: {
104
- backgroundColor: DEFAULT_COLORS.activeButtonBg
105
- },
106
- toolbarButtonTextStyle: {
107
- fontSize: 15,
108
- fontWeight: '600',
109
- color: DEFAULT_COLORS.text
110
- },
111
- toolbarButtonActiveTextStyle: {
112
- color: DEFAULT_COLORS.primary
113
- },
114
- codeStyle: {
115
- fontFamily: 'monospace',
116
- backgroundColor: DEFAULT_COLORS.codeBackground,
117
- paddingHorizontal: 4,
118
- borderRadius: 4,
119
- fontSize: 14
120
- },
121
- colors: {
122
- primary: DEFAULT_COLORS.primary,
123
- background: DEFAULT_COLORS.background,
124
- text: DEFAULT_COLORS.text,
125
- placeholder: DEFAULT_COLORS.placeholder,
126
- toolbarBackground: DEFAULT_COLORS.toolbarBackground,
127
- toolbarBorder: DEFAULT_COLORS.toolbarBorder,
128
- cursor: DEFAULT_COLORS.cursor
129
- }
130
- };
131
-
132
- /**
133
- * Default toolbar items for the built-in toolbar.
134
- */
135
- export const DEFAULT_TOOLBAR_ITEMS = [{
136
- id: 'bold',
137
- label: 'B',
138
- format: 'bold'
139
- }, {
140
- id: 'italic',
141
- label: 'I',
142
- format: 'italic'
143
- }, {
144
- id: 'underline',
145
- label: 'U',
146
- format: 'underline'
147
- }, {
148
- id: 'strikethrough',
149
- label: 'S',
150
- format: 'strikethrough'
151
- }, {
152
- id: 'code',
153
- label: '<>',
154
- format: 'code'
155
- }, {
156
- id: 'h1',
157
- label: 'H1',
158
- heading: 'h1'
159
- }, {
160
- id: 'h2',
161
- label: 'H2',
162
- heading: 'h2'
163
- }, {
164
- id: 'h3',
165
- label: 'H3',
166
- heading: 'h3'
167
- }];
168
- //# sourceMappingURL=defaultStyles.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["DEFAULT_COLORS","primary","background","text","placeholder","toolbarBackground","toolbarBorder","cursor","activeButtonBg","codeBackground","HEADING_FONT_SIZES","h1","h2","h3","none","DEFAULT_BASE_TEXT_STYLE","fontSize","lineHeight","color","fontFamily","undefined","EMPTY_FORMAT_STYLE","bold","italic","underline","strikethrough","code","backgroundColor","heading","DEFAULT_THEME","containerStyle","borderWidth","borderColor","borderRadius","overflow","inputStyle","paddingHorizontal","paddingVertical","textAlignVertical","overlayContainerStyle","position","top","left","right","bottom","baseTextStyle","toolbarStyle","flexDirection","alignItems","gap","toolbarButtonStyle","minWidth","justifyContent","toolbarButtonActiveStyle","toolbarButtonTextStyle","fontWeight","toolbarButtonActiveTextStyle","codeStyle","colors","DEFAULT_TOOLBAR_ITEMS","id","label","format"],"sourceRoot":"..\\..\\..\\src","sources":["constants/defaultStyles.ts"],"mappings":"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","ignoreList":[]}
@@ -1,4 +0,0 @@
1
- "use strict";
2
-
3
- export {};
4
- //# sourceMappingURL=RichTextContext.d.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["context/RichTextContext.d.ts"],"mappings":"","ignoreList":[]}
@@ -1,55 +0,0 @@
1
- "use strict";
2
-
3
- import React, { createContext, useContext } from 'react';
4
- import { useRichText } from '@/hooks/useRichText';
5
-
6
- // ─── Context ─────────────────────────────────────────────────────────────────
7
- import { jsx as _jsx } from "react/jsx-runtime";
8
- const RichTextContext = /*#__PURE__*/createContext(null);
9
-
10
- // ─── Provider ────────────────────────────────────────────────────────────────
11
-
12
- /**
13
- * RichTextProvider wraps children with rich text state via React Context.
14
- *
15
- * Use this when you need to access the rich text state/actions from
16
- * deeply nested components (e.g., a custom toolbar in a different part
17
- * of the component tree).
18
- *
19
- * @example
20
- * ```tsx
21
- * <RichTextProvider onChangeSegments={handleChange}>
22
- * <MyCustomToolbar />
23
- * <RichTextInput showToolbar={false} />
24
- * </RichTextProvider>
25
- * ```
26
- */
27
- export const RichTextProvider = ({
28
- children,
29
- ...options
30
- }) => {
31
- const richText = useRichText(options);
32
- return /*#__PURE__*/_jsx(RichTextContext.Provider, {
33
- value: richText,
34
- children: children
35
- });
36
- };
37
- RichTextProvider.displayName = 'RichTextProvider';
38
-
39
- // ─── Consumer Hook ───────────────────────────────────────────────────────────
40
-
41
- /**
42
- * Hook to access the RichText state and actions from context.
43
- *
44
- * Must be used within a `<RichTextProvider>`.
45
- *
46
- * @throws If used outside of a RichTextProvider
47
- */
48
- export function useRichTextContext() {
49
- const context = useContext(RichTextContext);
50
- if (!context) {
51
- throw new Error('useRichTextContext must be used within a <RichTextProvider>. ' + 'Wrap your component tree with <RichTextProvider> to use this hook.');
52
- }
53
- return context;
54
- }
55
- //# sourceMappingURL=RichTextContext.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","createContext","useContext","useRichText","jsx","_jsx","RichTextContext","RichTextProvider","children","options","richText","Provider","value","displayName","useRichTextContext","context","Error"],"sourceRoot":"..\\..\\..\\src","sources":["context/RichTextContext.tsx"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,aAAa,EAAEC,UAAU,QAAQ,OAAO;AAExD,SAASC,WAAW,QAAiC,qBAAqB;;AAE1E;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAEA,MAAMC,eAAe,gBAAGL,aAAa,CAA2B,IAAI,CAAC;;AAErE;;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMM,gBAAiD,GAAGA,CAAC;EAChEC,QAAQ;EACR,GAAGC;AACL,CAAC,KAAK;EACJ,MAAMC,QAAQ,GAAGP,WAAW,CAACM,OAAO,CAAC;EAErC,oBACEJ,IAAA,CAACC,eAAe,CAACK,QAAQ;IAACC,KAAK,EAAEF,QAAS;IAAAF,QAAA,EACvCA;EAAQ,CACe,CAAC;AAE/B,CAAC;AAEDD,gBAAgB,CAACM,WAAW,GAAG,kBAAkB;;AAEjD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,kBAAkBA,CAAA,EAAsB;EACtD,MAAMC,OAAO,GAAGb,UAAU,CAACI,eAAe,CAAC;EAC3C,IAAI,CAACS,OAAO,EAAE;IACZ,MAAM,IAAIC,KAAK,CACb,+DAA+D,GAC7D,oEACJ,CAAC;EACH;EACA,OAAOD,OAAO;AAChB","ignoreList":[]}
@@ -1,11 +0,0 @@
1
- "use strict";
2
-
3
- /**
4
- * Hook that provides formatting commands for the rich text editor.
5
- *
6
- * Handles both selection-based formatting (when text is selected)
7
- * and active-style updates (when no text is selected — affects next typed text).
8
- */
9
-
10
- export {};
11
- //# sourceMappingURL=useFormatting.d.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["hooks/useFormatting.d.ts"],"mappings":";;AAQA;AACA;AACA;AACA;AACA;AACA;;AAWA","ignoreList":[]}