fss-link 1.0.49 → 1.0.51

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 (419) hide show
  1. package/dist/index.js +0 -0
  2. package/dist/package.json +2 -2
  3. package/dist/src/config/auth.js +8 -5
  4. package/dist/src/config/auth.js.map +1 -1
  5. package/dist/src/config/database.d.ts +103 -11
  6. package/dist/src/config/database.js +301 -59
  7. package/dist/src/config/database.js.map +1 -1
  8. package/dist/src/config/databaseBackup.d.ts +114 -0
  9. package/dist/src/config/databaseBackup.js +334 -0
  10. package/dist/src/config/databaseBackup.js.map +1 -0
  11. package/dist/src/config/databaseMigrations.d.ts +63 -0
  12. package/dist/src/config/databaseMigrations.js +379 -0
  13. package/dist/src/config/databaseMigrations.js.map +1 -0
  14. package/dist/src/config/databasePool.d.ts +70 -0
  15. package/dist/src/config/databasePool.js +193 -0
  16. package/dist/src/config/databasePool.js.map +1 -0
  17. package/dist/src/config/queryOptimizer.d.ts +127 -0
  18. package/dist/src/config/queryOptimizer.js +309 -0
  19. package/dist/src/config/queryOptimizer.js.map +1 -0
  20. package/dist/src/utils/sandbox.js +2 -8
  21. package/dist/src/utils/sandbox.js.map +1 -1
  22. package/dist/src/validateNonInterActiveAuth.js +3 -7
  23. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  24. package/dist/tsconfig.tsbuildinfo +1 -1
  25. package/package.json +2 -2
  26. package/dist/commands/mcp/add.test.ts +0 -122
  27. package/dist/commands/mcp/add.ts +0 -222
  28. package/dist/commands/mcp/list.test.ts +0 -154
  29. package/dist/commands/mcp/list.ts +0 -139
  30. package/dist/commands/mcp/remove.test.ts +0 -69
  31. package/dist/commands/mcp/remove.ts +0 -60
  32. package/dist/commands/mcp.test.ts +0 -55
  33. package/dist/commands/mcp.ts +0 -27
  34. package/dist/config/apiValidation.test.ts +0 -118
  35. package/dist/config/auth.test.ts +0 -79
  36. package/dist/config/auth.ts +0 -100
  37. package/dist/config/config.integration.test.ts +0 -407
  38. package/dist/config/config.test.ts +0 -1952
  39. package/dist/config/config.ts +0 -690
  40. package/dist/config/database.test.ts +0 -96
  41. package/dist/config/database.ts +0 -824
  42. package/dist/config/extension.test.ts +0 -236
  43. package/dist/config/extension.ts +0 -180
  44. package/dist/config/keyBindings.test.ts +0 -62
  45. package/dist/config/keyBindings.ts +0 -184
  46. package/dist/config/modelManager.ts +0 -326
  47. package/dist/config/providerManager.ts +0 -244
  48. package/dist/config/providerPersistence.test.ts +0 -377
  49. package/dist/config/providerPersistence.ts +0 -105
  50. package/dist/config/sandboxConfig.ts +0 -107
  51. package/dist/config/settings.test.ts +0 -1424
  52. package/dist/config/settings.ts +0 -517
  53. package/dist/config/settingsSchema.test.ts +0 -252
  54. package/dist/config/settingsSchema.ts +0 -728
  55. package/dist/config/trustedFolders.test.ts +0 -208
  56. package/dist/config/trustedFolders.ts +0 -167
  57. package/dist/gemini.test.tsx +0 -252
  58. package/dist/gemini.tsx +0 -357
  59. package/dist/generated/git-commit.ts +0 -10
  60. package/dist/index.ts +0 -21
  61. package/dist/nonInteractiveCli.test.ts +0 -276
  62. package/dist/nonInteractiveCli.ts +0 -143
  63. package/dist/patches/is-in-ci.ts +0 -17
  64. package/dist/services/BuiltinCommandLoader.test.ts +0 -127
  65. package/dist/services/BuiltinCommandLoader.ts +0 -95
  66. package/dist/services/CommandService.test.ts +0 -352
  67. package/dist/services/CommandService.ts +0 -103
  68. package/dist/services/FileCommandLoader.test.ts +0 -1002
  69. package/dist/services/FileCommandLoader.ts +0 -289
  70. package/dist/services/McpPromptLoader.ts +0 -231
  71. package/dist/services/SearchEngineConfigProvider.ts +0 -100
  72. package/dist/services/prompt-processors/argumentProcessor.test.ts +0 -41
  73. package/dist/services/prompt-processors/argumentProcessor.ts +0 -23
  74. package/dist/services/prompt-processors/shellProcessor.test.ts +0 -709
  75. package/dist/services/prompt-processors/shellProcessor.ts +0 -248
  76. package/dist/services/prompt-processors/types.ts +0 -44
  77. package/dist/services/types.ts +0 -24
  78. package/dist/src/config/apiValidation.test.d.ts +0 -6
  79. package/dist/src/config/apiValidation.test.js +0 -99
  80. package/dist/src/config/apiValidation.test.js.map +0 -1
  81. package/dist/src/config/database.test.d.ts +0 -6
  82. package/dist/src/config/database.test.js +0 -80
  83. package/dist/src/config/database.test.js.map +0 -1
  84. package/dist/src/config/providerManager.d.ts +0 -74
  85. package/dist/src/config/providerManager.js +0 -203
  86. package/dist/src/config/providerManager.js.map +0 -1
  87. package/dist/src/config/providerPersistence.test.d.ts +0 -6
  88. package/dist/src/config/providerPersistence.test.js +0 -283
  89. package/dist/src/config/providerPersistence.test.js.map +0 -1
  90. package/dist/src/ui/components/GeminiKeyDialog.d.ts +0 -11
  91. package/dist/src/ui/components/GeminiKeyDialog.js +0 -156
  92. package/dist/src/ui/components/GeminiKeyDialog.js.map +0 -1
  93. package/dist/src/ui/components/OpenAIEndpointDialog.d.ts +0 -19
  94. package/dist/src/ui/components/OpenAIEndpointDialog.js +0 -163
  95. package/dist/src/ui/components/OpenAIEndpointDialog.js.map +0 -1
  96. package/dist/test-setup.ts +0 -12
  97. package/dist/test-utils/customMatchers.ts +0 -65
  98. package/dist/test-utils/mockCommandContext.test.ts +0 -62
  99. package/dist/test-utils/mockCommandContext.ts +0 -105
  100. package/dist/test-utils/render.tsx +0 -18
  101. package/dist/ui/App.test.tsx +0 -2181
  102. package/dist/ui/App.tsx +0 -1344
  103. package/dist/ui/IdeIntegrationNudge.tsx +0 -98
  104. package/dist/ui/__snapshots__/App.test.tsx.snap +0 -124
  105. package/dist/ui/colors.ts +0 -56
  106. package/dist/ui/commands/aboutCommand.test.ts +0 -153
  107. package/dist/ui/commands/aboutCommand.ts +0 -49
  108. package/dist/ui/commands/authCommand.test.ts +0 -36
  109. package/dist/ui/commands/authCommand.ts +0 -17
  110. package/dist/ui/commands/bugCommand.test.ts +0 -114
  111. package/dist/ui/commands/bugCommand.ts +0 -92
  112. package/dist/ui/commands/chatCommand.test.ts +0 -414
  113. package/dist/ui/commands/chatCommand.ts +0 -280
  114. package/dist/ui/commands/clearCommand.test.ts +0 -100
  115. package/dist/ui/commands/clearCommand.ts +0 -29
  116. package/dist/ui/commands/compressCommand.test.ts +0 -129
  117. package/dist/ui/commands/compressCommand.ts +0 -78
  118. package/dist/ui/commands/contextCommand.ts +0 -132
  119. package/dist/ui/commands/copyCommand.test.ts +0 -296
  120. package/dist/ui/commands/copyCommand.ts +0 -67
  121. package/dist/ui/commands/corgiCommand.test.ts +0 -34
  122. package/dist/ui/commands/corgiCommand.ts +0 -16
  123. package/dist/ui/commands/directoryCommand.test.tsx +0 -185
  124. package/dist/ui/commands/directoryCommand.tsx +0 -179
  125. package/dist/ui/commands/docsCommand.test.ts +0 -99
  126. package/dist/ui/commands/docsCommand.ts +0 -42
  127. package/dist/ui/commands/editorCommand.test.ts +0 -30
  128. package/dist/ui/commands/editorCommand.ts +0 -21
  129. package/dist/ui/commands/extensionsCommand.test.ts +0 -67
  130. package/dist/ui/commands/extensionsCommand.ts +0 -46
  131. package/dist/ui/commands/helpCommand.test.ts +0 -52
  132. package/dist/ui/commands/helpCommand.ts +0 -23
  133. package/dist/ui/commands/ideCommand.test.ts +0 -255
  134. package/dist/ui/commands/ideCommand.ts +0 -283
  135. package/dist/ui/commands/initCommand.test.ts +0 -127
  136. package/dist/ui/commands/initCommand.ts +0 -117
  137. package/dist/ui/commands/mcpCommand.test.ts +0 -1057
  138. package/dist/ui/commands/mcpCommand.ts +0 -531
  139. package/dist/ui/commands/memoryCommand.test.ts +0 -344
  140. package/dist/ui/commands/memoryCommand.ts +0 -305
  141. package/dist/ui/commands/privacyCommand.test.ts +0 -38
  142. package/dist/ui/commands/privacyCommand.ts +0 -17
  143. package/dist/ui/commands/quitCommand.test.ts +0 -55
  144. package/dist/ui/commands/quitCommand.ts +0 -36
  145. package/dist/ui/commands/restoreCommand.test.ts +0 -250
  146. package/dist/ui/commands/restoreCommand.ts +0 -157
  147. package/dist/ui/commands/searchEngineSetupCommand.ts +0 -18
  148. package/dist/ui/commands/settingsCommand.test.ts +0 -36
  149. package/dist/ui/commands/settingsCommand.ts +0 -17
  150. package/dist/ui/commands/setupGithubCommand.test.ts +0 -238
  151. package/dist/ui/commands/setupGithubCommand.ts +0 -212
  152. package/dist/ui/commands/speakCommand.ts +0 -175
  153. package/dist/ui/commands/statsCommand.test.ts +0 -78
  154. package/dist/ui/commands/statsCommand.ts +0 -70
  155. package/dist/ui/commands/terminalSetupCommand.test.ts +0 -85
  156. package/dist/ui/commands/terminalSetupCommand.ts +0 -45
  157. package/dist/ui/commands/themeCommand.test.ts +0 -38
  158. package/dist/ui/commands/themeCommand.ts +0 -17
  159. package/dist/ui/commands/toolsCommand.test.ts +0 -105
  160. package/dist/ui/commands/toolsCommand.ts +0 -71
  161. package/dist/ui/commands/ttsCommand.ts +0 -143
  162. package/dist/ui/commands/types.ts +0 -204
  163. package/dist/ui/commands/vimCommand.ts +0 -25
  164. package/dist/ui/commands/voiceCommand.ts +0 -125
  165. package/dist/ui/components/AboutBox.tsx +0 -133
  166. package/dist/ui/components/AsciiArt.ts +0 -54
  167. package/dist/ui/components/AuthDialog.test.tsx +0 -334
  168. package/dist/ui/components/AuthDialog.tsx +0 -289
  169. package/dist/ui/components/AuthInProgress.tsx +0 -62
  170. package/dist/ui/components/AutoAcceptIndicator.tsx +0 -47
  171. package/dist/ui/components/ConsoleSummaryDisplay.tsx +0 -35
  172. package/dist/ui/components/ContextSummaryDisplay.test.tsx +0 -85
  173. package/dist/ui/components/ContextSummaryDisplay.tsx +0 -120
  174. package/dist/ui/components/ContextUsageDisplay.tsx +0 -77
  175. package/dist/ui/components/DebugProfiler.tsx +0 -36
  176. package/dist/ui/components/DetailedMessagesDisplay.tsx +0 -82
  177. package/dist/ui/components/EditorSettingsDialog.tsx +0 -172
  178. package/dist/ui/components/FolderTrustDialog.test.tsx +0 -36
  179. package/dist/ui/components/FolderTrustDialog.tsx +0 -74
  180. package/dist/ui/components/Footer.test.tsx +0 -159
  181. package/dist/ui/components/Footer.tsx +0 -158
  182. package/dist/ui/components/GeminiKeyDialog.tsx +0 -252
  183. package/dist/ui/components/GeminiRespondingSpinner.tsx +0 -34
  184. package/dist/ui/components/Header.test.tsx +0 -44
  185. package/dist/ui/components/Header.tsx +0 -70
  186. package/dist/ui/components/Help.tsx +0 -174
  187. package/dist/ui/components/HistoryItemDisplay.test.tsx +0 -125
  188. package/dist/ui/components/HistoryItemDisplay.tsx +0 -98
  189. package/dist/ui/components/InputPrompt.test.tsx +0 -1467
  190. package/dist/ui/components/InputPrompt.tsx +0 -641
  191. package/dist/ui/components/LMStudioModelPrompt.tsx +0 -215
  192. package/dist/ui/components/LoadingIndicator.test.tsx +0 -296
  193. package/dist/ui/components/LoadingIndicator.tsx +0 -82
  194. package/dist/ui/components/MemoryUsageDisplay.tsx +0 -36
  195. package/dist/ui/components/ModelStatsDisplay.test.tsx +0 -252
  196. package/dist/ui/components/ModelStatsDisplay.tsx +0 -197
  197. package/dist/ui/components/OllamaModelPrompt.tsx +0 -206
  198. package/dist/ui/components/OpenAIEndpointDialog.tsx +0 -261
  199. package/dist/ui/components/OpenAIKeyPrompt.test.tsx +0 -64
  200. package/dist/ui/components/OpenAIKeyPrompt.tsx +0 -197
  201. package/dist/ui/components/PrepareLabel.tsx +0 -48
  202. package/dist/ui/components/SearchEngineConfigDialog.tsx +0 -280
  203. package/dist/ui/components/SessionSummaryDisplay.test.tsx +0 -75
  204. package/dist/ui/components/SessionSummaryDisplay.tsx +0 -18
  205. package/dist/ui/components/SettingsDialog.test.tsx +0 -865
  206. package/dist/ui/components/SettingsDialog.tsx +0 -753
  207. package/dist/ui/components/ShellConfirmationDialog.test.tsx +0 -53
  208. package/dist/ui/components/ShellConfirmationDialog.tsx +0 -103
  209. package/dist/ui/components/ShellModeIndicator.tsx +0 -18
  210. package/dist/ui/components/ShowMoreLines.tsx +0 -40
  211. package/dist/ui/components/StatsDisplay.test.tsx +0 -401
  212. package/dist/ui/components/StatsDisplay.tsx +0 -273
  213. package/dist/ui/components/SuggestionsDisplay.tsx +0 -102
  214. package/dist/ui/components/ThemeDialog.tsx +0 -310
  215. package/dist/ui/components/Tips.tsx +0 -45
  216. package/dist/ui/components/TodoDisplay.test.tsx +0 -97
  217. package/dist/ui/components/TodoDisplay.tsx +0 -72
  218. package/dist/ui/components/ToolStatsDisplay.test.tsx +0 -180
  219. package/dist/ui/components/ToolStatsDisplay.tsx +0 -208
  220. package/dist/ui/components/UpdateNotification.tsx +0 -23
  221. package/dist/ui/components/WelcomeBackDialog.tsx +0 -290
  222. package/dist/ui/components/__snapshots__/IDEContextDetailDisplay.test.tsx.snap +0 -24
  223. package/dist/ui/components/__snapshots__/ModelStatsDisplay.test.tsx.snap +0 -121
  224. package/dist/ui/components/__snapshots__/SessionSummaryDisplay.test.tsx.snap +0 -30
  225. package/dist/ui/components/__snapshots__/ShellConfirmationDialog.test.tsx.snap +0 -21
  226. package/dist/ui/components/__snapshots__/StatsDisplay.test.tsx.snap +0 -264
  227. package/dist/ui/components/__snapshots__/ToolStatsDisplay.test.tsx.snap +0 -91
  228. package/dist/ui/components/messages/CompressionMessage.tsx +0 -49
  229. package/dist/ui/components/messages/DiffRenderer.test.tsx +0 -365
  230. package/dist/ui/components/messages/DiffRenderer.tsx +0 -358
  231. package/dist/ui/components/messages/ErrorMessage.tsx +0 -31
  232. package/dist/ui/components/messages/GeminiMessage.tsx +0 -43
  233. package/dist/ui/components/messages/GeminiMessageContent.tsx +0 -43
  234. package/dist/ui/components/messages/InfoMessage.tsx +0 -32
  235. package/dist/ui/components/messages/ToolConfirmationMessage.test.tsx +0 -58
  236. package/dist/ui/components/messages/ToolConfirmationMessage.tsx +0 -297
  237. package/dist/ui/components/messages/ToolGroupMessage.tsx +0 -126
  238. package/dist/ui/components/messages/ToolMessage.test.tsx +0 -183
  239. package/dist/ui/components/messages/ToolMessage.tsx +0 -296
  240. package/dist/ui/components/messages/UserMessage.tsx +0 -43
  241. package/dist/ui/components/messages/UserShellMessage.tsx +0 -25
  242. package/dist/ui/components/shared/MaxSizedBox.test.tsx +0 -425
  243. package/dist/ui/components/shared/MaxSizedBox.tsx +0 -624
  244. package/dist/ui/components/shared/RadioButtonSelect.test.tsx +0 -181
  245. package/dist/ui/components/shared/RadioButtonSelect.tsx +0 -234
  246. package/dist/ui/components/shared/__snapshots__/RadioButtonSelect.test.tsx.snap +0 -47
  247. package/dist/ui/components/shared/text-buffer.test.ts +0 -1728
  248. package/dist/ui/components/shared/text-buffer.ts +0 -2227
  249. package/dist/ui/components/shared/vim-buffer-actions.test.ts +0 -1119
  250. package/dist/ui/components/shared/vim-buffer-actions.ts +0 -814
  251. package/dist/ui/constants.ts +0 -17
  252. package/dist/ui/contexts/KeypressContext.test.tsx +0 -391
  253. package/dist/ui/contexts/KeypressContext.tsx +0 -440
  254. package/dist/ui/contexts/OverflowContext.tsx +0 -87
  255. package/dist/ui/contexts/SessionContext.test.tsx +0 -132
  256. package/dist/ui/contexts/SessionContext.tsx +0 -143
  257. package/dist/ui/contexts/SettingsContext.tsx +0 -20
  258. package/dist/ui/contexts/StreamingContext.tsx +0 -22
  259. package/dist/ui/contexts/VimModeContext.tsx +0 -79
  260. package/dist/ui/editors/editorSettingsManager.ts +0 -66
  261. package/dist/ui/hooks/atCommandProcessor.test.ts +0 -1102
  262. package/dist/ui/hooks/atCommandProcessor.ts +0 -485
  263. package/dist/ui/hooks/shellCommandProcessor.test.ts +0 -481
  264. package/dist/ui/hooks/shellCommandProcessor.ts +0 -314
  265. package/dist/ui/hooks/slashCommandProcessor.test.ts +0 -1044
  266. package/dist/ui/hooks/slashCommandProcessor.ts +0 -595
  267. package/dist/ui/hooks/useAtCompletion.test.ts +0 -497
  268. package/dist/ui/hooks/useAtCompletion.ts +0 -244
  269. package/dist/ui/hooks/useAuthCommand.ts +0 -129
  270. package/dist/ui/hooks/useAutoAcceptIndicator.test.ts +0 -300
  271. package/dist/ui/hooks/useAutoAcceptIndicator.ts +0 -52
  272. package/dist/ui/hooks/useBracketedPaste.ts +0 -37
  273. package/dist/ui/hooks/useCommandCompletion.test.ts +0 -518
  274. package/dist/ui/hooks/useCommandCompletion.tsx +0 -238
  275. package/dist/ui/hooks/useCompletion.ts +0 -128
  276. package/dist/ui/hooks/useConsoleMessages.test.ts +0 -147
  277. package/dist/ui/hooks/useConsoleMessages.ts +0 -110
  278. package/dist/ui/hooks/useEditorSettings.test.ts +0 -283
  279. package/dist/ui/hooks/useEditorSettings.ts +0 -75
  280. package/dist/ui/hooks/useFocus.test.ts +0 -119
  281. package/dist/ui/hooks/useFocus.ts +0 -48
  282. package/dist/ui/hooks/useFolderTrust.test.ts +0 -159
  283. package/dist/ui/hooks/useFolderTrust.ts +0 -72
  284. package/dist/ui/hooks/useGeminiStream.test.tsx +0 -1998
  285. package/dist/ui/hooks/useGeminiStream.ts +0 -1017
  286. package/dist/ui/hooks/useGitBranchName.test.ts +0 -280
  287. package/dist/ui/hooks/useGitBranchName.ts +0 -79
  288. package/dist/ui/hooks/useHistoryManager.test.ts +0 -202
  289. package/dist/ui/hooks/useHistoryManager.ts +0 -111
  290. package/dist/ui/hooks/useInputHistory.test.ts +0 -261
  291. package/dist/ui/hooks/useInputHistory.ts +0 -111
  292. package/dist/ui/hooks/useKeypress.test.ts +0 -280
  293. package/dist/ui/hooks/useKeypress.ts +0 -39
  294. package/dist/ui/hooks/useKittyKeyboardProtocol.ts +0 -31
  295. package/dist/ui/hooks/useLoadingIndicator.test.ts +0 -139
  296. package/dist/ui/hooks/useLoadingIndicator.ts +0 -57
  297. package/dist/ui/hooks/useLogger.ts +0 -32
  298. package/dist/ui/hooks/useMessageQueue.test.ts +0 -226
  299. package/dist/ui/hooks/useMessageQueue.ts +0 -69
  300. package/dist/ui/hooks/usePhraseCycler.test.ts +0 -145
  301. package/dist/ui/hooks/usePhraseCycler.ts +0 -198
  302. package/dist/ui/hooks/usePrivacySettings.test.ts +0 -242
  303. package/dist/ui/hooks/usePrivacySettings.ts +0 -150
  304. package/dist/ui/hooks/useReactToolScheduler.ts +0 -309
  305. package/dist/ui/hooks/useRefreshMemoryCommand.ts +0 -7
  306. package/dist/ui/hooks/useReverseSearchCompletion.test.tsx +0 -260
  307. package/dist/ui/hooks/useReverseSearchCompletion.tsx +0 -95
  308. package/dist/ui/hooks/useSettingsCommand.ts +0 -25
  309. package/dist/ui/hooks/useShellHistory.test.ts +0 -219
  310. package/dist/ui/hooks/useShellHistory.ts +0 -133
  311. package/dist/ui/hooks/useShowMemoryCommand.ts +0 -75
  312. package/dist/ui/hooks/useSlashCompletion.test.ts +0 -434
  313. package/dist/ui/hooks/useSlashCompletion.ts +0 -187
  314. package/dist/ui/hooks/useStateAndRef.ts +0 -36
  315. package/dist/ui/hooks/useTerminalSize.ts +0 -32
  316. package/dist/ui/hooks/useThemeCommand.ts +0 -110
  317. package/dist/ui/hooks/useTimer.test.ts +0 -120
  318. package/dist/ui/hooks/useTimer.ts +0 -65
  319. package/dist/ui/hooks/useToolScheduler.test.ts +0 -1123
  320. package/dist/ui/hooks/useWelcomeBack.ts +0 -253
  321. package/dist/ui/hooks/vim.test.ts +0 -1691
  322. package/dist/ui/hooks/vim.ts +0 -784
  323. package/dist/ui/keyMatchers.test.ts +0 -337
  324. package/dist/ui/keyMatchers.ts +0 -105
  325. package/dist/ui/privacy/CloudFreePrivacyNotice.tsx +0 -117
  326. package/dist/ui/privacy/CloudPaidPrivacyNotice.tsx +0 -59
  327. package/dist/ui/privacy/GeminiPrivacyNotice.tsx +0 -62
  328. package/dist/ui/privacy/PrivacyNotice.tsx +0 -42
  329. package/dist/ui/semantic-colors.ts +0 -26
  330. package/dist/ui/themes/ansi-light.ts +0 -150
  331. package/dist/ui/themes/ansi.ts +0 -159
  332. package/dist/ui/themes/atom-one-dark.ts +0 -147
  333. package/dist/ui/themes/ayu-light.ts +0 -139
  334. package/dist/ui/themes/ayu.ts +0 -113
  335. package/dist/ui/themes/color-utils.test.ts +0 -221
  336. package/dist/ui/themes/color-utils.ts +0 -231
  337. package/dist/ui/themes/default-light.ts +0 -108
  338. package/dist/ui/themes/default.ts +0 -151
  339. package/dist/ui/themes/dracula.ts +0 -124
  340. package/dist/ui/themes/fss-code-dark.ts +0 -156
  341. package/dist/ui/themes/fss-dark.ts +0 -113
  342. package/dist/ui/themes/fss-light.ts +0 -139
  343. package/dist/ui/themes/github-dark.ts +0 -147
  344. package/dist/ui/themes/github-light.ts +0 -149
  345. package/dist/ui/themes/googlecode.ts +0 -146
  346. package/dist/ui/themes/no-color.ts +0 -125
  347. package/dist/ui/themes/qwen-dark.ts +0 -118
  348. package/dist/ui/themes/qwen-light.ts +0 -144
  349. package/dist/ui/themes/semantic-tokens.ts +0 -127
  350. package/dist/ui/themes/shades-of-purple.ts +0 -352
  351. package/dist/ui/themes/theme-manager.test.ts +0 -99
  352. package/dist/ui/themes/theme-manager.ts +0 -257
  353. package/dist/ui/themes/theme.test.ts +0 -97
  354. package/dist/ui/themes/theme.ts +0 -451
  355. package/dist/ui/themes/xcode.ts +0 -154
  356. package/dist/ui/types.ts +0 -255
  357. package/dist/ui/utils/CodeColorizer.tsx +0 -217
  358. package/dist/ui/utils/ConsolePatcher.ts +0 -71
  359. package/dist/ui/utils/InlineMarkdownRenderer.tsx +0 -173
  360. package/dist/ui/utils/MarkdownDisplay.test.tsx +0 -244
  361. package/dist/ui/utils/MarkdownDisplay.tsx +0 -415
  362. package/dist/ui/utils/TableRenderer.tsx +0 -159
  363. package/dist/ui/utils/__snapshots__/MarkdownDisplay.test.tsx.snap +0 -93
  364. package/dist/ui/utils/clipboardUtils.test.ts +0 -76
  365. package/dist/ui/utils/clipboardUtils.ts +0 -149
  366. package/dist/ui/utils/commandUtils.test.ts +0 -384
  367. package/dist/ui/utils/commandUtils.ts +0 -106
  368. package/dist/ui/utils/computeStats.test.ts +0 -292
  369. package/dist/ui/utils/computeStats.ts +0 -86
  370. package/dist/ui/utils/displayUtils.test.ts +0 -58
  371. package/dist/ui/utils/displayUtils.ts +0 -32
  372. package/dist/ui/utils/formatters.test.ts +0 -72
  373. package/dist/ui/utils/formatters.ts +0 -63
  374. package/dist/ui/utils/isNarrowWidth.ts +0 -9
  375. package/dist/ui/utils/kittyProtocolDetector.ts +0 -105
  376. package/dist/ui/utils/markdownUtilities.test.ts +0 -50
  377. package/dist/ui/utils/markdownUtilities.ts +0 -125
  378. package/dist/ui/utils/platformConstants.ts +0 -52
  379. package/dist/ui/utils/terminalSetup.ts +0 -342
  380. package/dist/ui/utils/textUtils.ts +0 -40
  381. package/dist/ui/utils/updateCheck.test.ts +0 -163
  382. package/dist/ui/utils/updateCheck.ts +0 -100
  383. package/dist/utils/checks.ts +0 -28
  384. package/dist/utils/cleanup.test.ts +0 -68
  385. package/dist/utils/cleanup.ts +0 -36
  386. package/dist/utils/dialogScopeUtils.ts +0 -64
  387. package/dist/utils/events.ts +0 -14
  388. package/dist/utils/gitUtils.test.ts +0 -149
  389. package/dist/utils/gitUtils.ts +0 -116
  390. package/dist/utils/handleAutoUpdate.test.ts +0 -272
  391. package/dist/utils/handleAutoUpdate.ts +0 -145
  392. package/dist/utils/installationInfo.test.ts +0 -315
  393. package/dist/utils/installationInfo.ts +0 -176
  394. package/dist/utils/package.ts +0 -38
  395. package/dist/utils/readStdin.ts +0 -51
  396. package/dist/utils/resolvePath.ts +0 -21
  397. package/dist/utils/sandbox-macos-permissive-closed.sb +0 -32
  398. package/dist/utils/sandbox-macos-permissive-open.sb +0 -25
  399. package/dist/utils/sandbox-macos-permissive-proxied.sb +0 -37
  400. package/dist/utils/sandbox-macos-restrictive-closed.sb +0 -93
  401. package/dist/utils/sandbox-macos-restrictive-open.sb +0 -96
  402. package/dist/utils/sandbox-macos-restrictive-proxied.sb +0 -98
  403. package/dist/utils/sandbox.ts +0 -962
  404. package/dist/utils/settingsUtils.test.ts +0 -797
  405. package/dist/utils/settingsUtils.ts +0 -489
  406. package/dist/utils/spawnWrapper.ts +0 -9
  407. package/dist/utils/startupWarnings.test.ts +0 -83
  408. package/dist/utils/startupWarnings.ts +0 -40
  409. package/dist/utils/updateEventEmitter.ts +0 -13
  410. package/dist/utils/userStartupWarnings.test.ts +0 -87
  411. package/dist/utils/userStartupWarnings.ts +0 -69
  412. package/dist/utils/version.ts +0 -12
  413. package/dist/validateNonInterActiveAuth.test.ts +0 -260
  414. package/dist/validateNonInterActiveAuth.ts +0 -51
  415. package/dist/vitest.config.ts +0 -37
  416. package/dist/zed-integration/acp.ts +0 -366
  417. package/dist/zed-integration/fileSystemService.ts +0 -47
  418. package/dist/zed-integration/schema.ts +0 -466
  419. package/dist/zed-integration/zedIntegration.ts +0 -944
