ignite-parse-auth-kit 1.0.0

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 (241) hide show
  1. package/CONTRIBUTING.md +0 -0
  2. package/LICENSE +21 -0
  3. package/README.md +492 -0
  4. package/app/app.tsx +116 -0
  5. package/app/components/AlertTongle.tsx +105 -0
  6. package/app/components/AutoImage.tsx +89 -0
  7. package/app/components/Button.tsx +248 -0
  8. package/app/components/Card.tsx +314 -0
  9. package/app/components/EmptyState.tsx +248 -0
  10. package/app/components/Header.tsx +332 -0
  11. package/app/components/Icon.tsx +140 -0
  12. package/app/components/ListItem.tsx +243 -0
  13. package/app/components/ListView.tsx +42 -0
  14. package/app/components/Screen.tsx +305 -0
  15. package/app/components/Text.test.tsx +23 -0
  16. package/app/components/Text.tsx +116 -0
  17. package/app/components/TextField.tsx +292 -0
  18. package/app/components/Toggle/Checkbox.tsx +123 -0
  19. package/app/components/Toggle/Radio.tsx +106 -0
  20. package/app/components/Toggle/Switch.tsx +264 -0
  21. package/app/components/Toggle/Toggle.tsx +285 -0
  22. package/app/components/index copy.ts +15 -0
  23. package/app/components/index.ts +18 -0
  24. package/app/config/config.base.ts +26 -0
  25. package/app/config/config.dev.ts +10 -0
  26. package/app/config/config.prod.ts +10 -0
  27. package/app/config/index.ts +28 -0
  28. package/app/context/AuthContext.tsx +14 -0
  29. package/app/context/EpisodeContext.tsx +136 -0
  30. package/app/context/auth/AuthProvider.tsx +340 -0
  31. package/app/context/auth/hooks.ts +29 -0
  32. package/app/context/auth/index.ts +38 -0
  33. package/app/context/auth/reducer.ts +68 -0
  34. package/app/context/auth/services.ts +394 -0
  35. package/app/context/auth/types.ts +99 -0
  36. package/app/context/auth/validation.ts +45 -0
  37. package/app/devtools/ReactotronClient.ts +9 -0
  38. package/app/devtools/ReactotronClient.web.ts +12 -0
  39. package/app/devtools/ReactotronConfig.ts +139 -0
  40. package/app/i18n/ar.ts +126 -0
  41. package/app/i18n/demo-ar.ts +464 -0
  42. package/app/i18n/demo-en.ts +462 -0
  43. package/app/i18n/demo-es.ts +469 -0
  44. package/app/i18n/demo-fr.ts +471 -0
  45. package/app/i18n/demo-hi.ts +468 -0
  46. package/app/i18n/demo-ja.ts +464 -0
  47. package/app/i18n/demo-ko.ts +457 -0
  48. package/app/i18n/en.ts +146 -0
  49. package/app/i18n/es.ts +132 -0
  50. package/app/i18n/fr.ts +132 -0
  51. package/app/i18n/hi.ts +131 -0
  52. package/app/i18n/index.ts +86 -0
  53. package/app/i18n/ja.ts +130 -0
  54. package/app/i18n/ko.ts +129 -0
  55. package/app/i18n/translate.ts +33 -0
  56. package/app/lib/Parse/index.ts +2 -0
  57. package/app/lib/Parse/parse.ts +62 -0
  58. package/app/navigators/AppNavigator.tsx +145 -0
  59. package/app/navigators/DemoNavigator.tsx +137 -0
  60. package/app/navigators/navigationUtilities.ts +208 -0
  61. package/app/screens/ChooseAuthScreen.tsx +224 -0
  62. package/app/screens/DemoCommunityScreen.tsx +141 -0
  63. package/app/screens/DemoDebugScreen.tsx +192 -0
  64. package/app/screens/DemoPodcastListScreen.tsx +387 -0
  65. package/app/screens/DemoShowroomScreen/DemoDivider.tsx +66 -0
  66. package/app/screens/DemoShowroomScreen/DemoShowroomScreen.tsx +313 -0
  67. package/app/screens/DemoShowroomScreen/DemoUseCase.tsx +52 -0
  68. package/app/screens/DemoShowroomScreen/DrawerIconButton.tsx +120 -0
  69. package/app/screens/DemoShowroomScreen/SectionListWithKeyboardAwareScrollView.tsx +59 -0
  70. package/app/screens/DemoShowroomScreen/demos/DemoAutoImage.tsx +230 -0
  71. package/app/screens/DemoShowroomScreen/demos/DemoButton.tsx +234 -0
  72. package/app/screens/DemoShowroomScreen/demos/DemoCard.tsx +181 -0
  73. package/app/screens/DemoShowroomScreen/demos/DemoEmptyState.tsx +78 -0
  74. package/app/screens/DemoShowroomScreen/demos/DemoHeader.tsx +151 -0
  75. package/app/screens/DemoShowroomScreen/demos/DemoIcon.tsx +115 -0
  76. package/app/screens/DemoShowroomScreen/demos/DemoListItem.tsx +218 -0
  77. package/app/screens/DemoShowroomScreen/demos/DemoText.tsx +144 -0
  78. package/app/screens/DemoShowroomScreen/demos/DemoTextField.tsx +233 -0
  79. package/app/screens/DemoShowroomScreen/demos/DemoToggle.tsx +354 -0
  80. package/app/screens/DemoShowroomScreen/demos/index.ts +12 -0
  81. package/app/screens/ErrorScreen/ErrorBoundary.tsx +76 -0
  82. package/app/screens/ErrorScreen/ErrorDetails.tsx +98 -0
  83. package/app/screens/ForgetPasswordScreen.tsx +180 -0
  84. package/app/screens/LoginScreen.tsx +260 -0
  85. package/app/screens/RegisterScreen.tsx +395 -0
  86. package/app/screens/WelcomeScreen.tsx +114 -0
  87. package/app/services/api/apiProblem.test.ts +73 -0
  88. package/app/services/api/apiProblem.ts +74 -0
  89. package/app/services/api/index.ts +91 -0
  90. package/app/services/api/types.ts +50 -0
  91. package/app/theme/colors.ts +85 -0
  92. package/app/theme/colorsDark.ts +50 -0
  93. package/app/theme/context.tsx +145 -0
  94. package/app/theme/context.utils.ts +25 -0
  95. package/app/theme/spacing.ts +14 -0
  96. package/app/theme/spacingDark.ts +14 -0
  97. package/app/theme/styles.ts +24 -0
  98. package/app/theme/theme.ts +23 -0
  99. package/app/theme/timing.ts +6 -0
  100. package/app/theme/types.ts +64 -0
  101. package/app/theme/typography.ts +71 -0
  102. package/app/utils/crashReporting.ts +62 -0
  103. package/app/utils/delay.ts +6 -0
  104. package/app/utils/formatDate.ts +49 -0
  105. package/app/utils/gestureHandler.native.ts +3 -0
  106. package/app/utils/gestureHandler.ts +6 -0
  107. package/app/utils/hasValidStringProp.ts +11 -0
  108. package/app/utils/openLinkInBrowser.ts +8 -0
  109. package/app/utils/storage/index.ts +82 -0
  110. package/app/utils/storage/storage.test.ts +61 -0
  111. package/app/utils/useHeader.tsx +37 -0
  112. package/app/utils/useIsMounted.ts +18 -0
  113. package/app/utils/useSafeAreaInsetsStyle.ts +46 -0
  114. package/app.config.ts +39 -0
  115. package/app.json +67 -0
  116. package/assets/icons/back.png +0 -0
  117. package/assets/icons/back@2x.png +0 -0
  118. package/assets/icons/back@3x.png +0 -0
  119. package/assets/icons/bell.png +0 -0
  120. package/assets/icons/bell@2x.png +0 -0
  121. package/assets/icons/bell@3x.png +0 -0
  122. package/assets/icons/caretLeft.png +0 -0
  123. package/assets/icons/caretLeft@2x.png +0 -0
  124. package/assets/icons/caretLeft@3x.png +0 -0
  125. package/assets/icons/caretRight.png +0 -0
  126. package/assets/icons/caretRight@2x.png +0 -0
  127. package/assets/icons/caretRight@3x.png +0 -0
  128. package/assets/icons/check.png +0 -0
  129. package/assets/icons/check@2x.png +0 -0
  130. package/assets/icons/check@3x.png +0 -0
  131. package/assets/icons/demo/clap.png +0 -0
  132. package/assets/icons/demo/clap@2x.png +0 -0
  133. package/assets/icons/demo/clap@3x.png +0 -0
  134. package/assets/icons/demo/community.png +0 -0
  135. package/assets/icons/demo/community@2x.png +0 -0
  136. package/assets/icons/demo/community@3x.png +0 -0
  137. package/assets/icons/demo/components.png +0 -0
  138. package/assets/icons/demo/components@2x.png +0 -0
  139. package/assets/icons/demo/components@3x.png +0 -0
  140. package/assets/icons/demo/debug.png +0 -0
  141. package/assets/icons/demo/debug@2x.png +0 -0
  142. package/assets/icons/demo/debug@3x.png +0 -0
  143. package/assets/icons/demo/github.png +0 -0
  144. package/assets/icons/demo/github@2x.png +0 -0
  145. package/assets/icons/demo/github@3x.png +0 -0
  146. package/assets/icons/demo/heart.png +0 -0
  147. package/assets/icons/demo/heart@2x.png +0 -0
  148. package/assets/icons/demo/heart@3x.png +0 -0
  149. package/assets/icons/demo/pin.png +0 -0
  150. package/assets/icons/demo/pin@2x.png +0 -0
  151. package/assets/icons/demo/pin@3x.png +0 -0
  152. package/assets/icons/demo/podcast.png +0 -0
  153. package/assets/icons/demo/podcast@2x.png +0 -0
  154. package/assets/icons/demo/podcast@3x.png +0 -0
  155. package/assets/icons/demo/slack.png +0 -0
  156. package/assets/icons/demo/slack@2x.png +0 -0
  157. package/assets/icons/demo/slack@3x.png +0 -0
  158. package/assets/icons/google.png +0 -0
  159. package/assets/icons/hidden.png +0 -0
  160. package/assets/icons/hidden@2x.png +0 -0
  161. package/assets/icons/hidden@3x.png +0 -0
  162. package/assets/icons/ladybug.png +0 -0
  163. package/assets/icons/ladybug@2x.png +0 -0
  164. package/assets/icons/ladybug@3x.png +0 -0
  165. package/assets/icons/lock.png +0 -0
  166. package/assets/icons/lock@2x.png +0 -0
  167. package/assets/icons/lock@3x.png +0 -0
  168. package/assets/icons/menu.png +0 -0
  169. package/assets/icons/menu@2x.png +0 -0
  170. package/assets/icons/menu@3x.png +0 -0
  171. package/assets/icons/more.png +0 -0
  172. package/assets/icons/more@2x.png +0 -0
  173. package/assets/icons/more@3x.png +0 -0
  174. package/assets/icons/settings.png +0 -0
  175. package/assets/icons/settings@2x.png +0 -0
  176. package/assets/icons/settings@3x.png +0 -0
  177. package/assets/icons/view.png +0 -0
  178. package/assets/icons/view@2x.png +0 -0
  179. package/assets/icons/view@3x.png +0 -0
  180. package/assets/icons/x.png +0 -0
  181. package/assets/icons/x@2x.png +0 -0
  182. package/assets/icons/x@3x.png +0 -0
  183. package/assets/images/app-icon-all.png +0 -0
  184. package/assets/images/app-icon-android-adaptive-background.png +0 -0
  185. package/assets/images/app-icon-android-adaptive-foreground.png +0 -0
  186. package/assets/images/app-icon-android-legacy.png +0 -0
  187. package/assets/images/app-icon-ios.png +0 -0
  188. package/assets/images/app-icon-web-favicon.png +0 -0
  189. package/assets/images/demo/cr-logo.png +0 -0
  190. package/assets/images/demo/cr-logo@2x.png +0 -0
  191. package/assets/images/demo/cr-logo@3x.png +0 -0
  192. package/assets/images/demo/rnl-logo.png +0 -0
  193. package/assets/images/demo/rnl-logo@2x.png +0 -0
  194. package/assets/images/demo/rnl-logo@3x.png +0 -0
  195. package/assets/images/demo/rnn-logo.png +0 -0
  196. package/assets/images/demo/rnn-logo@2x.png +0 -0
  197. package/assets/images/demo/rnn-logo@3x.png +0 -0
  198. package/assets/images/demo/rnr-image-1.png +0 -0
  199. package/assets/images/demo/rnr-image-1@2x.png +0 -0
  200. package/assets/images/demo/rnr-image-1@3x.png +0 -0
  201. package/assets/images/demo/rnr-image-2.png +0 -0
  202. package/assets/images/demo/rnr-image-2@2x.png +0 -0
  203. package/assets/images/demo/rnr-image-2@3x.png +0 -0
  204. package/assets/images/demo/rnr-image-3.png +0 -0
  205. package/assets/images/demo/rnr-image-3@2x.png +0 -0
  206. package/assets/images/demo/rnr-image-3@3x.png +0 -0
  207. package/assets/images/demo/rnr-logo.png +0 -0
  208. package/assets/images/demo/rnr-logo@2x.png +0 -0
  209. package/assets/images/demo/rnr-logo@3x.png +0 -0
  210. package/assets/images/logo.png +0 -0
  211. package/assets/images/logo@2x.png +0 -0
  212. package/assets/images/logo@3x.png +0 -0
  213. package/assets/images/sad-face.png +0 -0
  214. package/assets/images/sad-face@2x.png +0 -0
  215. package/assets/images/sad-face@3x.png +0 -0
  216. package/assets/images/welcome-face.png +0 -0
  217. package/assets/images/welcome-face@2x.png +0 -0
  218. package/assets/images/welcome-face@3x.png +0 -0
  219. package/babel.config.js +7 -0
  220. package/bin/cli.js +196 -0
  221. package/ignite/templates/app-icon/android-adaptive-background.png +0 -0
  222. package/ignite/templates/app-icon/android-adaptive-foreground.png +0 -0
  223. package/ignite/templates/app-icon/android-legacy.png +0 -0
  224. package/ignite/templates/app-icon/ios-universal.png +0 -0
  225. package/ignite/templates/component/NAME.tsx.ejs +39 -0
  226. package/ignite/templates/navigator/NAMENavigator.tsx.ejs +18 -0
  227. package/ignite/templates/screen/NAMEScreen.tsx.ejs +29 -0
  228. package/ignite/templates/splash-screen/logo.png +0 -0
  229. package/index.tsx +9 -0
  230. package/jest.config.js +5 -0
  231. package/metro.config.js +31 -0
  232. package/package.json +166 -0
  233. package/plugins/withSplashScreen.ts +69 -0
  234. package/src/app/_layout.tsx +58 -0
  235. package/src/app/index.tsx +5 -0
  236. package/test/i18n.test.ts +75 -0
  237. package/test/mockFile.ts +6 -0
  238. package/test/setup.ts +58 -0
  239. package/test/test-tsconfig.json +8 -0
  240. package/tsconfig.json +52 -0
  241. package/types/lib.es5.d.ts +25 -0
