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

VV - UI + Styles #6573

Merged
merged 3 commits into from
Jan 21, 2025
Merged

VV - UI + Styles #6573

merged 3 commits into from
Jan 21, 2025

Conversation

kieftrav
Copy link
Contributor

@kieftrav kieftrav commented Dec 17, 2024

Package

  • lib-subject-viewers

Describe your changes

  • Add 4, 8, 16, 32, and 64 example to Storybook
  • Add Histogram range slider
  • Fix scroll bug
  • Inline OrbitControls import
  • Incorporate Figma Styles

How to Review

  • Run lib-subject-viewers Storybook locally
  • Inspect styles in the deployed project-branch
  • Alternatively, you can run the local app-project

Please Review

  • Are layout and color styles implemented correctly?
    • Test both Desktop and Mobile in app-project or on the branch deploy
  • Does resizing the window still enable full annotating?
  • Planes
    • Does the toggle to expand/collapse work?
    • Does the "forward 10" move forward 10 frames?
    • Does holding the "forward 10" move forward at an interval?
    • Does letting go of the "forward 10" stop moving forward at an interval?
    • Does adjusting the slider work?
    • Does clicking anywhere on the cube create+add to an the annotation?
    • Does holding shift+click on the cube create a new annotation?
  • Cube
    • Can you rotate the cube?
    • Can you see annotations?
    • Does clicking anywhere on the cube create+add to an the annotation?
    • Does holding shift+click on the cube create a new annotation?
  • Histogram
    • Do both the plane and the cube remove pixels/voxels when the histogram range is narrowed?
    • Does the Histogram drawing re-normalize when adjusting the sliders?

Design Review Notes (from meeting with Sean)

  • Hide coordinate when collapsed
  • Keep coordinate size smaller when expanded
  • Start page with x slice open
  • 20px padding on the cube
  • Remove rounded corners on cube
  • Remove stroke from dark mode
  • Cut out the bottom black from the histogram
  • Click and hold to “loop through”
  • When the histogram and axes touch is the min size for the cube
    • When it gets to that size, then move to stacked layout
  • When threshold is moved, sometimes the annotations are not redrawn and remain hidden until the frame is changed

Future PR / Not Implemented

  • Ability to delete an Annotation in the cube
  • Ability to "undo" in the Toolbar
  • Get the outline to travel with the frame (math is complicated)

Checklist

PR Creator - Please cater the checklist to fit the review needed for your code changes.
PR Reviewer - Use the checklist during your review. Each point should be checkmarked or discussed before PR approval.

General

  • Tests are passing locally and on Github
  • Documentation is up to date and changelog has been updated if appropriate
  • You can yarn panic && yarn bootstrap or docker-compose up --build and FEM works as expected
  • FEM works in all major desktop browsers: Firefox, Chrome, Edge, Safari (Use Browserstack account as needed)
  • FEM works in a mobile browser

General UX

Example Staging Project: i-fancy-cats

  • All pages of a FEM project load: Home Page, Classify Page, and About Pages
  • Can submit a classification
  • Can sign-in and sign-out
  • The component is accessible

@coveralls
Copy link

coveralls commented Dec 17, 2024

Coverage Status

coverage: 75.628% (-1.7%) from 77.359%
when pulling cd6f65c on vv-styles
into 294dfb4 on master.

@kieftrav kieftrav marked this pull request as draft December 17, 2024 17:27
@kieftrav kieftrav force-pushed the vv-styles branch 4 times, most recently from 69b6604 to 069b614 Compare December 19, 2024 12:42
@kieftrav kieftrav changed the title VV - Styles VV - UI + Styles Dec 19, 2024
@kieftrav kieftrav marked this pull request as ready for review December 19, 2024 13:02
@kieftrav
Copy link
Contributor Author

kieftrav commented Jan 4, 2025

@seanmiller26 - I have incorporated all of your suggestions minus the outline for the frames within the Cube... This proved more mathematically difficult so I've punted for when I'm back. I also took the liberty of re-adding the rounded corners in dark mode on mobile because it follows the design intention more consistently. Easy to change if you disagree!

Copy link
Contributor

@goplayoutside3 goplayoutside3 left a comment

Choose a reason for hiding this comment

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