@@ -1,797 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- import { describe, it, expect } from 'vitest';
8
- import {
9
- // Schema utilities
10
- getSettingsByCategory,
11
- getSettingDefinition,
12
- requiresRestart,
13
- getDefaultValue,
14
- getRestartRequiredSettings,
15
- getEffectiveValue,
16
- getAllSettingKeys,
17
- getSettingsByType,
18
- getSettingsRequiringRestart,
19
- isValidSettingKey,
20
- getSettingCategory,
21
- shouldShowInDialog,
22
- getDialogSettingsByCategory,
23
- getDialogSettingsByType,
24
- getDialogSettingKeys,
25
- // Business logic utilities
26
- getSettingValue,
27
- isSettingModified,
28
- settingExistsInScope,
29
- setPendingSettingValue,
30
- hasRestartRequiredSettings,
31
- getRestartRequiredFromModified,
32
- getDisplayValue,
33
- isDefaultValue,
34
- isValueInherited,
35
- getEffectiveDisplayValue,
36
- } from './settingsUtils.js';
37
-
38
- describe('SettingsUtils', () => {
39
- describe('Schema Utilities', () => {
40
- describe('getSettingsByCategory', () => {
41
- it('should group settings by category', () => {
42
- const categories = getSettingsByCategory();
43
-
44
- expect(categories).toHaveProperty('General');
45
- expect(categories).toHaveProperty('Accessibility');
46
- expect(categories).toHaveProperty('Checkpointing');
47
- expect(categories).toHaveProperty('File Filtering');
48
- expect(categories).toHaveProperty('UI');
49
- expect(categories).toHaveProperty('Mode');
50
- expect(categories).toHaveProperty('Updates');
51
- });
52
-
53
- it('should include key property in grouped settings', () => {
54
- const categories = getSettingsByCategory();
55
-
56
- Object.entries(categories).forEach(([_category, settings]) => {
57
- settings.forEach((setting) => {
58
- expect(setting.key).toBeDefined();
59
- });
60
- });
61
- });
62
- });
63
-
64
- describe('getSettingDefinition', () => {
65
- it('should return definition for valid setting', () => {
66
- const definition = getSettingDefinition('showMemoryUsage');
67
- expect(definition).toBeDefined();
68
- expect(definition?.label).toBe('Show Memory Usage');
69
- });
70
-
71
- it('should return undefined for invalid setting', () => {
72
- const definition = getSettingDefinition('invalidSetting');
73
- expect(definition).toBeUndefined();
74
- });
75
- });
76
-
77
- describe('requiresRestart', () => {
78
- it('should return true for settings that require restart', () => {
79
- expect(requiresRestart('autoConfigureMaxOldSpaceSize')).toBe(true);
80
- expect(requiresRestart('checkpointing.enabled')).toBe(true);
81
- });
82
-
83
- it('should return false for settings that do not require restart', () => {
84
- expect(requiresRestart('showMemoryUsage')).toBe(false);
85
- expect(requiresRestart('hideTips')).toBe(false);
86
- });
87
-
88
- it('should return false for invalid settings', () => {
89
- expect(requiresRestart('invalidSetting')).toBe(false);
90
- });
91
- });
92
-
93
- describe('getDefaultValue', () => {
94
- it('should return correct default values', () => {
95
- expect(getDefaultValue('showMemoryUsage')).toBe(false);
96
- expect(getDefaultValue('fileFiltering.enableRecursiveFileSearch')).toBe(
97
- true,
98
- );
99
- });
100
-
101
- it('should return undefined for invalid settings', () => {
102
- expect(getDefaultValue('invalidSetting')).toBeUndefined();
103
- });
104
- });
105
-
106
- describe('getRestartRequiredSettings', () => {
107
- it('should return all settings that require restart', () => {
108
- const restartSettings = getRestartRequiredSettings();
109
- expect(restartSettings).toContain('autoConfigureMaxOldSpaceSize');
110
- expect(restartSettings).toContain('checkpointing.enabled');
111
- expect(restartSettings).not.toContain('showMemoryUsage');
112
- });
113
- });
114
-
115
- describe('getEffectiveValue', () => {
116
- it('should return value from settings when set', () => {
117
- const settings = { showMemoryUsage: true };
118
- const mergedSettings = { showMemoryUsage: false };
119
-
120
- const value = getEffectiveValue(
121
- 'showMemoryUsage',
122
- settings,
123
- mergedSettings,
124
- );
125
- expect(value).toBe(true);
126
- });
127
-
128
- it('should return value from merged settings when not set in current scope', () => {
129
- const settings = {};
130
- const mergedSettings = { showMemoryUsage: true };
131
-
132
- const value = getEffectiveValue(
133
- 'showMemoryUsage',
134
- settings,
135
- mergedSettings,
136
- );
137
- expect(value).toBe(true);
138
- });
139
-
140
- it('should return default value when not set anywhere', () => {
141
- const settings = {};
142
- const mergedSettings = {};
143
-
144
- const value = getEffectiveValue(
145
- 'showMemoryUsage',
146
- settings,
147
- mergedSettings,
148
- );
149
- expect(value).toBe(false); // default value
150
- });
151
-
152
- it('should handle nested settings correctly', () => {
153
- const settings = {
154
- accessibility: { disableLoadingPhrases: true },
155
- };
156
- const mergedSettings = {
157
- accessibility: { disableLoadingPhrases: false },
158
- };
159
-
160
- const value = getEffectiveValue(
161
- 'accessibility.disableLoadingPhrases',
162
- settings,
163
- mergedSettings,
164
- );
165
- expect(value).toBe(true);
166
- });
167
-
168
- it('should return undefined for invalid settings', () => {
169
- const settings = {};
170
- const mergedSettings = {};
171
-
172
- const value = getEffectiveValue(
173
- 'invalidSetting',
174
- settings,
175
- mergedSettings,
176
- );
177
- expect(value).toBeUndefined();
178
- });
179
- });
180
-
181
- describe('getAllSettingKeys', () => {
182
- it('should return all setting keys', () => {
183
- const keys = getAllSettingKeys();
184
- expect(keys).toContain('showMemoryUsage');
185
- expect(keys).toContain('accessibility.disableLoadingPhrases');
186
- expect(keys).toContain('checkpointing.enabled');
187
- });
188
- });
189
-
190
- describe('getSettingsByType', () => {
191
- it('should return only boolean settings', () => {
192
- const booleanSettings = getSettingsByType('boolean');
193
- expect(booleanSettings.length).toBeGreaterThan(0);
194
- booleanSettings.forEach((setting) => {
195
- expect(setting.type).toBe('boolean');
196
- });
197
- });
198
- });
199
-
200
- describe('getSettingsRequiringRestart', () => {
201
- it('should return only settings that require restart', () => {
202
- const restartSettings = getSettingsRequiringRestart();
203
- expect(restartSettings.length).toBeGreaterThan(0);
204
- restartSettings.forEach((setting) => {
205
- expect(setting.requiresRestart).toBe(true);
206
- });
207
- });
208
- });
209
-
210
- describe('isValidSettingKey', () => {
211
- it('should return true for valid setting keys', () => {
212
- expect(isValidSettingKey('showMemoryUsage')).toBe(true);
213
- expect(isValidSettingKey('accessibility.disableLoadingPhrases')).toBe(
214
- true,
215
- );
216
- });
217
-
218
- it('should return false for invalid setting keys', () => {
219
- expect(isValidSettingKey('invalidSetting')).toBe(false);
220
- expect(isValidSettingKey('')).toBe(false);
221
- });
222
- });
223
-
224
- describe('getSettingCategory', () => {
225
- it('should return correct category for valid settings', () => {
226
- expect(getSettingCategory('showMemoryUsage')).toBe('UI');
227
- expect(getSettingCategory('accessibility.disableLoadingPhrases')).toBe(
228
- 'Accessibility',
229
- );
230
- });
231
-
232
- it('should return undefined for invalid settings', () => {
233
- expect(getSettingCategory('invalidSetting')).toBeUndefined();
234
- });
235
- });
236
-
237
- describe('shouldShowInDialog', () => {
238
- it('should return true for settings marked to show in dialog', () => {
239
- expect(shouldShowInDialog('showMemoryUsage')).toBe(true);
240
- expect(shouldShowInDialog('vimMode')).toBe(true);
241
- expect(shouldShowInDialog('hideWindowTitle')).toBe(true);
242
- expect(shouldShowInDialog('usageStatisticsEnabled')).toBe(false);
243
- });
244
-
245
- it('should return false for settings marked to hide from dialog', () => {
246
- expect(shouldShowInDialog('selectedAuthType')).toBe(false);
247
- expect(shouldShowInDialog('coreTools')).toBe(false);
248
- expect(shouldShowInDialog('customThemes')).toBe(false);
249
- expect(shouldShowInDialog('theme')).toBe(false); // Changed to false
250
- expect(shouldShowInDialog('preferredEditor')).toBe(false); // Changed to false
251
- });
252
-
253
- it('should return true for invalid settings (default behavior)', () => {
254
- expect(shouldShowInDialog('invalidSetting')).toBe(true);
255
- });
256
- });
257
-
258
- describe('getDialogSettingsByCategory', () => {
259
- it('should only return settings marked for dialog display', async () => {
260
- const categories = getDialogSettingsByCategory();
261
-
262
- // Should include UI settings that are marked for dialog
263
- expect(categories['UI']).toBeDefined();
264
- const uiSettings = categories['UI'];
265
- const uiKeys = uiSettings.map((s) => s.key);
266
- expect(uiKeys).toContain('showMemoryUsage');
267
- expect(uiKeys).toContain('hideWindowTitle');
268
- expect(uiKeys).not.toContain('customThemes'); // This is marked false
269
- expect(uiKeys).not.toContain('theme'); // This is now marked false
270
- });
271
-
272
- it('should not include Advanced category settings', () => {
273
- const categories = getDialogSettingsByCategory();
274
-
275
- // Advanced settings should be filtered out
276
- expect(categories['Advanced']).toBeUndefined();
277
- });
278
-
279
- it('should include settings with showInDialog=true', () => {
280
- const categories = getDialogSettingsByCategory();
281
-
282
- const allSettings = Object.values(categories).flat();
283
- const allKeys = allSettings.map((s) => s.key);
284
-
285
- expect(allKeys).toContain('vimMode');
286
- expect(allKeys).toContain('ideMode');
287
- expect(allKeys).toContain('disableAutoUpdate');
288
- expect(allKeys).toContain('showMemoryUsage');
289
- expect(allKeys).not.toContain('usageStatisticsEnabled');
290
- expect(allKeys).not.toContain('selectedAuthType');
291
- expect(allKeys).not.toContain('coreTools');
292
- expect(allKeys).not.toContain('theme'); // Now hidden
293
- expect(allKeys).not.toContain('preferredEditor'); // Now hidden
294
- });
295
- });
296
-
297
- describe('getDialogSettingsByType', () => {
298
- it('should return only boolean dialog settings', () => {
299
- const booleanSettings = getDialogSettingsByType('boolean');
300
-
301
- const keys = booleanSettings.map((s) => s.key);
302
- expect(keys).toContain('showMemoryUsage');
303
- expect(keys).toContain('vimMode');
304
- expect(keys).toContain('hideWindowTitle');
305
- expect(keys).not.toContain('usageStatisticsEnabled');
306
- expect(keys).not.toContain('selectedAuthType'); // Advanced setting
307
- expect(keys).not.toContain('useExternalAuth'); // Advanced setting
308
- });
309
-
310
- it('should return only string dialog settings', () => {
311
- const stringSettings = getDialogSettingsByType('string');
312
-
313
- const keys = stringSettings.map((s) => s.key);
314
- // Note: theme and preferredEditor are now hidden from dialog
315
- expect(keys).not.toContain('theme'); // Now marked false
316
- expect(keys).not.toContain('preferredEditor'); // Now marked false
317
- expect(keys).not.toContain('selectedAuthType'); // Advanced setting
318
-
319
- // Most string settings are now hidden, so let's just check they exclude advanced ones
320
- expect(keys.every((key) => !key.startsWith('tool'))).toBe(true); // No tool-related settings
321
- });
322
- });
323
-
324
- describe('getDialogSettingKeys', () => {
325
- it('should return only settings marked for dialog display', () => {
326
- const dialogKeys = getDialogSettingKeys();
327
-
328
- // Should include settings marked for dialog
329
- expect(dialogKeys).toContain('showMemoryUsage');
330
- expect(dialogKeys).toContain('vimMode');
331
- expect(dialogKeys).toContain('hideWindowTitle');
332
- expect(dialogKeys).not.toContain('usageStatisticsEnabled');
333
- expect(dialogKeys).toContain('ideMode');
334
- expect(dialogKeys).toContain('disableAutoUpdate');
335
-
336
- // Should include nested settings marked for dialog
337
- expect(dialogKeys).toContain('fileFiltering.respectGitIgnore');
338
- expect(dialogKeys).toContain('fileFiltering.respectFssLinkIgnore');
339
- expect(dialogKeys).toContain('fileFiltering.enableRecursiveFileSearch');
340
-
341
- // Should NOT include settings marked as hidden
342
- expect(dialogKeys).not.toContain('theme'); // Hidden
343
- expect(dialogKeys).not.toContain('customThemes'); // Hidden
344
- expect(dialogKeys).not.toContain('preferredEditor'); // Hidden
345
- expect(dialogKeys).not.toContain('selectedAuthType'); // Advanced
346
- expect(dialogKeys).not.toContain('coreTools'); // Advanced
347
- expect(dialogKeys).not.toContain('mcpServers'); // Advanced
348
- expect(dialogKeys).not.toContain('telemetry'); // Advanced
349
- });
350
-
351
- it('should return fewer keys than getAllSettingKeys', () => {
352
- const allKeys = getAllSettingKeys();
353
- const dialogKeys = getDialogSettingKeys();
354
-
355
- expect(dialogKeys.length).toBeLessThan(allKeys.length);
356
- expect(dialogKeys.length).toBeGreaterThan(0);
357
- });
358
-
359
- it('should handle nested settings display correctly', () => {
360
- // Test the specific issue with fileFiltering.respectGitIgnore
361
- const key = 'fileFiltering.respectGitIgnore';
362
- const initialSettings = {};
363
- const pendingSettings = {};
364
-
365
- // Set the nested setting to true
366
- const updatedPendingSettings = setPendingSettingValue(
367
- key,
368
- true,
369
- pendingSettings,
370
- );
371
-
372
- // Check if the setting exists in pending settings
373
- const existsInPending = settingExistsInScope(
374
- key,
375
- updatedPendingSettings,
376
- );
377
- expect(existsInPending).toBe(true);
378
-
379
- // Get the value from pending settings
380
- const valueFromPending = getSettingValue(
381
- key,
382
- updatedPendingSettings,
383
- {},
384
- );
385
- expect(valueFromPending).toBe(true);
386
-
387
- // Test getDisplayValue should show the pending change
388
- const displayValue = getDisplayValue(
389
- key,
390
- initialSettings,
391
- {},
392
- new Set(),
393
- updatedPendingSettings,
394
- );
395
- expect(displayValue).toBe('true'); // Should show true (no * since value matches default)
396
-
397
- // Test that modified settings also show the * indicator
398
- const modifiedSettings = new Set([key]);
399
- const displayValueWithModified = getDisplayValue(
400
- key,
401
- initialSettings,
402
- {},
403
- modifiedSettings,
404
- {},
405
- );
406
- expect(displayValueWithModified).toBe('true*'); // Should show true* because it's in modified settings and default is true
407
- });
408
- });
409
- });
410
-
411
- describe('Business Logic Utilities', () => {
412
- describe('getSettingValue', () => {
413
- it('should return value from settings when set', () => {
414
- const settings = { showMemoryUsage: true };
415
- const mergedSettings = { showMemoryUsage: false };
416
-
417
- const value = getSettingValue(
418
- 'showMemoryUsage',
419
- settings,
420
- mergedSettings,
421
- );
422
- expect(value).toBe(true);
423
- });
424
-
425
- it('should return value from merged settings when not set in current scope', () => {
426
- const settings = {};
427
- const mergedSettings = { showMemoryUsage: true };
428
-
429
- const value = getSettingValue(
430
- 'showMemoryUsage',
431
- settings,
432
- mergedSettings,
433
- );
434
- expect(value).toBe(true);
435
- });
436
-
437
- it('should return default value for invalid setting', () => {
438
- const settings = {};
439
- const mergedSettings = {};
440
-
441
- const value = getSettingValue(
442
- 'invalidSetting',
443
- settings,
444
- mergedSettings,
445
- );
446
- expect(value).toBe(false); // Default fallback
447
- });
448
- });
449
-
450
- describe('isSettingModified', () => {
451
- it('should return true when value differs from default', () => {
452
- expect(isSettingModified('showMemoryUsage', true)).toBe(true);
453
- expect(
454
- isSettingModified('fileFiltering.enableRecursiveFileSearch', false),
455
- ).toBe(true);
456
- });
457
-
458
- it('should return false when value matches default', () => {
459
- expect(isSettingModified('showMemoryUsage', false)).toBe(false);
460
- expect(
461
- isSettingModified('fileFiltering.enableRecursiveFileSearch', true),
462
- ).toBe(false);
463
- });
464
- });
465
-
466
- describe('settingExistsInScope', () => {
467
- it('should return true for top-level settings that exist', () => {
468
- const settings = { showMemoryUsage: true };
469
- expect(settingExistsInScope('showMemoryUsage', settings)).toBe(true);
470
- });
471
-
472
- it('should return false for top-level settings that do not exist', () => {
473
- const settings = {};
474
- expect(settingExistsInScope('showMemoryUsage', settings)).toBe(false);
475
- });
476
-
477
- it('should return true for nested settings that exist', () => {
478
- const settings = {
479
- accessibility: { disableLoadingPhrases: true },
480
- };
481
- expect(
482
- settingExistsInScope('accessibility.disableLoadingPhrases', settings),
483
- ).toBe(true);
484
- });
485
-
486
- it('should return false for nested settings that do not exist', () => {
487
- const settings = {};
488
- expect(
489
- settingExistsInScope('accessibility.disableLoadingPhrases', settings),
490
- ).toBe(false);
491
- });
492
-
493
- it('should return false when parent exists but child does not', () => {
494
- const settings = { accessibility: {} };
495
- expect(
496
- settingExistsInScope('accessibility.disableLoadingPhrases', settings),
497
- ).toBe(false);
498
- });
499
- });
500
-
501
- describe('setPendingSettingValue', () => {
502
- it('should set top-level setting value', () => {
503
- const pendingSettings = {};
504
- const result = setPendingSettingValue(
505
- 'showMemoryUsage',
506
- true,
507
- pendingSettings,
508
- );
509
-
510
- expect(result.showMemoryUsage).toBe(true);
511
- });
512
-
513
- it('should set nested setting value', () => {
514
- const pendingSettings = {};
515
- const result = setPendingSettingValue(
516
- 'accessibility.disableLoadingPhrases',
517
- true,
518
- pendingSettings,
519
- );
520
-
521
- expect(result.accessibility?.disableLoadingPhrases).toBe(true);
522
- });
523
-
524
- it('should preserve existing nested settings', () => {
525
- const pendingSettings = {
526
- accessibility: { disableLoadingPhrases: false },
527
- };
528
- const result = setPendingSettingValue(
529
- 'accessibility.disableLoadingPhrases',
530
- true,
531
- pendingSettings,
532
- );
533
-
534
- expect(result.accessibility?.disableLoadingPhrases).toBe(true);
535
- });
536
-
537
- it('should not mutate original settings', () => {
538
- const pendingSettings = {};
539
- setPendingSettingValue('showMemoryUsage', true, pendingSettings);
540
-
541
- expect(pendingSettings).toEqual({});
542
- });
543
- });
544
-
545
- describe('hasRestartRequiredSettings', () => {
546
- it('should return true when modified settings require restart', () => {
547
- const modifiedSettings = new Set<string>([
548
- 'autoConfigureMaxOldSpaceSize',
549
- 'showMemoryUsage',
550
- ]);
551
- expect(hasRestartRequiredSettings(modifiedSettings)).toBe(true);
552
- });
553
-
554
- it('should return false when no modified settings require restart', () => {
555
- const modifiedSettings = new Set<string>([
556
- 'showMemoryUsage',
557
- 'hideTips',
558
- ]);
559
- expect(hasRestartRequiredSettings(modifiedSettings)).toBe(false);
560
- });
561
-
562
- it('should return false for empty set', () => {
563
- const modifiedSettings = new Set<string>();
564
- expect(hasRestartRequiredSettings(modifiedSettings)).toBe(false);
565
- });
566
- });
567
-
568
- describe('getRestartRequiredFromModified', () => {
569
- it('should return only settings that require restart', () => {
570
- const modifiedSettings = new Set<string>([
571
- 'autoConfigureMaxOldSpaceSize',
572
- 'showMemoryUsage',
573
- 'checkpointing.enabled',
574
- ]);
575
- const result = getRestartRequiredFromModified(modifiedSettings);
576
-
577
- expect(result).toContain('autoConfigureMaxOldSpaceSize');
578
- expect(result).toContain('checkpointing.enabled');
579
- expect(result).not.toContain('showMemoryUsage');
580
- });
581
-
582
- it('should return empty array when no settings require restart', () => {
583
- const modifiedSettings = new Set<string>([
584
- 'showMemoryUsage',
585
- 'hideTips',
586
- ]);
587
- const result = getRestartRequiredFromModified(modifiedSettings);
588
-
589
- expect(result).toEqual([]);
590
- });
591
- });
592
-
593
- describe('getDisplayValue', () => {
594
- it('should show value without * when setting matches default', () => {
595
- const settings = { showMemoryUsage: false }; // false matches default, so no *
596
- const mergedSettings = { showMemoryUsage: false };
597
- const modifiedSettings = new Set<string>();
598
-
599
- const result = getDisplayValue(
600
- 'showMemoryUsage',
601
- settings,
602
- mergedSettings,
603
- modifiedSettings,
604
- );
605
- expect(result).toBe('false*');
606
- });
607
-
608
- it('should show default value when setting is not in scope', () => {
609
- const settings = {}; // no setting in scope
610
- const mergedSettings = { showMemoryUsage: false };
611
- const modifiedSettings = new Set<string>();
612
-
613
- const result = getDisplayValue(
614
- 'showMemoryUsage',
615
- settings,
616
- mergedSettings,
617
- modifiedSettings,
618
- );
619
- expect(result).toBe('false'); // shows default value
620
- });
621
-
622
- it('should show value with * when changed from default', () => {
623
- const settings = { showMemoryUsage: true }; // true is different from default (false)
624
- const mergedSettings = { showMemoryUsage: true };
625
- const modifiedSettings = new Set<string>();
626
-
627
- const result = getDisplayValue(
628
- 'showMemoryUsage',
629
- settings,
630
- mergedSettings,
631
- modifiedSettings,
632
- );
633
- expect(result).toBe('true*');
634
- });
635
-
636
- it('should show default value without * when setting does not exist in scope', () => {
637
- const settings = {}; // setting doesn't exist in scope, show default
638
- const mergedSettings = { showMemoryUsage: false };
639
- const modifiedSettings = new Set<string>();
640
-
641
- const result = getDisplayValue(
642
- 'showMemoryUsage',
643
- settings,
644
- mergedSettings,
645
- modifiedSettings,
646
- );
647
- expect(result).toBe('false'); // default value (false) without *
648
- });
649
-
650
- it('should show value with * when user changes from default', () => {
651
- const settings = {}; // setting doesn't exist in scope originally
652
- const mergedSettings = { showMemoryUsage: false };
653
- const modifiedSettings = new Set<string>(['showMemoryUsage']);
654
- const pendingSettings = { showMemoryUsage: true }; // user changed to true
655
-
656
- const result = getDisplayValue(
657
- 'showMemoryUsage',
658
- settings,
659
- mergedSettings,
660
- modifiedSettings,
661
- pendingSettings,
662
- );
663
- expect(result).toBe('true*'); // changed from default (false) to true
664
- });
665
- });
666
-
667
- describe('isDefaultValue', () => {
668
- it('should return true when setting does not exist in scope', () => {
669
- const settings = {}; // setting doesn't exist
670
-
671
- const result = isDefaultValue('showMemoryUsage', settings);
672
- expect(result).toBe(true);
673
- });
674
-
675
- it('should return false when setting exists in scope', () => {
676
- const settings = { showMemoryUsage: true }; // setting exists
677
-
678
- const result = isDefaultValue('showMemoryUsage', settings);
679
- expect(result).toBe(false);
680
- });
681
-
682
- it('should return true when nested setting does not exist in scope', () => {
683
- const settings = {}; // nested setting doesn't exist
684
-
685
- const result = isDefaultValue(
686
- 'accessibility.disableLoadingPhrases',
687
- settings,
688
- );
689
- expect(result).toBe(true);
690
- });
691
-
692
- it('should return false when nested setting exists in scope', () => {
693
- const settings = { accessibility: { disableLoadingPhrases: true } }; // nested setting exists
694
-
695
- const result = isDefaultValue(
696
- 'accessibility.disableLoadingPhrases',
697
- settings,
698
- );
699
- expect(result).toBe(false);
700
- });
701
- });
702
-
703
- describe('isValueInherited', () => {
704
- it('should return false for top-level settings that exist in scope', () => {
705
- const settings = { showMemoryUsage: true };
706
- const mergedSettings = { showMemoryUsage: true };
707
-
708
- const result = isValueInherited(
709
- 'showMemoryUsage',
710
- settings,
711
- mergedSettings,
712
- );
713
- expect(result).toBe(false);
714
- });
715
-
716
- it('should return true for top-level settings that do not exist in scope', () => {
717
- const settings = {};
718
- const mergedSettings = { showMemoryUsage: true };
719
-
720
- const result = isValueInherited(
721
- 'showMemoryUsage',
722
- settings,
723
- mergedSettings,
724
- );
725
- expect(result).toBe(true);
726
- });
727
-
728
- it('should return false for nested settings that exist in scope', () => {
729
- const settings = {
730
- accessibility: { disableLoadingPhrases: true },
731
- };
732
- const mergedSettings = {
733
- accessibility: { disableLoadingPhrases: true },
734
- };
735
-
736
- const result = isValueInherited(
737
- 'accessibility.disableLoadingPhrases',
738
- settings,
739
- mergedSettings,
740
- );
741
- expect(result).toBe(false);
742
- });
743
-
744
- it('should return true for nested settings that do not exist in scope', () => {
745
- const settings = {};
746
- const mergedSettings = {
747
- accessibility: { disableLoadingPhrases: true },
748
- };
749
-
750
- const result = isValueInherited(
751
- 'accessibility.disableLoadingPhrases',
752
- settings,
753
- mergedSettings,
754
- );
755
- expect(result).toBe(true);
756
- });
757
- });
758
-
759
- describe('getEffectiveDisplayValue', () => {
760
- it('should return value from settings when available', () => {
761
- const settings = { showMemoryUsage: true };
762
- const mergedSettings = { showMemoryUsage: false };
763
-
764
- const result = getEffectiveDisplayValue(
765
- 'showMemoryUsage',
766
- settings,
767
- mergedSettings,
768
- );
769
- expect(result).toBe(true);
770
- });
771
-
772
- it('should return value from merged settings when not in scope', () => {
773
- const settings = {};
774
- const mergedSettings = { showMemoryUsage: true };
775
-
776
- const result = getEffectiveDisplayValue(
777
- 'showMemoryUsage',
778
- settings,
779
- mergedSettings,
780
- );
781
- expect(result).toBe(true);
782
- });
783
-
784
- it('should return default value for undefined values', () => {
785
- const settings = {};
786
- const mergedSettings = {};
787
-
788
- const result = getEffectiveDisplayValue(
789
- 'showMemoryUsage',
790
- settings,
791
- mergedSettings,
792
- );
793
- expect(result).toBe(false); // Default value
794
- });
795
- });
796
- });
797
- });