Notification Balloon
Notification balloons inform users of the events or system states related to a project or IDE.
data:image/s3,"s3://crabby-images/1b54b/1b54b190840817192aa64682cbb2a8e69031a06b" alt="A notification balloon for a found database connection with an action to connect to it A notification balloon for a found database connection with an action to connect to it"
Suggestion and timeline notifications
There are two types of notification balloons:
Suggestion notifications show the recommended action as a noticeable button. Use to suggest an automatic configuration for a project or an IDE, or to ask for user input.
Timeline notifications show useful actions as links. Use for showing results of long processes, automatic configuration, or actions without context.
These types appear in different sections of the Notifications tool window:
data:image/s3,"s3://crabby-images/75ec3/75ec3044634f642014f87c0d07a8349a84f8c01d" alt="The Notifications toolwindow with suggestion and timeline notifications in different sections The Notifications toolwindow with suggestion and timeline notifications in different sections"
When to use
Show result of a potentially long process
Use a timeline notification.
data:image/s3,"s3://crabby-images/754bd/754bd6f00d8d705a9b3c2a7d86f0129c8854aa39" alt="Two notifications with results of long processes: project build and git push Two notifications with results of long processes: project build and git push"
Show result of an action without context
Use a timeline notification when an action was called from a context that is already closed, like a dialog or a popup.
data:image/s3,"s3://crabby-images/a863e/a863ebc06d538f3556b3602ef842ebb42cb7f3fb" alt="Two notifications with results of actions that are not tied to a particular dialog: the UI language was changed and project folders excluded from Windows Defender Two notifications with results of actions that are not tied to a particular dialog: the UI language was changed and project folders excluded from Windows Defender"
Show result of an automatic configuration
Use a timeline notification when the project or IDE settings were automatically configured, and the user might need to check the changes.
data:image/s3,"s3://crabby-images/543e1/543e1104b543099674d5f7851a4382678dc3e314" alt="A notification about automatic project configuration: the workspace is restored after a branch is checked out A notification about automatic project configuration: the workspace is restored after a branch is checked out"
Suggest an action to configure a project or an IDE
Use a suggestion notification to promote an action for project or IDE configuration when not taking this action might lead to less optimal functioning or errors.
data:image/s3,"s3://crabby-images/96777/96777e99c6a6be9ff2589c6774ecb2341314be26" alt="Two examples of a suggestion notification for project or IDE configuration: Windows Defender affecting the IDE with a suggestion to explude a project from it, and a suggestion for switching the UI to an available language Two examples of a suggestion notification for project or IDE configuration: Windows Defender affecting the IDE with a suggestion to explude a project from it, and a suggestion for switching the UI to an available language"
Request user input
Use a suggestion notification to ask the user for an additional input or action that is not connected to their own workflows.
data:image/s3,"s3://crabby-images/20c62/20c62eba0b05e4aa9fd351d6e414cf44fa601312" alt="Two suggestion notifications for requiring user input: a request to fill a survey and a notice about a discount for PhpStorm Two suggestion notifications for requiring user input: a request to fill a survey and a notice about a discount for PhpStorm"
How to use
Sticky or timed
Sticky notifications stay on screen until the user clicks any of its actions or closes it. By default, use this behavior for suggestion notifications.
Timed notifications stay on screen for 10 seconds and then hide. By default, use this behavior for timeline notifications.
Change the default behavior if it makes sense in a particular use case.
Message severity
Error
Use to inform of a critical event or state that might disrupt the user experience.
data:image/s3,"s3://crabby-images/8df6b/8df6bfed6cc14116d8fbc1babee58e6995ec24d3" alt="An error notification about a plugin being suspended because it requires another plugin that is missing An error notification about a plugin being suspended because it requires another plugin that is missing"
Warning
Use in case an event or state might slow down the user's work or require an action to fix the project or IDE settings.
data:image/s3,"s3://crabby-images/14e7d/14e7d43269ddc66ae1865c2a3456eaf882561ba8" alt="A warning notification about IDE shortcuts conflicting with macOS shortcuts A warning notification about IDE shortcuts conflicting with macOS shortcuts"
Information
Use in all other cases.
data:image/s3,"s3://crabby-images/2d489/2d48917556cfc052a4a7cb63228d6c026a47c8cb" alt="An information notification requesting to fill a survey about a plugin An information notification requesting to fill a survey about a plugin"
When possible, use a plugin or functionality icon instead of the Info icon. This helps identifing the source of the notification quicker.
data:image/s3,"s3://crabby-images/fa484/fa484609ac9e2121e2b9e8ba07f00a252711b7be" alt="Two notifications with dedicated icons instead of the generic info icon: database connection found with the database icon and suggested plugins found with the generic plugin icon Two notifications with dedicated icons instead of the generic info icon: database connection found with the database icon and suggested plugins found with the generic plugin icon"
Text
Writing
Write short and clear as notifications have limited space and may appear for a short time.
Use sentence case for both the title and the body.
Follow the punctuation rules.
Title
Describe the event and the context in which it occurred. The context could be the name of a plugin, library, or functionality.
Body
Provide the details on the event or system state to help users decide what to do next. Consider answering these questions:
What was the cause of this state?
What are the consequences?
What is affected: files, libraries, versions, plugins, etc.?
Using only title or body
Use only the title when it is short and fits in one line.
data:image/s3,"s3://crabby-images/f56b7/f56b7202d6426f9f3aa5c835b3d7fce69b283db5" alt="A notification with the title only about the number of files updated after git pull A notification with the title only about the number of files updated after git pull"
Use only the body text when it fits in two lines and the title would duplicate its meaning.
Correct
data:image/s3,"s3://crabby-images/f2f13/f2f13e620a6ceab6c383069cdacff9279dbe0e93" alt="A notification with the body only about the workspace being restored after branch checkout A notification with the body only about the workspace being restored after branch checkout"
Incorrect
data:image/s3,"s3://crabby-images/22c3f/22c3f5c618f8ac1b603016350529c528eb7867cf" alt="The same notification as above but with duplicating information in the title The same notification as above but with duplicating information in the title"
Long messages are collapsed
Only the first two lines of the body text are visible by default, the rest is shown when expanded. Place the most important information in the beginning of the body text so it is visible by default.
data:image/s3,"s3://crabby-images/b38dd/b38dd7dd468280b396f0facba2c1a7e34d433e73" alt="A notification about Windows Defender slowing down the IDE in the collapsed and expanded states. The notification body is long and takes 9 lines A notification about Windows Defender slowing down the IDE in the collapsed and expanded states. The notification body is long and takes 9 lines"
Actions
Add actions to help users take the next steps: fix a problem, view relevant information, configure settings, etc.
Number of actions
The preferable number of actions is two, as it is easier for the user to choose. If more than two actions are useful, place the most likely to be used first, and hide the others under the More dropdown:
data:image/s3,"s3://crabby-images/75f6d/75f6d2635c975008dae4dac593e5a81de19925a2" alt="The Windows Defender notification with the primary action "Exclude folders" on the left and 3 more actions under the "More" dropdown link The Windows Defender notification with the primary action "Exclude folders" on the left and 3 more actions under the "More" dropdown link"
Actions in error and warning notifications
If the notification reports an error or warning, always provide an action to help users fix the problem:
data:image/s3,"s3://crabby-images/16a27/16a2789663205f083dc5c667ef1c89e9a41c3910" alt="An error notification about the plugin being suspended because it requires another plugin to work with actions "Manage plugins" and "Disable the suspended plugin" An error notification about the plugin being suspended because it requires another plugin to work with actions "Manage plugins" and "Disable the suspended plugin""
If no actions are available, provide more details in the body text: how to fix or what was the cause.
Correct
data:image/s3,"s3://crabby-images/1c4d5/1c4d5eb5e6f23d848390bb1167c72807d0d0ce3e" alt="A notification about a plugin being incompatible with the current IDE version with a suggestion to update the plugin A notification about a plugin being incompatible with the current IDE version with a suggestion to update the plugin"
Incorrect
data:image/s3,"s3://crabby-images/caf5b/caf5b5e609470d64fefb62cd54eb66b732e4c24f" alt="The name notification but without the suggestion to update the plugin The name notification but without the suggestion to update the plugin"
The "Don't show again" action
If the notification is informational, and there is a possibility it might appear too often, add the Don’t show again action:
data:image/s3,"s3://crabby-images/1b54b/1b54b190840817192aa64682cbb2a8e69031a06b" alt="A notification about a database connection found with the "Don't show again link" A notification about a database connection found with the "Don't show again link""
Capitalization
Use sentence capitalization for all actions in notification balloons.
Naming a notification group
Each notification balloon belongs to a group. Groups can be seen in
.To name a notification group, follow these rules:
Name the group with an ending to the phrase "Notifications in this group notify the user about…". Examples: Automatic indent detection, Content root duplicates.
If a name about a particular process or event cannot be given, use the name of a subsystem or plugin. Examples: HTTP Client, Power Save Mode.
When a group contains notifications about errors or problems, do not use a verb. Example: Debugger errors, not Debugger errors found.
Do not use words "notification" or "group". They are implied from the settings context.