I'm creating a color palette where I have a clipboard icon within a Tooltip component next to each color. On click it will copy the color's name onto the user's clipboard. When that happens, the Tooltip's message should change from "copy" to "copy success". I'm having issues trying to display the success message individually for each color.
How to properly render a success message upon clipboard click and copy
1.3k Views Asked by AudioBubble At
2
There are 2 best solutions below
0
Donnyesq
On
Try passing 'event' as a parameter to your onClick function and using the stopPropagation() method. Like so:
<Tooltip title={copyMessage} placement="right">
<span
onClick={(event) => {
event.stopPropagation()
copyNameToClipboard(color.name);
setState({
copyMessage: 'copy success',
});
}}
>
This should stop your event from 'bubbling up' to other components:
https://developer.mozilla.org/en-US/docs/Web/API/Event/stopPropagation
Related Questions in JAVASCRIPT
- Using Puppeteer to scrape a public API only when the data changes
- inline SVG text (js)
- An array of images and a for loop display the buttons. How to assign each button to open its own block by name?
- Storing the preferred font-size in localStorage
- Simple movie API request not showing up in the console log
- Authenticate Flask rest API
- Deploying sveltekit app with gunjs on vercel throws cannot find module './lib/text-encoding'
- How to request administrator rights?
- mp4 embedded videos within github pages website not loading
- Scrimba tutorial was working, suddenly stopped even trying the default
- In Datatables, start value resets to 0, when column sorting
- How do I link two models in mongoose?
- parameter values only being sent to certain columns in google sheet?
- Run main several times of wasm in browser
- Variable inside a Variable, not updating
Related Questions in REACTJS
- ussd reader in Recket Native module
- Teams tab application returns SSO error in mobile Outlook
- Github Pages Deployment deploys a blank page
- Is there any way to glow this bulb image like a real light bulb
- Optimize LCP ReactJs
- Page in React only renders elements after refreshing
- Unable to Post Form Data to MongoDB because of picturepath
- MERN Stack App - User Avatar Upload - 500 Error After Deployment on Render
- Hooks are not supported inside an async component error in nextjs project using useQuery
- How to change the Font Weight of a SelectValue component in React when a SelectItem is selected?
- On the server side, it returns undefined but on the client side, logs the values no problem
- Multilevel dropdown with checkboxes in Select component
- TypeScript Error only on big type only when assigned to a variable
- Deployment through app engine, cloud sql database, problem connecting with server code, doesn't connect
- Data is not filtering in props. Showing passdata.map is not a function
Related Questions in MATERIAL-UI
- Multilevel dropdown with checkboxes in Select component
- Why a component? Drawer of mui Does not work inside Iframe
- Next js delay before applying Emotion and MUI styles
- How can I make a ListItem(in React) in the bottom left corner, in the following example?
- How to Make MUI TextField label behave as default whilst having a Start Input Adornment
- How to add custom property to palette in MUI custom theme
- Can I use a transparent version of the MUI AppBar with the original color from theme?
- Angular Material mat-form-field appearance="outline"
- Using Chart.js library to draw a Line graph using coingeko api is not working properly
- Migrating from MaterialUI to FluentUI
- How to use mui-x without nodejs?
- Display Image in a Material-UI Dialog after clicking an IconButton of the ImageListItemBar
- The filtering screen in mui datagrid is broken
- Material 3 Bottom App Bar - Centered FloatingActionButton moved icon to the left instead of right
- MUI autocomplete from a button
Related Questions in FRONTEND
- How to perform CRUD operations on a static JSON array in Angular? (without API)
- Java and React WebSocket - Error Connection
- Why can't I use PUT requests?
- Adding Modules to a Namespace using IIFE
- How to use PrimeNG multiselect search to trigger an API call based on user search input and populate the multiselect with the retrieved data?
- Should I compress images in java backend before sending to frontend?
- Privsate channel doesn;t display messages - propably it's problem with authentication
- Swiper Js Slider Reveal Next Slider Partially
- How can i prevent the image from zooming in when i resize the browser?
- NextJs 14. Intercepting Routes. Modal. Routing Problem
- How to perform get, update, add and delete operation in a multi-parameter JSON array just like an API in Angular
- How to animate calculated position/container height when viewport changes?
- Applying a different position for each child of a parent element with a formula?
- (React)At rendering, initial value of zustand comesout firstly Please, give me your opinions
- My state is undefined despite being setted
Related Questions in HTML5-CLIPBOARD-API
- Items written to clipboard by Navigator.clipboard.write() could not be pasted correctly
- Send Image in WhatsApp Web with Chrome Extension
- Copy Canvas content to clipboard in Javascript in iOS
- How can I use writeText() and readText() to copy and paste text throughout browsers using my Chrome Extension?
- Need help in this code Disable printscreen in Angular 14
- How to Integrate Copy to Clipboard with Rainbow Syntax Highlighter
- Clipboard API copy to clipboard and then open new window? Avoid loosing window focus
- How create link with text and paste it to telegram desktop
- Changing only the name of a variable appears to break JavaScript code to copy a link to the clipboard
- dispatching ClipboardEvent on textarea element does not work
- Clipboard API used in conjunction with Axios in click event
- JS: Can't use asynchronous clipboard API for pages that will be minimized or put in the background
- How to properly render a success message upon clipboard click and copy
- Using the clipboard API from a Google Apps Script Web Application
- How to fix the "Cannot find name 'ClipboardItem'" error?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
All of you
Tooltipcomponents are using the same parent statethis.state.copyMessage. If you click copy on one, that setsthis.state.copyMessageto"copy success", and it gets rerendered for all other Tooltips. You need to be able to either:I'd personally go with a way to identify who was clicked.
Global declaration
Set your state onClick
Get the appropriate message for the specific color
Pass in the title
There are many ways to work around this, and this is just one I find readable!