From 16174a053ed89fb9554d096395ab7bf69c8f6911 Mon Sep 17 00:00:00 2001 From: Thomas Heyenbrock Date: Tue, 15 Nov 2022 12:46:17 +0100 Subject: [PATCH] fix autocomplete popover styles (#2910) --- .changeset/fresh-readers-walk.md | 5 ++++ .../graphiql-react/src/editor/completion.ts | 27 +++++++++++++------ .../graphiql-react/src/editor/style/hint.css | 4 +-- 3 files changed, 26 insertions(+), 10 deletions(-) create mode 100644 .changeset/fresh-readers-walk.md diff --git a/.changeset/fresh-readers-walk.md b/.changeset/fresh-readers-walk.md new file mode 100644 index 00000000000..339a179403a --- /dev/null +++ b/.changeset/fresh-readers-walk.md @@ -0,0 +1,5 @@ +--- +'@graphiql/react': patch +--- + +Fix autocomplete styles for field type and description on the right diff --git a/packages/graphiql-react/src/editor/completion.ts b/packages/graphiql-react/src/editor/completion.ts index 2313c11d94a..4127f1e2982 100644 --- a/packages/graphiql-react/src/editor/completion.ts +++ b/packages/graphiql-react/src/editor/completion.ts @@ -119,15 +119,19 @@ export function onHasCompletion( * is already positioned absolutely. * * There are two things to the solution here: - * - We add another `overflow: auto` to the `information` element. - * This makes it scrollable on its own if the description or - * deprecation reason is higher that the container element. + * - We add a `max-height` and another `overflow: auto` to the + * `information` element. This makes it scrollable on its own + * if the description or deprecation reason is higher that the + * container element. * - We add an `onscroll` handler to the container element. When the - * user scrolls here we dynamically adjust the top padding of the - * information element such that it looks like it's sticking to - * the top. (Since the `information` element has some padding by - * default we also have to make sure to use this as baseline for - * the total padding.) + * user scrolls here we dynamically adjust the top padding and the + * max-height of the information element such that it looks like + * it's sticking to the top. (Since the `information` element has + * some padding by default we also have to make sure to use this + * as baseline for the total padding.) + * Note that we need to also adjust the max-height because we + * default to using `border-box` for box sizing. When using + * `content-box` this would not be necessary. */ const defaultInformationPadding = parseInt( @@ -136,10 +140,17 @@ export function onHasCompletion( .paddingBottom.replace(/px$/, ''), 10, ) || 0; + const defaultInformationMaxHeight = + parseInt( + window.getComputedStyle(information).maxHeight.replace(/px$/, ''), + 10, + ) || 0; const handleScroll = () => { if (information) { information.style.paddingTop = hintsUl.scrollTop + defaultInformationPadding + 'px'; + information.style.maxHeight = + hintsUl.scrollTop + defaultInformationMaxHeight + 'px'; } }; hintsUl.addEventListener('scroll', handleScroll); diff --git a/packages/graphiql-react/src/editor/style/hint.css b/packages/graphiql-react/src/editor/style/hint.css index 7bd4d544677..85e89336b49 100644 --- a/packages/graphiql-react/src/editor/style/hint.css +++ b/packages/graphiql-react/src/editor/style/hint.css @@ -39,8 +39,8 @@ li.CodeMirror-hint-active { hsla(var(--color-neutral), var(--alpha-background-heavy)); grid-column: 2 / 3; grid-row: 1 / 99999; - /* Same as the popup as a whole minus padding */ - max-height: calc(264px - 2 * var(--px-12)); + /* Same as the popup */ + max-height: 264px; overflow: auto; padding: var(--px-12); }