- 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
67 lines
2.3 KiB
JavaScript
67 lines
2.3 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.UniqueFieldDefinitionNamesRule = UniqueFieldDefinitionNamesRule;
|
|
|
|
var _GraphQLError = require("../../error/GraphQLError.js");
|
|
|
|
var _definition = require("../../type/definition.js");
|
|
|
|
/**
|
|
* Unique field definition names
|
|
*
|
|
* A GraphQL complex type is only valid if all its fields are uniquely named.
|
|
*/
|
|
function UniqueFieldDefinitionNamesRule(context) {
|
|
var schema = context.getSchema();
|
|
var existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);
|
|
var knownFieldNames = Object.create(null);
|
|
return {
|
|
InputObjectTypeDefinition: checkFieldUniqueness,
|
|
InputObjectTypeExtension: checkFieldUniqueness,
|
|
InterfaceTypeDefinition: checkFieldUniqueness,
|
|
InterfaceTypeExtension: checkFieldUniqueness,
|
|
ObjectTypeDefinition: checkFieldUniqueness,
|
|
ObjectTypeExtension: checkFieldUniqueness
|
|
};
|
|
|
|
function checkFieldUniqueness(node) {
|
|
var _node$fields;
|
|
|
|
var typeName = node.name.value;
|
|
|
|
if (!knownFieldNames[typeName]) {
|
|
knownFieldNames[typeName] = Object.create(null);
|
|
} // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2203')
|
|
|
|
|
|
var fieldNodes = (_node$fields = node.fields) !== null && _node$fields !== void 0 ? _node$fields : [];
|
|
var fieldNames = knownFieldNames[typeName];
|
|
|
|
for (var _i2 = 0; _i2 < fieldNodes.length; _i2++) {
|
|
var fieldDef = fieldNodes[_i2];
|
|
var fieldName = fieldDef.name.value;
|
|
|
|
if (hasField(existingTypeMap[typeName], fieldName)) {
|
|
context.reportError(new _GraphQLError.GraphQLError("Field \"".concat(typeName, ".").concat(fieldName, "\" already exists in the schema. It cannot also be defined in this type extension."), fieldDef.name));
|
|
} else if (fieldNames[fieldName]) {
|
|
context.reportError(new _GraphQLError.GraphQLError("Field \"".concat(typeName, ".").concat(fieldName, "\" can only be defined once."), [fieldNames[fieldName], fieldDef.name]));
|
|
} else {
|
|
fieldNames[fieldName] = fieldDef.name;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|
|
|
|
function hasField(type, fieldName) {
|
|
if ((0, _definition.isObjectType)(type) || (0, _definition.isInterfaceType)(type) || (0, _definition.isInputObjectType)(type)) {
|
|
return type.getFields()[fieldName] != null;
|
|
}
|
|
|
|
return false;
|
|
}
|