mirror of
https://github.com/twentyhq/twenty.git
synced 2026-06-12 01:46:39 -04:00
## Summary - **SSE unification**: Replaced 11 individual SSE effect components with a single generic `MetadataStoreSSEEffect` - **Metadata store cleanup**: Merged `metadataCollectionHashesState` into `metadataStoreState` (currentCollectionHash / draftCollectionHash per entity), moved `objectMetadataItemsSelector` to `object-metadata` domain, converted `navigationMenuItemsState` to a derived selector - **Naming clarity**: Renamed `isAppMetadataReadyState` → `isMinimalMetadataReadyState`, `MetadataGater` → `MinimalMetadataGater`, `useIsLogged` → `useHasAccessTokenPair`, `patchMetadataStoreFromSSEEvent` now takes named object params - **Mock metadata loading**: Added `generate-navigation-menu-items.ts` script, rewrote `useLoadMockedMinimalMetadata` to load full objects/fields/indexes/views/navItems from generated mock data, enabling proper sign-in background rendering (table columns, view picker, navigation) - **Login/logout transitions**: `MinimalMetadataLoadEffect` manages mocked↔real metadata transitions based on auth state, `MainContextStoreProvider` computes context on auth pages for view picker support - **Login redirect fix**: `handleLoadWorkspaceAfterAuthentication` now re-enables `isAppEffectRedirectEnabled` after `loadCurrentUser()` completes, fixing the blocked post-login navigation - **Dead code removal**: Deleted `useRefreshPageLayouts`, `useApplyPageLayouts`, `useStaleMetadataEntities`, `metadataCollectionHashesState`, and all individual SSE effects ## Test plan - [x] Login from welcome page redirects to companies page - [x] Logout transitions cleanly to mocked metadata on welcome page - [x] Sign-in background shows table columns, view picker, and navigation items - [x] SSE events still update metadata store entries correctly - [x] Navigation menu items persist across page refreshes - [ ] CI: lint, typecheck, tests pass
44 lines
1.4 KiB
TypeScript
44 lines
1.4 KiB
TypeScript
/* oxlint-disable no-console */
|
|
import { generateApiKeys } from './mock-data/generate-api-keys.js';
|
|
import { generateBillingPlans } from './mock-data/generate-billing-plans.js';
|
|
import { generateObjectMetadata } from './mock-data/generate-object-metadata.js';
|
|
import { generateMinimalMetadata } from './mock-data/generate-minimal-metadata.js';
|
|
import { generateRecordData } from './mock-data/generate-record-data.js';
|
|
import { generateRoles } from './mock-data/generate-roles.js';
|
|
import { generateNavigationMenuItems } from './mock-data/generate-navigation-menu-items.js';
|
|
import { generateViews } from './mock-data/generate-views.js';
|
|
import { authenticate } from './mock-data/utils.js';
|
|
|
|
const main = async () => {
|
|
const token = await authenticate();
|
|
|
|
const metadata = await generateObjectMetadata(token);
|
|
await generateMinimalMetadata(token);
|
|
await generateRecordData(token, metadata);
|
|
await generateRoles(token);
|
|
await generateViews(token);
|
|
await generateNavigationMenuItems(token);
|
|
|
|
try {
|
|
await generateBillingPlans(token);
|
|
} catch (error) {
|
|
console.warn(
|
|
'Skipping billing plans generation (billing not available):',
|
|
(error as Error).message,
|
|
);
|
|
}
|
|
|
|
try {
|
|
await generateApiKeys(token);
|
|
} catch (error) {
|
|
console.warn('Skipping API keys generation:', (error as Error).message);
|
|
}
|
|
|
|
console.log('All mock data generated!');
|
|
};
|
|
|
|
main().catch((error) => {
|
|
console.error('Fatal error:', error);
|
|
process.exit(1);
|
|
});
|