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

HDS::CodeEditor with Code Mirror 6 #2573

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

Conversation

zamoore
Copy link
Contributor

@zamoore zamoore commented Nov 19, 2024

📌 Summary

This PR adds a code editor utilizing Code Mirror 6 to the HDS component library. The code editor can be instantiated via:

  • The hds-code-editor modifier, which can be added to any element to transform that element into a code editor instance
  • The Hds::CodeEditor component, which uses the hds-code-editor modifier under the hood, but adds support for title, description, and various tools.

Details

hds-code-editor modifier

This modifier will instantiate a Code Mirror editor on the element that it's added to. In order to reduce the up-front cost of loading the editor, we only load the CodeMirror package when the editor is scrolled into view. Because of this, there may be an exceptionally brief loading state before the editor is ready when it is viewed by the user.

// Example
<div {{hds-code-editor
  value=@value
  language=@language
  onInput=@onInput
  onSetup=this.onSetup
}} />

value: The initial value of the editor
language: optional, one of 4 possible supported languages (json, sql, go, hcl)
onInput: callback function when the code editor changes
onSetup: callback function when the modifier has completed loading dependencies and instantiating the editor, receives CodeMirror Editor instance.

This editor features support for:

  • Custom title
  • Custom description
  • Copy editor content
  • Fullscreen toggle
  • Keyboard support including directional navigation
  • History (support for cmd+z and other history commands)

Hds::CodeEditor component

This component uses the hds-code-editor modifier in combination with a customizable header and support for a fullscreen mode.

// Example
<Hds::CodeEditor
  @language="go"
  @value="test"
  @hasExpandButton={{true}}
  @hasCopyButton={{true}}
  @onInput={{this.noop}}
  @onSetup={{this.noop}}
  as |CE|
>
  <CE.Title>Code editor with title</CE.Title>
  <CE.Description>This is a code editor with a description</CE.Description>
  <Hds::Button @text="Custom button" />
  <Hds::Icon @name="code" @color="#fff" />
</Hds::CodeEditor>

value: The initial value of the editor
hasExpandButton: Whether the editor can be expanded into fullscreen mode
hasCopyButton: Whether the editor has a button that adds the current value to the clipboard
language: optional, one of 4 possible supported languages (json, sql, go, hcl)
onInput: callback function when the code editor changes
onSetup: callback function when the component has completed loading dependencies and instantiating the editor, receives CodeMirror Editor instance.

📸 Screenshots

Screenshot 2024-12-17 at 5 22 00 PM

🔗 External links

Jira ticket: HDS-4016
Figma


👀 Component checklist

💬 Please consider using conventional comments when reviewing this PR.

@zamoore zamoore self-assigned this Nov 19, 2024
Copy link

vercel bot commented Nov 19, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
hds-showcase ✅ Ready (Inspect) Visit Preview Dec 30, 2024 9:22pm
hds-website ✅ Ready (Inspect) Visit Preview Dec 30, 2024 9:22pm

Copy link
Member

@alex-ju alex-ju left a comment

Choose a reason for hiding this comment

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

Thank you for opening this PR for early feedback! The functionalities look very promising.

The main comment at this stage (when the design is finalized I can do an in-depth review of the component API) is to look into how can we leverage dynamic imports (leveraging ember-auto-import) to defer loading the third-party code until consumers start using the component on the page

packages/components/src/modifiers/hds-code-editor.ts Outdated Show resolved Hide resolved
packages/components/package.json Outdated Show resolved Hide resolved
packages/components/package.json Outdated Show resolved Hide resolved
packages/components/src/modifiers/hds-code-editor.ts Outdated Show resolved Hide resolved
Copy link
Contributor

@didoo didoo left a comment

Choose a reason for hiding this comment

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

Left a couple of high-level comments, about something that stood out for me (I hope you won't mind).

packages/components/src/styles/components/code-editor.scss Outdated Show resolved Hide resolved
packages/tokens/src/global/color/semantic-code.json Outdated Show resolved Hide resolved
Copy link
Contributor

@shleewhite shleewhite left a comment

Choose a reason for hiding this comment

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

Looks great! Just one issue with the loading state.

/>
{{#unless this._isSetupComplete}}
<div class="hds-code-editor__loader" aria-live="polite" role="status">
<Hds::Icon @name="loading" @size="24" />
Copy link
Contributor

Choose a reason for hiding this comment

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

Issue: sorry, I think this got lost in the last comment, but you also need to add a visually hidden span inside the div that says "loading" otherwise there is no text in the aria-live region.

<span class="sr-only">Loading</span>

Copy link
Contributor

@dchyun dchyun left a comment

Choose a reason for hiding this comment

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

Looks great! Just caught one small thing in the styles.

// CODE-EDITOR
//

@import "theme";
Copy link
Contributor

@dchyun dchyun Dec 26, 2024

Choose a reason for hiding this comment

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

Suggested change
@import "theme";
@use "theme";

[Nit] Small change to avoid the sass deprecation warnings, and align with other scss files.

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

Successfully merging this pull request may close these issues.

7 participants