- 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
callsites 
Get callsites from the V8 stack trace API
Install
$ npm install --save callsites
Usage
const callsites = require('callsites');
function unicorn() {
console.log(callsites()[0].getFileName());
//=> '/Users/sindresorhus/dev/callsites/test.js'
}
unicorn();
API
Returns an array of callsite objects with the following methods:
getTypeName: returns the type of this as a string. This is the name of the function stored in the constructor field of this, if available, otherwise the object's Class internal property.getFunctionName: returns the name of the current function, typically its name property. If a name property is not available an attempt will be made to try to infer a name from the function's context.getMethodName: returns the name of the property of this or one of its prototypes that holds the current functiongetFileName: if this function was defined in a script returns the name of the scriptgetLineNumber: if this function was defined in a script returns the current line numbergetColumnNumber: if this function was defined in a script returns the current column numbergetEvalOrigin: if this function was created using a call to eval returns a CallSite object representing the location where eval was calledisToplevel: is this a top-level invocation, that is, is this the global object?isEval: does this call take place in code defined by a call to eval?isNative: is this call in native V8 code?isConstructor: is this a constructor call?
License
MIT © Sindre Sorhus