- 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
75 lines
2.4 KiB
JavaScript
75 lines
2.4 KiB
JavaScript
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }var _linesandcolumns = require('lines-and-columns'); var _linesandcolumns2 = _interopRequireDefault(_linesandcolumns);
|
|
|
|
|
|
var _types = require('../parser/tokenizer/types');
|
|
|
|
function formatTokens(code, tokens) {
|
|
if (tokens.length === 0) {
|
|
return "";
|
|
}
|
|
|
|
const tokenKeys = Object.keys(tokens[0]).filter(
|
|
(k) => k !== "type" && k !== "value" && k !== "start" && k !== "end" && k !== "loc",
|
|
);
|
|
const typeKeys = Object.keys(tokens[0].type).filter((k) => k !== "label" && k !== "keyword");
|
|
|
|
const headings = ["Location", "Label", "Raw", ...tokenKeys, ...typeKeys];
|
|
|
|
const lines = new (0, _linesandcolumns2.default)(code);
|
|
const rows = [headings, ...tokens.map(getTokenComponents)];
|
|
const padding = headings.map(() => 0);
|
|
for (const components of rows) {
|
|
for (let i = 0; i < components.length; i++) {
|
|
padding[i] = Math.max(padding[i], components[i].length);
|
|
}
|
|
}
|
|
return rows
|
|
.map((components) => components.map((component, i) => component.padEnd(padding[i])).join(" "))
|
|
.join("\n");
|
|
|
|
function getTokenComponents(token) {
|
|
const raw = code.slice(token.start, token.end);
|
|
return [
|
|
formatRange(token.start, token.end),
|
|
_types.formatTokenType.call(void 0, token.type),
|
|
truncate(String(raw), 14),
|
|
// @ts-ignore: Intentional dynamic access by key.
|
|
...tokenKeys.map((key) => formatValue(token[key], key)),
|
|
// @ts-ignore: Intentional dynamic access by key.
|
|
...typeKeys.map((key) => formatValue(token.type[key], key)),
|
|
];
|
|
}
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
function formatValue(value, key) {
|
|
if (value === true) {
|
|
return key;
|
|
} else if (value === false || value === null) {
|
|
return "";
|
|
} else {
|
|
return String(value);
|
|
}
|
|
}
|
|
|
|
function formatRange(start, end) {
|
|
return `${formatPos(start)}-${formatPos(end)}`;
|
|
}
|
|
|
|
function formatPos(pos) {
|
|
const location = lines.locationForIndex(pos);
|
|
if (!location) {
|
|
return "Unknown";
|
|
} else {
|
|
return `${location.line + 1}:${location.column + 1}`;
|
|
}
|
|
}
|
|
} exports.default = formatTokens;
|
|
|
|
function truncate(s, length) {
|
|
if (s.length > length) {
|
|
return `${s.slice(0, length - 3)}...`;
|
|
} else {
|
|
return s;
|
|
}
|
|
}
|