- 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
81 lines
2.5 KiB
HTML
81 lines
2.5 KiB
HTML
<html>
|
|
<head>
|
|
</head>
|
|
<body>
|
|
<script>(function(){
|
|
var props = {};
|
|
|
|
function addObject(obj) {
|
|
if (obj == null) return;
|
|
try {
|
|
Object.getOwnPropertyNames(obj).forEach(add);
|
|
} catch(ex) {}
|
|
if (obj.prototype) {
|
|
Object.getOwnPropertyNames(obj.prototype).forEach(add);
|
|
}
|
|
if (typeof obj == "function") {
|
|
try {
|
|
Object.getOwnPropertyNames(new obj).forEach(add);
|
|
} catch(ex) {}
|
|
}
|
|
}
|
|
|
|
function add(name) {
|
|
if (/^[a-z_$][a-z0-9_$]*$/i.test(name)) {
|
|
props[name] = true;
|
|
}
|
|
}
|
|
|
|
Object.getOwnPropertyNames(window).forEach(function(thing){
|
|
addObject(window[thing]);
|
|
});
|
|
|
|
try {
|
|
addObject(new Event("click"));
|
|
addObject(new Event("contextmenu"));
|
|
addObject(new Event("mouseup"));
|
|
addObject(new Event("mousedown"));
|
|
addObject(new Event("keydown"));
|
|
addObject(new Event("keypress"));
|
|
addObject(new Event("keyup"));
|
|
addObject(new Event("input"));
|
|
addObject(new Event("touchstart"));
|
|
addObject(new Event("touchmove"));
|
|
addObject(new Event("touchend"));
|
|
addObject(new Event("touchcancel"));
|
|
addObject(new Event("pointerdown"));
|
|
addObject(new Event("pointermove"));
|
|
addObject(new Event("pointerup"));
|
|
addObject(new Event("pointercancel"));
|
|
addObject(new Event("pointerenter"));
|
|
addObject(new Event("pointerleave"));
|
|
} catch(ex) {console.error(ex)}
|
|
|
|
try {
|
|
addObject(Temporal.Duration.from({ years: 1 }));
|
|
addObject(new Temporal.Instant());
|
|
addObject(Temporal.Now);
|
|
addObject(new Temporal.PlainDate(2021, 7, 1));
|
|
addObject(new Temporal.ZonedDateTime(0n, "America/New_York"));
|
|
addObject(new Temporal.PlainYearMonth(2021, 7));
|
|
addObject(new Temporal.PlainTime());
|
|
addObject(new Temporal.PlainMonthDay(7, 1));
|
|
addObject(new Temporal.PlainDateTime(2021, 7, 1));
|
|
} catch(ex) {console.error(ex)}
|
|
|
|
var ta = document.createElement("textarea");
|
|
ta.style.width = "100%";
|
|
ta.style.height = "20em";
|
|
ta.style.boxSizing = "border-box";
|
|
ta.value = 'export var domprops = ' + JSON.stringify(Object.keys(props).sort(cmp), null, 4);
|
|
document.body.appendChild(ta);
|
|
|
|
function cmp(a, b) {
|
|
a = a.toLowerCase();
|
|
b = b.toLowerCase();
|
|
return a < b ? -1 : a > b ? 1 : 0;
|
|
}
|
|
})();</script>
|
|
</body>
|
|
</html>
|