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

perf: make switch between chat list and workspaces smoother #36420

Merged
merged 68 commits into from
Apr 25, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
68 commits
Select commit Hold shift + click to select a range
3088672
perf: use context for shared reports access
hurali97 Feb 13, 2024
f33930e
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Feb 15, 2024
6921051
perf: improve renderItem and use FlatList
hurali97 Feb 15, 2024
4d267b4
Merge branch 'main' into hur/perf/issue-35704
jbroma Feb 26, 2024
dc88950
refactor: revert changes to withCurrentReportID
jbroma Feb 26, 2024
9ae8701
refactor: remove useReports context & hooks
jbroma Feb 26, 2024
b613e97
refactor: use reports from onyx in useOrderedReportIDs
jbroma Feb 28, 2024
7f15fbc
refactor: move creating orderedReport objects from getOrderedReportId…
jbroma Feb 28, 2024
7fa44fc
Revert "refactor: revert changes to withCurrentReportID"
jbroma Feb 28, 2024
ae12b00
refactor: remove comment in SidebarLinksData
jbroma Feb 28, 2024
8087e59
Merge branch 'main' into hur/perf/issue-35704
jbroma Feb 28, 2024
c87f579
refactor: rename useOrderedReportIDs to useOrderedReportListItems
jbroma Feb 28, 2024
df1069c
perf: use memo for extraData in LHNOptionList
jbroma Feb 28, 2024
1d294bc
fix: typescript fixes
jbroma Feb 28, 2024
7dfba43
fix: update reportActionsSelector to match the one from SidebarLinksData
jbroma Feb 28, 2024
696c5ee
fix: typescript issues
hurali97 Feb 29, 2024
6739b58
test: fix reassure failing test
hurali97 Feb 29, 2024
92fae0c
revert: move option item data calculation to the renderItem component
hurali97 Feb 29, 2024
596fd63
fix: linting
hurali97 Feb 29, 2024
e735658
test: fix failing test
hurali97 Mar 1, 2024
94fcc48
fix: prettier
hurali97 Mar 1, 2024
31f5ed4
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 5, 2024
e0673e0
refactor: rename to useReportIDs
hurali97 Mar 5, 2024
30ca303
refactor: don't set currentReportID if it's on workspaces screen
hurali97 Mar 5, 2024
121b537
refactor: remove dead code
hurali97 Mar 5, 2024
9e41603
fix: linting
hurali97 Mar 5, 2024
4a32841
refactor: remove irrelevant changes
hurali97 Mar 5, 2024
581d09d
fix: comments
hurali97 Mar 11, 2024
fffe41a
fix: safely check the nested properties
hurali97 Mar 11, 2024
6b41bf7
feat: add comments for extraData prop
hurali97 Mar 11, 2024
5f832f9
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 11, 2024
49e32fd
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 13, 2024
6412711
fix: reassure tests
hurali97 Mar 13, 2024
e3477b2
fix: apply prettier
hurali97 Mar 13, 2024
769f83a
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 14, 2024
30b319f
perf: check for the settings tab existence in screen params and early…
hurali97 Mar 14, 2024
71978c2
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 15, 2024
8dba89b
feat: add selector from SidebarLinksData
hurali97 Mar 15, 2024
c39f358
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 15, 2024
f333232
fix: reassure tests
hurali97 Mar 15, 2024
3557027
fix: resolve merge conflicts
hurali97 Mar 15, 2024
335f1fa
Merge branch 'main' into hur/perf/issue-35704
jbroma Mar 20, 2024
61ef588
refactor: use currentReportID from useReportIDs
hurali97 Mar 21, 2024
84aa5ac
refactor: remove unnecessary ref
hurali97 Mar 21, 2024
2d8f88a
Merge branch 'hur/perf/issue-35704' of https://github.com/callstack-i…
hurali97 Mar 21, 2024
8532c08
update comment is updateCurrentReportID function
hurali97 Mar 21, 2024
ac465f3
update comment in useReportIDs hook
hurali97 Mar 21, 2024
886622e
refactor: make comment less verbose
hurali97 Mar 21, 2024
6d17116
refactor: remove irrelevant comment
hurali97 Mar 21, 2024
91ed2e6
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 21, 2024
4e1fbd2
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 22, 2024
2ef5c7f
refactor: reduce memo usage
hurali97 Mar 22, 2024
3bcc037
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Mar 27, 2024
ab5bce3
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Apr 16, 2024
9e4f464
fix: typecheck
hurali97 Apr 16, 2024
20d798e
refactor: remove unnecessary diff
hurali97 Apr 16, 2024
6f20396
refactor: leverage useOnyx hook instead of withOnyx HOC
hurali97 Apr 16, 2024
33fe888
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Apr 18, 2024
c791be0
fix: max depth exceeded error by not mutating allReports object
hurali97 Apr 18, 2024
4aa6b99
fix: use inline options and relevant initialValue
hurali97 Apr 18, 2024
459e86c
fix: remove not needed prop
hurali97 Apr 18, 2024
61fc9ce
fix: use correct prop in memo check
hurali97 Apr 18, 2024
489c652
fix: use policies instead of policyMembers
hurali97 Apr 18, 2024
10c0c04
Apply workaround for initialValue
fabioh8010 Apr 18, 2024
e075aee
fix: failing SidebarOrderTest
hurali97 Apr 19, 2024
0d4637e
fix: typecheck
hurali97 Apr 19, 2024
42068cc
Merge branch 'main' of https://github.com/callstack-internal/Expensif…
hurali97 Apr 25, 2024
821e4e0
refactor: remove initialValues
hurali97 Apr 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: reassure tests
  • Loading branch information
