-
Notifications
You must be signed in to change notification settings - Fork 80
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
[FC-0059] feat: add copy to clipboard feature to library authoring #1197
[FC-0059] feat: add copy to clipboard feature to library authoring #1197
Conversation
Thanks for the pull request, @rpenido! What's next?Please work through the following steps to get your changes ready for engineering review: 🔘 Get product approvalIf you haven't already, check this list to see if your contribution needs to go through the product review process.
🔘 Provide contextTo help your reviewers and other members of the community understand the purpose and larger context of your changes, feel free to add as much of the following information to the PR description as you can:
🔘 Get a green buildIf one or more checks are failing, continue working on your changes until this is no longer the case and your build turns green. 🔘 Let us know that your PR is ready for review:Who will review my changes?This repository is currently maintained by Where can I find more information?If you'd like to get more details on all aspects of the review process for open source pull requests (OSPRs), check out the following resources:
When can I expect my changes to be merged?Our goal is to get community contributions seen and reviewed as efficiently as possible. However, the amount of time that it takes to review and merge a PR can vary significantly based on factors such as:
💡 As a result it may take up to several weeks or months to complete a review and merge your PR. |
2f2ef0d
to
0dae5ae
Compare
e2004d5
to
a12c942
Compare
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #1197 +/- ##
==========================================
+ Coverage 92.88% 92.90% +0.01%
==========================================
Files 750 750
Lines 13468 13480 +12
Branches 2930 2927 -3
==========================================
+ Hits 12510 12523 +13
+ Misses 923 922 -1
Partials 35 35 ☔ View full report in Codecov by Sentry. |
@@ -101,13 +112,13 @@ export interface ContentHit { | |||
* - After that is the name and usage key of any parent Section/Subsection/Unit/etc. | |||
*/ | |||
breadcrumbs: [{ displayName: string }, ...Array<{ displayName: string, usageKey: string }>]; | |||
tags: Record<'taxonomy' | 'level0' | 'level1' | 'level2' | 'level3', string[]>; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't necessarily have these fields in a ContentHit
. A hit without tags will have tag: {}
. A hit with a level1
tag will have tags: { "taxonomy": ["Taxonomy"], level0: ["Taxonomy > Level0"], level1: ["Taxonomy > Level0 > Level1"] }
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@rpenido Great work on this! The code looks good here had a few nits. I also left a comment about an issue I faced in the edx-platform PR that needs to be addressed.
src={MoreVert} | ||
iconAs={Icon} | ||
variant="primary" | ||
alt="component-card-menu-toggle" // FixMe: Add alt text |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: Adding the alt intl text
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed here: ace4c25
<Dropdown.Item disabled> | ||
{intl.formatMessage(messages.menuEdit)} | ||
</Dropdown.Item> | ||
<Dropdown.Item onClick={updateClipboardClick} data-testid="component-card-menu-copy-clipboard"> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: Is it possible to get the dropdown item in the tests through other means instead of relying on the data-testid? Since that is generally discouraged and should be the last resort.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unfortunately not. 😞
The card menu is a button without a label. Getting via getByRole('button', { name: '' })
could work, but I don't think it will have a better result in the test readability.
For the Dropdown.Item, I'm using the label. Removing the data-testid here as it is not being used: b960fc5
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Got it, thanks for the clarification
@rpenido 🎉 Your pull request was merged! Please take a moment to answer a two question survey so we can improve your experience in the future. |
Description
This PR adds the feature to copy library components to the clipboard to be later pasted into a course or another library (in progress #1176)
Note: Drag and Drop blocks will be supported in a follow up task
Support information
Closes #1104
Depends on:
Testing Instructions
Private ref: FAL-3769