-
Notifications
You must be signed in to change notification settings - Fork 473
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
Feat: public transaction notes #4693
Conversation
Branch preview✅ Deploy successful! Website: Storybook: |
Coverage report
Show new covered files 🐣
Show files with reduced coverage 🔻
Test suite run success1752 tests passing in 237 suites. Report generated by 🧪jest coverage report action from 96a1684 |
📦 Next.js Bundle Analysis for @safe-global/webThis analysis was generated by the Next.js Bundle Analysis action. 🤖
|
Page | Size (compressed) |
---|---|
global |
1 MB (🟡 +16.31 KB) |
Details
The global bundle is the javascript bundle that loads alongside every page. It is in its own category because its impact is much higher - an increase to its size means that every page on your website loads slower, and a decrease means every page loads faster.
Any third party scripts you have added directly to your app using the <script>
tag are not accounted for in this analysis
If you want further insight into what is behind the changes, give @next/bundle-analyzer a try!
Thirty-one Pages Changed Size
The following pages changed size from the code in this PR compared to its base branch:
Page | Size (compressed) | First Load |
---|---|---|
/ |
508 B (🟢 -2 B) |
1.01 MB |
/address-book |
23.21 KB (🟡 +142 B) |
1.03 MB |
/apps |
35.8 KB (🟡 +2.08 KB) |
1.04 MB |
/apps/custom |
33.87 KB (🟡 +2.08 KB) |
1.04 MB |
/apps/open |
55.57 KB (🟡 +1.96 KB) |
1.06 MB |
/balances |
29.88 KB (🟡 +176 B) |
1.03 MB |
/balances/nfts |
9.52 KB (🟢 -24 B) |
1.01 MB |
/bridge |
2.56 KB (🟡 +2 B) |
1.01 MB |
/cookie |
8.77 KB (🟡 +1 B) |
1.01 MB |
/home |
61.38 KB (🟡 +2.12 KB) |
1.06 MB |
/new-safe/advanced-create |
26.38 KB (🟢 -70 B) |
1.03 MB |
/new-safe/create |
25.52 KB (🟢 -71 B) |
1.03 MB |
/privacy |
14.57 KB (🟡 +2 B) |
1.02 MB |
/settings/appearance |
2.25 KB (🟡 +2 B) |
1.01 MB |
/settings/environment-variables |
3.27 KB (🟢 -1 B) |
1.01 MB |
/settings/modules |
4.06 KB (🟡 +1 B) |
1.01 MB |
/settings/notifications |
21 KB (🟢 -324 B) |
1.03 MB |
/settings/safe-apps |
20.35 KB (🟡 +2.08 KB) |
1.02 MB |
/settings/security |
2.34 KB (🟡 +1 B) |
1.01 MB |
/settings/setup |
30.82 KB (🟡 +92 B) |
1.03 MB |
/share/safe-app |
7.56 KB (🟢 -5 B) |
1.01 MB |
/stake |
618 B (🟢 -1 B) |
1.01 MB |
/swap |
761 B (🟡 +1 B) |
1.01 MB |
/terms |
12.93 KB (🟡 +1 B) |
1.02 MB |
/transactions |
99.47 KB (🟡 +2.9 KB) |
1.1 MB |
/transactions/history |
99.43 KB (🟡 +2.9 KB) |
1.1 MB |
/transactions/messages |
60.26 KB (🟡 +1.96 KB) |
1.06 MB |
/transactions/msg |
56.51 KB (🟡 +1.96 KB) |
1.06 MB |
/transactions/queue |
49.37 KB (🟡 +1.97 KB) |
1.05 MB |
/transactions/tx |
48.73 KB (🟡 +1.96 KB) |
1.05 MB |
/welcome/accounts |
409 B (🟡 +2 B) |
1.01 MB |
Details
Only the gzipped size is provided here based on an expert tip.
First Load is the size of the global bundle plus the bundle for the individual page. If a user were to show up to your website and land on a given page, the first load size represents the amount of javascript that user would need to download. If next/link
is used, subsequent page loads would only need to download that page's bundle (the number in the "Size" column), since the global bundle has already been downloaded.
Any third party scripts you have added directly to your app using the <script>
tag are not accounted for in this analysis
Next to the size is how much the size has increased or decreased compared with the base branch of this PR. If this percentage has increased by 20% or more, there will be a red status indicator applied, indicating that special attention should be given to this.
Coverage report for
|
St.❔ |
Category | Percentage | Covered / Total |
---|---|---|---|
🟡 | Statements | 74.13% (+0.02% 🔼) |
14631/19737 |
🔴 | Branches | 51.72% (+0.02% 🔼) |
3489/6746 |
🔴 | Functions | 57.09% (-0.04% 🔻) |
2070/3626 |
🟡 | Lines | 75.68% (+0.02% 🔼) |
13273/17539 |
Show new covered files 🐣
St.❔ |
File | Statements | Branches | Functions | Lines |
---|---|---|---|---|---|
🟢 | ... / index.tsx |
87.5% | 100% | 100% | 100% |
🟢 | ... / featureToggled.tsx |
100% | 75% | 100% | 100% |
🟡 | ... / TxNote.tsx |
55.56% | 0% | 0% | 62.5% |
🟢 | ... / TxNoteForm.tsx |
100% | 0% | 0% | 100% |
🔴 | ... / TxNoteInput.tsx |
46.15% | 100% | 0% | 50% |
🟢 | ... / encodeTxNote.ts |
100% | 100% | 100% | 100% |
Show files with reduced coverage 🔻
St.❔ |
File | Statements | Branches | Functions | Lines |
---|---|---|---|---|---|
🟢 | ... / SignOrExecuteForm.tsx |
91.57% (-1.49% 🔻) |
86.67% (-1.74% 🔻) |
50% | 91.14% (-1.51% 🔻) |
🟢 | ... / SignForm.tsx |
91.8% (-0.13% 🔻) |
85.71% (+0.42% 🔼) |
100% | 92.98% (-0.12% 🔻) |
Test suite run success
1762 tests passing in 239 suites.
Report generated by 🧪jest coverage report action from dfe1df7
@katspaugh The deployment has failed. Can you try again? |
@francovenica fixed! ✅ |
Issue: When a tx is just signed and then executed by another owner, the "Note" field shows up again.
The filed should not show up or show as a read only input |
Issue: Notes created by "proposers" don't show in the tx. I'm not sure if it is possible since the user is just proposing the tx so it's only in the backend. If is possible the note added by the proposer should show in the tx. |
Fixed both, thank you. ✅ |
Fixed ✅ |
Looks good now! |
const onChange = useCallback( | ||
(e: React.ChangeEvent<HTMLInputElement>) => { | ||
onSubmit(e.target.value.slice(0, MAX_NOTE_LENGTH)) | ||
trackEvent(MODALS_EVENTS.ADD_TX_NOTE) |
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.
Shouldn't this only be tracked once we submit the transaction? Now each team I click outside of the note textbox it will trigger this event, which potentially means that we have to look at our tx service to get reliable insights
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.
Yes, absolutely correct. Fixed here: #4771
What it solves
Resolves SW-700
This PR adds the ability to add a public note when creating a transaction. It's sent to the backend in the previously unused
origin.name
field as JSON.The feature is behind a feature flag called
TX_NOTES
.Adding a note
Displaying a note
How to test