- 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
69 lines
1.9 KiB
JavaScript
69 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
var GetIntrinsic = require('get-intrinsic');
|
|
var callBound = require('call-bound');
|
|
var inspect = require('object-inspect');
|
|
|
|
var $TypeError = require('es-errors/type');
|
|
var $Map = GetIntrinsic('%Map%', true);
|
|
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => V} */
|
|
var $mapGet = callBound('Map.prototype.get', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K, value: V) => void} */
|
|
var $mapSet = callBound('Map.prototype.set', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
|
|
var $mapHas = callBound('Map.prototype.has', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>, key: K) => boolean} */
|
|
var $mapDelete = callBound('Map.prototype.delete', true);
|
|
/** @type {<K, V>(thisArg: Map<K, V>) => number} */
|
|
var $mapSize = callBound('Map.prototype.size', true);
|
|
|
|
/** @type {import('.')} */
|
|
module.exports = !!$Map && /** @type {Exclude<import('.'), false>} */ function getSideChannelMap() {
|
|
/** @typedef {ReturnType<typeof getSideChannelMap>} Channel */
|
|
/** @typedef {Parameters<Channel['get']>[0]} K */
|
|
/** @typedef {Parameters<Channel['set']>[1]} V */
|
|
|
|
/** @type {Map<K, V> | undefined} */ var $m;
|
|
|
|
/** @type {Channel} */
|
|
var channel = {
|
|
assert: function (key) {
|
|
if (!channel.has(key)) {
|
|
throw new $TypeError('Side channel does not contain ' + inspect(key));
|
|
}
|
|
},
|
|
'delete': function (key) {
|
|
if ($m) {
|
|
var result = $mapDelete($m, key);
|
|
if ($mapSize($m) === 0) {
|
|
$m = void undefined;
|
|
}
|
|
return result;
|
|
}
|
|
return false;
|
|
},
|
|
get: function (key) { // eslint-disable-line consistent-return
|
|
if ($m) {
|
|
return $mapGet($m, key);
|
|
}
|
|
},
|
|
has: function (key) {
|
|
if ($m) {
|
|
return $mapHas($m, key);
|
|
}
|
|
return false;
|
|
},
|
|
set: function (key, value) {
|
|
if (!$m) {
|
|
// @ts-expect-error TS can't handle narrowing a variable inside a closure
|
|
$m = new $Map();
|
|
}
|
|
$mapSet($m, key, value);
|
|
}
|
|
};
|
|
|
|
// @ts-expect-error TODO: figure out why TS is erroring here
|
|
return channel;
|
|
};
|