- 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
38 lines
1.2 KiB
Plaintext
38 lines
1.2 KiB
Plaintext
// @flow strict
|
|
import inspect from '../jsutils/inspect';
|
|
|
|
import type { ASTNode } from '../language/ast';
|
|
|
|
import { GraphQLError } from './GraphQLError';
|
|
|
|
/**
|
|
* Given an arbitrary value, presumably thrown while attempting to execute a
|
|
* GraphQL operation, produce a new GraphQLError aware of the location in the
|
|
* document responsible for the original Error.
|
|
*/
|
|
export function locatedError(
|
|
rawOriginalError: mixed,
|
|
nodes: ASTNode | $ReadOnlyArray<ASTNode> | void | null,
|
|
path?: ?$ReadOnlyArray<string | number>,
|
|
): GraphQLError {
|
|
// Sometimes a non-error is thrown, wrap it as an Error instance to ensure a consistent Error interface.
|
|
const originalError: Error | GraphQLError =
|
|
rawOriginalError instanceof Error
|
|
? rawOriginalError
|
|
: new Error('Unexpected error value: ' + inspect(rawOriginalError));
|
|
|
|
// Note: this uses a brand-check to support GraphQL errors originating from other contexts.
|
|
if (Array.isArray(originalError.path)) {
|
|
return (originalError: any);
|
|
}
|
|
|
|
return new GraphQLError(
|
|
originalError.message,
|
|
(originalError: any).nodes ?? nodes,
|
|
(originalError: any).source,
|
|
(originalError: any).positions,
|
|
path,
|
|
originalError,
|
|
);
|
|
}
|