hurali97 committed Mar 15, 2024
commit f333232781b6b64566801dc1958c05284c90081d
26 changes: 6 additions & 20 deletions tests/perf-test/SidebarUtils.perf-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import type {PersonalDetails, TransactionViolation} from '@src/types/onyx';
import type Policy from '@src/types/onyx/Policy';
import type Report from '@src/types/onyx/Report';
import type ReportAction from '@src/types/onyx/ReportAction';
import createCollection from '../utils/collections/createCollection';
import createCollection, {createNestedCollection} from '../utils/collections/createCollection';
import createPersonalDetails from '../utils/collections/personalDetails';
import createRandomPolicy from '../utils/collections/policies';
import createRandomReportAction, {getRandomDate} from '../utils/collections/reportActions';
Expand Down Expand Up @@ -51,25 +51,11 @@ const policies = createCollection<Policy>(

const mockedBetas = Object.values(CONST.BETAS);

const allReportActions = Object.fromEntries(
Object.keys(reportActions).map((key) => [
`${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${key}`,
[
{
errors: reportActions[key].errors ?? [],
message: [
{
moderationDecision: {
decision: reportActions[key].message?.[0]?.moderationDecision?.decision,
},
},
],
reportActionID: reportActions[key].reportActionID,
},
],
]),
) as unknown as OnyxCollection<ReportAction[]>;

const allReportActions = createNestedCollection<ReportAction>(
(item) => `${ONYXKEYS.COLLECTION.REPORT}${item.reportID}`,
(item) => `${item.reportActionID}`,
(index) => createRandomReportAction(index),
);
const currentReportId = '1';
const transactionViolations = {} as OnyxCollection<TransactionViolation[]>;

Expand Down
23 changes: 23 additions & 0 deletions tests/utils/collections/createCollection.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,26 @@ export default function createCollection<T>(createKey: (item: T, index: number)

return map;
}

function createNestedCollection<T>(
createParentKey: (item: T, index: number) => string | number,
createKey: (item: T, index: number) => string | number,
createItem: (index: number) => T,
length = 500,
): Record<string, Record<string, T>> {
const map: Record<string, Record<string, T>> = {};

for (let i = 0; i < length; i++) {
const item = createItem(i);
const itemKey = createKey(item, i);
const itemParentKey = createParentKey(item, i);
map[itemParentKey] = {
...map[itemParentKey],
[itemKey]: item,
};
}

return map;
}

export {createNestedCollection};