- 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
104 lines
1.5 KiB
Markdown
104 lines
1.5 KiB
Markdown
# env-editor
|
|
|
|
> Get metadata on the default editor or a specific editor
|
|
|
|
This module is used by [`open-editor`](https://github.com/sindresorhus/open-editor).
|
|
|
|
|
|
## Supported editors
|
|
|
|
- Sublime Text
|
|
- Atom
|
|
- Visual Studio Code
|
|
- WebStorm
|
|
- TextMate
|
|
- Vim
|
|
- NeoVim
|
|
- IntelliJ
|
|
- GNU nano
|
|
- GNU Emacs
|
|
- Android Studio
|
|
|
|
|
|
## Install
|
|
|
|
```
|
|
$ npm install env-editor
|
|
```
|
|
|
|
|
|
## Usage
|
|
|
|
```js
|
|
const {defaultEditor, getEditor, allEditors} = require('env-editor');
|
|
|
|
defaultEditor();
|
|
/*
|
|
{
|
|
id: 'atom',
|
|
name: 'Atom',
|
|
binary: 'atom',
|
|
isTerminalEditor: false,
|
|
paths: [
|
|
'/Applications/Atom.app/Contents/Resources/app/atom.sh'
|
|
],
|
|
keywords: []
|
|
}
|
|
*/
|
|
|
|
getEditor('sublime');
|
|
/*
|
|
{
|
|
id: 'sublime',
|
|
name: 'Sublime Text',
|
|
binary: 'subl',
|
|
isTerminalEditor: false,
|
|
paths: [
|
|
'/Applications/Sublime Text.app/Contents/SharedSupport/bin/subl',
|
|
'/Applications/Sublime Text 2.app/Contents/SharedSupport/bin/subl'
|
|
],
|
|
keywords: []
|
|
}
|
|
*/
|
|
|
|
allEditors();
|
|
/*
|
|
[
|
|
{
|
|
id: 'atom',
|
|
…
|
|
},
|
|
{
|
|
id: 'sublime,
|
|
…
|
|
},
|
|
…
|
|
]
|
|
*/
|
|
```
|
|
|
|
|
|
## API
|
|
|
|
### defaultEditor()
|
|
|
|
Returns metadata on the default editor.
|
|
|
|
The user is expected to have the `$EDITOR` environment variable set, and if not, a user-friendly error is thrown.
|
|
|
|
### getEditor(editor)
|
|
|
|
Returns metadata on the specified editor.
|
|
|
|
#### editor
|
|
|
|
Type: `string`
|
|
|
|
This can be pretty flexible. It matches against all the data it has.
|
|
|
|
For example, to get Sublime Text, you could write either of the following: `sublime`, `Sublime Text`, `subl`.
|
|
|
|
### allEditors()
|
|
|
|
Returns an array with metadata on all the editors.
|