gtx-cli 2.6.31 → 2.7.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 (348) hide show
  1. package/CHANGELOG.md +4 -1261
  2. package/README.md +12 -3
  3. package/dist/bin/bin-entry.js +2 -1
  4. package/dist/config/generateSettings.d.ts +1 -9
  5. package/dist/config/generateSettings.js +1 -214
  6. package/dist/config/resolveConfig.d.ts +1 -4
  7. package/dist/config/resolveConfig.js +1 -33
  8. package/dist/fs/config/setupConfig.d.ts +1 -17
  9. package/dist/fs/config/setupConfig.js +1 -50
  10. package/dist/fs/matchFiles.d.ts +1 -1
  11. package/dist/fs/matchFiles.js +1 -8
  12. package/dist/functions.d.ts +1 -7
  13. package/dist/functions.js +1 -6
  14. package/dist/index.d.ts +1 -4
  15. package/dist/index.js +1 -27
  16. package/dist/main.js +2 -2
  17. package/dist/next/parse/handleInitGT.d.ts +1 -7
  18. package/dist/next/parse/handleInitGT.js +1 -157
  19. package/dist/next/parse/wrapContent.d.ts +1 -12
  20. package/dist/next/parse/wrapContent.js +1 -164
  21. package/dist/react/parse/wrapContent.d.ts +1 -12
  22. package/dist/react/parse/wrapContent.js +1 -162
  23. package/dist/types/index.d.ts +1 -243
  24. package/dist/types/index.js +1 -1
  25. package/dist/utils/installPackage.d.ts +1 -3
  26. package/dist/utils/installPackage.js +1 -77
  27. package/dist/utils/packageInfo.d.ts +1 -3
  28. package/dist/utils/packageInfo.js +1 -17
  29. package/dist/utils/packageJson.d.ts +1 -6
  30. package/dist/utils/packageJson.js +1 -68
  31. package/dist/utils/packageManager.d.ts +1 -28
  32. package/dist/utils/packageManager.js +1 -269
  33. package/package.json +11 -97
  34. package/dist/api/collectUserEditDiffs.d.ts +0 -9
  35. package/dist/api/collectUserEditDiffs.js +0 -159
  36. package/dist/api/downloadFileBatch.d.ts +0 -23
  37. package/dist/api/downloadFileBatch.js +0 -190
  38. package/dist/api/saveLocalEdits.d.ts +0 -6
  39. package/dist/api/saveLocalEdits.js +0 -38
  40. package/dist/cli/base.d.ts +0 -59
  41. package/dist/cli/base.js +0 -529
  42. package/dist/cli/commands/download.d.ts +0 -8
  43. package/dist/cli/commands/download.js +0 -51
  44. package/dist/cli/commands/enqueue.d.ts +0 -9
  45. package/dist/cli/commands/enqueue.js +0 -27
  46. package/dist/cli/commands/setupProject.d.ts +0 -7
  47. package/dist/cli/commands/setupProject.js +0 -37
  48. package/dist/cli/commands/stage.d.ts +0 -9
  49. package/dist/cli/commands/stage.js +0 -59
  50. package/dist/cli/commands/translate.d.ts +0 -7
  51. package/dist/cli/commands/translate.js +0 -70
  52. package/dist/cli/commands/upload.d.ts +0 -13
  53. package/dist/cli/commands/upload.js +0 -142
  54. package/dist/cli/commands/utils/validation.d.ts +0 -13
  55. package/dist/cli/commands/utils/validation.js +0 -38
  56. package/dist/cli/flags.d.ts +0 -15
  57. package/dist/cli/flags.js +0 -70
  58. package/dist/cli/inline.d.ts +0 -17
  59. package/dist/cli/inline.js +0 -135
  60. package/dist/cli/next.d.ts +0 -10
  61. package/dist/cli/next.js +0 -12
  62. package/dist/cli/node.d.ts +0 -10
  63. package/dist/cli/node.js +0 -9
  64. package/dist/cli/react.d.ts +0 -12
  65. package/dist/cli/react.js +0 -72
  66. package/dist/config/optionPresets.d.ts +0 -3
  67. package/dist/config/optionPresets.js +0 -65
  68. package/dist/config/utils.d.ts +0 -2
  69. package/dist/config/utils.js +0 -4
  70. package/dist/config/validateSettings.d.ts +0 -3
  71. package/dist/config/validateSettings.js +0 -32
  72. package/dist/console/colors.d.ts +0 -6
  73. package/dist/console/colors.js +0 -19
  74. package/dist/console/displayTranslateSummary.d.ts +0 -1
  75. package/dist/console/displayTranslateSummary.js +0 -42
  76. package/dist/console/formatting.d.ts +0 -1
  77. package/dist/console/formatting.js +0 -7
  78. package/dist/console/index.d.ts +0 -34
  79. package/dist/console/index.js +0 -46
  80. package/dist/console/logger.d.ts +0 -35
  81. package/dist/console/logger.js +0 -250
  82. package/dist/console/logging.d.ts +0 -52
  83. package/dist/console/logging.js +0 -175
  84. package/dist/formats/files/aggregateFiles.d.ts +0 -4
  85. package/dist/formats/files/aggregateFiles.js +0 -156
  86. package/dist/formats/files/collectFiles.d.ts +0 -6
  87. package/dist/formats/files/collectFiles.js +0 -49
  88. package/dist/formats/files/convertToFileTranslationData.d.ts +0 -15
  89. package/dist/formats/files/convertToFileTranslationData.js +0 -21
  90. package/dist/formats/files/fileMapping.d.ts +0 -11
  91. package/dist/formats/files/fileMapping.js +0 -115
  92. package/dist/formats/files/preprocess/mdx.d.ts +0 -6
  93. package/dist/formats/files/preprocess/mdx.js +0 -14
  94. package/dist/formats/files/preprocess/mintlify.d.ts +0 -5
  95. package/dist/formats/files/preprocess/mintlify.js +0 -15
  96. package/dist/formats/files/preprocessContent.d.ts +0 -8
  97. package/dist/formats/files/preprocessContent.js +0 -23
  98. package/dist/formats/files/save.d.ts +0 -5
  99. package/dist/formats/files/save.js +0 -17
  100. package/dist/formats/files/supportedFiles.d.ts +0 -11
  101. package/dist/formats/files/supportedFiles.js +0 -20
  102. package/dist/formats/json/extractJson.d.ts +0 -15
  103. package/dist/formats/json/extractJson.js +0 -101
  104. package/dist/formats/json/flattenJson.d.ts +0 -14
  105. package/dist/formats/json/flattenJson.js +0 -64
  106. package/dist/formats/json/mergeJson.d.ts +0 -13
  107. package/dist/formats/json/mergeJson.js +0 -367
  108. package/dist/formats/json/parseJson.d.ts +0 -2
  109. package/dist/formats/json/parseJson.js +0 -109
  110. package/dist/formats/json/utils.d.ts +0 -47
  111. package/dist/formats/json/utils.js +0 -150
  112. package/dist/formats/utils.d.ts +0 -2
  113. package/dist/formats/utils.js +0 -24
  114. package/dist/formats/yaml/mergeYaml.d.ts +0 -5
  115. package/dist/formats/yaml/mergeYaml.js +0 -61
  116. package/dist/formats/yaml/parseYaml.d.ts +0 -5
  117. package/dist/formats/yaml/parseYaml.js +0 -24
  118. package/dist/formats/yaml/utils.d.ts +0 -2
  119. package/dist/formats/yaml/utils.js +0 -23
  120. package/dist/fs/clearLocaleDirs.d.ts +0 -8
  121. package/dist/fs/clearLocaleDirs.js +0 -126
  122. package/dist/fs/config/downloadedVersions.d.ts +0 -21
  123. package/dist/fs/config/downloadedVersions.js +0 -50
  124. package/dist/fs/config/loadConfig.d.ts +0 -1
  125. package/dist/fs/config/loadConfig.js +0 -9
  126. package/dist/fs/config/parseFilesConfig.d.ts +0 -27
  127. package/dist/fs/config/parseFilesConfig.js +0 -150
  128. package/dist/fs/config/updateConfig.d.ts +0 -21
  129. package/dist/fs/config/updateConfig.js +0 -57
  130. package/dist/fs/config/updateVersions.d.ts +0 -11
  131. package/dist/fs/config/updateVersions.js +0 -30
  132. package/dist/fs/copyFile.d.ts +0 -7
  133. package/dist/fs/copyFile.js +0 -39
  134. package/dist/fs/createLoadTranslationsFile.d.ts +0 -1
  135. package/dist/fs/createLoadTranslationsFile.js +0 -49
  136. package/dist/fs/determineFramework.d.ts +0 -5
  137. package/dist/fs/determineFramework.js +0 -53
  138. package/dist/fs/findFilepath.d.ts +0 -36
  139. package/dist/fs/findFilepath.js +0 -90
  140. package/dist/fs/index.d.ts +0 -1
  141. package/dist/fs/index.js +0 -1
  142. package/dist/fs/loadJSON.d.ts +0 -6
  143. package/dist/fs/loadJSON.js +0 -17
  144. package/dist/fs/saveJSON.d.ts +0 -1
  145. package/dist/fs/saveJSON.js +0 -7
  146. package/dist/fs/utils.d.ts +0 -1
  147. package/dist/fs/utils.js +0 -16
  148. package/dist/generated/version.d.ts +0 -1
  149. package/dist/generated/version.js +0 -2
  150. package/dist/git/branches.d.ts +0 -7
  151. package/dist/git/branches.js +0 -88
  152. package/dist/hooks/postProcess.d.ts +0 -4
  153. package/dist/hooks/postProcess.js +0 -110
  154. package/dist/locadex/setupFlow.d.ts +0 -2
  155. package/dist/locadex/setupFlow.js +0 -9
  156. package/dist/next/config/parseNextConfig.d.ts +0 -10
  157. package/dist/next/config/parseNextConfig.js +0 -53
  158. package/dist/next/jsx/utils.d.ts +0 -7
  159. package/dist/next/jsx/utils.js +0 -42
  160. package/dist/react/config/createESBuildConfig.d.ts +0 -2
  161. package/dist/react/config/createESBuildConfig.js +0 -119
  162. package/dist/react/jsx/evaluateJsx.d.ts +0 -24
  163. package/dist/react/jsx/evaluateJsx.js +0 -123
  164. package/dist/react/jsx/utils/buildImportMap.d.ts +0 -9
  165. package/dist/react/jsx/utils/buildImportMap.js +0 -30
  166. package/dist/react/jsx/utils/constants.d.ts +0 -15
  167. package/dist/react/jsx/utils/constants.js +0 -49
  168. package/dist/react/jsx/utils/getCalleeNameFromExpression.d.ts +0 -9
  169. package/dist/react/jsx/utils/getCalleeNameFromExpression.js +0 -32
  170. package/dist/react/jsx/utils/getPathsAndAliases.d.ts +0 -21
  171. package/dist/react/jsx/utils/getPathsAndAliases.js +0 -91
  172. package/dist/react/jsx/utils/isNumberLiteral.d.ts +0 -7
  173. package/dist/react/jsx/utils/isNumberLiteral.js +0 -13
  174. package/dist/react/jsx/utils/jsxParsing/addGTIdentifierToSyntaxTree.d.ts +0 -9
  175. package/dist/react/jsx/utils/jsxParsing/addGTIdentifierToSyntaxTree.js +0 -138
  176. package/dist/react/jsx/utils/jsxParsing/handleChildrenWhitespace.d.ts +0 -6
  177. package/dist/react/jsx/utils/jsxParsing/handleChildrenWhitespace.js +0 -197
  178. package/dist/react/jsx/utils/jsxParsing/multiplication/findMultiplicationNode.d.ts +0 -13
  179. package/dist/react/jsx/utils/jsxParsing/multiplication/findMultiplicationNode.js +0 -42
  180. package/dist/react/jsx/utils/jsxParsing/multiplication/multiplyJsxTree.d.ts +0 -5
  181. package/dist/react/jsx/utils/jsxParsing/multiplication/multiplyJsxTree.js +0 -69
  182. package/dist/react/jsx/utils/jsxParsing/parseJsx.d.ts +0 -33
  183. package/dist/react/jsx/utils/jsxParsing/parseJsx.js +0 -918
  184. package/dist/react/jsx/utils/jsxParsing/parseTProps.d.ts +0 -8
  185. package/dist/react/jsx/utils/jsxParsing/parseTProps.js +0 -65
  186. package/dist/react/jsx/utils/jsxParsing/removeNullChildrenFields.d.ts +0 -2
  187. package/dist/react/jsx/utils/jsxParsing/removeNullChildrenFields.js +0 -61
  188. package/dist/react/jsx/utils/jsxParsing/types.d.ts +0 -48
  189. package/dist/react/jsx/utils/jsxParsing/types.js +0 -34
  190. package/dist/react/jsx/utils/mapAttributeName.d.ts +0 -11
  191. package/dist/react/jsx/utils/mapAttributeName.js +0 -12
  192. package/dist/react/jsx/utils/parseAst.d.ts +0 -31
  193. package/dist/react/jsx/utils/parseAst.js +0 -278
  194. package/dist/react/jsx/utils/parseDeclareStatic.d.ts +0 -15
  195. package/dist/react/jsx/utils/parseDeclareStatic.js +0 -540
  196. package/dist/react/jsx/utils/parseString.d.ts +0 -25
  197. package/dist/react/jsx/utils/parseString.js +0 -540
  198. package/dist/react/jsx/utils/parseStringFunction.d.ts +0 -30
  199. package/dist/react/jsx/utils/parseStringFunction.js +0 -348
  200. package/dist/react/jsx/utils/resolveImportPath.d.ts +0 -11
  201. package/dist/react/jsx/utils/resolveImportPath.js +0 -111
  202. package/dist/react/jsx/utils/stringParsing/processTranslationCall/extractStringEntryMetadata.d.ts +0 -29
  203. package/dist/react/jsx/utils/stringParsing/processTranslationCall/extractStringEntryMetadata.js +0 -86
  204. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleInvalidTranslationCall.d.ts +0 -14
  205. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleInvalidTranslationCall.js +0 -24
  206. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleLiteralTranslationCall.d.ts +0 -19
  207. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleLiteralTranslationCall.js +0 -31
  208. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleStaticTranslationCall.d.ts +0 -22
  209. package/dist/react/jsx/utils/stringParsing/processTranslationCall/handleStaticTranslationCall.js +0 -51
  210. package/dist/react/jsx/utils/stringParsing/processTranslationCall/index.d.ts +0 -18
  211. package/dist/react/jsx/utils/stringParsing/processTranslationCall/index.js +0 -39
  212. package/dist/react/jsx/utils/stringParsing/processTranslationCall/routeTranslationCall.d.ts +0 -24
  213. package/dist/react/jsx/utils/stringParsing/processTranslationCall/routeTranslationCall.js +0 -68
  214. package/dist/react/jsx/utils/stringParsing/types.d.ts +0 -41
  215. package/dist/react/jsx/utils/stringParsing/types.js +0 -1
  216. package/dist/react/jsx/utils/types.d.ts +0 -14
  217. package/dist/react/jsx/utils/types.js +0 -1
  218. package/dist/react/jsx/utils/validateStringFunction.d.ts +0 -7
  219. package/dist/react/jsx/utils/validateStringFunction.js +0 -31
  220. package/dist/react/jsx/wrapJsx.d.ts +0 -51
  221. package/dist/react/jsx/wrapJsx.js +0 -387
  222. package/dist/react/parse/addVitePlugin/index.d.ts +0 -22
  223. package/dist/react/parse/addVitePlugin/index.js +0 -41
  224. package/dist/react/parse/addVitePlugin/installCompiler.d.ts +0 -8
  225. package/dist/react/parse/addVitePlugin/installCompiler.js +0 -22
  226. package/dist/react/parse/addVitePlugin/updateViteConfig.d.ts +0 -19
  227. package/dist/react/parse/addVitePlugin/updateViteConfig.js +0 -120
  228. package/dist/react/parse/addVitePlugin/utils/addCompilerImport.d.ts +0 -9
  229. package/dist/react/parse/addVitePlugin/utils/addCompilerImport.js +0 -34
  230. package/dist/react/parse/addVitePlugin/utils/addPluginInvocation.d.ts +0 -11
  231. package/dist/react/parse/addVitePlugin/utils/addPluginInvocation.js +0 -48
  232. package/dist/react/parse/addVitePlugin/utils/checkCompilerImport.d.ts +0 -15
  233. package/dist/react/parse/addVitePlugin/utils/checkCompilerImport.js +0 -113
  234. package/dist/react/parse/addVitePlugin/utils/checkPluginInvocation.d.ts +0 -12
  235. package/dist/react/parse/addVitePlugin/utils/checkPluginInvocation.js +0 -32
  236. package/dist/react/parse/createDictionaryUpdates.d.ts +0 -3
  237. package/dist/react/parse/createDictionaryUpdates.js +0 -187
  238. package/dist/react/parse/createInlineUpdates.d.ts +0 -13
  239. package/dist/react/parse/createInlineUpdates.js +0 -161
  240. package/dist/react/utils/flattenDictionary.d.ts +0 -20
  241. package/dist/react/utils/flattenDictionary.js +0 -75
  242. package/dist/react/utils/getEntryAndMetadata.d.ts +0 -5
  243. package/dist/react/utils/getEntryAndMetadata.js +0 -11
  244. package/dist/react/utils/getVariableName.d.ts +0 -25
  245. package/dist/react/utils/getVariableName.js +0 -37
  246. package/dist/setup/agentInstructions.d.ts +0 -24
  247. package/dist/setup/agentInstructions.js +0 -138
  248. package/dist/setup/detectFramework.d.ts +0 -31
  249. package/dist/setup/detectFramework.js +0 -106
  250. package/dist/setup/frameworkUtils.d.ts +0 -3
  251. package/dist/setup/frameworkUtils.js +0 -30
  252. package/dist/setup/instructions/base.md +0 -29
  253. package/dist/setup/instructions/gt-next.md +0 -107
  254. package/dist/setup/instructions/gt-react.md +0 -98
  255. package/dist/setup/userInput.d.ts +0 -4
  256. package/dist/setup/userInput.js +0 -32
  257. package/dist/setup/wizard.d.ts +0 -3
  258. package/dist/setup/wizard.js +0 -147
  259. package/dist/state/recentDownloads.d.ts +0 -12
  260. package/dist/state/recentDownloads.js +0 -18
  261. package/dist/state/translateWarnings.d.ts +0 -10
  262. package/dist/state/translateWarnings.js +0 -13
  263. package/dist/translation/parse.d.ts +0 -17
  264. package/dist/translation/parse.js +0 -77
  265. package/dist/translation/stage.d.ts +0 -3
  266. package/dist/translation/stage.js +0 -44
  267. package/dist/translation/validate.d.ts +0 -14
  268. package/dist/translation/validate.js +0 -100
  269. package/dist/types/branch.d.ts +0 -14
  270. package/dist/types/branch.js +0 -1
  271. package/dist/types/data/json.d.ts +0 -6
  272. package/dist/types/data/json.js +0 -1
  273. package/dist/types/data.d.ts +0 -37
  274. package/dist/types/data.js +0 -1
  275. package/dist/types/files.d.ts +0 -8
  276. package/dist/types/files.js +0 -1
  277. package/dist/types/libraries.d.ts +0 -31
  278. package/dist/types/libraries.js +0 -72
  279. package/dist/types/parsing.d.ts +0 -3
  280. package/dist/types/parsing.js +0 -1
  281. package/dist/utils/addExplicitAnchorIds.d.ts +0 -24
  282. package/dist/utils/addExplicitAnchorIds.js +0 -416
  283. package/dist/utils/constants.d.ts +0 -5
  284. package/dist/utils/constants.js +0 -6
  285. package/dist/utils/credentials.d.ts +0 -12
  286. package/dist/utils/credentials.js +0 -120
  287. package/dist/utils/flattenJsonFiles.d.ts +0 -2
  288. package/dist/utils/flattenJsonFiles.js +0 -36
  289. package/dist/utils/gitDiff.d.ts +0 -8
  290. package/dist/utils/gitDiff.js +0 -34
  291. package/dist/utils/gt.d.ts +0 -2
  292. package/dist/utils/gt.js +0 -2
  293. package/dist/utils/hash.d.ts +0 -6
  294. package/dist/utils/hash.js +0 -11
  295. package/dist/utils/headers.d.ts +0 -1
  296. package/dist/utils/headers.js +0 -14
  297. package/dist/utils/localizeRelativeAssets.d.ts +0 -8
  298. package/dist/utils/localizeRelativeAssets.js +0 -166
  299. package/dist/utils/localizeStaticImports.d.ts +0 -15
  300. package/dist/utils/localizeStaticImports.js +0 -397
  301. package/dist/utils/localizeStaticUrls.d.ts +0 -19
  302. package/dist/utils/localizeStaticUrls.js +0 -450
  303. package/dist/utils/mintlifyTitleFallback.d.ts +0 -6
  304. package/dist/utils/mintlifyTitleFallback.js +0 -80
  305. package/dist/utils/parse/needsCJS.d.ts +0 -20
  306. package/dist/utils/parse/needsCJS.js +0 -72
  307. package/dist/utils/persistPostprocessHashes.d.ts +0 -12
  308. package/dist/utils/persistPostprocessHashes.js +0 -39
  309. package/dist/utils/processAnchorIds.d.ts +0 -6
  310. package/dist/utils/processAnchorIds.js +0 -56
  311. package/dist/utils/processOpenApi.d.ts +0 -8
  312. package/dist/utils/processOpenApi.js +0 -651
  313. package/dist/utils/sanitizeFileContent.d.ts +0 -6
  314. package/dist/utils/sanitizeFileContent.js +0 -29
  315. package/dist/utils/sharedStaticAssets.d.ts +0 -9
  316. package/dist/utils/sharedStaticAssets.js +0 -384
  317. package/dist/utils/validateMdx.d.ts +0 -10
  318. package/dist/utils/validateMdx.js +0 -25
  319. package/dist/utils/wrapPlainUrls.d.ts +0 -8
  320. package/dist/utils/wrapPlainUrls.js +0 -72
  321. package/dist/workflows/download.d.ts +0 -32
  322. package/dist/workflows/download.js +0 -131
  323. package/dist/workflows/enqueue.d.ts +0 -17
  324. package/dist/workflows/enqueue.js +0 -59
  325. package/dist/workflows/setupProject.d.ts +0 -13
  326. package/dist/workflows/setupProject.js +0 -48
  327. package/dist/workflows/stage.d.ts +0 -18
  328. package/dist/workflows/stage.js +0 -59
  329. package/dist/workflows/steps/BranchStep.d.ts +0 -13
  330. package/dist/workflows/steps/BranchStep.js +0 -161
  331. package/dist/workflows/steps/DownloadStep.d.ts +0 -19
  332. package/dist/workflows/steps/DownloadStep.js +0 -131
  333. package/dist/workflows/steps/EnqueueStep.d.ts +0 -15
  334. package/dist/workflows/steps/EnqueueStep.js +0 -33
  335. package/dist/workflows/steps/PollJobsStep.d.ts +0 -31
  336. package/dist/workflows/steps/PollJobsStep.js +0 -288
  337. package/dist/workflows/steps/SetupStep.d.ts +0 -16
  338. package/dist/workflows/steps/SetupStep.js +0 -72
  339. package/dist/workflows/steps/UploadSourcesStep.d.ts +0 -27
  340. package/dist/workflows/steps/UploadSourcesStep.js +0 -131
  341. package/dist/workflows/steps/UploadTranslationsStep.d.ts +0 -22
  342. package/dist/workflows/steps/UploadTranslationsStep.js +0 -71
  343. package/dist/workflows/steps/UserEditDiffsStep.d.ts +0 -11
  344. package/dist/workflows/steps/UserEditDiffsStep.js +0 -30
  345. package/dist/workflows/steps/WorkflowStep.d.ts +0 -4
  346. package/dist/workflows/steps/WorkflowStep.js +0 -2
  347. package/dist/workflows/upload.d.ts +0 -15
  348. package/dist/workflows/upload.js +0 -47
