- 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
88 lines
2.0 KiB
JavaScript
88 lines
2.0 KiB
JavaScript
|
|
|
|
import * as Curry from "bs-platform/lib/es6/curry.js";
|
|
import * as Wonka_helpers from "./helpers/Wonka_helpers.bs.js";
|
|
|
|
function subscribe(f) {
|
|
return (function (source) {
|
|
var state = {
|
|
talkback: Wonka_helpers.talkbackPlaceholder,
|
|
ended: false
|
|
};
|
|
Curry._1(source, (function (signal) {
|
|
if (typeof signal === "number") {
|
|
state.ended = true;
|
|
return ;
|
|
}
|
|
if (signal.tag) {
|
|
if (!state.ended) {
|
|
f(signal[0]);
|
|
return state.talkback(/* Pull */0);
|
|
} else {
|
|
return ;
|
|
}
|
|
}
|
|
var x = signal[0];
|
|
state.talkback = x;
|
|
return x(/* Pull */0);
|
|
}));
|
|
return {
|
|
unsubscribe: (function (param) {
|
|
if (!state.ended) {
|
|
state.ended = true;
|
|
return state.talkback(/* Close */1);
|
|
}
|
|
|
|
})
|
|
};
|
|
});
|
|
}
|
|
|
|
function forEach(f) {
|
|
return (function (source) {
|
|
subscribe(f)(source);
|
|
|
|
});
|
|
}
|
|
|
|
function publish(source) {
|
|
return subscribe((function (param) {
|
|
|
|
}))(source);
|
|
}
|
|
|
|
function toArray(source) {
|
|
var state = {
|
|
values: new Array(),
|
|
talkback: Wonka_helpers.talkbackPlaceholder,
|
|
value: undefined,
|
|
ended: false
|
|
};
|
|
Curry._1(source, (function (signal) {
|
|
if (typeof signal === "number") {
|
|
state.ended = true;
|
|
return ;
|
|
}
|
|
if (signal.tag) {
|
|
state.values.push(signal[0]);
|
|
return state.talkback(/* Pull */0);
|
|
}
|
|
var x = signal[0];
|
|
state.talkback = x;
|
|
return x(/* Pull */0);
|
|
}));
|
|
if (!state.ended) {
|
|
state.talkback(/* Close */1);
|
|
}
|
|
return state.values;
|
|
}
|
|
|
|
export {
|
|
subscribe ,
|
|
forEach ,
|
|
publish ,
|
|
toArray ,
|
|
|
|
}
|
|
/* No side effect */
|