immersive2/public/api/user/features-none.json
Michael Mainguy c1503d959e Add configurable feature management system with JSON-based feature flags
Implement comprehensive feature toggle system allowing menu options and features
to be controlled via JSON configuration fetched from API endpoint or static files.

Core System:
- Create FeatureConfig type system with page, feature, and limit-based flags
- Add React Context (FeatureProvider) that fetches from /api/user/features
- Implement custom hooks (useFeatures, useIsFeatureEnabled, useFeatureLimit, etc.)
- Default config disables everything except home page

Integration:
- Update PageHeader to filter menu items based on page flags
- Add ProtectedRoute component to guard routes
- Update VR menu to conditionally render items based on feature flags
- Update CreateDiagramModal to enable/disable options (private, encrypted, invite)
- Update ManageDiagramsModal to use configurable maxDiagrams limit

Configuration Files:
- Add static JSON files for local testing (none, free, basic, pro tiers)
- Add dev proxy for /api/user/features endpoint
- Include README with testing instructions

Updates:
- Complete CLAUDE.md naming conventions section
- Version bump to 0.0.8-27

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-18 06:52:39 -06:00

27 lines
534 B
JSON

{
"tier": "none",
"pages": {
"examples": false,
"documentation": false,
"pricing": false,
"vrExperience": false
},
"features": {
"createDiagram": false,
"createFromTemplate": false,
"manageDiagrams": false,
"shareCollaborate": false,
"privateDesigns": false,
"encryptedDesigns": false,
"editData": false,
"config": false,
"enterImmersive": false,
"launchMetaQuest": false
},
"limits": {
"maxDiagrams": 0,
"maxCollaborators": 0,
"storageQuotaMB": 0
}
}