-
Notifications
You must be signed in to change notification settings - Fork 180
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
[DO NOT MERGE UNTIL NEW KDS RELEASE] Almost complete icons migration from Vuetify to KDS #4633
base: unstable
Are you sure you want to change the base?
[DO NOT MERGE UNTIL NEW KDS RELEASE] Almost complete icons migration from Vuetify to KDS #4633
Conversation
a4261a4
to
5bb1ce9
Compare
- Shows dropup icon when item is open - Makes dropdown/dropup icons size consistent with the channel dropdown/dropup
For slideshow and error, there's a slight visual difference, however it is aligned with the KDS. Includes a new icons map and renames the previous one to indicate that it is Vuetify specific and in the process of deprecation.
- prepares ground for adding related files - no changes to the file contents
Part of migration to KIcon. The icons removed are not currently used from anywhere in Studio. and if we need them in the future, they will be added to KDS.
to common utils file. It has nothing to do with Vuetify icons anymore.
This is part of migrating Studio to KIcon. Thumbnail.vue component is the only remaning component using VIconWrapper. It can't be migrated to KIcon yet since KIcon needs to be updated at first with some new features. Moving the files here ensures that VIconWrapper won't be used from anywhere else in the Studio.
Icon.vue was originally a temporary wrapper that offered some extra logic, such as RTL support. However, KIcon is taking care of it and the wrapper doesn't really do anything extra.
IconButton.vue was originally a temporary wrapper, oferring some extra logic such as RTL support. However, KDS takes care of RTL, so it's not needed. One more thing IconButton did was automatically setting aria label - if we're certain this is desired in all cases, it can be introduced as a KDS feature.
They need to be displayed next to the text rather to take the whole block.
54c4476
to
cfa0e15
Compare
7640bc6
to
5494a6e
Compare
5494a6e
to
272be7e
Compare
272be7e
to
14cfe2b
Compare
94b2359
to
440f698
Compare
440f698
to
e0563de
Compare
Resolved latest conflicts and updated to the latest changes in learningequality/kolibri-design-system#722 |
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.
I added my code comment last week re: i18n, but failed to complete my "review" overall the changes look good to me.
I think it'd be worth getting some significant QA done on this for regressions in any case.
Should I do some manual QA on this? If so I can make time to do it tomorrow
tooltip="Email" | ||
ariaLabel="Email" |
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.
I was wondering if these should be translated but then I think I recall that we don't translate the administration
app?
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.
Good catch. Hmm I am not sure, I just used what was there. @bjester or @marcellamaki do you know?
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.
Yeah generally we haven't worried about translating the administration side of Studio. So this is acceptable given the current state of it.
Thank you @nucleogenesis
Absolutely. I did my best to preview as I worked, but was returning to it repeatedly after longer periods of time, and now I also keep rebasing, so we will very likely find some trouble.
That's a generous offer :) I think for developers it'd make more sense to manually preview a suspicious place in code. We talked with @bjester some time ago and agreed this would be rather task for the pre-release QA (which happens after merging to |
@@ -62,7 +62,7 @@ | |||
<VListTileAction | |||
class="action-col px-1 v-list__group__header__append-icon" | |||
> | |||
<Icon icon="dropdown" /> | |||
<KIcon :icon="open ? 'dropup' : 'dropdown'" :style="{ fontSize: '22px' }" /> |
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.
Not a blocker, but I'm wondering if there's a way to make a nice visual transition between these two icons.
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.
Everything looks pretty good. My main concern though, which I'm not sure whether it's a blocker yet, is whether KTooltip
behaves similarly to VTooltip
with the lazy
prop. Previously, we found that because of the large number of tooltips, we can could cut down on the number of rendered elements and reduce memory usage slightly with the use of lazy
. With these changes, if the differences aren't evaluated, we could end up increasing the memory usage of a channel page.
</VBtn> | ||
<VBtn | ||
v-if="node.kind === 'topic'" | ||
icon | ||
class="mx-1 rtl-flip" |
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.
Are we certain rtl-flip
should be removed here?
ariaLabel="text" | ||
:color="color" | ||
:size="size" | ||
:class="{ 'rtl-flip': rtlFlip }" |
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.
If this component was essentially a wrapper for KIconButton
, what were the reasons for having this apply the rtl-flip
class? It seems that it would still be important unless this was because of a deficiency in the KDS component itself that has been fixed.
Thanks @bjester, that's a good feedback. I will look into it all as soon as I'm back in November, since for some parts I think I will need more time. |
Summary
Description of the change(s) you made
Almost completes icons migration from Vuetify to KDS.
VIconWrapper
s withKIcon
,KLabeledIcon
, orKIconButton
VTooltip
byKTooltip
at places where KDS icons usage requires itsidebar
iconKTooltip
to the teleport root element in few places where there seemed to be no other way to fix its parts being cut off (mostly related to being surrounded by Vuetify components)See commit messages for details.
Note that the
Thumbnail
component still usesVIconWrapper
. There are some features that we need to add first toKIcon
to allow for the refactor. I will try to write what needs to happen to a KDS issue as soon as I have time for this agian. To prevent from usingVIconWrapper
except this one place, I moved it to theThumbnail
directory and left deprecation note.Manual verification steps performed
I was gradually previewing all places where I worked.
Reviewer guidance
How can a reviewer test these changes?
node_modules
(otherwise you won't get updated KDS version in the installation step) and then runyarn install
to ensure that Let's teleport + make 'sidebar' icon flip in RTL languages kolibri-design-system#722 work is availableReferences
Follow-up to @BabyElias's #4502
Contributor's Checklist
PR process:
If this is an important user-facing change, PR or related issue theCHANGELOG
label been added to this PR. Note: items with this label will be added to the CHANGELOG at a later timeIf this includes an internal dependency change, a link to the diff is providedThedocs
label has been added if this introduces a change that needs to be updated in the user docs?If any Python requirements have changed, the updatedrequirements.txt
files also included in this PROpportunities for using Google Analytics here are notedMigrations are safe for a large dbStudio-specifc:
All user-facing strings are translated properlyThenotranslate
class been added to elements that shouldn't be translated by Google Chrome's automatic translation feature (e.g. icons, user-generated text)Views are organized intopages
,components
, andlayouts
directories as described in the docsUsers' storage used is recalculated properly on any changes to main tree filesIf there new ways this uses user data that needs to be factored into our Privacy Policy, it has been noted.Testing:
Critical user journeys are covered by Gherkin storiesAny new interactions have been added to the QA SheetCritical and brittle code paths are covered by unit testsReviewer's Checklist
This section is for reviewers to fill out.
yarn
andpip
)