Mailspring/internal_packages/plugins/lib/package.cjsx
Jackie Luo 457abbf329 feat(plugins): Move uninstall from theme picker to plugins tab
Summary: Move uninstall functionality to the plugins tab in preferences.

Test Plan: Tested locally.

Reviewers: bengotow, evan

Reviewed By: evan

Differential Revision: https://phab.nylas.com/D2716
2016-03-10 14:16:07 -08:00

84 lines
2.6 KiB
CoffeeScript

React = require 'react'
_ = require 'underscore'
{Flexbox, RetinaImg, Switch} = require 'nylas-component-kit'
PluginsActions = require './plugins-actions'
class Package extends React.Component
@displayName: 'Package'
@propTypes:
'package': React.PropTypes.object.isRequired
constructor: (@props) ->
render: =>
actions = []
extras = []
if @props.package.icon
icon = <img src="nylas://#{@props.package.name}/#{@props.package.icon}" style={width:27, alignContent: 'center', objectFit: 'scale-down'} />
else
icon = <RetinaImg name="plugin-icon-default.png"/>
if @props.package.installed
if @props.package.category in ['user' ,'dev', 'example'] and not @props.package.theme
if @props.package.enabled
actions.push <Switch onChange={@_onDisablePackage} checked=true>Disable</Switch>
else
actions.push <Switch onChange={@_onEnablePackage} checked=false>Enable</Switch>
if @props.package.category is 'user'
uninstallButton = <div className="uninstall-plugin" onClick={@_onUninstallPackage}>Uninstall</div>
if @props.package.category is 'dev'
actions.push <div className="btn" onClick={@_onShowPackage}>Show...</div>
else if @props.package.installing
actions.push <div className="btn">Installing...</div>
else
actions.push <div className="btn" onClick={@_onInstallPackage}>Install</div>
{name, description, title} = @props.package
if @props.package.newerVersionAvailable
extras.push(
<div className="padded update-info">
A newer version is available: {@props.package.newerVersion}
<div className="btn btn-emphasis" onClick={@_onUpdatePackage}>Update</div>
</div>
)
<Flexbox className="package" direction="row">
<div className="icon-container">
<div className="icon" >{icon}</div>
</div>
<div className="info">
<div style={{display: "flex", flexDirection: "row"}}>
<div className="title">{title ? name}</div>
{uninstallButton}
</div>
<div className="description">{description}</div>
</div>
<div className="actions">{actions}</div>
{extras}
</Flexbox>
_onDisablePackage: =>
PluginsActions.disablePackage(@props.package)
_onEnablePackage: =>
PluginsActions.enablePackage(@props.package)
_onUninstallPackage: =>
PluginsActions.uninstallPackage(@props.package)
_onUpdatePackage: =>
PluginsActions.updatePackage(@props.package)
_onInstallPackage: =>
PluginsActions.installPackage(@props.package)
_onShowPackage: =>
PluginsActions.showPackage(@props.package)
module.exports = Package