2019-09-26 12:28:08 -04:00
|
|
|
import { connect } from 'react-redux';
|
2020-06-21 12:51:06 -04:00
|
|
|
import {
|
|
|
|
selectMyChannelClaims,
|
|
|
|
selectMyChannelUrls,
|
|
|
|
selectFetchingMyChannels,
|
2021-08-26 11:51:53 -03:00
|
|
|
makeSelectClaimIsPending,
|
2021-10-17 16:36:14 +08:00
|
|
|
} from 'redux/selectors/claims';
|
|
|
|
import { doFetchChannelListMine } from 'redux/actions/claims';
|
2021-06-19 00:02:36 +08:00
|
|
|
import { doSetActiveChannel } from 'redux/actions/app';
|
2020-06-15 16:33:03 -04:00
|
|
|
import { selectYoutubeChannels } from 'redux/selectors/user';
|
2019-09-26 12:28:08 -04:00
|
|
|
import ChannelsPage from './view';
|
|
|
|
|
2021-08-26 11:51:53 -03:00
|
|
|
const select = (state) => {
|
|
|
|
const channelUrls = selectMyChannelUrls(state);
|
|
|
|
let pendingChannels = [];
|
|
|
|
if (channelUrls) {
|
|
|
|
channelUrls.map((channelUrl) => {
|
|
|
|
const isPendingUrl = makeSelectClaimIsPending(channelUrl)(state);
|
|
|
|
if (isPendingUrl) pendingChannels.push(channelUrl);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
channelUrls,
|
|
|
|
channels: selectMyChannelClaims(state),
|
|
|
|
fetchingChannels: selectFetchingMyChannels(state),
|
|
|
|
youtubeChannels: selectYoutubeChannels(state),
|
|
|
|
pendingChannels,
|
|
|
|
};
|
|
|
|
};
|
2019-09-26 12:28:08 -04:00
|
|
|
|
2021-06-19 00:02:36 +08:00
|
|
|
const perform = (dispatch) => ({
|
2019-09-26 12:28:08 -04:00
|
|
|
fetchChannelListMine: () => dispatch(doFetchChannelListMine()),
|
2021-06-19 00:02:36 +08:00
|
|
|
doSetActiveChannel: (claimId) => dispatch(doSetActiveChannel(claimId)),
|
2019-09-26 12:28:08 -04:00
|
|
|
});
|
|
|
|
|
2020-06-15 16:33:03 -04:00
|
|
|
export default connect(select, perform)(ChannelsPage);
|