Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add option for line-wrapping to prevent horizontal scrolling #20

Open
wants to merge 43 commits into
base: main
Choose a base branch
from

Conversation

akoreman
Copy link
Collaborator

@akoreman akoreman commented Feb 24, 2024

Description

Builds on top of #15.

When using code-view with lines longer than the width of the component, currently horizontal scroll bars are shown. This causes potential accessibility problems:

  • code-view is not focusable, so keyboard users are unable to scroll the long lines into view.
  • when code view is used in a vertically scrolling list, this might cause situations where users are required to scroll in two directions to scroll longs lines into view.

This adds a lineWrapping property to the API which, if set to true, makes the component line-wrap long lines to keep them within the view without scrolling.

Screenshot 2024-02-25 at 00 35 19

Visual regression tests in the PR actions are failing because this PR makes visual changes.

Related links, issue #, if available: n/a

How has this been tested?

  • adds unit tests testing that the right class is applied when lineWrapping is false, undefined or true
  • adds page with different reflow scenarios with and without line numbers, allowing for visual and manual testing.
Review checklist

The following items are to be evaluated by the author(s) and the reviewer(s).

Correctness

  • Changes include appropriate documentation updates.
  • Changes are backward-compatible if not indicated, see CONTRIBUTING.md.
  • Changes do not include unsupported browser features, see CONTRIBUTING.md.
  • Changes were manually tested for accessibility, see accessibility guidelines.

Testing

  • Changes are covered with new/existing unit tests?
  • Changes are covered with new/existing integration tests?

By submitting this pull request, I confirm that you can use, modify, copy, and redistribute this contribution, under the terms of your choice.

Comment on lines 59 to 62
<td className={styles["line-number"]} aria-hidden={true}>
<Box color="text-status-inactive" fontSize="body-m">
{index + 1}
</Box>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Changing the markup here breaks selection feature. Line numbers get added into selection.

For the reference you can check how it works on Github

Screen.Recording.2024-02-25.at.16.11.35.mov

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, yeah that's a good catch, thanks. Added some CSS that should fix this.

@@ -2,71 +2,84 @@
// SPDX-License-Identifier: Apache-2.0
import { useCurrentMode } from "@cloudscape-design/component-toolkit/internal";
import Box from "@cloudscape-design/components/box";
import { TextHighlightRules } from "ace-code/src/mode/text_highlight_rules";
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this needed?

The original idea of this component to remove ace dependency from the bundle when syntax highlight is not used.

Copy link
Collaborator Author

@akoreman akoreman Feb 25, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I needed something to go from string to ReactElement for non-highlighted code, for this draft/POC I used the texthighlight rules from Ace for that because it's quick to grab. I can write a simple function within this repo to do the same thing before merging if we decide this approach for line-wrapping looks good.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the info. Let's ensure it gets removed at the final stage

Copy link
Collaborator Author

@akoreman akoreman Feb 25, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed it and replaced it with a function defined in the PR.

@akoreman akoreman marked this pull request as ready for review February 26, 2024 14:11
@akoreman akoreman requested a review from a team as a code owner February 26, 2024 14:11
@akoreman akoreman requested review from abdhalees and removed request for a team February 26, 2024 14:11
@rubencarvalho
Copy link
Contributor

rubencarvalho commented Mar 12, 2024

I'm looking at this PR.
From my first high-level look at it, there are a couple of blocking, open to-dos:

  • Add a minimum height for when actions are present (so the actions have enough space when it is only 1 line)
  • Actions absolute positioning is currently not relative to the code view block, so they scroll with the content
  • Code identation was lost on the highlighting page

@rubencarvalho
Copy link
Contributor

rubencarvalho commented Mar 12, 2024

I'm looking at this PR. From my first high-level look at it, there are a couple of blocking, open to-dos:

  • Add a minimum height for when actions are present (so the actions have enough space when it is only 1 line)
  • Actions absolute positioning is currently not relative to the code view block, so they scroll with the content
  • Code identation was lost on the highlighting page

I've went ahead and pushed a commit to tackle the initial two. I am looking into the last one now.

Copy link

codecov bot commented Mar 12, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 100.00%. Comparing base (f12b6cc) to head (3b8ad86).

Additional details and impacted files
@@            Coverage Diff            @@
##              main       #20   +/-   ##
=========================================
  Coverage   100.00%   100.00%           
=========================================
  Files           27        27           
  Lines          348       383   +35     
  Branches        31        30    -1     
=========================================
+ Hits           348       383   +35     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@rubencarvalho rubencarvalho self-requested a review March 12, 2024 11:35
@rubencarvalho
Copy link
Contributor

I'm looking at this PR. From my first high-level look at it, there are a couple of blocking, open to-dos:

  • Add a minimum height for when actions are present (so the actions have enough space when it is only 1 line)
  • Actions absolute positioning is currently not relative to the code view block, so they scroll with the content
  • Code identation was lost on the highlighting page

I've went ahead and pushed a commit to tackle the initial two. I am looking into the last one now.

I've fixed the code indentation by setting white-space to pre.

<pre
ref={preRef}
<div className={styles["scroll-container"]}>
<table
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is it necessary for this to be semantically a table? or is this more just to get table layout, in which case could we do that purely with CSS? (thinking about a11y, and whether it makes sense for this to be announced as a "table")

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The primary reason for choosing a table here is to align line numbers with their corresponding lines of code, now that we are introducing line-wrapping. Let us consult with A11Y to double-check.

@pan-kot pan-kot changed the title feat: add option for line-wrapping to prevent horizontal scrolling feat: Add option for line-wrapping to prevent horizontal scrolling Nov 27, 2024
@@ -34,5 +41,5 @@ export interface CodeViewProps {
* A function to perform custom syntax highlighting.
*
*/
highlight?: (code: string) => React.ReactNode;
highlight?: (code: string) => React.ReactElement;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this change needed?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it got it: we ensure the type is ReactElement so that Children.map() can be used. However, this change is not backward-compatible because the ReactElement type is more narrow than ReactNode.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yeah true that ReactElement is more narrow than ReactNode, I've updated the PR to try to work around it by creating a ReactElement based on the ReactNode given to us.

<ScreenshotArea>
<h1>Code View</h1>
<SpaceBetween direction="vertical" size="l">
No wrapping, no line numbers
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you please update this page and also with-syntax-highlighting.page.tsx with wrapping text content inside SpaceBetween in some container, e.g. a Box? That is to satisfy the guidelines: https://cloudscape.aws.dev/components/space-between/?tabId=api

Currently, there are React warnings in these pages.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah yeah good point, fixed in new commit

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants