- App.tsx: full navigation (Auth stack + Main tabs with 5 screens) - Auth: LoginScreen, RegisterScreen, ForgotPasswordScreen - HomeScreen: dashboard with IoT metrics, weather widget, alerts, quick actions, sensors - MapScreen: interactive map with layer toggles (6 layers) - MarketplaceScreen: categories (6), products (5), search - ChatScreen: AI chat with quick prompts (4), bot responses - ProfileScreen: user info, stats, menu (9 items), logout - AlertsScreen: alert list with severity, acknowledge - SensorsScreen: sensor list with type filters (6 types), search - ZonesScreen: zone cards with stats - SettingsScreen: language picker (FR/EN/ES/DE), privacy, about - Stores: iotStore (sensors, zones, alerts), notificationStore, uiStore + i18n - Hooks: useSensors, useAlerts, useNotifications, useLocation - Components: Card, Button, LoadingSpinner, ErrorBoundary, Header - Services: iotService, notificationService (with axios API client) - Utils: formatters (temp, AQI, noise, dates), validators (email, password, IBAN) - Theme: colors.ts with full design system (Blue Ocean palette) - Ditto: fixed MongoDB connection, new JWT secrets, official gateway image
51 lines
1.4 KiB
JavaScript
51 lines
1.4 KiB
JavaScript
const findProjectRoot = require('@react-native-community/cli-tools').findProjectRoot;
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const projectRoot = findProjectRoot();
|
|
|
|
function isMatchedInFile(filePath, regexp) {
|
|
const contents = fs.readFileSync(filePath, 'utf8');
|
|
return !!contents.match(regexp);
|
|
}
|
|
|
|
/**
|
|
* Checks if expo-modules-autolinking is setup on iOS
|
|
*/
|
|
function isExpoModulesInstalledIos(projectRoot) {
|
|
const podfilePath = path.join(projectRoot, 'ios', 'Podfile');
|
|
if (!fs.existsSync(podfilePath)) {
|
|
// Assumes true for managed apps
|
|
return true;
|
|
}
|
|
return isMatchedInFile(podfilePath, /use_expo_modules!/);
|
|
}
|
|
|
|
/**
|
|
* Checks if expo-modules-autolinking is setup on Android
|
|
*/
|
|
function isExpoModulesInstalledAndroid(projectRoot) {
|
|
const gradlePath = path.join(projectRoot, 'android', 'settings.gradle');
|
|
if (!fs.existsSync(gradlePath)) {
|
|
// Assumes true for managed apps
|
|
return true;
|
|
}
|
|
return isMatchedInFile(gradlePath, /useExpoModules/);
|
|
}
|
|
|
|
module.exports = {
|
|
dependency: {
|
|
platforms: {
|
|
// To make Expo CLI works on bare react-native projects without installing Expo Modules, we disable autolinking in this case.
|
|
ios: !isExpoModulesInstalledIos(projectRoot) ? null : {},
|
|
android: !isExpoModulesInstalledAndroid(projectRoot)
|
|
? null
|
|
: {
|
|
packageImportPath: 'import expo.modules.ExpoModulesPackage;',
|
|
},
|
|
macos: null,
|
|
windows: null,
|
|
},
|
|
},
|
|
};
|