mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 10:11:25 +08:00
refactor(packages): move internal sidebar to own repo
Fixes T3425 Remove Nylas internal admin sidebar from default edgehill
This commit is contained in:
parent
e8bffef723
commit
91bc61e03a
5 changed files with 0 additions and 294 deletions
|
@ -1,87 +0,0 @@
|
||||||
_ = require 'underscore'
|
|
||||||
Reflux = require 'reflux'
|
|
||||||
request = require 'request'
|
|
||||||
{FocusedContactsStore,
|
|
||||||
AccountStore,
|
|
||||||
PriorityUICoordinator} = require 'nylas-exports'
|
|
||||||
|
|
||||||
module.exports =
|
|
||||||
# The InternalAdminStore manages the data that backs the admin sidebar and emits
|
|
||||||
# a "trigger" event that the view listens to.
|
|
||||||
#
|
|
||||||
# If the Admin sidebar allowed you to take actions, like modifying someone's
|
|
||||||
# Nylas account, the InternalAdminStore would also listen for those user actions
|
|
||||||
# and perform business logic.
|
|
||||||
#
|
|
||||||
InternalAdminStore = Reflux.createStore
|
|
||||||
|
|
||||||
init: ->
|
|
||||||
@_accountCache = null
|
|
||||||
@_enabled = false
|
|
||||||
@_error = null
|
|
||||||
|
|
||||||
# Stores often listen to other stores to vend correct data to their views.
|
|
||||||
# Since we serve information about a contact we listen for changes to the
|
|
||||||
# focused contact. Since we only want to be enabled for @nylas.com emails,
|
|
||||||
# we listen for changes to available Accounts.
|
|
||||||
@listenTo FocusedContactsStore, @_onFocusedContacts
|
|
||||||
@listenTo AccountStore, @_onAccountChanged
|
|
||||||
|
|
||||||
@_onAccountChanged()
|
|
||||||
|
|
||||||
|
|
||||||
dataForFocusedContact: ->
|
|
||||||
return {loading: true} if @_accountCache is null
|
|
||||||
contact = FocusedContactsStore.focusedContact()
|
|
||||||
return {} unless contact
|
|
||||||
|
|
||||||
account = _.find @_accountCache, (account) -> account.email is contact.email
|
|
||||||
apps = undefined
|
|
||||||
apps = account.applications if account
|
|
||||||
|
|
||||||
# Coffeescript shorthand for {account: account, apps: apps}
|
|
||||||
{account, apps}
|
|
||||||
|
|
||||||
enabled: ->
|
|
||||||
@_enabled
|
|
||||||
|
|
||||||
error: ->
|
|
||||||
@_error
|
|
||||||
|
|
||||||
_onFocusedContacts: ->
|
|
||||||
# When the user focuses on a contact, we don't need to do any work because we
|
|
||||||
# cache everything. Just trigger so that our view updates and calls
|
|
||||||
# `dataForFocusedContact`.
|
|
||||||
@trigger(@)
|
|
||||||
|
|
||||||
_onAccountChanged: ->
|
|
||||||
clearInterval(@_fetchInterval) if @_fetchInterval
|
|
||||||
@_fetchInterval = null
|
|
||||||
|
|
||||||
# We only want to enable this package for users with nylas.com email addresses.
|
|
||||||
n = AccountStore.current()
|
|
||||||
if n and n.emailAddress.indexOf('@nylas.com') > 0
|
|
||||||
@_fetchInterval = setInterval(( => @_fetchAPIData()), 5 * 60 * 1000)
|
|
||||||
@_fetchAPIData()
|
|
||||||
@_enabled = true
|
|
||||||
else
|
|
||||||
@_accountCache = null
|
|
||||||
@_enabled = false
|
|
||||||
@trigger(@)
|
|
||||||
|
|
||||||
_fetchAPIData: ->
|
|
||||||
# Make a HTTP request to the Admin service using the `request` library. Using
|
|
||||||
# the priority UI coordinator ensures that the expensive JSON.parse operation
|
|
||||||
# doesn't happen while an animation is running.
|
|
||||||
request 'https://admin.nylas.com/api/status/accounts', (err, resp, data) =>
|
|
||||||
PriorityUICoordinator.settle.then =>
|
|
||||||
if err
|
|
||||||
@_error = err
|
|
||||||
else
|
|
||||||
@_error = null
|
|
||||||
try
|
|
||||||
@_accountCache = JSON.parse(data)
|
|
||||||
catch err
|
|
||||||
@_error = err
|
|
||||||
@_accountCache = null
|
|
||||||
@trigger(@)
|
|
|
@ -1,16 +0,0 @@
|
||||||
_ = require 'underscore'
|
|
||||||
React = require "react"
|
|
||||||
SidebarInternal = require "./sidebar-internal"
|
|
||||||
{ComponentRegistry, WorkspaceStore} = require "nylas-exports"
|
|
||||||
|
|
||||||
module.exports =
|
|
||||||
item: null
|
|
||||||
|
|
||||||
activate: (@state={}) ->
|
|
||||||
ComponentRegistry.register SidebarInternal,
|
|
||||||
location: WorkspaceStore.Location.MessageListSidebar
|
|
||||||
|
|
||||||
deactivate: ->
|
|
||||||
ComponentRegistry.unregister(SidebarInternal)
|
|
||||||
|
|
||||||
serialize: -> @state
|
|
|
@ -1,129 +0,0 @@
|
||||||
_ = require 'underscore'
|
|
||||||
React = require "react"
|
|
||||||
moment = require 'moment-timezone'
|
|
||||||
InternalAdminStore = require "./internal-admin-store"
|
|
||||||
|
|
||||||
AccountStates =
|
|
||||||
"developer_program": "Developer Program"
|
|
||||||
"trial-expired": "Trial Expired"
|
|
||||||
"paid": "Paid"
|
|
||||||
"cancelled": "Cancelled"
|
|
||||||
|
|
||||||
AccountKeys =
|
|
||||||
"deleted_at": "Deleted At"
|
|
||||||
"healthy": "Healthy"
|
|
||||||
"initial_sync": "Initial Sync"
|
|
||||||
"is_enabled": "Enabled"
|
|
||||||
"account_id": "Account Id"
|
|
||||||
"provider": "Provider"
|
|
||||||
"remote_count": "Remote Count"
|
|
||||||
"state": "State"
|
|
||||||
"status": "Status"
|
|
||||||
"sync_disabled_reason": "Sync Disabled Reason"
|
|
||||||
"sync_end_time": "Sync End Time"
|
|
||||||
"sync_error": "Sync Error"
|
|
||||||
"sync_host": "Sync Host"
|
|
||||||
"sync_restart_time": "Sync Restart Time"
|
|
||||||
"sync_start_time": "Sync Start Time"
|
|
||||||
"sync_type": "Sync Type"
|
|
||||||
|
|
||||||
|
|
||||||
class SidebarInternal extends React.Component
|
|
||||||
@displayName: "SidebarInternal"
|
|
||||||
|
|
||||||
@containerStyles:
|
|
||||||
order: 10
|
|
||||||
maxWidth: 300
|
|
||||||
minWidth: 200
|
|
||||||
|
|
||||||
constructor: (@props) ->
|
|
||||||
@state = @_getStateFromStores()
|
|
||||||
|
|
||||||
componentDidMount: =>
|
|
||||||
@unsubscribe = InternalAdminStore.listen @_onChange
|
|
||||||
|
|
||||||
componentWillUnmount: =>
|
|
||||||
@unsubscribe()
|
|
||||||
|
|
||||||
render: =>
|
|
||||||
return <div></div> unless @state.enabled
|
|
||||||
|
|
||||||
<div className="internal-sidebar">
|
|
||||||
<div className="internal-sidebar-sections">
|
|
||||||
<div className="sidebar-section">
|
|
||||||
<h2 className="sidebar-h2">Mailsync Account</h2>
|
|
||||||
{@_renderAccount()}
|
|
||||||
</div>
|
|
||||||
<div className="sidebar-section">
|
|
||||||
<h2 className="sidebar-h2">Authenticated Applications</h2>
|
|
||||||
{@_renderApplications()}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
_renderAccount: =>
|
|
||||||
if @state.error
|
|
||||||
return <div>{@_errorString()}</div>
|
|
||||||
else if @state.data.loading
|
|
||||||
return <div>Loading...</div>
|
|
||||||
else
|
|
||||||
acct = @state.data.account
|
|
||||||
if acct
|
|
||||||
<div className="sidebar-item">
|
|
||||||
<h3 className="sidebar-h3"><a href={@_accountUrl(acct)}>{acct.email} ({acct.id})</a></h3>
|
|
||||||
<div className="sidebar-extra-info">{@_accountDetails(acct)}</div>
|
|
||||||
</div>
|
|
||||||
else
|
|
||||||
<div>No Matching Account</div>
|
|
||||||
|
|
||||||
_renderApplications: =>
|
|
||||||
if @state.error
|
|
||||||
return <div>{@_errorString()}</div>
|
|
||||||
else if @state.data.loading
|
|
||||||
return <div>Loading...</div>
|
|
||||||
else if @state.data.apps
|
|
||||||
@state.data.apps.map (app) =>
|
|
||||||
<div className="sidebar-item">
|
|
||||||
<h3 className="sidebar-h3"><a href={@_appUrl(app)}>{app.name}</a></h3>
|
|
||||||
<div className="sidebar-extra-info">{@_appDetails(app)}</div>
|
|
||||||
</div>
|
|
||||||
else
|
|
||||||
<div>No Matching Applications</div>
|
|
||||||
|
|
||||||
_errorString: =>
|
|
||||||
if @state.error.toString().indexOf('ENOTFOUND') >= 0
|
|
||||||
"Unable to reach admin.nylas.com"
|
|
||||||
else
|
|
||||||
@state.error.toString()
|
|
||||||
|
|
||||||
_accountUrl: (account) =>
|
|
||||||
"https://admin.nylas.com/accounts/#{account.id}"
|
|
||||||
|
|
||||||
_accountDetails: (account) =>
|
|
||||||
cjsx = []
|
|
||||||
for key, value of account
|
|
||||||
displayName = AccountKeys[key]
|
|
||||||
continue unless displayName
|
|
||||||
continue unless value
|
|
||||||
value = "True" if value is true
|
|
||||||
value = "False" if value is false
|
|
||||||
value = moment.unix(value).format("DD / MM / YYYY h:mm a z") if key.indexOf("_time") > 0
|
|
||||||
cjsx.push <div style={textAlign:'right'} key={key}><span style={float:'left'}>{displayName}:</span>{value}</div>
|
|
||||||
cjsx
|
|
||||||
|
|
||||||
_appUrl: (app) =>
|
|
||||||
"https://admin.nylas.com/apps/#{app.id}"
|
|
||||||
|
|
||||||
_appDetails: (app) =>
|
|
||||||
"No Extra Details"
|
|
||||||
|
|
||||||
_onChange: =>
|
|
||||||
@setState(@_getStateFromStores())
|
|
||||||
|
|
||||||
_getStateFromStores: =>
|
|
||||||
data: InternalAdminStore.dataForFocusedContact()
|
|
||||||
enabled: InternalAdminStore.enabled()
|
|
||||||
error: InternalAdminStore.error()
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = SidebarInternal
|
|
|
@ -1,13 +0,0 @@
|
||||||
{
|
|
||||||
"name": "sidebar-inbox-internal",
|
|
||||||
"version": "0.1.0",
|
|
||||||
"main": "./lib/main",
|
|
||||||
"description": "View user data on the sidebar from inbox internal systems",
|
|
||||||
"license": "Proprietary",
|
|
||||||
"private": true,
|
|
||||||
"engines": {
|
|
||||||
"atom": "*"
|
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,49 +0,0 @@
|
||||||
@import "ui-variables";
|
|
||||||
|
|
||||||
.internal-sidebar {
|
|
||||||
padding: @spacing-standard;
|
|
||||||
padding-bottom: 0;
|
|
||||||
order: 4;
|
|
||||||
flex-shrink: 0;
|
|
||||||
|
|
||||||
a{text-decoration: none}
|
|
||||||
|
|
||||||
.sidebar-section {
|
|
||||||
margin-top: @spacing-double;
|
|
||||||
font-size: @font-size-smaller;
|
|
||||||
&:first-child {margin-top: 0}
|
|
||||||
}
|
|
||||||
|
|
||||||
.internal-prompt {
|
|
||||||
color: fade(@text-color, 30%);
|
|
||||||
ul {
|
|
||||||
list-style: none;
|
|
||||||
padding-left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.internal-no-connect-placeholder {
|
|
||||||
text-align: center;
|
|
||||||
margin: @spacing-double 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3.sidebar-h3 {
|
|
||||||
font-size: @font-size-smaller;
|
|
||||||
font-weight: @font-weight-normal;
|
|
||||||
margin: 1em 0 0.4em 0;
|
|
||||||
}
|
|
||||||
.sidebar-extra-info {
|
|
||||||
font-size: 11px;
|
|
||||||
font-weight: @font-weight-medium;
|
|
||||||
color: @text-color-subtle;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2.sidebar-h2 {
|
|
||||||
font-size: 11px;
|
|
||||||
font-weight: @font-weight-semi-bold;
|
|
||||||
text-transform: uppercase;
|
|
||||||
color: @text-color-very-subtle;
|
|
||||||
border-bottom: 1px solid @border-color-divider;
|
|
||||||
margin: 2em 0 1em 0;
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue