mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-15 04:27:39 +08:00
85 lines
2.7 KiB
CoffeeScript
85 lines
2.7 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 if @props.package.theme
|
|
icon = <RetinaImg name="theme-icon-default.png"/>
|
|
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
|