- 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
49 lines
2.1 KiB
JavaScript
49 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.withAssetsAndroid = void 0;
|
|
const config_plugins_1 = require("expo/config-plugins");
|
|
const fs_1 = __importDefault(require("fs"));
|
|
const promises_1 = __importDefault(require("fs/promises"));
|
|
const path_1 = __importDefault(require("path"));
|
|
const utils_1 = require("./utils");
|
|
const withAssetsAndroid = (config, assets) => {
|
|
return (0, config_plugins_1.withDangerousMod)(config, [
|
|
'android',
|
|
async (config) => {
|
|
const resolvedAssets = await (0, utils_1.resolveAssetPaths)(assets, config.modRequest.projectRoot);
|
|
const validAssets = (0, utils_1.validateAssets)(resolvedAssets);
|
|
validAssets.forEach((asset) => {
|
|
const assetsDir = getAssetDir(asset, config.modRequest.platformProjectRoot);
|
|
fs_1.default.mkdirSync(assetsDir, { recursive: true });
|
|
});
|
|
await Promise.all(validAssets.map(async (asset) => {
|
|
const assetsDir = getAssetDir(asset, config.modRequest.platformProjectRoot);
|
|
const output = path_1.default.join(assetsDir, path_1.default.basename(asset));
|
|
await promises_1.default.copyFile(asset, output);
|
|
}));
|
|
return config;
|
|
},
|
|
]);
|
|
};
|
|
exports.withAssetsAndroid = withAssetsAndroid;
|
|
function getAssetDir(asset, root) {
|
|
const assetPath = ['app', 'src', 'main', 'assets'];
|
|
const resPath = ['app', 'src', 'main', 'res'];
|
|
const ext = path_1.default.extname(asset);
|
|
if (utils_1.IMAGE_TYPES.includes(ext)) {
|
|
return path_1.default.join(root, ...resPath, 'drawable');
|
|
}
|
|
else if (utils_1.FONT_TYPES.includes(ext)) {
|
|
return path_1.default.join(root, ...assetPath, 'fonts');
|
|
}
|
|
else if (utils_1.MEDIA_TYPES.includes(ext)) {
|
|
return path_1.default.join(root, ...resPath, 'raw');
|
|
}
|
|
else {
|
|
return path_1.default.join(root, ...assetPath);
|
|
}
|
|
}
|