@@ -0,0 +1,469 @@
1
+ import { DemoTranslations } from "./demo-en"
2
+
3
+ export const demoEs: DemoTranslations = {
4
+ demoIcon: {
5
+ description:
6
+ "Un componente para dibujar un ícono pre-definido. Si se proporciona el atributo `onPress`, se rodea por un componente <TouchableOpacity />. De lo contrario, se rodea por un componente <View />.",
7
+ useCase: {
8
+ icons: {
9
+ name: "Íconos",
10
+ description: "Lista de los íconos pre-definidos para el componente.",
11
+ },
12
+ size: {
13
+ name: "Tamaño",
14
+ description: "Hay un atributo para el tamaño.",
15
+ },
16
+ color: {
17
+ name: "Color",
18
+ description: "Hay un atributo para el color.",
19
+ },
20
+ styling: {
21
+ name: "Estilo",
22
+ description: "El componente puede ser configurado fácilmente.",
23
+ },
24
+ },
25
+ },
26
+ demoTextField: {
27
+ description: "El componente <TextField /> permite el ingreso y edición de texto.",
28
+ useCase: {
29
+ statuses: {
30
+ name: "Estados",
31
+ description:
32
+ "Hay un atributo para el estado - similar a `preset` en otros componentes, pero que además impacta en la funcionalidad del componente.",
33
+ noStatus: {
34
+ label: "Sin estado",
35
+ helper: "Este es el estado por defecto",
36
+ placeholder: "El texto va acá",
37
+ },
38
+ error: {
39
+ label: "Estado de error",
40
+ helper: "Estado para usar en caso de error",
41
+ placeholder: "El texto va acá",
42
+ },
43
+ disabled: {
44
+ label: "Estado desactivado",
45
+ helper: "Desactiva la edición y atenúa el texto",
46
+ placeholder: "El texto va acá",
47
+ },
48
+ },
49
+ passingContent: {
50
+ name: "Entregando contenido",
51
+ description: "Hay varias formas de entregar contenido.",
52
+ viaLabel: {
53
+ labelTx: "A través del atributo `label`",
54
+ helper: "A través del atributo `helper`",
55
+ placeholder: "A través del atributo `placeholder`",
56
+ },
57
+ rightAccessory: {
58
+ label: "Complemento derecho",
59
+ helper: "Este atributo requiere una función que retorne un elemento React.",
60
+ },
61
+ leftAccessory: {
62
+ label: "Complemento izquierdo",
63
+ helper: "Este atributo requiere una función que retorne un elemento React.",
64
+ },
65
+ supportsMultiline: {
66
+ label: "Soporta múltilíneas",
67
+ helper: "Permite un input de texto más largo para texto multilinea.",
68
+ },
69
+ },
70
+ styling: {
71
+ name: "Estilo",
72
+ description: "El componente puede ser configurado fácilmente.",
73
+ styleInput: {
74
+ label: "Estilo del input",
75
+ helper: "A través de el atributo `style`",
76
+ },
77
+ styleInputWrapper: {
78
+ label: "Estilo del contenedor del input",
79
+ helper: "A través de el atributo `inputWrapperStyle`",
80
+ },
81
+ styleContainer: {
82
+ label: "Estilo del contenedor",
83
+ helper: "A través de el atributo `containerStyle`",
84
+ },
85
+ styleLabel: {
86
+ label: "Estilo de la etiqueta y texto de ayuda",
87
+ helper: "A través de las props de estilo `LabelTextProps` y `HelperTextProps`",
88
+ },
89
+ styleAccessories: {
90
+ label: "Estilo de los accesorios",
91
+ helper: "A través de las props de estilo `RightAccessory` y `LeftAccessory`",
92
+ },
93
+ },
94
+ },
95
+ },
96
+ demoToggle: {
97
+ description:
98
+ "Dibuja un switch de tipo booleano. Este componente requiere un callback `onValueChange` que actualice el atributo `value` para que este refleje las acciones del usuario. Si el atributo `value` no se actualiza, el componente seguirá mostrando el valor proporcionado por defecto en lugar de lo esperado por las acciones del usuario.",
99
+ useCase: {
100
+ variants: {
101
+ name: "Variantes",
102
+ description:
103
+ "El componente soporta diferentes variantes. Si se necesita una personalización más avanzada o variante específica, puede ser fácilmente refactorizada. El valor por defecto es `checkbox`.",
104
+ checkbox: {
105
+ label: "Variante `checkbox`",
106
+ helper: "Puede ser utilizada para un único valor del tipo on/off.",
107
+ },
108
+ radio: {
109
+ label: "Variante `radio`",
110
+ helper: "Usa esto cuando tengas múltiples opciones.",
111
+ },
112
+ switch: {
113
+ label: "Variante `switch`",
114
+ helper:
115
+ "Una entrada del tipo on/off que sobresale más. Tiene mejor soporte de accesibilidad.",
116
+ },
117
+ },
118
+ statuses: {
119
+ name: "Estados",
120
+ description:
121
+ "Hay un atributo de estado - similar a `preset` en otros componentes, pero que además impacta en la funcionalidad del componente.",
122
+ noStatus: "Sin estado - este es el valor por defecto",
123
+ errorStatus: "Estado de error - para usar cuando haya un error",
124
+ disabledStatus: "Estado desactivado - desactiva la edición y silencia el input",
125
+ },
126
+ passingContent: {
127
+ name: "Entregando contenido",
128
+ description: "Hay varias formas de entregar contenido.",
129
+ useCase: {
130
+ checkBox: {
131
+ label: "A través del atributo `labelTx`",
132
+ helper: "A través del atributo `helperTx`.",
133
+ },
134
+ checkBoxMultiLine: {
135
+ helper: "Soporta multi líneas - Nulla proident consectetur labore sunt ea labore.",
136
+ },
137
+ radioChangeSides: {
138
+ helper: "Puedes cambiarle el lado - Laborum labore adipisicing in eu ipsum deserunt.",
139
+ },
140
+ customCheckBox: {
141
+ label: "Pasa un ícono para un checkbox personalizado.",
142
+ },
143
+ switch: {
144
+ label: "Los interruptores pueden leerse como texto",
145
+ helper:
146
+ "Por defecto, esta opción no usa `Text` ya que, dependiendo de la fuente, los caracteres on/off podrían no dibujarse bien. Personalízalo según tus necesidades.",
147
+ },
148
+ switchAid: {
149
+ label: "O con la ayuda de un ícono",
150
+ },
151
+ },
152
+ },
153
+ styling: {
154
+ name: "Estilo",
155
+ description: "El componente puede ser configurado fácilmente.",
156
+ outerWrapper: "1 - configura el contenedor externo del input",
157
+ innerWrapper: "2 - configura el contenedor interno del input",
158
+ inputDetail: "3 - configura el detalle del input",
159
+ labelTx: "También puedes configurar el atributo labelTx",
160
+ styleContainer: "O, configura todo el contenedor",
161
+ },
162
+ },
163
+ },
164
+ demoButton: {
165
+ description:
166
+ "Un componente que permite a los usuarios realizar acciones y hacer elecciones. Rodea un componente Text con otro componente Pressable.",
167
+ useCase: {
168
+ presets: {
169
+ name: "Preajustes",
170
+ description: "Hay algunos preajustes por defecto.",
171
+ },
172
+ passingContent: {
173
+ name: "Entregando contenido",
174
+ description: "Hay varias formas de entregar contenido.",
175
+ viaTextProps: "A través del atributo `text` - Billum In",
176
+ children: "Contenido anidado (children) - Irure Reprehenderit",
177
+ rightAccessory: "Componente derecho - Duis Quis",
178
+ leftAccessory: "Componente izquierdo - Duis Proident",
179
+ nestedChildren: "Contenido anidado - proident veniam.",
180
+ nestedChildren2: "Ullamco cupidatat officia exercitation velit non ullamco nisi..",
181
+ nestedChildren3: "Occaecat aliqua irure proident veniam.",
182
+ multiLine:
183
+ "Multilínea - consequat veniam veniam reprehenderit. Fugiat id nisi quis duis sunt proident mollit dolor mollit adipisicing proident deserunt.",
184
+ },
185
+ styling: {
186
+ name: "Estilo",
187
+ description: "El componente puede ser configurando fácilmente.",
188
+ styleContainer: "Estilo del contenedor - Exercitation",
189
+ styleText: "Estilo del texto - Ea Anim",
190
+ styleAccessories: "Estilo de los componentes - enim ea id fugiat anim ad.",
191
+ pressedState: "Estilo para el estado presionado - fugiat anim",
192
+ },
193
+ disabling: {
194
+ name: "Desactivado",
195
+ description:
196
+ "El componente puede ser desactivado y como consecuencia, estilizado. El comportamiento para hacer clic será desactivado.",
197
+ standard: "Desactivado - estándar",
198
+ filled: "Desactivado - relleno",
199
+ reversed: "Desactivado - invertido",
200
+ accessory: "Estilo del componente desactivado",
201
+ textStyle: "Estilo del texto desactivado",
202
+ },
203
+ },
204
+ },
205
+ demoListItem: {
206
+ description:
207
+ "Un componente estilizado que representa una fila para ser utilizada dentro de un FlatList, SectionList o por sí solo.",
208
+ useCase: {
209
+ height: {
210
+ name: "Altura",
211
+ description: "La fila puede tener diferentes alturas.",
212
+ defaultHeight: "Altura por defecto (56px)",
213
+ customHeight: "Altura personalizada a través del atributo `height`",
214
+ textHeight:
215
+ "Altura determinada por el contenido del texto - Reprehenderit incididunt deserunt do do ea labore.",
216
+ longText:
217
+ "Limitar texto largo a solo una línea - Reprehenderit incididunt deserunt do do ea labore.",
218
+ },
219
+ separators: {
220
+ name: "Separadores",
221
+ description: "El separador/divisor está preconfigurado y es opcional.",
222
+ topSeparator: "Separador solo en la parte superior",
223
+ topAndBottomSeparator: "Separadores en la parte superior e inferior",
224
+ bottomSeparator: "Separador solo en la parte inferior",
225
+ },
226
+ icons: {
227
+ name: "Íconos",
228
+ description: "Puedes personalizar los íconos a la izquierda o a la derecha.",
229
+ leftIcon: "Ícono izquierdo",
230
+ rightIcon: "Ícono derecho",
231
+ leftRightIcons: "Íconos izquierdo y derecho",
232
+ },
233
+ customLeftRight: {
234
+ name: "Componentes personalizados en la izquierda o derecha",
235
+ description:
236
+ "Puede pasar un componente personalizado en la izquierda o derecha, si así lo necesitas.",
237
+ customLeft: "Componente personalizado a la izquierda",
238
+ customRight: "Componente personalizado a la derecha",
239
+ },
240
+ passingContent: {
241
+ name: "Entregando contenido",
242
+ description: "Hay varias formas de entregar contenido.",
243
+ text: "A través del atributo `text` - reprehenderit sint",
244
+ children: "Contenido anidado (children) - mostrud mollit",
245
+ nestedChildren1: "Contenido anidado 1 - proident veniam.",
246
+ nestedChildren2: "Ullamco cupidatat officia exercitation velit non ullamco nisi..",
247
+ },
248
+ listIntegration: {
249
+ name: "Integración con FlatList y FlashList",
250
+ description:
251
+ "El componente puede ser fácilmente integrado con tu interfaz de lista preferida.",
252
+ },
253
+ styling: {
254
+ name: "Estilo",
255
+ description: "El componente puede ser configurando fácilmente.",
256
+ styledText: "Texto estilizado",
257
+ styledContainer: "Contenedor estilizado (separadores)",
258
+ tintedIcons: "Íconos coloreados",
259
+ },
260
+ },
261
+ },
262
+ demoCard: {
263
+ description:
264
+ "Las tarjetas son útiles para mostrar información relacionada de forma englobada. Si un ListItem muestra el contenido horizontalmente, una tarjeta puede ser también utilizada para mostrar el contenido de manera vertical.",
265
+ useCase: {
266
+ presets: {
267
+ name: "Preajustes",
268
+ description: "Hay algunos ajustes preconfigurados.",
269
+ default: {
270
+ heading: "Preajuste por defecto (default)",
271
+ content: "Incididunt magna ut aliquip consectetur mollit dolor.",
272
+ footer: "Consectetur nulla non aliquip velit.",
273
+ },
274
+ reversed: {
275
+ heading: "Preajuste inverso",
276
+ content: "Reprehenderit occaecat proident amet id laboris.",
277
+ footer: "Consectetur tempor ea non labore anim.",
278
+ },
279
+ },
280
+ verticalAlignment: {
281
+ name: "Alineamiento vertical",
282
+ description:
283
+ "Dependiendo del requerimiento, la tarjeta está preconfigurada con diferentes estrategias de alineación.",
284
+ top: {
285
+ heading: "Arriba (por defecto)",
286
+ content: "Todo el contenido está automáticamente alineado en la parte superior.",
287
+ footer: "Incluso en el pie de página",
288
+ },
289
+ center: {
290
+ heading: "Centro",
291
+ content: "El contenido está centrado en relación con la altura de la tarjeta.",
292
+ footer: "¡Yo también!",
293
+ },
294
+ spaceBetween: {
295
+ heading: "Espacio entre",
296
+ content: "Todo el contenido está espaciado uniformemente.",
297
+ footer: "Estoy donde quiero estar.",
298
+ },
299
+ reversed: {
300
+ heading: "Forzar el pie de página hacia abajo",
301
+ content: "Esto empuja el pie de página hacia donde pertenece.",
302
+ footer: "Estoy tan solo aquí abajo.",
303
+ },
304
+ },
305
+ passingContent: {
306
+ name: "Entregando contenido",
307
+ description: "Hay varias formas de entregar contenido.",
308
+ heading: "A través del atributo `heading`",
309
+ content: "A través del atributo `content`",
310
+ footer: "Estoy tan solo aquí abajo.",
311
+ },
312
+ customComponent: {
313
+ name: "Componentes personalizados",
314
+ description:
315
+ "Cualquier componente preconfigurado puede ser reemplazado por uno específico. Puedes agregar otros si así lo requieres.",
316
+ rightComponent: "Componente derecho",
317
+ leftComponent: "Componente izquierdo",
318
+ },
319
+ style: {
320
+ name: "Estilo",
321
+ description: "El componente puede ser configurado fácilmente.",
322
+ heading: "Estilizar el encabezado",
323
+ content: "Estilizar el contenido",
324
+ footer: "Estilizar el pie de página",
325
+ },
326
+ },
327
+ },
328
+ demoAutoImage: {
329
+ description:
330
+ "Un componente que se ajusta automáticamente el tamaño de una imagen remota o utilizando el atributo data-uri.",
331
+ useCase: {
332
+ remoteUri: { name: "URI remota" },
333
+ base64Uri: { name: "URI Base64" },
334
+ scaledToFitDimensions: {
335
+ name: "Escalado que se ajusta a las dimensiones",
336
+ description:
337
+ "Al proporcionar los atributos `maxWidth` y/o `maxHeight`, la imagen se redimensionará automáticamente manteniendo el ratio. ¿En qué se diferencia de `resizeMode: 'contain'`? Para empezar, puedes especificar el tamaño de un solo lado (no ambos). Segundo, la imagen se ajustará a las dimensiones deseadas en lugar de simplemente estar contenida en su contenedor.",
338
+ heightAuto: "ancho: 60 / altura: auto",
339
+ widthAuto: "ancho: auto / altura: 32",
340
+ bothManual: "ancho: 60 / altura: 60",
341
+ },
342
+ },
343
+ },
344
+ demoText: {
345
+ description:
346
+ "Para todo tipo de requerimiento relacionado a mostrar texto. Este componente es un 'wrapper' (HOC) del componente Text de React Native.",
347
+ useCase: {
348
+ presets: {
349
+ name: "Preajustes",
350
+ description: "Hay algunos ajustes preconfigurados.",
351
+ default:
352
+ "ajuste por defecto - Cillum eu laboris in labore. Excepteur mollit tempor reprehenderit fugiat elit et eu consequat laborum.",
353
+ bold: "preajuste negrita - Tempor et ullamco cupidatat in officia. Nulla ea duis elit id sunt ipsum cillum duis deserunt nostrud ut nostrud id.",
354
+ subheading: "preajuste subtítulo - In Cupidatat Cillum.",
355
+ heading: "preajuste título - Voluptate Adipis.",
356
+ },
357
+ sizes: {
358
+ name: "Tamaños",
359
+ description: "Hay un atributo de tamaño.",
360
+ xs: "xs - Ea ipsum est ea ex sunt.",
361
+ sm: "sm - Lorem sunt adipisicin.",
362
+ md: "md - Consequat id do lorem.",
363
+ lg: "lg - Nostrud ipsum ea.",
364
+ xl: "xl - Eiusmod ex excepteur.",
365
+ xxl: "xxl - Cillum eu laboris.",
366
+ },
367
+ weights: {
368
+ name: "Grueso",
369
+ description: "Hay un atributo de grueso.",
370
+ light:
371
+ "ligero - Nulla magna incididunt excepteur est occaecat duis culpa dolore cupidatat enim et.",
372
+ normal:
373
+ "normal - Magna incididunt dolor ut veniam veniam laboris aliqua velit ea incididunt.",
374
+ medium: "medio - Non duis laborum quis laboris occaecat culpa cillum.",
375
+ semibold: "seminegrita - Exercitation magna nostrud pariatur laborum occaecat aliqua.",
376
+ bold: "negrita - Eiusmod ullamco magna exercitation est excepteur.",
377
+ },
378
+ passingContent: {
379
+ name: "Entregando contenido",
380
+ description: "Hay varias formas de entregar contenido.",
381
+ viaText:
382
+ "a través del atributo `text` - Billum in aute fugiat proident nisi pariatur est. Cupidatat anim cillum eiusmod ad. Officia eu magna aliquip labore dolore consequat.",
383
+ viaTx: "a través del atributo `tx` -",
384
+ children:
385
+ "Contenido anidado (children) - Aliqua velit irure reprehenderit eu qui amet veniam consectetur.",
386
+ nestedChildren: "Contenidos anidados -",
387
+ nestedChildren2: "Occaecat aliqua irure proident veniam.",
388
+ nestedChildren3: "Ullamco cupidatat officia exercitation velit non ullamco nisi..",
389
+ nestedChildren4: "Occaecat aliqua irure proident veniam.",
390
+ },
391
+ styling: {
392
+ name: "Estilo",
393
+ description: "El componente puede ser configurando fácilmente.",
394
+ text: "Consequat ullamco veniam velit mollit proident excepteur aliquip id culpa ipsum velit sint nostrud.",
395
+ text2:
396
+ "Eiusmod occaecat laboris eu ex veniam ipsum adipisicing consectetur. Magna ullamco adipisicing tempor adipisicing.",
397
+ text3:
398
+ "Eiusmod occaecat laboris eu ex veniam ipsum adipisicing consectetur. Magna ullamco adipisicing tempor adipisicing.",
399
+ },
400
+ },
401
+ },
402
+ demoHeader: {
403
+ description:
404
+ "Componente desplegado en varias pantallas. Va a contener botones de navegación y el título de la pantalla.",
405
+ useCase: {
406
+ actionIcons: {
407
+ name: "Íconos de acción",
408
+ description: "Puedes pasar fácilmente íconos a los componentes de la izquierda o derecha.",
409
+ leftIconTitle: "Ícono izquierdo",
410
+ rightIconTitle: "Ícono derecho",
411
+ bothIconsTitle: "Ambos íconos",
412
+ },
413
+ actionText: {
414
+ name: "Texto de acción",
415
+ description: "Puedes pasar fácilmente texto a los componentes de la izquierda o derecha.",
416
+ leftTxTitle: "A través de `leftTx`",
417
+ rightTextTitle: "A través de `rightText`",
418
+ },
419
+ customActionComponents: {
420
+ name: "Componentes personalizados de acción",
421
+ description:
422
+ "Si las opciones de ícono o texto no son suficientes, puedes pasar tu propio componente personalizado de acción.",
423
+ customLeftActionTitle: "Acción izquierda personalizada",
424
+ },
425
+ titleModes: {
426
+ name: "Alineamiento para el título",
427
+ description:
428
+ "El título puede ser forzado a permanecer centrado (por defecto), pero podría cortarse si es demasiado largo. También puedes hacer que se ajuste a los botones a la izquierda o derecha.",
429
+ centeredTitle: "Título centrado",
430
+ flexTitle: "Título flexible",
431
+ },
432
+ styling: {
433
+ name: "Estilo",
434
+ description: "El componente puede ser configurado fácilmente.",
435
+ styledTitle: "Título estilizado",
436
+ styledWrapperTitle: "Contenedor estilizado",
437
+ tintedIconsTitle: "Íconos coloreados",
438
+ },
439
+ },
440
+ },
441
+ demoEmptyState: {
442
+ description:
443
+ "Un componente para cuando no hay información que mostrar. Puede usarse también para guiar al usuario sobre qué hacer a continuación.",
444
+ useCase: {
445
+ presets: {
446
+ name: "Preajustes",
447
+ description:
448
+ "Puedes crear distintos conjuntos de texto/imagen. Por ejemplo, con un ajuste predefinido `generic`. Si quieres tener un EmptyState completamente personalizado, ten en cuenta que no hay un valor por defecto.",
449
+ },
450
+ passingContent: {
451
+ name: "Entregando contenido",
452
+ description: "Hay varias formas de entregar contenido.",
453
+ customizeImageHeading: "Personalizar la imagen",
454
+ customizeImageContent: "Puedes pasar cualquier una imagen de distintas fuentes.",
455
+ viaHeadingProp: "A través del atributo `heading`",
456
+ viaContentProp: "A través del atributo `content`.",
457
+ viaButtonProp: "A través del atributo `button`",
458
+ },
459
+ styling: {
460
+ name: "Estilo",
461
+ description: "El componente puede ser configurado fácilmente.",
462
+ },
463
+ },
464
+ },
465
+ }
466
+
467
+ export default demoEs
468
+
469
+ // @demo remove-file