@@ -1,397 +0,0 @@
1
- import * as fs from 'fs';
2
- import * as path from 'path';
3
- import { createFileMapping } from '../formats/files/fileMapping.js';
4
- import micromatch from 'micromatch';
5
- import { unified } from 'unified';
6
- import remarkParse from 'remark-parse';
7
- import remarkMdx from 'remark-mdx';
8
- import remarkFrontmatter from 'remark-frontmatter';
9
- import { visit } from 'unist-util-visit';
10
- const { isMatch } = micromatch;
11
- /**
12
- * Localizes static imports in content files.
13
- * Currently only supported for md and mdx files. (/docs/ -> /[locale]/docs/)
14
- * @param settings - The settings object containing the project configuration.
15
- * @returns void
16
- *
17
- * @TODO This is an experimental feature, and only works in very specific cases. This needs to be improved before
18
- * it can be enabled by default.
19
- *
20
- * Before this becomes a non-experimental feature, we need to:
21
- * - Support more file types
22
- * - Support more complex paths
23
- */
24
- export default async function localizeStaticImports(settings, includeFiles) {
25
- if (!settings.files ||
26
- (Object.keys(settings.files.placeholderPaths).length === 1 &&
27
- settings.files.placeholderPaths.gt)) {
28
- return;
29
- }
30
- const { resolvedPaths: sourceFiles } = settings.files;
31
- const fileMapping = createFileMapping(sourceFiles, settings.files.placeholderPaths, settings.files.transformPaths, settings.locales, settings.defaultLocale);
32
- // Process all file types at once with a single call
33
- const processPromises = [];
34
- // First, process default locale files (from source files)
35
- // This is needed because they might not be in the fileMapping if they're not being translated
36
- if (!fileMapping[settings.defaultLocale] && !includeFiles) {
37
- const defaultLocaleFiles = [];
38
- // Collect all .md and .mdx files from sourceFiles
39
- if (sourceFiles.md) {
40
- defaultLocaleFiles.push(...sourceFiles.md);
41
- }
42
- if (sourceFiles.mdx) {
43
- defaultLocaleFiles.push(...sourceFiles.mdx);
44
- }
45
- if (defaultLocaleFiles.length > 0) {
46
- const defaultPromise = Promise.all(defaultLocaleFiles.map(async (filePath) => {
47
- // Check if file exists before processing
48
- if (!fs.existsSync(filePath)) {
49
- return;
50
- }
51
- // Get file content
52
- const fileContent = await fs.promises.readFile(filePath, 'utf8');
53
- // Localize the file using default locale
54
- const localizedFile = localizeStaticImportsForFile(fileContent, settings.defaultLocale, settings.defaultLocale, // Process as default locale
55
- settings.options?.docsHideDefaultLocaleImport || false, settings.options?.docsImportPattern, settings.options?.excludeStaticImports, filePath, settings.options);
56
- // Write the localized file back to the same path
57
- await fs.promises.writeFile(filePath, localizedFile);
58
- }));
59
- processPromises.push(defaultPromise);
60
- }
61
- }
62
- // Then process all other locales from fileMapping
63
- const mappingPromises = Object.entries(fileMapping).map(async ([locale, filesMap]) => {
64
- // Get all files that are md or mdx
65
- const targetFiles = Object.values(filesMap).filter((p) => (p.endsWith('.md') || p.endsWith('.mdx')) &&
66
- (!includeFiles || includeFiles.has(p)));
67
- // Replace the placeholder path with the target path
68
- await Promise.all(targetFiles.map(async (filePath) => {
69
- // Check if file exists before processing
70
- if (!fs.existsSync(filePath)) {
71
- return;
72
- }
73
- // Get file content
74
- const fileContent = await fs.promises.readFile(filePath, 'utf8');
75
- // Localize the file
76
- const localizedFile = localizeStaticImportsForFile(fileContent, settings.defaultLocale, locale, settings.options?.docsHideDefaultLocaleImport || false, settings.options?.docsImportPattern, settings.options?.excludeStaticImports, filePath, settings.options);
77
- // Write the localized file to the target path
78
- await fs.promises.writeFile(filePath, localizedFile);
79
- }));
80
- });
81
- processPromises.push(...mappingPromises);
82
- await Promise.all(processPromises);
83
- }
84
- /**
85
- * Determines if an import path should be processed based on pattern matching
86
- */
87
- function shouldProcessImportPath(importPath, patternHead, targetLocale, defaultLocale) {
88
- const patternWithoutSlash = patternHead.replace(/\/$/, '');
89
- if (targetLocale === defaultLocale) {
90
- // For default locale processing, check if path contains the pattern
91
- return importPath.includes(patternWithoutSlash);
92
- }
93
- else {
94
- // For non-default locales, check if path starts with pattern
95
- return importPath.includes(patternWithoutSlash);
96
- }
97
- }
98
- /**
99
- * Checks if an import path should be excluded based on exclusion patterns
100
- */
101
- function isImportPathExcluded(importPath, exclude, defaultLocale) {
102
- const excludePatterns = exclude.map((p) => p.replace(/\[locale\]/g, defaultLocale));
103
- return excludePatterns.some((pattern) => isMatch(importPath, pattern));
104
- }
105
- /**
106
- * Transforms import path for default locale processing
107
- */
108
- function transformDefaultLocaleImportPath(fullPath, patternHead, defaultLocale, hideDefaultLocale) {
109
- if (hideDefaultLocale) {
110
- // Remove locale from imports that have it: '/snippets/en/file.mdx' -> '/snippets/file.mdx'
111
- if (fullPath.includes(`/${defaultLocale}/`)) {
112
- return fullPath.replace(`/${defaultLocale}/`, '/');
113
- }
114
- else if (fullPath.endsWith(`/${defaultLocale}`)) {
115
- return fullPath.replace(`/${defaultLocale}`, '');
116
- }
117
- return null; // Path doesn't have default locale
118
- }
119
- else {
120
- // Add locale to imports that don't have it: '/snippets/file.mdx' -> '/snippets/en/file.mdx'
121
- if (fullPath.includes(`/${defaultLocale}/`) ||
122
- fullPath.endsWith(`/${defaultLocale}`)) {
123
- return null; // Already has default locale
124
- }
125
- if (fullPath.startsWith(patternHead)) {
126
- const pathAfterHead = fullPath.slice(patternHead.length);
127
- if (pathAfterHead) {
128
- return `${patternHead}${defaultLocale}/${pathAfterHead}`;
129
- }
130
- else {
131
- return `${patternHead.replace(/\/$/, '')}/${defaultLocale}`;
132
- }
133
- }
134
- return null; // Path doesn't match pattern
135
- }
136
- }
137
- /**
138
- * Transforms import path for non-default locale processing with hideDefaultLocale=true
139
- */
140
- function transformNonDefaultLocaleImportPathWithHidden(fullPath, patternHead, targetLocale, defaultLocale) {
141
- // Check if already localized
142
- if (fullPath.startsWith(`${patternHead}${targetLocale}/`) ||
143
- fullPath === `${patternHead}${targetLocale}`) {
144
- return null;
145
- }
146
- // Replace default locale with target locale
147
- const expectedPathWithDefaultLocale = `${patternHead}${defaultLocale}`;
148
- if (fullPath.startsWith(`${expectedPathWithDefaultLocale}/`) ||
149
- fullPath === expectedPathWithDefaultLocale) {
150
- return fullPath.replace(`${patternHead}${defaultLocale}`, `${patternHead}${targetLocale}`);
151
- }
152
- // Handle exact pattern match
153
- if (fullPath === patternHead.replace(/\/$/, '')) {
154
- return `${patternHead.replace(/\/$/, '')}/${targetLocale}`;
155
- }
156
- // Add target locale to path without any locale
157
- const pathAfterHead = fullPath.slice(patternHead.length);
158
- return pathAfterHead
159
- ? `${patternHead}${targetLocale}/${pathAfterHead}`
160
- : `${patternHead}${targetLocale}`;
161
- }
162
- /**
163
- * Transforms import path for non-default locale processing with hideDefaultLocale=false
164
- */
165
- function transformNonDefaultLocaleImportPath(fullPath, patternHead, targetLocale, defaultLocale) {
166
- // If already localized to target, skip
167
- const expectedPathWithTarget = `${patternHead}${targetLocale}`;
168
- if (fullPath.startsWith(`${expectedPathWithTarget}/`) ||
169
- fullPath === expectedPathWithTarget) {
170
- return null;
171
- }
172
- const expectedPathWithLocale = `${patternHead}${defaultLocale}`;
173
- if (fullPath.startsWith(`${expectedPathWithLocale}/`) ||
174
- fullPath === expectedPathWithLocale) {
175
- // Replace existing default locale with target locale
176
- return fullPath.replace(`${patternHead}${defaultLocale}`, `${patternHead}${targetLocale}`);
177
- }
178
- else if (fullPath.startsWith(patternHead)) {
179
- // Add target locale to path that doesn't have any locale
180
- const pathAfterHead = fullPath.slice(patternHead.length);
181
- if (pathAfterHead) {
182
- return `${patternHead}${targetLocale}/${pathAfterHead}`;
183
- }
184
- else {
185
- return `${patternHead.replace(/\/$/, '')}/${targetLocale}`;
186
- }
187
- }
188
- return null; // Path doesn't match pattern
189
- }
190
- /**
191
- * Main import path transformation function that delegates to specific scenarios
192
- */
193
- function transformImportPath(fullPath, patternHead, targetLocale, defaultLocale, hideDefaultLocale, currentFilePath, projectRoot = process.cwd(), // fallback if not provided
194
- rewrites) {
195
- // Apply explicit rewrites first (e.g., Docusaurus @site/docs -> @site/i18n/[locale]/...)
196
- if (rewrites && rewrites.length > 0) {
197
- const localeMap = {
198
- '[locale]': targetLocale,
199
- '[defaultLocale]': defaultLocale,
200
- };
201
- for (const { match, replace } of rewrites) {
202
- const resolvedMatch = match.replace(/\[locale\]|\[defaultLocale\]/g, (token) => localeMap[token] || token);
203
- if (fullPath.startsWith(resolvedMatch)) {
204
- const remainder = fullPath.slice(resolvedMatch.length);
205
- const resolvedReplace = replace.replace(/\[locale\]|\[defaultLocale\]/g, (token) => localeMap[token] || token);
206
- let newPath;
207
- if (resolvedReplace.endsWith('/')) {
208
- newPath = `${resolvedReplace}${remainder.replace(/^\//, '')}`;
209
- }
210
- else if (remainder.startsWith('/')) {
211
- newPath = `${resolvedReplace}${remainder}`;
212
- }
213
- else {
214
- newPath = `${resolvedReplace}/${remainder}`;
215
- }
216
- return newPath;
217
- }
218
- }
219
- }
220
- let newPath;
221
- if (targetLocale === defaultLocale) {
222
- newPath = transformDefaultLocaleImportPath(fullPath, patternHead, defaultLocale, hideDefaultLocale);
223
- }
224
- else if (hideDefaultLocale) {
225
- newPath = transformNonDefaultLocaleImportPathWithHidden(fullPath, patternHead, targetLocale, defaultLocale);
226
- }
227
- else {
228
- newPath = transformNonDefaultLocaleImportPath(fullPath, patternHead, targetLocale, defaultLocale);
229
- }
230
- if (!newPath)
231
- return null;
232
- if (currentFilePath) {
233
- let resolvedPath;
234
- if (newPath.startsWith('/')) {
235
- // Interpret as project-root relative
236
- resolvedPath = path.join(projectRoot, newPath.replace(/^\//, ''));
237
- }
238
- else {
239
- // Relative to current file
240
- const currentDir = path.dirname(currentFilePath);
241
- resolvedPath = path.resolve(currentDir, newPath);
242
- }
243
- if (!fs.existsSync(resolvedPath)) {
244
- return null;
245
- }
246
- }
247
- return newPath;
248
- }
249
- /**
250
- * AST-based transformation for MDX files using remark-mdx
251
- */
252
- function transformMdxImports(mdxContent, defaultLocale, targetLocale, hideDefaultLocale, pattern = '/[locale]', exclude = [], currentFilePath, options) {
253
- const transformedImports = [];
254
- // Don't auto-prefix relative patterns that start with . or ..
255
- if (!pattern.startsWith('/') && !pattern.startsWith('.')) {
256
- pattern = '/' + pattern;
257
- }
258
- const patternHead = pattern.split('[locale]')[0];
259
- // Quick check: if the file doesn't contain the pattern, skip expensive AST parsing
260
- // For default locale processing, we also need to check if content might need adjustment
261
- if (targetLocale === defaultLocale) {
262
- // For default locale files, we always need to check as we're looking for either:
263
- // - paths without locale (when hideDefaultLocale=false)
264
- // - paths with default locale (when hideDefaultLocale=true)
265
- const patternWithoutSlash = patternHead.replace(/\/$/, '');
266
- if (!mdxContent.includes(patternWithoutSlash)) {
267
- return {
268
- content: mdxContent,
269
- hasChanges: false,
270
- transformedImports: [],
271
- };
272
- }
273
- }
274
- else {
275
- // For non-default locales, use the original logic
276
- if (!mdxContent.includes(patternHead.replace(/\/$/, ''))) {
277
- return {
278
- content: mdxContent,
279
- hasChanges: false,
280
- transformedImports: [],
281
- };
282
- }
283
- }
284
- // Parse the MDX content into an AST
285
- let processedAst;
286
- try {
287
- const parseProcessor = unified()
288
- .use(remarkParse)
289
- .use(remarkFrontmatter, ['yaml', 'toml'])
290
- .use(remarkMdx);
291
- const ast = parseProcessor.parse(mdxContent);
292
- processedAst = parseProcessor.runSync(ast);
293
- }
294
- catch {
295
- return transformImportsStringFallback(mdxContent, defaultLocale, targetLocale, hideDefaultLocale, pattern, exclude, currentFilePath, options);
296
- }
297
- let content = mdxContent;
298
- // Visit only mdxjsEsm nodes (import/export statements) to collect replacements
299
- visit(processedAst, 'mdxjsEsm', (node) => {
300
- if (node.value && node.value.includes(patternHead.replace(/\/$/, ''))) {
301
- // Find import lines that need transformation
302
- const lines = node.value.split('\n');
303
- lines.forEach((line) => {
304
- // Only process import lines that match our pattern
305
- if (!line.trim().startsWith('import ')) {
306
- return;
307
- }
308
- // Check if this line should be processed
309
- if (!shouldProcessImportPath(line, patternHead, targetLocale, defaultLocale)) {
310
- return;
311
- }
312
- // Extract the path from the import statement
313
- const quotes = ['"', "'", '`'];
314
- for (const quote of quotes) {
315
- // Try both with and without trailing slash
316
- let startPattern = `${quote}${patternHead}`;
317
- let startIndex = line.indexOf(startPattern);
318
- // If pattern has trailing slash but path doesn't, try without slash
319
- if (startIndex === -1 && patternHead.endsWith('/')) {
320
- const patternWithoutSlash = patternHead.slice(0, -1);
321
- startPattern = `${quote}${patternWithoutSlash}`;
322
- startIndex = line.indexOf(startPattern);
323
- }
324
- if (startIndex === -1)
325
- continue;
326
- const pathStart = startIndex + 1; // After the quote
327
- const pathEnd = line.indexOf(quote, pathStart);
328
- if (pathEnd === -1)
329
- continue;
330
- const fullPath = line.slice(pathStart, pathEnd);
331
- // Transform the import path
332
- const newPath = transformImportPath(fullPath, patternHead, targetLocale, defaultLocale, hideDefaultLocale, currentFilePath, process.cwd(), options?.docsImportRewrites);
333
- if (!newPath) {
334
- continue; // No transformation needed
335
- }
336
- // Check exclusions
337
- if (isImportPathExcluded(fullPath, exclude, defaultLocale)) {
338
- continue;
339
- }
340
- // Apply the transformation to the original content
341
- // Simply replace the import path with the new path
342
- content = content.replace(`${quote}${fullPath}${quote}`, `${quote}${newPath}${quote}`);
343
- transformedImports.push({ originalPath: fullPath, newPath });
344
- break;
345
- }
346
- });
347
- }
348
- });
349
- return {
350
- content,
351
- hasChanges: transformedImports.length > 0,
352
- transformedImports,
353
- };
354
- }
355
- /**
356
- * String-based fallback for import localization when MDX parsing fails (e.g., on .md files)
357
- */
358
- function transformImportsStringFallback(mdxContent, defaultLocale, targetLocale, hideDefaultLocale, pattern = '/[locale]', exclude = [], currentFilePath, options) {
359
- const transformedImports = [];
360
- if (!pattern.startsWith('/') && !pattern.startsWith('.')) {
361
- pattern = '/' + pattern;
362
- }
363
- const patternHead = pattern.split('[locale]')[0];
364
- let content = mdxContent;
365
- const importRegex = /import\s+[^'"]*['"]([^'"]+)['"]\s*;?/g;
366
- let match;
367
- while ((match = importRegex.exec(mdxContent)) !== null) {
368
- const fullMatch = match[0];
369
- const importPath = match[1];
370
- if (!shouldProcessImportPath(importPath, patternHead, targetLocale, defaultLocale)) {
371
- continue;
372
- }
373
- if (isImportPathExcluded(importPath, exclude, defaultLocale)) {
374
- continue;
375
- }
376
- const newPath = transformImportPath(importPath, patternHead, targetLocale, defaultLocale, hideDefaultLocale, currentFilePath, process.cwd(), options?.docsImportRewrites);
377
- if (!newPath)
378
- continue;
379
- const updatedImport = fullMatch.replace(importPath, newPath);
380
- content = content.replace(fullMatch, updatedImport);
381
- transformedImports.push({ originalPath: importPath, newPath });
382
- }
383
- return {
384
- content,
385
- hasChanges: transformedImports.length > 0,
386
- transformedImports,
387
- };
388
- }
389
- /**
390
- * AST-based transformation for MDX files only
391
- */
392
- function localizeStaticImportsForFile(file, defaultLocale, targetLocale, hideDefaultLocale, pattern = '/[locale]', // eg /docs/[locale] or /[locale]
393
- exclude = [], currentFilePath, options) {
394
- // For MDX files, use AST-based transformation
395
- const result = transformMdxImports(file, defaultLocale, targetLocale, hideDefaultLocale, pattern, exclude, currentFilePath, options);
396
- return result.content;
397
- }
@@ -1,19 +0,0 @@
1
- import { Settings } from '../types/index.js';
2
- /**
3
- * Localizes static urls in content files.
4
- * Currently only supported for md and mdx files. (/docs/ -> /[locale]/docs/)
5
- * @param settings - The settings object containing the project configuration.
6
- * @returns void
7
- *
8
- * @TODO This is an experimental feature, and only works in very specific cases. This needs to be improved before
9
- * it can be enabled by default.
10
- *
11
- * Before this becomes a non-experimental feature, we need to:
12
- * - Support more file types
13
- * - Support more complex paths
14
- */
15
- export default function localizeStaticUrls(settings: Settings, targetLocales?: string[], includeFiles?: Set<string>): Promise<void>;
16
- /**
17
- * Main URL transformation function that delegates to specific scenarios
18
- */
19
- export declare function transformUrlPath(originalUrl: string, patternHead: string, targetLocale: string, defaultLocale: string, hideDefaultLocale: boolean): string | null;