I reviewed by running lib-subject-viewer's Storybook and testing the workflow of your VV test project and the NeuroTracerBrain test project. I've left a few comments/questions, but otherwise skimmed the lib-subject-viewer code because 2k lines of changes is a lot for an in-depth review.

The steps in How To Review work as expected, but I have a few additional UI questions:

  1. Should the interaction to expand / collapse include clicking the text label? For example, as a user I expected to be able to click on the word "Expand" or the carat icon to expand the plane, but for now only the carat can be interacted with.
    Screenshot 2025-01-16 at 1 38 26 PM
  2. Have you noted the accessibility violations in Storybook? For instance, the Slider in particular is missing accessible labels. And in general, the Cube area doesn't have aria to announce the contents to a screen reader (for example, the bar chart for user stats has an aria-label to communicate the description of the bar chart). These points don't have to be resolved in this PR, but definitely should be documented todos, maybe in the project board?
  3. The test project UI includes zoom buttons and rotate button in the image toolbar. What are the plans for those and is the intended UX documented in the project board?

And lastly, this is potentially already behavior you're aware of, but there's a console error generated by Cube.js TypeError: Cannot set properties of undefined (setting 'x'). I can reliably produce the error by running NeuroTracerBrain locally in dev mode. In dev mode, it's a console error, but in production mode there's no error. With this test project in particular, it also takes an unexpectedly long time for annotations to show up on the Cube and Plane after a user click (about 5 - 10 seconds). The delay could be unrelated to the console error, but wanted to document a detailed UX during review so performance issues and errors can be added to the project board if not addressed in this PR.

