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

add contrast alpha node #272

Merged
merged 3 commits into from
Jun 17, 2024
Merged

add contrast alpha node #272

merged 3 commits into from
Jun 17, 2024

Conversation

mck
Copy link
Collaborator

@mck mck commented Jun 13, 2024

PR Type

Enhancement


Description

  • Added a new Contrasting Alpha node for color contrast calculation using APCA-W3 and WCAG 2.1 standards.
  • Implemented a binary search algorithm to adjust alpha values until the desired contrast threshold is met.
  • Refactored existing code to use the new flattenAlpha utility function for alpha blending.
  • Updated the node index to export the new contrastingAlpha node.
  • Added a changeset to document the new feature.

Changes walkthrough 📝

Relevant files
Enhancement
contrastingAlpha.ts
Add `Contrasting Alpha` node for color contrast calculation

packages/graph-engine/src/nodes/color/contrastingAlpha.ts

  • Added new Contrasting Alpha node for color contrast calculation.
  • Implemented binary search for alpha reduction to meet contrast
    threshold.
  • Defined inputs and outputs for the node.
  • +153/-0 
    flattenAlpha.ts
    Refactor to use `flattenAlpha` function for alpha blending

    packages/graph-engine/src/nodes/color/flattenAlpha.ts

    • Refactored to use flattenAlpha function for alpha blending.
    +5/-25   
    index.ts
    Export `contrastingAlpha` node in index                                   

    packages/graph-engine/src/nodes/color/index.ts

    • Added contrastingAlpha to the list of exported nodes.
    +4/-2     
    flattenAlpha.ts
    Create `flattenAlpha` utility function for alpha blending

    packages/graph-engine/src/nodes/color/lib/flattenAlpha.ts

    • Created flattenAlpha utility function for alpha blending.
    +31/-0   
    Documentation
    lovely-boxes-knock.md
    Add changeset for `Contrasting Alpha` node                             

    .changeset/lovely-boxes-knock.md

    • Added changeset for new Contrasting Alpha node.
    +5/-0     

    💡 PR-Agent usage:
    Comment /help on the PR to get a list of all available PR-Agent tools and their descriptions

    Copy link

    changeset-bot bot commented Jun 13, 2024

    🦋 Changeset detected

    Latest commit: 87020b9

    The changes in this PR will be included in the next version bump.

    This PR includes changesets to release 3 packages
    Name Type
    @tokens-studio/graph-engine Minor
    @tokens-studio/graph-engine-nodes-audio Major
    @tokens-studio/graph-engine-nodes-design-tokens Major

    Not sure what this means? Click here to learn what changesets are.

    Click here if you're a maintainer who wants to add another changeset to this PR

    @mck mck requested a review from SorsOps June 13, 2024 12:43
    Copy link
    Contributor

    PR Reviewer Guide 🔍

    ⏱️ Estimated effort to review [1-5]

    4

    🧪 Relevant tests

    No

    🔒 Security concerns

    No

    ⚡ Key issues to review

    Possible Bug:
    The binarySearchAlpha function in contrastingAlpha.ts might lead to infinite recursion if the high - low condition is not met and iterations is not decremented properly.

    Code Duplication:
    The flattenAlpha function logic seems to be duplicated in both flattenAlpha.ts and lib/flattenAlpha.ts. Consider refactoring to use the function from the library to maintain code consistency and avoid redundancy.

    Copy link
    Contributor

    PR Code Suggestions ✨

    CategorySuggestion                                                                                                                                    Score
    Performance
    Convert recursive binary search to iterative to avoid stack overflow

    Refactor the binarySearchAlpha function to avoid using recursion, which can lead to stack
    overflow errors for large input sizes or high precision values. Instead, use an iterative
    approach.

    packages/graph-engine/src/nodes/color/contrastingAlpha.ts [105-124]

     const binarySearchAlpha = (low, high, fg, bg, targetContrast, iterations) => {
    -  ...
    +  while (iterations > 0 && high - low >= 0.01) {
    +    const mid = (low + high) / 2;
    +    fg.alpha = mid;
    +    const solidColor = flattenAlpha(fg, bg);
    +    const currentContrast = contrastCheck(solidColor, bg, wcag);
    +    if (currentContrast >= targetContrast) {
    +      high = mid;
    +    } else {
    +      low = mid;
    +    }
    +    iterations--;
    +  }
    +  fg.alpha = high;
    +  return high;
     };
     
    Suggestion importance[1-10]: 10

    Why: Converting the recursive binary search to an iterative approach is a significant improvement that prevents potential stack overflow errors, especially for large input sizes or high precision values.

    10
    Possible bug
    Add error handling for color creation to prevent runtime errors

    Consider adding error handling for the Color constructor in case the input color strings
    are invalid. This will prevent runtime errors and provide clearer feedback to users about
    the issue.

    packages/graph-engine/src/nodes/color/contrastingAlpha.ts [127-128]

    -const foregroundColor = new Color(foreground);
    -const backgroundColor = new Color(background);
    +let foregroundColor, backgroundColor;
    +try {
    +  foregroundColor = new Color(foreground);
    +  backgroundColor = new Color(background);
    +} catch (error) {
    +  console.error("Invalid color format:", error);
    +  return; // Optionally, handle the error more gracefully
    +}
     
    Suggestion importance[1-10]: 9

    Why: Adding error handling for the Color constructor is crucial to prevent runtime errors and provide clearer feedback to users. This significantly improves the robustness of the code.

    9
    Best practice
    Avoid mutating the original color object directly to prevent side effects

    Replace the direct assignment of fg.alpha within the binary search function with a method
    that clones the color object. This avoids mutating the original color object, which can
    lead to unintended side effects.

    packages/graph-engine/src/nodes/color/contrastingAlpha.ts [113]

    -fg.alpha = mid;
    +const newColor = fg.clone();
    +newColor.alpha = mid;
     
    Suggestion importance[1-10]: 8

    Why: Avoiding direct mutation of the original color object is a best practice that prevents unintended side effects, enhancing the reliability of the function.

    8
    Maintainability
    Initialize variables before use to improve code clarity

    Initialize currentContrast before its first use in the execute method to ensure it is
    always defined, which enhances code readability and maintainability.

    packages/graph-engine/src/nodes/color/contrastingAlpha.ts [129]

    -let currentContrast = contrastCheck(foregroundColor, backgroundColor, wcag);
    +let currentContrast: number;
    +currentContrast = contrastCheck(foregroundColor, backgroundColor, wcag);
     
    Suggestion importance[1-10]: 5

    Why: While initializing currentContrast before its first use can improve code clarity, it is a minor improvement since TypeScript's type inference already ensures its definition.

    5

    @SorsOps SorsOps merged commit 4134454 into major/strong-typing Jun 17, 2024
    1 of 2 checks passed
    @SorsOps SorsOps deleted the contrasting-alpha branch June 17, 2024 11:04
    SorsOps added a commit that referenced this pull request Jun 18, 2024
    * Stash
    
    * Stash
    
    * WIP
    
    * Cleanup inline nodes and re-enable array nodes
    
    * Add drop panel to show windows
    
    * Remove settings dialog
    
    * Fix bug with values sticking if selecting between two nodes of the same type
    
    * Fix not reinvalidating the node settings
    
    * Fix issue with duplication
    
    * Fix audio source
    
    * Update UI package and simplify dialog
    
    * Cleanup file explorer
    
    * Update files system
    
    * Add support for audio buffer conversions
    
    * Fix changed bufferschema refs in audio pkg
    
    * add ceil and floor nodes
    
    * Subgraphs mostly working
    
    * Cleanup not selecting the correct graph on tab transition
    
    * Cleanup typescript types
    
    * Cleanup UI and fix deserialization of edges
    
    * Additional UI cleanup
    
    * Fix padding on settings
    
    * Minor update on documentation
    
    * Cleanup on styles
    
    * Fix nodenext resolution
    
    * Cleanup ts config
    
    * Cleanup ts import for consistency
    
    * Replace all .ts? imports
    
    * Fix issue with typing
    
    * Add assets for apple touch startup
    
    * Add initial k8s for mailcatcher for local dev
    
    * Add docker-compose for open telemetry for nextjs
    
    * Cleanup styles
    
    * Add postgres for persistence
    
    * Fix circular import
    
    * Fix menu Item boolean value issue
    
    * Remove console log
    
    * Add prometheus and otel config
    
    * Set default to be darktheme
    
    * Cleanup menubar rest render spread
    
    * Move controls for token arrays to the token package
    
    * Cleanup old redux models
    
    * Remove global css usage
    
    * Set darktheme to be the default and remove global css usage
    
    * Remove old output providers from preview. They will need to be reworked to handle routing the data
    
    * Add support for client side storage providers
    
    * Add mailcatcher and postgres to docker-compose
    
    * Add otel instrumentation
    
    * Update packge for otel
    
    * Setup ory kratos, replace mailcatcher with mailslurper
    
    * Add tracing for debugging
    
    * Restyle node (#245)
    
    * restyle node
    
    * restyle node
    
    * restyle node
    
    * remove unused background
    
    * remove unused background
    
    * remove string from import
    
    * fix pointer events on handle
    
    * Fix storybook setup
    
    * add rail
    
    * style graph editor
    
    * update node style to have more contrast
    
    * add exp and sqrt node
    
    * Add initial scaffold for backend
    
    * change icon for type any
    
    * mute down handle background
    
    * fix transparent background on panels
    
    * Fix graph loading
    
    * Swap ui to use scss and remove unnecessary styling
    
    * Add scss support for Marco and fix non .js imports
    
    * fix reference to styles.css to .scss
    
    * Add example of barebones implementation of the graph-editor
    
    * Cleanup file
    
    * Fix issue with zustand not being the same
    
    * Extend color ranges and fix colors showing up correctly in port previews
    
    * Remove console log during graph serialization
    
    * Update backend to use prisma, add in DI, setup ory kratos connection
    
    * Add oathkeeper and kratos setup
    
    * Add next link for rail
    
    * Remove drag initiator styling
    
    * Add generated SDK
    
    * Update backend package
    
    * Remove copied changelog
    
    * Get backend docker build working
    
    * Move docker resources and add a readme entry for running the docker compose
    
    * Remove all icon packages except for iconoir
    
    * Remove import assertion for importing json.  We assume this is unnecessary
    
    * Remove DB, we will assume migration as needed
    
    * Replace graphlib with later version
    
    * Ignore users local db
    
    * Move docker compose env to root
    
    * Graphlib replace
    
    * Optimize icon usage
    
    * Add basic keto client, setup proper documentation
    
    * Add initial controllers
    
    * Update SDK
    
    * Add SDK to UI
    
    * Cleanup docs
    
    * Update edge docs
    
    * Fix oathkeeper origins
    
    * Expand models
    
    * Ignore noisy generated changes
    
    * Ignore noisy files
    
    * Export typing on the serialized graph
    
    * Clean cors
    
    * Remove cors as expected to be handled externally
    
    * Update kratos
    
    * Fix ref
    
    * Untrack generated
    
    * ignore json import which should be external
    
    * Persist dynamic type
    
    * Integrate API
    
    * Remove console log
    
    * Remove prometheus
    
    * Add example for preview
    
    * add preview nodes
    
    * Force generation on build
    
    * add viewport saving, math expression visualisation, default values for number
    
    * add gradient stops and gradient handle positions
    
    * Setup storybook test
    
    * remove gradient handles, add gradient schema
    
    * Export util functions
    
    * Don't require typing on input unless its intentionally dynamic
    
    * Add storybook example
    
    * Add delayed updates to controls, fix issue with choosing a type and not having the control update
    
    * Fix non standard curve change that was breaking preview
    
    * Fix issue with token set controls and expose them correctly
    
    * Fix token saving not serializing correctly
    
    * Remove live update of position annotation, was causing unnecessary recalc
    
    * Clean up hot key usage and first pass at fixing subgraphs
    
    * Add manifest for PWA in the future
    
    * Cleanup UI and start app router migration
    
    * Clean up docs
    
    * Mention initial db setup for prisma
    
    * Setup for gitpod
    
    * Cleanup build type errors
    
    * More gitpod setup
    
    * Additional setup for app router conversion
    
    * Fix for Marco
    
    * Fix style ordering
    
    * Update graph-engine to use tsup over rollup. Remove aliasing as the esbuild does not seem to respect the alias transform
    
    * Finish converting other node packages to use tsup
    
    * Fix missing tsx for tsup
    
    * Fix issue with token preview if undefined
    
    * Fix menu bombing due to nextjs removing svg loader
    
    * Remove old rollup file
    
    * Continued rollup removal
    
    * add new colors for types on handles
    
    * change size of handle icon
    
    * Update tsup configs
    
    * Fix type problem with engine bundling
    
    * Fix build splitting
    
    * Cleanup hotkeys
    
    * Fix external sanitize usage
    
    * add radix ui colors
    
    * Cleanup docker build
    
    * Update dep for design-tokens
    
    * Fix host name on deploy
    
    * Fix for readiness probe
    
    * Stop redirecting on index
    
    * Remove second level domain
    
    * Revert
    
    * Setup lit example of context usage
    
    * Add typograph preview specifics
    
    * Add building the backend and docs to workflow
    
    * Make the docs use the same dev command as everything else
    
    * Fix variadic typing for Marco
    
    * Change build command for documentation
    
    * Allow dynamic inputs for array map subgraph
    
    * Fix issue with subgraph typing for tokens
    
    * Minor fix to display the font size
    
    * Add cypress testing to graph-editor
    
    * Deploy graph docs
    
    * Re add up to date position changes
    
    * Add basic vector 2 support
    
    * Simplify typing on arrays
    
    * Cleanup from changes
    
    * Add setting to hide minimap and to show the title in the subgraph
    
    * Fix finding nodes
    
    * Improve searching
    
    * Add copy value to port
    
    * Stop subgraph from gathering input values every loop
    
    * Add reduce subgraph
    
    * Expose convert color
    
    * Fix poline
    
    * Make series consistent with naming
    
    * Add advanced blending to design tokens
    
    * Cleanup schemas on token arrays
    
    * Fix cases where input is not detected
    
    * Add secret and deployment
    
    * Add alignment and distribution
    
    * Add better support for network messages
    
    * Fix bug where we don't disconnect an edge and minor cleanup in tests
    
    * Complete subgraph creation , convert output to multi output
    
    * Cleanup typing on graph
    
    * Update docs
    
    * Update docs
    
    * Fix issue with subgraph not reconnecting nodes
    
    * Fix grouping
    
    * Start releasing on dockerhub
    
    * Remove tauri
    
    * Update versions
    
    * Fix ignore
    
    * Update Gimlet
    
    * Update deployment for docs and backend
    
    * fix bugs
    
    * rm log
    
    * fix input inputs
    
    * add dimension
    
    * 250: fix shift+k (#251)
    
    * fix(250): Fix quick search triggered in input fields
    Co-authored-by: SorsOps <80043879+sorsOps@users.noreply.github.com>
    
    * Reorder variadic ports (#258)
    
    
    
    ---------
    
    Co-authored-by: SorsOps <80043879+sorsOps@users.noreply.github.com>
    
    * fix color wheel (#261)
    
    * Show value preview in nodes (#257)
    
    * Show value preview in nodes
    
    * Add dot for variadic and other improvements
    
    * Fix edge case with object variadics and allow toggling on and off of inline values
    
    * Merge george's changes
    
    ---------
    
    Co-authored-by: SorsOps <80043879+sorsOps@users.noreply.github.com>
    
    * fix valid check (#263)
    
    * Feat/debugger (#259)
    
    * Add debugger and remove flamegraph
    
    * add xyz65 to color convert
    
    * fix flatten node
    
    * add flatten alpha node
    
    * fix(1013): Subgraph ouput
    
    * Setup alpha and beta deploys (#270)
    
    * Hide unfinished work (#271)
    
    * Setup alpha and beta deploys
    
    * Hide unfinished work
    
    * Fix arrayMap and arrayReduce
    
    * fix(273): Fix input output execution
    
    * Copy type to outputs
    
    * fix(273): Fix input output execution (#274)
    
    * fix(273): Fix input output execution
    
    * Copy type to outputs
    
    * Revert "fix(273): Fix input output execution (#274)" (#275)
    
    This reverts commit 6d14dbc.
    
    * Revert "Fix input output execution" (#277)
    
    * feat: Update input.ts to handle dynamic type changes in Input.setValue()
    
    * Feat/documentation (#279)
    
    * Add script to generate documentation
    Remove 'NodeTypes` in favor of direct values for the node types
    Change input/output nodes to not clear and instead diff values
    Fixed some issues with flexbox of the node wrapper
    Add in an array indicator
    Fixed subgraph to be reactive to additional outputs
    Fix find menu
    
    * add contrast alpha node (#272)
    
    * add contrast alpha node
    
    * Remove console logs
    
    ---------
    
    Co-authored-by: SorsOps <80043879+sorsOps@users.noreply.github.com>
    
    * UI rework (#278)
    
    * add subtitle and style ui
    
    * Fix select and download
    
    * Add constant for graph id
    
    ---------
    
    Co-authored-by: Marco Christian Krenn <marco.krenn@gmail.com>
    
    * prevent delete when annotation is present (#281)
    
    * Fix inputs which are any type to be overridden with new values. (#282)
    
    Fix typing with the array subgraph
    Allow creating array input types
    
    * add colors to legend (#283)
    
    * Feat/token sets (#284)
    
    * Fix inputs which are any type to be overridden with new values.
    Fix typing with the array subgraph
    Allow creating array input types
    
    * Expose additional vars in the array map and add the ability to convert to a token set
    
    * Fix/command k (#287)
    
    * Fix inputs which are any type to be overridden with new values.
    Fix typing with the array subgraph
    Allow creating array input types
    
    * Expose additional vars in the array map and add the ability to convert to a token set
    
    * Fix command palette messing up positions
    
    * Fix contrasting alpha import
    
    * Add markdown support
    
    * Change objectmerge and flatten to not  be variadic
    
    * fix: input bug
    
    * Remove console logs
    
    * Remove console logs
    
    * Fix color wheel (#300)
    
    * fix color wheel calculation
    
    * add changeset
    
    * fix position reference (#298)
    
    * fix pos reference
    
    * spread annotations
    
    * Feat/prep master (#303)
    
    * Fix can delete.
    Fix issues with variadic passing through type for any array.
    Prep for the major overhaul
    Add back in examples
    
    * Setup gimlet for deploys
    
    ---------
    
    Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
    Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
    Co-authored-by: popdrazvan <popdrazvan@gmail.com>
    Co-authored-by: Vaibhav Bhosale <mail2vsbhosale@gmail.com>
    Co-authored-by: Jan Six <six7@github.com>
    Co-authored-by: Jan Six <six.jan@gmail.com>
    
    ---------
    
    Co-authored-by: Marco Christian Krenn <marco.krenn@gmail.com>
    Co-authored-by: popdrazvan <popdrazvan@gmail.com>
    Co-authored-by: georgebuciuman <georgebuciuman@gmail.com>
    Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
    Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
    Co-authored-by: Vaibhav Bhosale <mail2vsbhosale@gmail.com>
    Co-authored-by: Jan Six <six7@github.com>
    Co-authored-by: Jan Six <six.jan@gmail.com>
    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
    Labels
    Projects
    None yet
    Development

    Successfully merging this pull request may close these issues.

    2 participants