1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-10-18 20:09:08 +02:00
unleash.unleash/frontend/src/component/feature/list-container.jsx

82 lines
2.5 KiB
React
Raw Normal View History

2016-11-10 14:26:24 +01:00
import { connect } from 'react-redux';
2017-08-28 21:40:44 +02:00
import { toggleFeature, fetchFeatureToggles } from '../../store/feature-actions';
2016-12-04 11:56:41 +01:00
import { updateSettingForGroup } from '../../store/settings/actions';
2016-11-10 14:26:24 +01:00
import FeatureListComponent from './list-component';
const mapStateToProps = state => {
2016-12-04 11:56:41 +01:00
const featureMetrics = state.featureMetrics.toJS();
const settings = state.settings.toJS().feature || {};
let features = state.features.toJS();
if (settings.filter) {
try {
const regex = new RegExp(settings.filter, 'i');
features = features.filter(
feature =>
regex.test(feature.name) ||
regex.test(feature.description) ||
feature.strategies.some(s => s && s.name && regex.test(s.name))
);
} catch (e) {
// Invalid filter regex
}
2016-12-04 11:56:41 +01:00
}
2017-02-14 11:05:34 +01:00
if (!settings.sort) {
settings.sort = 'name';
}
if (settings.sort === 'enabled') {
features = features.sort(
(a, b) =>
// eslint-disable-next-line
2017-02-14 11:05:34 +01:00
a.enabled === b.enabled ? 0 : a.enabled ? -1 : 1
);
2017-02-14 11:05:34 +01:00
} else if (settings.sort === 'created') {
2017-08-28 21:40:44 +02:00
features = features.sort((a, b) => (new Date(a.createdAt) > new Date(b.createdAt) ? -1 : 1));
2017-02-14 11:05:34 +01:00
} else if (settings.sort === 'name') {
features = features.sort((a, b) => {
if (a.name < b.name) {
return -1;
}
if (a.name > b.name) {
return 1;
}
2017-02-14 11:05:34 +01:00
return 0;
});
} else if (settings.sort === 'strategies') {
2017-08-28 21:40:44 +02:00
features = features.sort((a, b) => (a.strategies.length > b.strategies.length ? -1 : 1));
2017-02-14 11:05:34 +01:00
} else if (settings.sort === 'metrics') {
2017-08-28 21:40:44 +02:00
const target = settings.showLastHour ? featureMetrics.lastHour : featureMetrics.lastMinute;
2016-12-05 12:57:21 +01:00
2017-02-14 11:05:34 +01:00
features = features.sort((a, b) => {
if (!target[a.name]) {
return 1;
}
if (!target[b.name]) {
return -1;
}
2017-02-14 11:05:34 +01:00
if (target[a.name].yes > target[b.name].yes) {
return -1;
}
return 1;
});
2016-12-04 11:56:41 +01:00
}
return {
features,
featureMetrics,
settings,
};
};
2016-11-10 14:26:24 +01:00
const mapDispatchToProps = {
toggleFeature,
2016-11-10 14:26:24 +01:00
fetchFeatureToggles,
2016-12-04 11:56:41 +01:00
updateSetting: updateSettingForGroup('feature'),
2016-11-10 14:26:24 +01:00
};
2017-08-28 21:40:44 +02:00
const FeatureListContainer = connect(mapStateToProps, mapDispatchToProps)(FeatureListComponent);
2016-11-10 14:26:24 +01:00
export default FeatureListContainer;