- 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
56 lines
2.1 KiB
JavaScript
56 lines
2.1 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.loadConfigAsync = void 0;
|
|
const promises_1 = __importDefault(require("fs/promises"));
|
|
const path_1 = __importDefault(require("path"));
|
|
const require_from_string_1 = __importDefault(require("require-from-string"));
|
|
const resolve_from_1 = __importDefault(require("resolve-from"));
|
|
const utils_1 = require("./utils");
|
|
let tsMain = undefined;
|
|
/**
|
|
* Load the `react-native.config.js` or `react-native.config.ts` from the package.
|
|
*/
|
|
async function loadConfigAsync(packageRoot) {
|
|
const configJsPath = path_1.default.join(packageRoot, 'react-native.config.js');
|
|
if (await (0, utils_1.fileExistsAsync)(configJsPath)) {
|
|
try {
|
|
return require(configJsPath);
|
|
}
|
|
catch {
|
|
return null;
|
|
}
|
|
}
|
|
const configTsPath = path_1.default.join(packageRoot, 'react-native.config.ts');
|
|
if (await (0, utils_1.fileExistsAsync)(configTsPath)) {
|
|
if (tsMain === undefined) {
|
|
const tsPath = resolve_from_1.default.silent(packageRoot, 'typescript');
|
|
if (tsPath) {
|
|
tsMain = require(tsPath);
|
|
}
|
|
}
|
|
else if (tsMain == null) {
|
|
return null;
|
|
}
|
|
const configContents = await promises_1.default.readFile(configTsPath, 'utf8');
|
|
const transpiledContents = tsMain?.transpileModule(configContents, {
|
|
compilerOptions: {
|
|
module: tsMain.ModuleKind.NodeNext,
|
|
moduleResolution: tsMain.ModuleResolutionKind.NodeNext,
|
|
target: tsMain.ScriptTarget.ESNext,
|
|
},
|
|
});
|
|
const outputText = transpiledContents?.outputText;
|
|
let config;
|
|
try {
|
|
config = outputText ? (0, require_from_string_1.default)(outputText) : null;
|
|
}
|
|
catch { }
|
|
return config?.default ?? config ?? null;
|
|
}
|
|
return null;
|
|
}
|
|
exports.loadConfigAsync = loadConfigAsync;
|
|
//# sourceMappingURL=config.js.map
|