Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

254 linhas
7.9 KiB

  1. import type { MessageItem } from 'vscode';
  2. import { ConfigurationTarget, window } from 'vscode';
  3. import { configuration, SuppressedMessages } from './configuration';
  4. import { Commands } from './constants';
  5. import type { GitCommit } from './git/models/commit';
  6. import { Logger } from './logger';
  7. import { executeCommand } from './system/command';
  8. export function showCommitHasNoPreviousCommitWarningMessage(commit?: GitCommit): Promise<MessageItem | undefined> {
  9. if (commit == null) {
  10. return showMessage('info', 'There is no previous commit.', SuppressedMessages.CommitHasNoPreviousCommitWarning);
  11. }
  12. return showMessage(
  13. 'info',
  14. `Commit ${commit.shortSha} (${commit.author.name}, ${commit.formattedDate}) has no previous commit.`,
  15. SuppressedMessages.CommitHasNoPreviousCommitWarning,
  16. );
  17. }
  18. export function showCommitNotFoundWarningMessage(message: string): Promise<MessageItem | undefined> {
  19. return showMessage('warn', `${message}. The commit could not be found.`, SuppressedMessages.CommitNotFoundWarning);
  20. }
  21. export async function showCreatePullRequestPrompt(branch: string): Promise<boolean> {
  22. const create = { title: 'Create Pull Request...' };
  23. const result = await showMessage(
  24. 'info',
  25. `Would you like to create a Pull Request for branch '${branch}'?`,
  26. SuppressedMessages.CreatePullRequestPrompt,
  27. { title: "Don't Show Again" },
  28. create,
  29. );
  30. return result === create;
  31. }
  32. export async function showDebugLoggingWarningMessage(): Promise<boolean> {
  33. const disable = { title: 'Disable Debug Logging' };
  34. const result = await showMessage(
  35. 'warn',
  36. 'GitLens debug logging is currently enabled. Unless you are reporting an issue, it is recommended to be disabled. Would you like to disable it?',
  37. SuppressedMessages.SuppressDebugLoggingWarning,
  38. { title: "Don't Show Again" },
  39. disable,
  40. );
  41. return result === disable;
  42. }
  43. export async function showGenericErrorMessage(message: string): Promise<MessageItem | undefined> {
  44. const actions: MessageItem[] = [{ title: 'Open Output Channel' }];
  45. const result = await showMessage(
  46. 'error',
  47. `${message}. See output channel for more details`,
  48. undefined,
  49. null,
  50. ...actions,
  51. );
  52. if (result !== undefined) {
  53. Logger.showOutputChannel();
  54. }
  55. return result;
  56. }
  57. export function showFileNotUnderSourceControlWarningMessage(message: string): Promise<MessageItem | undefined> {
  58. return showMessage(
  59. 'warn',
  60. `${message}. The file is probably not under source control.`,
  61. SuppressedMessages.FileNotUnderSourceControlWarning,
  62. );
  63. }
  64. export function showGitDisabledErrorMessage() {
  65. return showMessage(
  66. 'error',
  67. 'GitLens requires Git to be enabled. Please re-enable Git \u2014 set `git.enabled` to true and reload.',
  68. SuppressedMessages.GitDisabledWarning,
  69. );
  70. }
  71. export function showGitInvalidConfigErrorMessage() {
  72. return showMessage(
  73. 'error',
  74. 'GitLens is unable to use Git. Your Git configuration seems to be invalid. Please resolve any issues with your Git configuration and reload.',
  75. );
  76. }
  77. export function showGitMissingErrorMessage() {
  78. return showMessage(
  79. 'error',
  80. "GitLens was unable to find Git. Please make sure Git is installed. Also ensure that Git is either in the PATH, or that 'git.path' is pointed to its installed location.",
  81. SuppressedMessages.GitMissingWarning,
  82. );
  83. }
  84. export function showGitVersionUnsupportedErrorMessage(
  85. version: string,
  86. required: string,
  87. ): Promise<MessageItem | undefined> {
  88. return showMessage(
  89. 'error',
  90. `GitLens requires a newer version of Git (>= ${required}) than is currently installed (${version}). Please install a more recent version of Git.`,
  91. SuppressedMessages.GitVersionWarning,
  92. );
  93. }
  94. export function showInsidersErrorMessage() {
  95. return showMessage(
  96. 'error',
  97. 'GitLens (Insiders) cannot be used while GitLens is also enabled. Please ensure that only one version is enabled.',
  98. );
  99. }
  100. export function showPreReleaseExpiredErrorMessage(version: string, insiders: boolean) {
  101. return showMessage(
  102. 'error',
  103. `This GitLens ${
  104. insiders ? '(Insiders)' : 'pre-release'
  105. } version (${version}) has expired. Please upgrade to a more recent version.`,
  106. );
  107. }
  108. export function showLineUncommittedWarningMessage(message: string): Promise<MessageItem | undefined> {
  109. return showMessage(
  110. 'warn',
  111. `${message}. The line has uncommitted changes.`,
  112. SuppressedMessages.LineUncommittedWarning,
  113. );
  114. }
  115. export function showNoRepositoryWarningMessage(message: string): Promise<MessageItem | undefined> {
  116. return showMessage('warn', `${message}. No repository could be found.`, SuppressedMessages.NoRepositoryWarning);
  117. }
  118. export function showRebaseSwitchToTextWarningMessage(): Promise<MessageItem | undefined> {
  119. return showMessage(
  120. 'warn',
  121. 'Closing either the git-rebase-todo file or the Rebase Editor will start the rebase.',
  122. SuppressedMessages.RebaseSwitchToTextWarning,
  123. );
  124. }
  125. export function showIntegrationDisconnectedTooManyFailedRequestsWarningMessage(
  126. providerName: string,
  127. ): Promise<MessageItem | undefined> {
  128. return showMessage(
  129. 'error',
  130. `Rich integration with ${providerName} has been disconnected for this session, because of too many failed requests.`,
  131. SuppressedMessages.IntegrationDisconnectedTooManyFailedRequestsWarning,
  132. undefined,
  133. {
  134. title: 'OK',
  135. },
  136. );
  137. }
  138. export function showIntegrationRequestFailed500WarningMessage(message: string): Promise<MessageItem | undefined> {
  139. return showMessage('error', message, SuppressedMessages.IntegrationRequestFailed500Warning, undefined, {
  140. title: 'OK',
  141. });
  142. }
  143. export function showIntegrationRequestTimedOutWarningMessage(providerName: string): Promise<MessageItem | undefined> {
  144. return showMessage(
  145. 'error',
  146. `${providerName} request timed out.`,
  147. SuppressedMessages.IntegrationRequestTimedOutWarning,
  148. undefined,
  149. {
  150. title: 'OK',
  151. },
  152. );
  153. }
  154. export async function showWhatsNewMessage(version: string) {
  155. const whatsnew = { title: "See What's New" };
  156. const result = await showMessage(
  157. 'info',
  158. `GitLens ${version} is here — check out what's new!`,
  159. undefined,
  160. null,
  161. whatsnew,
  162. );
  163. if (result === whatsnew) {
  164. void (await executeCommand(Commands.ShowWelcomePage));
  165. }
  166. }
  167. async function showMessage(
  168. type: 'info' | 'warn' | 'error',
  169. message: string,
  170. suppressionKey?: SuppressedMessages,
  171. dontShowAgain: MessageItem | null = { title: "Don't Show Again" },
  172. ...actions: MessageItem[]
  173. ): Promise<MessageItem | undefined> {
  174. Logger.log(`ShowMessage(${type}, '${message}', ${suppressionKey}, ${JSON.stringify(dontShowAgain)})`);
  175. if (suppressionKey != null && configuration.get(`advanced.messages.${suppressionKey}` as const)) {
  176. Logger.log(`ShowMessage(${type}, '${message}', ${suppressionKey}, ${JSON.stringify(dontShowAgain)}) skipped`);
  177. return undefined;
  178. }
  179. if (suppressionKey != null && dontShowAgain !== null) {
  180. actions.push(dontShowAgain);
  181. }
  182. let result: MessageItem | undefined = undefined;
  183. switch (type) {
  184. case 'info':
  185. result = await window.showInformationMessage(message, ...actions);
  186. break;
  187. case 'warn':
  188. result = await window.showWarningMessage(message, ...actions);
  189. break;
  190. case 'error':
  191. result = await window.showErrorMessage(message, ...actions);
  192. break;
  193. }
  194. if (suppressionKey != null && (dontShowAgain === null || result === dontShowAgain)) {
  195. Logger.log(
  196. `ShowMessage(${type}, '${message}', ${suppressionKey}, ${JSON.stringify(
  197. dontShowAgain,
  198. )}) don't show again requested`,
  199. );
  200. await suppressedMessage(suppressionKey);
  201. if (result === dontShowAgain) return undefined;
  202. }
  203. Logger.log(
  204. `ShowMessage(${type}, '${message}', ${suppressionKey}, ${JSON.stringify(dontShowAgain)}) returned ${
  205. result != null ? result.title : result
  206. }`,
  207. );
  208. return result;
  209. }
  210. function suppressedMessage(suppressionKey: SuppressedMessages) {
  211. const messages = { ...configuration.get('advanced.messages') };
  212. messages[suppressionKey] = true;
  213. for (const [key, value] of Object.entries(messages)) {
  214. if (value !== true) {
  215. delete messages[key as keyof typeof messages];
  216. }
  217. }
  218. return configuration.update('advanced.messages', messages, ConfigurationTarget.Global);
  219. }