Hi,
How do I exclude the hidden columns and row values from the copied data when a user selects multiple rows and clicks on the ctrl-c?
I have tried deselecting the columns also from the context menu, but these still appear in the copied clipboard data. I have also tried setting the column.visible property to false, but this just removes the column header values, the row values still show.
I have had a look around the forum and can't find much about it at all, and nothing on the MVC forums. Apologies if I have missed this question being asked already.
Thanks :)
Hi Rob,
Greetings from Syncfusion support.
We have validated your query “Remove hidden columns from Grid Clipboard” and set column visible property as false for a column and copied multiple rows and it’s working fine from our end. We have prepared a video sample to explain you how we tried to recreate this scenario. Please refer to the attached video.
In order to provide an accurate and effective solution, we kindly ask that you provide us with the following information:
Regards,
Santhosh Iruthayaraj
Hi Santhosh,
Thanks for your reply, however, I can't seem to see the attached video that you are referring to. Am I missing it, or did you not attach it?
Thanks,
Rob
Hi Rob,
I apologize for any inconvenience caused by the omission of the ZIP file in our previous communication. Please find attached the required ZIP file for your reference.
Regards,
Santhosh Iruthayaraj
Hi Santhosh,
That method won't work as I want to hide the columns after the selection has been made, and the refreshColumns() deselects anything that was previously selected. It would also look bad on the screen as the columns would temporarily disappear, and then reappear after the copy. The flow I am after is something along the lines of:
Hi Rob,
To achieve your requirement we need to use hideColumns property. But hideColumns property not working properly. We have confirmed the scenario as a bug from our side and logged a defect report for the same as “Copy not working properly when using hideColumns property”. At Syncfusion, we are committed to fixing all validated defects (subject to technological feasibility and Product Development Life Cycle ) and will include the defect fix in our patch release scheduled to be rolled out on 8th March, 2023. We appreciate your patience until then.
You can now track the current status of your request, review the proposed resolution timeline, and contact us for any further inquiries through the below link.
Feedback: https://www.syncfusion.com/feedback/41195/copy-not-working-properly-when-using-hidecolumns-property
Regards,
Santhosh Iruthayaraj
Rob,
Sorry for the inconvenience caused.
We are unable to complete this issue (“Copy not working properly when using
hideColumns property”) as planned due to its complexity. We will include
the fix in our upcoming patch release which is expected to be rolled out on Mar
15th, 2023. Till then we appreciate your patience.
Feedback Link: https://www.syncfusion.com/feedback/41195/copy-not-working-properly-when-using-hidecolumns-property
Hi Rob,
We are glad to announce that our Essential Javascript2 patch release (v20.4.54) has been rolled out successfully and in that release, we have added the fix of “Copy not working properly when using hideColumns property” issue. So, please update your Syncfusion packages to the current version and use latest styles to get this.
Release Notes: https://ej2.syncfusion.com/javascript/documentation/release-notes/20.4.54/?type=all#grid
We thank you for your support and appreciate your patience in waiting for this release. We have also prepared a code snippet that will help achieve your requirement “Remove hidden columns from Grid Clipboard” using the beforeCopy event and hideColumns method.
[index.js]
function beforeCopy(args) { if (args.data != '') { let values = args.data.split('\n').length === 1 ? args.data.split('\t') : args.data.split('\n')[0].split('\t'); if (values.length < 5) { grid.showColumns(['Customer Name', 'Order Date']); grid.selectRows(selectedRows); selectedRows = undefined; } else { args.cancel = true; selectedRows = grid.getSelectedRowIndexes(); grid.hideColumns(['Customer Name', 'Order Date']); grid.selectRows(selectedRows); grid.copy(); } } } |
Sample: https://stackblitz.com/edit/gejtyg?file=index.js
Please get in touch with us if you would require further assistance.
Regards,
Santhosh I