- 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
91 lines
2.3 KiB
JavaScript
91 lines
2.3 KiB
JavaScript
'use strict'
|
|
|
|
const vendors = require('./vendors.json')
|
|
|
|
const env = process.env
|
|
|
|
// Used for testing only
|
|
Object.defineProperty(exports, '_vendors', {
|
|
value: vendors.map(function (v) {
|
|
return v.constant
|
|
})
|
|
})
|
|
|
|
exports.name = null
|
|
exports.isPR = null
|
|
|
|
vendors.forEach(function (vendor) {
|
|
const envs = Array.isArray(vendor.env) ? vendor.env : [vendor.env]
|
|
const isCI = envs.every(function (obj) {
|
|
return checkEnv(obj)
|
|
})
|
|
|
|
exports[vendor.constant] = isCI
|
|
|
|
if (!isCI) {
|
|
return
|
|
}
|
|
|
|
exports.name = vendor.name
|
|
|
|
switch (typeof vendor.pr) {
|
|
case 'string':
|
|
// "pr": "CIRRUS_PR"
|
|
exports.isPR = !!env[vendor.pr]
|
|
break
|
|
case 'object':
|
|
if ('env' in vendor.pr) {
|
|
// "pr": { "env": "BUILDKITE_PULL_REQUEST", "ne": "false" }
|
|
exports.isPR = vendor.pr.env in env && env[vendor.pr.env] !== vendor.pr.ne
|
|
} else if ('any' in vendor.pr) {
|
|
// "pr": { "any": ["ghprbPullId", "CHANGE_ID"] }
|
|
exports.isPR = vendor.pr.any.some(function (key) {
|
|
return !!env[key]
|
|
})
|
|
} else {
|
|
// "pr": { "DRONE_BUILD_EVENT": "pull_request" }
|
|
exports.isPR = checkEnv(vendor.pr)
|
|
}
|
|
break
|
|
default:
|
|
// PR detection not supported for this vendor
|
|
exports.isPR = null
|
|
}
|
|
})
|
|
|
|
exports.isCI = !!(
|
|
env.CI !== 'false' && // Bypass all checks if CI env is explicitly set to 'false'
|
|
(env.BUILD_ID || // Jenkins, Cloudbees
|
|
env.BUILD_NUMBER || // Jenkins, TeamCity
|
|
env.CI || // Travis CI, CircleCI, Cirrus CI, Gitlab CI, Appveyor, CodeShip, dsari
|
|
env.CI_APP_ID || // Appflow
|
|
env.CI_BUILD_ID || // Appflow
|
|
env.CI_BUILD_NUMBER || // Appflow
|
|
env.CI_NAME || // Codeship and others
|
|
env.CONTINUOUS_INTEGRATION || // Travis CI, Cirrus CI
|
|
env.RUN_ID || // TaskCluster, dsari
|
|
exports.name ||
|
|
false)
|
|
)
|
|
|
|
function checkEnv (obj) {
|
|
// "env": "CIRRUS"
|
|
if (typeof obj === 'string') return !!env[obj]
|
|
|
|
// "env": { "env": "NODE", "includes": "/app/.heroku/node/bin/node" }
|
|
if ('env' in obj) {
|
|
// Currently there are no other types, uncomment when there are
|
|
// if ('includes' in obj) {
|
|
return env[obj.env] && env[obj.env].includes(obj.includes)
|
|
// }
|
|
}
|
|
if ('any' in obj) {
|
|
return obj.any.some(function (k) {
|
|
return !!env[k]
|
|
})
|
|
}
|
|
return Object.keys(obj).every(function (k) {
|
|
return env[k] === obj[k]
|
|
})
|
|
}
|