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

[HOLD for payment 2025-01-18] [$250] Non-editable rows on the workspace profile show a hover state #54090

Open
1 of 8 tasks
m-natarajan opened this issue Dec 13, 2024 · 38 comments
Assignees
Labels
Awaiting Payment Auto-added when associated PR is deployed to production Bug Something is broken. Auto assigns a BugZero manager. External Added to denote the issue can be worked on by a contributor Weekly KSv2

Comments

@m-natarajan
Copy link

m-natarajan commented Dec 13, 2024

If you haven’t already, check out our contributing guidelines for onboarding and email contributors@expensify.com to request to join our Slack channel!


Version Number: 9.0.75-6
Reproducible in staging?: Y
Reproducible in production?: Y
If this was caught on HybridApp, is this reproducible on New Expensify Standalone?:
If this was caught during regression testing, add the test name, ID and link from TestRail:
Email or phone of affected tester (no customers):
Logs: https://stackoverflow.com/c/expensify/questions/4856
Expensify/Expensify Issue URL:
Issue reported by: @dannymcclain
Slack conversation (hyperlinked to channel name): expensify_bugs

Action Performed:

Prerequiste: Invite User B as employee to User A's Workspace

  1. Login as user B
  2. Open the workspace from settings
  3. Hover over the profile and currency field

Expected Result:

No hover state as the fields are not editable

Actual Result:

Non-editable rows on the workspace profile show a hover state

Workaround:

Can the user still use Expensify without this being fixed? Have you informed them of the workaround?

Platforms:

Which of our officially supported platforms is this issue occurring on?

  • Android: Standalone
  • Android: HybridApp
  • Android: mWeb Chrome
  • iOS: Standalone
  • iOS: HybridApp
  • iOS: mWeb Safari
  • MacOS: Chrome / Safari
  • MacOS: Desktop

Screenshots/Videos

Add any screenshot/video evidence
CleanShot.2024-12-12.at.08.23.17.mp4
Recording.845.mp4

View all open jobs on GitHub

Upwork Automation - Do Not Edit
  • Upwork Job URL: https://www.upwork.com/jobs/~021867410578187381937
  • Upwork Job ID: 1867410578187381937
  • Last Price Increase: 2024-12-27
  • Automatic offers:
    • shubham1206agra | Contributor | 105546447
Issue OwnerCurrent Issue Owner: @isabelastisser
@m-natarajan m-natarajan added Daily KSv2 Bug Something is broken. Auto assigns a BugZero manager. labels Dec 13, 2024
Copy link

melvin-bot bot commented Dec 13, 2024

Triggered auto assignment to @isabelastisser (Bug), see https://stackoverflow.com/c/expensify/questions/14418 for more details. Please add this bug to a GH project, as outlined in the SO.

@Krishna2323
Copy link
Contributor

Krishna2323 commented Dec 13, 2024

Proposal

Please re-state the problem that we are trying to solve in this issue.

Non-editable rows on the workspace profile show a hover state

What is the root cause of that problem?

  • We are using the isDisabled property without shouldRemoveHoverBackground or shouldRemoveBackground prop.
    <MenuItemWithTopDescription
    title={policyName}
    titleStyle={styles.workspaceTitleStyle}
    description={translate('workspace.editor.nameInputLabel')}
    shouldShowRightIcon={!readOnly}
    disabled={readOnly}
    wrapperStyle={[styles.sectionMenuItemTopDescription, shouldUseNarrowLayout ? styles.mt3 : {}]}
    onPress={onPressName}
    shouldGreyOutWhenDisabled={false}
    shouldUseDefaultCursorWhenDisabled
    />
    </OfflineWithFeedback>
    {(!StringUtils.isEmptyString(policy?.description ?? '') || !readOnly) && (
    <OfflineWithFeedback
    pendingAction={policy?.pendingFields?.description}
    errors={ErrorUtils.getLatestErrorField(policy ?? {}, CONST.POLICY.COLLECTION_KEYS.DESCRIPTION)}
    onClose={() => Policy.clearPolicyErrorField(policy?.id ?? '-1', CONST.POLICY.COLLECTION_KEYS.DESCRIPTION)}
    >
    <MenuItemWithTopDescription
    title={policyDescription}
    description={translate('workspace.editor.descriptionInputLabel')}
    shouldShowRightIcon={!readOnly}
    disabled={readOnly}
    wrapperStyle={styles.sectionMenuItemTopDescription}
    onPress={onPressDescription}
    shouldGreyOutWhenDisabled={false}
    shouldUseDefaultCursorWhenDisabled
    shouldRenderAsHTML
    />
    </OfflineWithFeedback>
    )}
    <OfflineWithFeedback
    pendingAction={policy?.pendingFields?.outputCurrency}
    errors={ErrorUtils.getLatestErrorField(policy ?? {}, CONST.POLICY.COLLECTION_KEYS.GENERAL_SETTINGS)}
    onClose={() => Policy.clearPolicyErrorField(policy?.id ?? '-1', CONST.POLICY.COLLECTION_KEYS.GENERAL_SETTINGS)}
    errorRowStyles={[styles.mt2]}
    >
    <View>
    <MenuItemWithTopDescription
    title={formattedCurrency}
    description={translate('workspace.editor.currencyInputLabel')}
    shouldShowRightIcon={!readOnly}
    disabled={hasVBA ? true : readOnly}
    wrapperStyle={styles.sectionMenuItemTopDescription}
    onPress={onPressCurrency}
    shouldGreyOutWhenDisabled={false}
    shouldUseDefaultCursorWhenDisabled
    hintText={hasVBA ? translate('workspace.editor.currencyInputDisabledText') : translate('workspace.editor.currencyInputHelpText')}
    />
    </View>
    </OfflineWithFeedback>
    {!!canUseSpotnanaTravel && shouldShowAddress && (
    <OfflineWithFeedback pendingAction={policy?.pendingFields?.address}>
    <View>
    <MenuItemWithTopDescription
    title={formattedAddress}
    description={translate('common.companyAddress')}
    shouldShowRightIcon={!readOnly}
    disabled={readOnly}
    wrapperStyle={styles.sectionMenuItemTopDescription}
    onPress={onPressAddress}
    shouldGreyOutWhenDisabled={false}
    shouldUseDefaultCursorWhenDisabled
    />
    </View>
    </OfflineWithFeedback>
    )}

What changes do you think we should make in order to solve the problem?

  • We can pass shouldRemoveHoverBackground={readOnly} or shouldRemoveBackground={readOnly}.
  • We can keep isDisabled prop, and also add isInteractive prop. interactive={!readOnly}. While isInteractive alone would address the issue, the absence of isDisabled will result in a dimming effect when the field is pressed.
  • Note: we can only apply this to name and currency field because other fields are not shown to non-admins. We

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?


  • We can remove the style below because the hovered state is already handled here.
    isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,
  • We would also need to update the condition to:
!shouldRemoveBackground &&
    StyleUtils.getButtonBackgroundColorStyle(
        getButtonState(shouldRemoveHoverBackground && (focused || isHovered), pressed, success, disabled, interactive),
        true,
    ),
    
// OR

!shouldRemoveBackground && shouldRemoveHoverBackground &&
    StyleUtils.getButtonBackgroundColorStyle(
        getButtonState(focused || isHovered, pressed, success, disabled, interactive),
        true,
    ),    

What alternative solutions did you explore? (Optional)

@isabelastisser isabelastisser added External Added to denote the issue can be worked on by a contributor Help Wanted Apply this label when an issue is open to proposals by contributors labels Dec 13, 2024
@melvin-bot melvin-bot bot changed the title Non-editable rows on the workspace profile show a hover state [$250] Non-editable rows on the workspace profile show a hover state Dec 13, 2024
Copy link

melvin-bot bot commented Dec 13, 2024

Job added to Upwork: https://www.upwork.com/jobs/~021867410578187381937

Copy link

melvin-bot bot commented Dec 13, 2024

Triggered auto assignment to Contributor-plus team member for initial proposal review - @akinwale (External)

@mkzie2
Copy link
Contributor

mkzie2 commented Dec 13, 2024

Proposal

Please re-state the problem that we are trying to solve in this issue.

Non-editable rows on the workspace profile show a hover state

What is the root cause of that problem?

If the user is non-admin, disabled is true

getButtonBackgroundColorStyle returns an empty style if the state is disabled

StyleUtils.getButtonBackgroundColorStyle(getButtonState(focused || isHovered, pressed, success, disabled, interactive), true),

App/src/styles/utils/index.ts

Lines 1367 to 1375 in 29d546b

getButtonBackgroundColorStyle: (buttonState: ButtonStateName = CONST.BUTTON_STATES.DEFAULT, isMenuItem = false): ViewStyle => {
switch (buttonState) {
case CONST.BUTTON_STATES.PRESSED:
return isMenuItem ? {backgroundColor: theme.buttonHoveredBG} : {backgroundColor: theme.buttonPressedBG};
case CONST.BUTTON_STATES.ACTIVE:
return isMenuItem ? {backgroundColor: theme.border} : {backgroundColor: theme.buttonHoveredBG};
case CONST.BUTTON_STATES.DISABLED:
case CONST.BUTTON_STATES.DEFAULT:
default:

and we don't disable the hover style here if disabled prop is true

isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

Then the hover style is still applied for a disabled menu item

What changes do you think we should make in order to solve the problem?

We should not apply the hover style for the disabled items here, we can add !disabled check here

isHovered && interactive && !focused && !pressed && !disabled && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

NA

What alternative solutions did you explore? (Optional)

We can use interactive={! readOnly} then we can remove shouldGreyOutWhenDisabled and shouldUseDefaultCursorWhenDisabled since the interactive prop already handles the default cursor style. We should update both the name and currency items.

disabled={readOnly}
wrapperStyle={[styles.sectionMenuItemTopDescription, shouldUseNarrowLayout ? styles.mt3 : {}]}
onPress={onPressName}
shouldGreyOutWhenDisabled={false}
shouldUseDefaultCursorWhenDisabled
/>

Reminder: Please use plain English, be brief and avoid jargon. Feel free to use images, charts or pseudo-code if necessary. Do not post large multi-line diffs or write walls of text. Do not create PRs unless you have been hired for this job.

@ChavdaSachin
Copy link
Contributor

Proposal

Please re-state the problem that we are trying to solve in this issue.

Non-editable rows on the workspace profile show a hover state

What is the root cause of that problem?

MenuItems here are made disabled instead it should be in-interactive. And side Effects of disabled are over written.

<MenuItemWithTopDescription
title={policyName}
titleStyle={styles.workspaceTitleStyle}
description={translate('workspace.editor.nameInputLabel')}
shouldShowRightIcon={!readOnly}
disabled={readOnly}
wrapperStyle={[styles.sectionMenuItemTopDescription, shouldUseNarrowLayout ? styles.mt3 : {}]}
onPress={onPressName}
shouldGreyOutWhenDisabled={false}
shouldUseDefaultCursorWhenDisabled
/>

What changes do you think we should make in order to solve the problem?

Use appropriate props here, interactive prop is specially designed for such purpose.

Pass interactive={!readOnly} and remove props disabled and supporting props passed to overwrite side effects shouldGreyOutWhenDisabled and shouldUseDefaultCursorWhenDisabled at following places.

workspace Title
Workspace Description
Currency
Company Address

++    interactive={!readOnly}

--    disabled={readOnly}
--    shouldGreyOutWhenDisabled={false}
--    shouldUseDefaultCursorWhenDisabled

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

What alternative solutions did you explore? (Optional)

Reminder: Please use plain English, be brief and avoid jargon. Feel free to use images, charts or pseudo-code if necessary. Do not post large multi-line diffs or write walls of text. Do not create PRs unless you have been hired for this job.

@shubham1206agra
Copy link
Contributor

Proposal

Please re-state the problem that we are trying to solve in this issue.

Non-editable rows on the workspace profile show a hover state

What is the root cause of that problem?

In https://github.com/Expensify/App/blob/29d546b9fc25fab8c30d9aebe9fee501e696bada/src/pages/workspace/WorkspaceProfilePage.tsx

MenuItemWithTopDescription are made disabled instead of non-interactive, which does not disable the hover styling

<MenuItemWithTopDescription
title={policyName}
titleStyle={styles.workspaceTitleStyle}
description={translate('workspace.editor.nameInputLabel')}
shouldShowRightIcon={!readOnly}
disabled={readOnly}
wrapperStyle={[styles.sectionMenuItemTopDescription, shouldUseNarrowLayout ? styles.mt3 : {}]}
onPress={onPressName}
shouldGreyOutWhenDisabled={false}
shouldUseDefaultCursorWhenDisabled
/>

What changes do you think we should make in order to solve the problem?

We need to solve a bug with interactive first. When we press the menuitem when interactive={false}, we see a dimming effect. This happens due to opacity being applied on pressed here

activeOpacity={variables.pressDimValue}

Change this to

activeOpacity={!interactive ? 1 : variables.pressDimValue} 

Now, use interactive prop instead of disabled here, and here

Diff below

++    interactive={!readOnly}
--    disabled={readOnly}
--    shouldGreyOutWhenDisabled={false}
--    shouldUseDefaultCursorWhenDisabled

Also, we can remove the disabled prop entirely from here and here, since we can't see these properties when non-admin member sees the page.

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

NA since this is an UI change.

What alternative solutions did you explore? (Optional)

NA

@bernhardoj
Copy link
Contributor

Proposal

Please re-state the problem that we are trying to solve in this issue.

The non-editable workspace field has a hovered style even though it's disabled.

What is the root cause of that problem?

When the item is disabled, we already return an empty style from getButtonBackgroundColorStyle, but since we manually added the hovered style (the last line below), the style is still added even when it's disabled.

!shouldRemoveBackground &&
StyleUtils.getButtonBackgroundColorStyle(getButtonState(focused || isHovered, pressed, success, disabled, interactive), true),
...(Array.isArray(wrapperStyle) ? wrapperStyle : [wrapperStyle]),
shouldGreyOutWhenDisabled && disabled && styles.buttonOpacityDisabled,
isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

What changes do you think we should make in order to solve the problem?

I want to propose a different approach which is more complex but I think is cleaner. The goal is to remove this long line of conditions.

isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

To remove it properly, we need to go back first to find out why it was added. It started on this issue where the blockquote color is the same as the MenuItem hover color, so we want to use a different color. This PR then changes the color inside getButtonBackgroundColorStyle when the button state is ACTIVE. However, it causes a regression because ACTIVE can either mean HOVERED or FOCUSED for MenuItem (I checked all other usages and only MenuItem that does this).

So, a new PR is created to add the hover style manually.

isHovered && !pressed && styles.hoveredComponentBG,

But it causes another regression since the non-interactive MenuItem still received the hover style. So we patch it by adding interactive condition to fix it in this PR.

After several patches, we end up with this:

isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

Since we want to have a different BG color (only for MenuItem) for HOVERED and FOCUSED, we can separate the ACTIVE button state to HOVERED and FOCUSED. Here are the steps to fix this:

  1. In getButtonState, replace isActive with isHovered and isFocused`, including the new state, FOCUSED and HOVERED.
function getButtonState(isHovered = false, isFocused = false, isPressed = false, ...) {
    if (isFocused) {
        return CONST.BUTTON_STATES.FOCUSED;
    }

    if (isHovered) {
        return CONST.BUTTON_STATES.HOVERED;
    }
  1. In getButtonBackgroundColorStyle, replace the ACTIVE case with the FOCUSED and HOVERED case. FOCUSED and HOVERED will have the same BG color (which is the same as ACTIVE), except when it's HOVERED and it's a menu item.
getButtonBackgroundColorStyle: (...) => {
    switch (buttonState) {
        ...
        case CONST.BUTTON_STATES.FOCUSED:
            return isMenuItem ? {backgroundColor: theme.border} : {backgroundColor: theme.buttonHoveredBG};
        case CONST.BUTTON_STATES.HOVERED:
            return isMenuItem ? {backgroundColor: theme.hoverComponentBG} : {backgroundColor: theme.buttonHoveredBG};
        ...
    }
},
  1. Remove this long conditional style.

    isHovered && interactive && !focused && !pressed && !shouldRemoveBackground && !shouldRemoveHoverBackground && styles.hoveredComponentBG,

  2. Update the getButtonState usage of MenuItem.

!shouldRemoveBackground &&
StyleUtils.getButtonBackgroundColorStyle(getButtonState(focused || isHovered, pressed, success, disabled, interactive), true),

!shouldRemoveBackground &&
    StyleUtils.getButtonBackgroundColorStyle(getButtonState(isHovered && !shouldRemoveHoverBackground, focused, pressed, success, disabled, interactive), true),

StyleUtils.getIconFillColor(
getButtonState(focused || isHovered, pressed, success, disabled, interactive),

and etc. isHovered will be the first param, isFocused will be the second param.

  1. Update the rest of the usages of getButtonState.

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

I think we can test getButtonBackgroundColorStyle and getButtonState to cover combinations of focused, disabled, etc.

@akinwale
Copy link
Contributor

After reviewing the proposals here, we can move forward with @bernhardoj's proposal which provides a comprehensive approach to solving the issue, and would prevent further patching / workarounds down the line.

🎀👀🎀 C+ reviewed.

Copy link

melvin-bot bot commented Dec 14, 2024

Triggered auto assignment to @Julesssss, see https://stackoverflow.com/c/expensify/questions/7972 for more details.

@shubham1206agra
Copy link
Contributor

Sorry @akinwale, but what problem does selected proposal solve? It does the logic refactoring but it does not solve the main issue. And what about this issue

When we press the menuitem when interactive={false}, we see a dimming effect.

Copy link

melvin-bot bot commented Dec 17, 2024

@akinwale, @Julesssss, @isabelastisser Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@melvin-bot melvin-bot bot added the Overdue label Dec 17, 2024
@Julesssss
Copy link
Contributor

Hey @akinwale, would you mind reviewing @shubham1206agra's comment about proposals? thanks

@akinwale
Copy link
Contributor

Sorry @akinwale, but what problem does selected proposal solve? It does the logic refactoring but it does not solve the main issue. And what about this issue

When we press the menuitem when interactive={false}, we see a dimming effect.

Going with the refactor route would help prevent the wrong states from being applied to the menu item which would solve the main issue, and it effectively improves the maintainability of the code to prevent further patching or workarounds in the future.

cc @Julesssss

@melvin-bot melvin-bot bot removed the Overdue label Dec 18, 2024
@shubham1206agra
Copy link
Contributor

shubham1206agra commented Dec 18, 2024

Sorry @akinwale, but what problem does selected proposal solve? It does the logic refactoring but it does not solve the main issue. And what about this issue

When we press the menuitem when interactive={false}, we see a dimming effect.

Going with the refactor route would help prevent the wrong states from being applied to the menu item which would solve the main issue, and it effectively improves the maintainability of the code to prevent further patching or workarounds in the future.

cc @Julesssss

Sorry @akinwale, but my question still stands. How does this refactoring solve the current issue? I understand the proposal tries to split states for hovered and focused. But it does not solve the root issue since this is an incomplete proposal, and we should not undertake such refactoring without advise from design team. Plus, no other proposal offers any workaround. It just suggests usage of correct params, which selected proposal does not.

Plus, you are opening yourself for tons of regression.

When we press the menuitem when interactive={false}, we see a dimming effect.

This is still not answered yet.

@akinwale
Copy link
Contributor

akinwale commented Dec 18, 2024

Sorry @akinwale, but what problem does selected proposal solve? It does the logic refactoring but it does not solve the main issue. And what about this issue

When we press the menuitem when interactive={false}, we see a dimming effect.

Going with the refactor route would help prevent the wrong states from being applied to the menu item which would solve the main issue, and it effectively improves the maintainability of the code to prevent further patching or workarounds in the future.
cc @Julesssss

Sorry @akinwale, but my question still stands. How does this refactoring solve the current issue? I understand the proposal tries to split states for hovered and focused. But it does not solve the root issue since this is an incomplete proposal, and we should not undertake such refactoring without advise from design team. Plus, no other proposal offers any workaround. It just suggests usage of correct params, which selected proposal does not.

Plus, you are opening yourself for tons of regression.

The refactor introduces better handling of the combination of styles which would also prevent the hover styles from being applied when the menu item is disabled. It is also mostly geared towards code, not design. Being wary of regressions shouldn't be a hindrance to improving the codebase. I do agree however, that the proposal does not completely solve the issue.

When we press the menuitem when interactive={false}, we see a dimming effect.

This is still not answered yet.

I initially missed this. Since the bug is related to the interactive prop affecting the active opacity of the menu item, it looks like your solution addresses the underlying cause.

@Julesssss We can move forward with @shubham1206agra's proposal here.

@bernhardoj
Copy link
Contributor

When we press the menuitem when interactive={false}, we see a dimming effect.

This is still not answered yet.

I initially missed this. Since the bug is related to the interactive prop affecting the active opacity of the menu item, it looks > like your solution addresses the underlying cause.

This isn't a problem in my proposal since we don't use interactive, and instead keep the disabled props.

@shubham1206agra
Copy link
Contributor

When we press the menuitem when interactive={false}, we see a dimming effect.

This is still not answered yet.

I initially missed this. Since the bug is related to the interactive prop affecting the active opacity of the menu item, it looks > like your solution addresses the underlying cause.

This isn't a problem in my proposal since we don't use interactive, and instead keep the disabled props.

This is even more problematic since this introduces new design interface.

@bernhardoj
Copy link
Contributor

new design interface

Can you point out which one? I don't think there is any new interface is added from my proposal

@shubham1206agra
Copy link
Contributor

There isn't a design guideline about that, but looking at the code, interactive is like the subset of disabled.

In what way?

Copy link

melvin-bot bot commented Dec 20, 2024

📣 It's been a week! Do we have any satisfactory proposals yet? Do we need to adjust the bounty for this issue? 💸

@melvin-bot melvin-bot bot added the Overdue label Dec 20, 2024
@isabelastisser
Copy link
Contributor

FYI, I will be OOO from Dec 23 to Jan 6, so please reassign the issue to another team member for urgency, IF needed.

@muttmuure muttmuure moved this to MEDIUM in [#whatsnext] #quality Dec 23, 2024
Copy link

melvin-bot bot commented Dec 24, 2024

@akinwale, @Julesssss, @isabelastisser Eep! 4 days overdue now. Issues have feelings too...

Copy link

melvin-bot bot commented Dec 26, 2024

@akinwale, @Julesssss, @isabelastisser Still overdue 6 days?! Let's take care of this!

Copy link

melvin-bot bot commented Dec 27, 2024

@akinwale @Julesssss @isabelastisser this issue was created 2 weeks ago. Are we close to approving a proposal? If not, what's blocking us from getting this issue assigned? Don't hesitate to create a thread in #expensify-open-source to align faster in real time. Thanks!

Copy link

melvin-bot bot commented Dec 27, 2024

📣 It's been a week! Do we have any satisfactory proposals yet? Do we need to adjust the bounty for this issue? 💸

Copy link

melvin-bot bot commented Dec 30, 2024

@akinwale, @Julesssss, @isabelastisser 10 days overdue. Is anyone even seeing these? Hello?

Copy link

melvin-bot bot commented Jan 1, 2025

@akinwale, @Julesssss, @isabelastisser 12 days overdue now... This issue's end is nigh!

@Julesssss
Copy link
Contributor

I prefer @bernhardoj's button logic improvements in the long-term. But I agree it should be a wider choice we make in Slack. I would support you in making this proposal in Slack and we can tag the design team as an improvement.

For now though, lets stick with the fix from @shubham1206agra

@melvin-bot melvin-bot bot removed the Help Wanted Apply this label when an issue is open to proposals by contributors label Jan 3, 2025
Copy link

melvin-bot bot commented Jan 3, 2025

📣 @shubham1206agra 🎉 An offer has been automatically sent to your Upwork account for the Contributor role 🎉 Thanks for contributing to the Expensify app!

Offer link
Upwork job
Please accept the offer and leave a comment on the Github issue letting us know when we can expect a PR to be ready for review 🧑‍💻
Keep in mind: Code of Conduct | Contributing 📖

@melvin-bot melvin-bot bot removed the Overdue label Jan 3, 2025
@melvin-bot melvin-bot bot added Reviewing Has a PR in review Weekly KSv2 and removed Daily KSv2 labels Jan 5, 2025
@Julesssss
Copy link
Contributor

PR is in progress

@melvin-bot melvin-bot bot added Weekly KSv2 Awaiting Payment Auto-added when associated PR is deployed to production and removed Weekly KSv2 labels Jan 11, 2025
@melvin-bot melvin-bot bot changed the title [$250] Non-editable rows on the workspace profile show a hover state [HOLD for payment 2025-01-18] [$250] Non-editable rows on the workspace profile show a hover state Jan 11, 2025
@melvin-bot melvin-bot bot removed the Reviewing Has a PR in review label Jan 11, 2025
Copy link

melvin-bot bot commented Jan 11, 2025

Reviewing label has been removed, please complete the "BugZero Checklist".

Copy link

melvin-bot bot commented Jan 11, 2025

The solution for this issue has been 🚀 deployed to production 🚀 in version 9.0.83-5 and is now subject to a 7-day regression period 📆. Here is the list of pull requests that resolve this issue:

If no regressions arise, payment will be issued on 2025-01-18. 🎊

For reference, here are some details about the assignees on this issue:

Copy link

melvin-bot bot commented Jan 11, 2025

@akinwale / @shubham1206agra @isabelastisser @akinwale / @shubham1206agra The PR fixing this issue has been merged! The following checklist (instructions) will need to be completed before the issue can be closed. Please copy/paste the BugZero Checklist from here into a new comment on this GH and complete it. If you have the K2 extension, you can simply click: [this button]

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Awaiting Payment Auto-added when associated PR is deployed to production Bug Something is broken. Auto assigns a BugZero manager. External Added to denote the issue can be worked on by a contributor Weekly KSv2
Projects
Development

No branches or pull requests

9 participants