2016-04-01 06:52:03 +08:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import PackageSet from './package-set';
|
|
|
|
import PackagesStore from './packages-store';
|
|
|
|
import PluginsActions from './plugins-actions';
|
|
|
|
|
|
|
|
class TabExplore extends React.Component {
|
|
|
|
static displayName = 'TabExplore';
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
this.state = this._getStateFromStores();
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
this._unsubscribers = [];
|
|
|
|
this._unsubscribers.push(PackagesStore.listen(this._onChange));
|
|
|
|
|
|
|
|
// Trigger a refresh of the featured packages
|
2017-09-27 02:33:08 +08:00
|
|
|
PluginsActions.refreshFeaturedPackages();
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
this._unsubscribers.forEach(unsubscribe => unsubscribe());
|
|
|
|
}
|
|
|
|
|
|
|
|
_getStateFromStores() {
|
|
|
|
return {
|
|
|
|
featured: PackagesStore.featured(),
|
|
|
|
search: PackagesStore.globalSearchValue(),
|
|
|
|
searchResults: PackagesStore.searchResults(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
_onChange = () => {
|
|
|
|
this.setState(this._getStateFromStores());
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_onSearchChange = event => {
|
2016-04-01 06:52:03 +08:00
|
|
|
PluginsActions.setGlobalSearchValue(event.target.value);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-04-01 06:52:03 +08:00
|
|
|
|
|
|
|
render() {
|
|
|
|
let collection = this.state.featured;
|
2017-09-27 02:33:08 +08:00
|
|
|
let collectionPrefix = 'Featured ';
|
2016-04-01 06:52:03 +08:00
|
|
|
let emptyText = null;
|
|
|
|
if (this.state.search.length > 0) {
|
2017-09-27 02:33:08 +08:00
|
|
|
collectionPrefix = 'Matching ';
|
2016-04-01 06:52:03 +08:00
|
|
|
if (this.state.searchResults) {
|
|
|
|
collection = this.state.searchResults;
|
2017-09-27 02:33:08 +08:00
|
|
|
emptyText = 'No results found.';
|
2016-04-01 06:52:03 +08:00
|
|
|
} else {
|
|
|
|
collection = {
|
|
|
|
packages: [],
|
|
|
|
themes: [],
|
|
|
|
};
|
2017-09-27 02:33:08 +08:00
|
|
|
emptyText = 'Loading results...';
|
2016-04-01 06:52:03 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="explore">
|
|
|
|
<div className="inner">
|
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
className="search"
|
|
|
|
value={this.state.search}
|
2016-05-07 07:06:16 +08:00
|
|
|
onChange={this._onSearchChange}
|
|
|
|
placeholder="Search Packages and Themes"
|
|
|
|
/>
|
2016-04-01 06:52:03 +08:00
|
|
|
<PackageSet
|
|
|
|
title={`${collectionPrefix} Themes`}
|
2017-09-27 02:33:08 +08:00
|
|
|
emptyText={emptyText || 'There are no featured themes yet.'}
|
2016-05-07 07:06:16 +08:00
|
|
|
packages={collection.themes}
|
|
|
|
/>
|
2016-04-01 06:52:03 +08:00
|
|
|
<PackageSet
|
|
|
|
title={`${collectionPrefix} Packages`}
|
2017-09-27 02:33:08 +08:00
|
|
|
emptyText={emptyText || 'There are no featured packages yet.'}
|
2016-05-07 07:06:16 +08:00
|
|
|
packages={collection.packages}
|
|
|
|
/>
|
2016-04-01 06:52:03 +08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default TabExplore;
|