2016-04-01 06:52:03 +08:00
|
|
|
import React from 'react';
|
2017-09-27 02:33:08 +08:00
|
|
|
import PropTypes from 'prop-types';
|
2016-04-01 06:52:03 +08:00
|
|
|
|
2017-09-27 02:46:00 +08:00
|
|
|
import { Flexbox, RetinaImg, Switch } from 'mailspring-component-kit';
|
2016-04-01 06:52:03 +08:00
|
|
|
import PluginsActions from './plugins-actions';
|
|
|
|
|
|
|
|
class Package extends React.Component {
|
|
|
|
static displayName = 'Package';
|
|
|
|
|
|
|
|
static propTypes = {
|
2017-09-27 02:33:08 +08:00
|
|
|
package: PropTypes.object.isRequired,
|
|
|
|
showVersions: PropTypes.bool,
|
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onDisablePackage = () => {
|
|
|
|
PluginsActions.disablePackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onEnablePackage = () => {
|
|
|
|
PluginsActions.enablePackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onUninstallPackage = () => {
|
|
|
|
PluginsActions.uninstallPackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onUpdatePackage = () => {
|
|
|
|
PluginsActions.updatePackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onInstallPackage = () => {
|
|
|
|
PluginsActions.installPackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
_onShowPackage = () => {
|
|
|
|
PluginsActions.showPackage(this.props.package);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
render() {
|
|
|
|
const actions = [];
|
|
|
|
const extras = [];
|
2017-09-27 02:33:08 +08:00
|
|
|
let icon = <RetinaImg name="plugin-icon-default.png" mode="ContentPreserve" />;
|
2016-04-01 06:52:03 +08:00
|
|
|
let uninstallButton = null;
|
|
|
|
|
|
|
|
if (this.props.package.icon) {
|
2017-09-27 02:33:08 +08:00
|
|
|
icon = (
|
|
|
|
<img
|
|
|
|
src={`mailspring://${this.props.package.name}/${this.props.package.icon}`}
|
|
|
|
alt=""
|
|
|
|
style={{ width: 27, alignContent: 'center', objectFit: 'scale-down' }}
|
|
|
|
/>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
} else if (this.props.package.theme) {
|
2017-09-27 02:33:08 +08:00
|
|
|
icon = <RetinaImg name="theme-icon-default.png" mode="ContentPreserve" />;
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (this.props.package.installed) {
|
2017-09-27 02:33:08 +08:00
|
|
|
if (
|
|
|
|
['user', 'dev', 'example'].indexOf(this.props.package.category) !== -1 &&
|
|
|
|
!this.props.package.theme
|
|
|
|
) {
|
2016-04-01 06:52:03 +08:00
|
|
|
if (this.props.package.enabled) {
|
2017-09-27 02:33:08 +08:00
|
|
|
actions.push(
|
|
|
|
<Switch key="disable" checked onChange={this._onDisablePackage}>
|
|
|
|
Disable
|
|
|
|
</Switch>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
} else {
|
2017-09-27 02:33:08 +08:00
|
|
|
actions.push(
|
|
|
|
<Switch key="enable" onChange={this._onEnablePackage}>
|
|
|
|
Enable
|
|
|
|
</Switch>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (this.props.package.category === 'user') {
|
2017-09-27 02:33:08 +08:00
|
|
|
uninstallButton = (
|
|
|
|
<div className="uninstall-plugin" onClick={this._onUninstallPackage}>
|
|
|
|
Uninstall
|
|
|
|
</div>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
if (this.props.package.category === 'dev') {
|
2017-09-27 02:33:08 +08:00
|
|
|
actions.push(
|
|
|
|
<div key="show-package" className="btn" onClick={this._onShowPackage}>
|
|
|
|
Show...
|
|
|
|
</div>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
} else if (this.props.package.installing) {
|
2017-09-27 02:33:08 +08:00
|
|
|
actions.push(
|
|
|
|
<div key="installing" className="btn">
|
|
|
|
Installing...
|
|
|
|
</div>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
} else {
|
2017-09-27 02:33:08 +08:00
|
|
|
actions.push(
|
|
|
|
<div key="install" className="btn" onClick={this._onInstallPackage}>
|
|
|
|
Install
|
|
|
|
</div>
|
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const { name, description, title, version } = this.props.package;
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
if (this.props.package.newerVersionAvailable) {
|
|
|
|
extras.push(
|
|
|
|
<div className="padded update-info">
|
|
|
|
A newer version is available: {this.props.package.newerVersion}
|
2017-09-27 02:33:08 +08:00
|
|
|
<div className="btn btn-emphasis" onClick={this._onUpdatePackage}>
|
|
|
|
Update
|
|
|
|
</div>
|
2016-04-01 06:52:03 +08:00
|
|
|
</div>
|
2017-09-27 02:33:08 +08:00
|
|
|
);
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
|
2016-05-26 05:13:42 +08:00
|
|
|
const versionLabel = this.props.showVersions ? `v${version}` : null;
|
|
|
|
|
2016-04-01 06:52:03 +08:00
|
|
|
return (
|
|
|
|
<Flexbox className="package" direction="row">
|
|
|
|
<div className="icon-container">
|
2017-09-27 02:33:08 +08:00
|
|
|
<div className="icon">{icon}</div>
|
2016-04-01 06:52:03 +08:00
|
|
|
</div>
|
|
|
|
<div className="info">
|
2017-09-27 02:33:08 +08:00
|
|
|
<div style={{ display: 'flex', flexDirection: 'row' }}>
|
|
|
|
<div className="title">
|
|
|
|
{title || name} <span className="version">{versionLabel}</span>
|
|
|
|
</div>
|
2016-04-01 06:52:03 +08:00
|
|
|
{uninstallButton}
|
|
|
|
</div>
|
|
|
|
<div className="description">{description}</div>
|
|
|
|
</div>
|
|
|
|
<div className="actions">{actions}</div>
|
|
|
|
{extras}
|
|
|
|
</Flexbox>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Package;
|