mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-01 13:14:16 +08:00
hide(zoom): Remove UI for zoom, move to CONFIG.md
This commit is contained in:
parent
c76582194a
commit
a1691c10b2
5 changed files with 105 additions and 89 deletions
97
CONFIGURATION.md
Normal file
97
CONFIGURATION.md
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
# Configuration
|
||||||
|
|
||||||
|
This document outlines configuration options which aren't exposed via N1's
|
||||||
|
preferences interface, but may be useful.
|
||||||
|
|
||||||
|
## Running Against Open Source Sync Engine
|
||||||
|
|
||||||
|
N1 needs to fetch mail from a running instance of the [Nylas Sync
|
||||||
|
Engine](https://github.com/nylas/sync-engine). The Sync Engine is what
|
||||||
|
abstracts away IMAP, POP, and SMTP to serve your email on any provider
|
||||||
|
through a modern, RESTful API.
|
||||||
|
|
||||||
|
By default the N1 source points to our hosted version of the sync-engine;
|
||||||
|
however, the Sync Engine is open source and you can run it yourself.
|
||||||
|
|
||||||
|
1. Install the Nylas Sync Engine in a Vagrant virtual machine by following the
|
||||||
|
[installation and setup](https://github.com/nylas/sync-engine#installation-and-setup)
|
||||||
|
instructions.
|
||||||
|
|
||||||
|
2. Once you've installed the sync engine, add accounts by running the inbox-auth
|
||||||
|
script. For Gmail accounts, the syntax is simple: `bin/inbox-auth you@gmail.com`
|
||||||
|
|
||||||
|
3. Start the sync engine by running `bin/inbox-start` and the API via `bin/inbox-api`.
|
||||||
|
|
||||||
|
4. After you've linked accounts to the Sync Engine, open or create a file at
|
||||||
|
`~/.nylas/config.cson`. This is the config file that N1 reads at launch.
|
||||||
|
|
||||||
|
Replace `env: "production"` with `env: "local"` at the top level of the config.
|
||||||
|
This tells N1 to look at `localhost:5555` for the sync engine. If you've deployed
|
||||||
|
the sync engine elsewhere, add the following block beneath `env: "local"`:
|
||||||
|
|
||||||
|
```
|
||||||
|
syncEngine:
|
||||||
|
APIRoot: "http://mysite.com:5555"
|
||||||
|
```
|
||||||
|
|
||||||
|
NOTE: If you are using a custom network layout and your sync engine is not on
|
||||||
|
`localhost:5555`, use `env: custom` instead along with your alternate IP for the
|
||||||
|
API Root, for example `192.168.1.00:5555`
|
||||||
|
|
||||||
|
```
|
||||||
|
env: "custom"
|
||||||
|
syncEngine:
|
||||||
|
APIRoot: "http://192.168.1.100:5555"
|
||||||
|
```
|
||||||
|
|
||||||
|
Copy the JSON array of accounts returned from the Sync Engine's `/accounts`
|
||||||
|
endpoint (ex. `http://localhost:5555/accounts`) into the config file at the
|
||||||
|
path `*.nylas.accounts`.
|
||||||
|
|
||||||
|
N1 will look for access tokens for these accounts under `*.nylas.accountTokens`,
|
||||||
|
but the open source version of the sync engine does not provide access tokens.
|
||||||
|
When you make requests to the open source API, you provide an account
|
||||||
|
ID in the HTTP Basic Auth username field instead of an account token.
|
||||||
|
|
||||||
|
For each account you've created, add an entry to `*.nylas.accountTokens`
|
||||||
|
with the account ID as both the key and value.
|
||||||
|
|
||||||
|
The final `config.cson` file should look something like this:
|
||||||
|
|
||||||
|
"*":
|
||||||
|
env: "local"
|
||||||
|
nylas:
|
||||||
|
accounts: [
|
||||||
|
{
|
||||||
|
server_id: "{ACCOUNT_ID_1}"
|
||||||
|
object: "account"
|
||||||
|
account_id: "{ACCOUNT_ID_1}"
|
||||||
|
name: "{YOUR NAME}"
|
||||||
|
provider: "{PROVIDER_NAME}"
|
||||||
|
email_address: "{YOUR_EMAIL_ADDRESS}"
|
||||||
|
organization_unit: "{folder or label}"
|
||||||
|
id: "{ACCOUNT_ID_1}"
|
||||||
|
}
|
||||||
|
{
|
||||||
|
server_id: "{ACCOUNT_ID_2}"
|
||||||
|
object: "account"
|
||||||
|
account_id: "{ACCOUNT_ID_2}"
|
||||||
|
name: "{YOUR_NAME}"
|
||||||
|
provider: "{PROVIDER_NAME}"
|
||||||
|
email_address: "{YOUR_EMAIL_ADDRESS}"
|
||||||
|
organization_unit: "{folder or label}"
|
||||||
|
id: "{ACCOUNT_ID_2}"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
accountTokens:
|
||||||
|
"{ACCOUNT_ID_1}": "{ACCOUNT_ID_1}"
|
||||||
|
"{ACCOUNT_ID_2}": "{ACCOUNT_ID_2}"
|
||||||
|
|
||||||
|
Note: `{ACCOUNT_ID_1}` refers to the database ID of the `Account` object
|
||||||
|
you create when setting up the Sync Engine. The JSON above should match
|
||||||
|
fairly closely with the Sync Engine `Account` object.
|
||||||
|
|
||||||
|
|
||||||
|
## Other Config Options
|
||||||
|
|
||||||
|
- `core.workspace.interfaceZoom`: If you'd like the N1 interface to be smaller or larger, this option allows you to scale the UI globally. (Default: 1)
|
|
@ -82,88 +82,4 @@ We do have a few heuristics:
|
||||||
|
|
||||||
# Running Against Open Source Sync Engine
|
# Running Against Open Source Sync Engine
|
||||||
|
|
||||||
N1 needs to fetch mail from a running instance of the [Nylas Sync
|
See [Configuration](https://github.com/nylas/N1/blob/master/CONFIGURATION.md)
|
||||||
Engine](https://github.com/nylas/sync-engine). The Sync Engine is what
|
|
||||||
abstracts away IMAP, POP, and SMTP to serve your email on any provider
|
|
||||||
through a modern, RESTful API.
|
|
||||||
|
|
||||||
By default the N1 source points to our hosted version of the sync-engine;
|
|
||||||
however, the Sync Engine is open source and you can run it yourself.
|
|
||||||
|
|
||||||
1. Install the Nylas Sync Engine in a Vagrant virtual machine by following the
|
|
||||||
[installation and setup](https://github.com/nylas/sync-engine#installation-and-setup)
|
|
||||||
instructions.
|
|
||||||
|
|
||||||
2. Once you've installed the sync engine, add accounts by running the inbox-auth
|
|
||||||
script. For Gmail accounts, the syntax is simple: `bin/inbox-auth you@gmail.com`
|
|
||||||
|
|
||||||
3. Start the sync engine by running `bin/inbox-start` and the API via `bin/inbox-api`.
|
|
||||||
|
|
||||||
4. After you've linked accounts to the Sync Engine, open or create a file at
|
|
||||||
`~/.nylas/config.cson`. This is the config file that N1 reads at launch.
|
|
||||||
|
|
||||||
Replace `env: "production"` with `env: "local"` at the top level of the config.
|
|
||||||
This tells N1 to look at `localhost:5555` for the sync engine. If you've deployed
|
|
||||||
the sync engine elsewhere, add the following block beneath `env: "local"`:
|
|
||||||
|
|
||||||
```
|
|
||||||
syncEngine:
|
|
||||||
APIRoot: "http://mysite.com:5555"
|
|
||||||
```
|
|
||||||
|
|
||||||
NOTE: If you are using a custom network layout and your sync engine is not on
|
|
||||||
`localhost:5555`, use `env: custom` instead along with your alternate IP for the
|
|
||||||
API Root, for example `192.168.1.00:5555`
|
|
||||||
|
|
||||||
```
|
|
||||||
env: "custom"
|
|
||||||
syncEngine:
|
|
||||||
APIRoot: "http://192.168.1.100:5555"
|
|
||||||
```
|
|
||||||
|
|
||||||
Copy the JSON array of accounts returned from the Sync Engine's `/accounts`
|
|
||||||
endpoint (ex. `http://localhost:5555/accounts`) into the config file at the
|
|
||||||
path `*.nylas.accounts`.
|
|
||||||
|
|
||||||
N1 will look for access tokens for these accounts under `*.nylas.accountTokens`,
|
|
||||||
but the open source version of the sync engine does not provide access tokens.
|
|
||||||
When you make requests to the open source API, you provide an account
|
|
||||||
ID in the HTTP Basic Auth username field instead of an account token.
|
|
||||||
|
|
||||||
For each account you've created, add an entry to `*.nylas.accountTokens`
|
|
||||||
with the account ID as both the key and value.
|
|
||||||
|
|
||||||
The final `config.cson` file should look something like this:
|
|
||||||
|
|
||||||
"*":
|
|
||||||
env: "local"
|
|
||||||
nylas:
|
|
||||||
accounts: [
|
|
||||||
{
|
|
||||||
server_id: "{ACCOUNT_ID_1}"
|
|
||||||
object: "account"
|
|
||||||
account_id: "{ACCOUNT_ID_1}"
|
|
||||||
name: "{YOUR NAME}"
|
|
||||||
provider: "{PROVIDER_NAME}"
|
|
||||||
email_address: "{YOUR_EMAIL_ADDRESS}"
|
|
||||||
organization_unit: "{folder or label}"
|
|
||||||
id: "{ACCOUNT_ID_1}"
|
|
||||||
}
|
|
||||||
{
|
|
||||||
server_id: "{ACCOUNT_ID_2}"
|
|
||||||
object: "account"
|
|
||||||
account_id: "{ACCOUNT_ID_2}"
|
|
||||||
name: "{YOUR_NAME}"
|
|
||||||
provider: "{PROVIDER_NAME}"
|
|
||||||
email_address: "{YOUR_EMAIL_ADDRESS}"
|
|
||||||
organization_unit: "{folder or label}"
|
|
||||||
id: "{ACCOUNT_ID_2}"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
accountTokens:
|
|
||||||
"{ACCOUNT_ID_1}": "{ACCOUNT_ID_1}"
|
|
||||||
"{ACCOUNT_ID_2}": "{ACCOUNT_ID_2}"
|
|
||||||
|
|
||||||
Note: `{ACCOUNT_ID_1}` refers to the database ID of the `Account` object
|
|
||||||
you create when setting up the Sync Engine. The JSON above should match
|
|
||||||
fairly closely with the Sync Engine `Account` object.
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
[![Slack Invite Button](http://slack-invite.nylas.com/badge.svg)](http://slack-invite.nylas.com)
|
[![Slack Invite Button](http://slack-invite.nylas.com/badge.svg)](http://slack-invite.nylas.com)
|
||||||
[![GitHub issues On Deck](https://badge.waffle.io/nylas/N1.png?label=on deck&title=On Deck)](https://waffle.io/nylas/N1)
|
[![GitHub issues On Deck](https://badge.waffle.io/nylas/N1.png?label=on deck&title=On Deck)](https://waffle.io/nylas/N1)
|
||||||
|
|
||||||
#### Want help build the future of email? [Nylas is hiring](https://jobs.lever.co/nylas)!
|
#### Want help build the future of email? [Nylas is hiring](https://jobs.lever.co/nylas)!
|
||||||
|
|
||||||
# Download N1
|
# Download N1
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ Great starting points for creating your own plugins!
|
||||||
- In Development: [Cypher](https://github.com/mbilker/cypher) (PGP Encryption)
|
- In Development: [Cypher](https://github.com/mbilker/cypher) (PGP Encryption)
|
||||||
|
|
||||||
# Running Locally
|
# Running Locally
|
||||||
By default the N1 source points to our hosted version of the Nylas Sync Engine; however, the Sync Engine is open source and you can [run it yourself](https://github.com/nylas/N1/blob/master/CONTRIBUTING.md#running-against-open-source-sync-engine).
|
By default the N1 source points to our hosted version of the Nylas Sync Engine; however, the Sync Engine is open source and you can [run it yourself](https://github.com/nylas/N1/blob/master/CONFIGURATION.md).
|
||||||
|
|
||||||
# Feature Requests / Plugin Ideas
|
# Feature Requests / Plugin Ideas
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,10 @@ class ConfigSchemaItem extends React.Component
|
||||||
|
|
||||||
render: ->
|
render: ->
|
||||||
return false unless @_appliesToPlatform()
|
return false unless @_appliesToPlatform()
|
||||||
|
|
||||||
|
# In the future, we may add an option to reveal "advanced settings"
|
||||||
|
return false if @props.configSchema.advanced is true
|
||||||
|
|
||||||
if @props.configSchema.type is 'object'
|
if @props.configSchema.type is 'object'
|
||||||
<section>
|
<section>
|
||||||
<h2>{_str.humanize(@props.keyName)}</h2>
|
<h2>{_str.humanize(@props.keyName)}</h2>
|
||||||
|
|
|
@ -26,8 +26,7 @@ module.exports =
|
||||||
title: "Override standard interface scaling"
|
title: "Override standard interface scaling"
|
||||||
type: 'number'
|
type: 'number'
|
||||||
default: 1
|
default: 1
|
||||||
enum: [0.6, 0.8, 1, 1.2, 1.4]
|
advanced: true
|
||||||
enumLabels: ['60%', '80%', '100%', '120%', '140%']
|
|
||||||
disabledPackages:
|
disabledPackages:
|
||||||
type: 'array'
|
type: 'array'
|
||||||
default: []
|
default: []
|
||||||
|
|
Loading…
Reference in a new issue