completions: do not render empty multi-line documentation (#7279)

I ran into this a lot with Go code: the documentation would be empty so
we'd display a big box with nothing in it.

I think it's better if we only display the box if we have documentation.

Release Notes:

- Fixed documentation box in showing up when using auto-complete even if
documentation was empty.

## Before

![screenshot-2024-02-02-14 00
18@2x](https://github.com/zed-industries/zed/assets/1185253/e4915d51-a573-41f4-aa5d-21de6d1b0ff1)

## After

![screenshot-2024-02-02-14 01
58@2x](https://github.com/zed-industries/zed/assets/1185253/74b244af-3fc7-45e9-8cb3-7264e34b7ab7)
This commit is contained in:
Thorsten Ball 2024-02-02 16:42:43 +01:00 committed by GitHub
parent ec9f44727e
commit 01ddf840f5
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -857,9 +857,15 @@ impl CompletionsMenu {
Some(Documentation::MultiLinePlainText(text)) => { Some(Documentation::MultiLinePlainText(text)) => {
Some(div().child(SharedString::from(text.clone()))) Some(div().child(SharedString::from(text.clone())))
} }
Some(Documentation::MultiLineMarkdown(parsed)) => Some(div().child( Some(Documentation::MultiLineMarkdown(parsed)) if !parsed.text.is_empty() => {
render_parsed_markdown("completions_markdown", parsed, &style, workspace, cx), Some(div().child(render_parsed_markdown(
)), "completions_markdown",
parsed,
&style,
workspace,
cx,
)))
}
_ => None, _ => None,
}; };
multiline_docs.map(|div| { multiline_docs.map(|div| {