- Create symlink mobile/shared -> ../shared for Metro bundler access
- Update all @pezkuwi/lib/* imports to use relative paths (../../shared/lib/*)
- Dashboard Roles card now fetches real tiki data from blockchain
- Staking screen uses production getStakingInfo and getAllScores
- All citizenship, referral, and NFT screens use real blockchain queries
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
BREAKING: Removed multi-language support (i18n) - will be re-added later
Changes:
- Removed i18n system (6 language files, LanguageContext)
- Expanded WalletScreen, SettingsScreen, SwapScreen with more features
- Added KurdistanSun component, HEZ/PEZ token icons
- Added EditProfileScreen, WalletSetupScreen
- Added button e2e tests (Profile, Settings, Wallet)
- Updated plan: honest assessment - 42 nav buttons with mock data
- Fixed terminology: Polkadot→Pezkuwi, Substrate→Bizinikiwi
Reality check: UI complete with mock data, converting to production one-by-one
Replace TODO placeholder with real citizenship KYC application:
**Updated File:**
- mobile/src/screens/BeCitizenScreen.tsx
**Implementation Details:**
- Imported usePolkadot for blockchain API access
- Imported submitKycApplication and uploadToIPFS from shared library
- Added isSubmitting loading state
- Implemented full citizenship registration flow:
1. Collect form data (fullName, fatherName, motherName, email, etc.)
2. Upload encrypted data to IPFS via uploadToIPFS()
3. Submit KYC application to blockchain via submitKycApplication()
**Features:**
- Wallet connection validation before submission
- Two-step process: IPFS upload → blockchain submission
- Uses pallet-identity-kyc extrinsics:
* api.tx.identityKyc.setIdentity(name, email)
* api.tx.identityKyc.applyForKyc(ipfsCid, notes)
- Proper error handling with user-friendly messages
- Loading state with ActivityIndicator during submission
- Disabled submit button while processing
- Form reset on successful submission
- Success message: "Your citizenship application has been submitted for review"
**Data Flow:**
1. User fills form with personal information
2. App encrypts and uploads data to IPFS
3. App submits KYC application with IPFS CID to blockchain
4. Blockchain stores commitment hash
5. User notified of pending review
**Security:**
- Sensitive data encrypted before IPFS upload
- Only commitment hash stored on-chain
- Full data stored on IPFS (encrypted)
- Wallet signature required for submission
**User Experience:**
- Clear loading indicator during submission
- Detailed error messages for failures
- Handles edge cases: already pending, already approved
- Form validation before submission
- Automatic form reset on success
This completes P0 citizenship blockchain integration for mobile app.
Real KYC application matching pallet-identity-kyc specification.
This commit implements the complete blockchain integration for the mobile app's wallet functionality:
**Polkadot.js Integration:**
- Created PolkadotContext for mobile with full blockchain connectivity
- Implemented wallet creation with mnemonic seed phrases
- Added secure key management with AsyncStorage
- Connected to Pezkuwi testnet (wss://beta-rpc.pezkuwi.art)
**WalletScreen Enhancements:**
- Live blockchain balance fetching for HEZ (native token)
- Live balance fetching for PEZ and wUSDT (assets)
- Real-time balance updates every 30 seconds
- Actual send transactions using api.tx.balances.transfer (HEZ)
- Actual send transactions using api.tx.assets.transfer (PEZ, wUSDT)
- Transaction signing with user's keypair
- Loading states and error handling
- Wallet creation flow for new users
- Connect/disconnect wallet functionality
**Bottom Navigation:**
- Created BottomTabNavigator with 5 tabs
- Added WalletScreen with live blockchain integration
- Added BeCitizenScreen (citizenship application)
- Added ReferralScreen (referral program)
- Renamed SettingsScreen to ProfileScreen
- Custom center button for "Be Citizen" feature
**App Structure:**
- Wrapped app with PolkadotProvider in App.tsx
- Updated AppNavigator to use BottomTabNavigator
- Integrated language selection flow with blockchain features
All wallet features now use live blockchain data instead of mock data.