subject={subject}
/>
const config = {
annotations: [],
Copy link
Contributor

Choose a reason for hiding this comment

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

annotations is being defined here as a prop, but not used in the React component it's passed to 🤔 Did you mean to? Looking at the VolumetricViewer in lib-subject-viewers, the component does not expect to receive annotations as a prop.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Unnecessary default - removing

@@ -4,3 +4,5 @@ This directory holds all the relevant code for rendering the VolumetricViewer. T

- `VolumetricViewerComponent` - a React component for the VolumetricViewer
- `VolumetricViewerData` - a function that returns the data with instantiated models along with the React Component

NOTE: Webpack has trouble importing from a node_module package from dependent package chains (`lib-subject-viewers` => `lib-classifier` => `app-project`), therefore we have inlined `OrbitControls.js` file so that it works without Webpack issues. When updating the `three` dependency in `package.json` make sure to copy the file from `node_modules/three/examples/jsm/controls/OrbitControls.js` to `lib-subject-viewers/src/VolumetricViewer/helpers/OrbitControls.js`.
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change in wording because FEM can use node_module resources lib => lib-classifier => app-project, and an example is whenever the repo requires lib-react-components => lib-classifier => app-project. However, in this case OrbitControls is a ES Module, and FEM is not pure ESM (hence the cjs export scripts in all package.json), so trying import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls' throws the error ESM packages (three/examples/jsm/controls/OrbitControls) need to be imported in lib-subject-viewers/dist/cjs/VolumetricViewer/components/Cube.js.

Suggested change
NOTE: Webpack has trouble importing from a node_module package from dependent package chains (`lib-subject-viewers` => `lib-classifier` => `app-project`), therefore we have inlined `OrbitControls.js` file so that it works without Webpack issues. When updating the `three` dependency in `package.json` make sure to copy the file from `node_modules/three/examples/jsm/controls/OrbitControls.js` to `lib-subject-viewers/src/VolumetricViewer/helpers/OrbitControls.js`.
NOTE: OrbitControls are typically imported as `import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls'` but that syntax throws an error due to FEM not being pure ESM, therefore we have inlined `OrbitControls.js` file so that it works without bundling issues. When updating the `three` dependency in `package.json` make sure to copy the file from `node_modules/three/examples/jsm/controls/OrbitControls.js` to `lib-subject-viewers/src/VolumetricViewer/helpers/OrbitControls.js`.

Comment on lines +7 to +13
/* RAW SVG FOR SLIDER | Needs to be URL encoded to view
const SVGSlider = `<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 32'>
<rect width='100%' height='100%' rx='8' ry='8' style='fill: rgb(0,93,105);' />
<path d='M16 10 l-7 6 l7 6;' style='stroke:rgb(173, 221, 224); stroke-width:2; fill: none;'/>
<path d='M24 10 l7 6 l-7 6;' style='stroke:rgb(173, 221, 224); stroke-width:2; fill: none;'/>
</svg>`
*/
Copy link
Contributor

Choose a reason for hiding this comment

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

I noticed this is commented-out, did you want to keep it in the Slider.js code?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Not yet. If Sean wants a design edit I'll edit that as the raw SVG and then remove it as a comment once fully approved.

@@ -14,7 +14,7 @@ export const ModelViewer = () => {
planesAbsoluteSets: [[], [], []],
planeFrameActive: [0, 0, 0],
points: [],
threshold: { min: 0, max: 255 },
threshold: { min: 5, max: 255 }, // min of 5 cuts out missing data noise
Copy link
Contributor

Choose a reason for hiding this comment

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

Out of curiosity, will uploaded subjects possibly have missing data?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes - that's actually the intention for clipping the bottom 5. If a cube has "no data" or is essentially black for a part of its cube, it cannot be part of any annotation. The annotations will usually exist in the top 50% of the lightness spectra, but it's the variation that can sometimes help detect where the neuron runs. This was Sean's suggestion to cut out blocks of "black" in the cube.

Copy link
Contributor

Choose a reason for hiding this comment

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

Good to know, thanks!

@kieftrav
Copy link
Contributor Author

kieftrav commented Jan 21, 2025

I reviewed by running lib-subject-viewer's Storybook and testing the workflow of your VV test project and the NeuroTracerBrain test project. I've left a few comments/questions, but otherwise skimmed the lib-subject-viewer code because 2k lines of changes is a lot for an in-depth review.

The steps in How To Review work as expected, but I have a few additional UI questions:

  1. Should the interaction to expand / collapse include clicking the text label? For example, as a user I expected to be able to click on the word "Expand" or the carat icon to expand the plane, but for now only the carat can be interacted with.
    Screenshot 2025-01-16 at 1 38 26 PM
  2. Have you noted the accessibility violations in Storybook? For instance, the Slider in particular is missing accessible labels. And in general, the Cube area doesn't have aria to announce the contents to a screen reader (for example, the bar chart for user stats has an aria-label to communicate the description of the bar chart). These points don't have to be resolved in this PR, but definitely should be documented todos, maybe in the project board?
  3. The test project UI includes zoom buttons and rotate button in the image toolbar. What are the plans for those and is the intended UX documented in the project board?

And lastly, this is potentially already behavior you're aware of, but there's a console error generated by Cube.js TypeError: Cannot set properties of undefined (setting 'x'). I can reliably produce the error by running NeuroTracerBrain locally in dev mode. In dev mode, it's a console error, but in production mode there's no error. With this test project in particular, it also takes an unexpectedly long time for annotations to show up on the Cube and Plane after a user click (about 5 - 10 seconds). The delay could be unrelated to the console error, but wanted to document a detailed UX during review so performance issues and errors can be added to the project board if not addressed in this PR.

After our weekly meeting it was decided that:

  1. Expand interaction click/toggle decision will be part of a follow-up Design PR
  2. Accessibility changes will be part of the follow up PR that includes question 3's zoom and rotate.
  3. Zoom and rotate will be a separate PR that includes question 2's accessibility changes
  4. Cannot set properties of undefined (setting 'x') and annotation performance will be part of follow up PR's

All of these decisions have been reflected in the VolumetricViewer project board.

Copy link
Contributor

@goplayoutside3 goplayoutside3 left a comment

Choose a reason for hiding this comment

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

Looks good, thanks!

@github-actions github-actions bot added the approved This PR is approved for merging label Jan 21, 2025
- Add 4, 8, 16, 32, and 64 example to Storybook
- Add Histogram range slider
- Add params to overall Viewer
- Fix scroll bug
- Inline OrbitControls import
- Incorporate Figma Styles
@kieftrav kieftrav merged commit f2b3a0b into master Jan 21, 2025
7 checks passed
@kieftrav kieftrav deleted the vv-styles branch January 21, 2025 22:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved This PR is approved for merging
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants