-
Notifications
You must be signed in to change notification settings - Fork 15
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
Fix: Disable payment buttons for staged payments when release is in progress #4237
Conversation
f7f1ad9
to
dce96f2
Compare
…rogress Fix: Disable payment buttons for staged payments when release is in progress
dce96f2
to
f17d39d
Compare
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.
Cool fix @mmioana, I think the context makes total sense. I've just left one comment about the placement of the context which maybe we could look into.
Aside from that, it all looks to be working great. I even tried to cheat it at the end by finalizing the reputation payment and then quickly making it with permissions, but everything still worked perfectly.
Nice job!
Screen.Recording.2025-02-04.at.17.10.14.mov
Screen.Recording.2025-02-04.at.17.14.44.mov
<Outlet /> | ||
</ColonyLayout> | ||
</ActionContextProvider> | ||
</StagedPaymentContextProvider> |
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.
Just wondering if this has to wrap the entire route, or can it simply wrap the staged payment completed action?
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.
@davecreaser that was my initial thought, but soon realised the context state will get wiped when the CompletedAction
is unmounted, thus changing between actions would have needed to get the current state of the milestones and initialise the context. That seemed a bit too cumbersome 😢
items={items.filter((item) => !item.isClaimed)} | ||
className="w-full text-end" | ||
/> | ||
); |
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.
👏 🧹
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.
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.
Nice job tidying this up, it works so much better now!
I managed to find one issue, but it's only really possible to recreate in dev, I don't think you'd be able to click through metamask quick enough in production and it doesn't super break things anyway. Here I have created a motion to release milestone 3, then as I finalize the motion, I release the same milestone with permissions. The result is that the motion box shows both methods of releasing as passed.
Screen.Recording.2025-02-05.at.09.14.572.mov
I don't know if it's easy to disable the "Pay now" button whilst a related motion is being finalized? But it's also such a small issue that we can just leave it.
Similar issue here, the "Pay now" button briefly remains clickable even after a relation motion has finished finalising:
Screen.Recording.2025-02-05.at.09.14.573.mov
Everything else works great.
Description
Staged payment
action where thePay now
andPay all
buttons remained enabled until payments were successfully claimed in case of actions.To resolve this, I introduced a context dedicated specifically for the
Staged payments
(and refactored everything related to this type of action that was unnecessarily polluting thePaymentBuilderContext
). The context stores the current milestones for release, all the milestones awaiting release, and a flag for the pending release. Based on the last two props, we can easily decide theenabled
/disabled
state of the buttons, the first prop being used only for the release modal and the saga. In case of using motions to release a payment, once the motion got created, the button will be re-enabled in order to allow using a different decision method.Moreover, the context state is scoped by
txHash
, given we can switch betweenStaged payment
actions and we still want to keep the state until all the payments are released.Important
If we are using motions (aka Reputation) to release the payments, after discussing with Prod and Network teams, we should still be able to use another method to release those payments. If the payments got released in the meantime using a different decision method, the motions will still pass, but no amount will be transferred.
Note
Even though the context looses its state upon page refresh, it's highly unlikely to refresh the page and the payment to not get in a claimed state, thus making it possible for someone to re-trigger the claim process. However, I'm open to more opinions.
Testing
TODO: Ok, enough talking, now let's make sure we get our desired state.
Step 1. First make sure to install the
Staged payments
andReputation
extensions.Step 2. Now, please create a staged payments with about 4 milestones and go trough all the steps until
data:image/s3,"s3://crabby-images/1a60b/1a60bce4af307b36263260964af9149c49f416de" alt="Screenshot 2025-02-03 at 20 09 58"
Payment
stageStep 3. Create another one and reach the
data:image/s3,"s3://crabby-images/ef9f7/ef9f7801000b04442fd6dfe79db77214e210b839" alt="Screenshot 2025-02-03 at 20 10 52"
Payment
stageStep 4. Now please use
Permissions
andPayment creator
to release different milestones. Switch between theStaged payment
actions you previously created and make sure thePay now
/Pay all
buttons remain disabled until theReleased
pill is shownScreen.Recording.2025-02-03.at.20.11.23.mov
Staged payments
action with 2 milestones and go through all steps until thePayment
stepReputation
to release the milestone. The button should be disabled until the motion got created.Reputation
again. This should not be possible.claimed
.Screen.Recording.2025-02-04.at.13.43.15.mov
Reputation
.I haven't done any change for the last step, but it's worth to double-check this issue is no longer happening.
Diffs
New stuff ✨
StagedPaymentContext
ReleaseButton
Deletions ⚰️
PaymentBuilderContext
Resolves #4049