7eb5eb9996
- Moved from reach/ui to material/ui menu components, because reach ui wouldn't work with 2 menus - This channel selector stores the default on settings - setActiveChannelIfNotSet was deprecated, if the account has channels, it will always return a channel even if there is no active channel or stored channel
116 lines
5.2 KiB
JavaScript
116 lines
5.2 KiB
JavaScript
import { createSelector } from 'reselect';
|
|
import * as SETTINGS from 'constants/settings';
|
|
import { selectClaimWithId, selectMyChannelClaims, selectStakedLevelForChannelUri } from 'redux/selectors/claims';
|
|
import { selectUserEmail } from 'redux/selectors/user';
|
|
import { selectClientSetting } from 'redux/selectors/settings';
|
|
|
|
export const selectState = (state) => state.app || {};
|
|
|
|
export const selectPlatform = (state) => selectState(state).platform;
|
|
|
|
export const selectUpdateUrl = createSelector(selectPlatform, (platform) => {
|
|
switch (platform) {
|
|
case 'darwin':
|
|
return 'https://lbry.com/get/lbry.dmg';
|
|
case 'linux':
|
|
return 'https://lbry.com/get/lbry.deb';
|
|
case 'win32':
|
|
return 'https://lbry.com/get/lbry.exe';
|
|
default:
|
|
throw Error('Unknown platform');
|
|
}
|
|
});
|
|
|
|
export const selectHasClickedComment = (state) => selectState(state).hasClickedComment;
|
|
export const selectRemoteVersion = (state) => selectState(state).remoteVersion;
|
|
export const selectIsUpgradeAvailable = (state) => selectState(state).isUpgradeAvailable;
|
|
export const selectIsReloadRequired = (state) => selectState(state).isReloadRequired;
|
|
|
|
export const selectUpgradeFilename = createSelector(selectPlatform, selectRemoteVersion, (platform, version) => {
|
|
switch (platform) {
|
|
case 'darwin':
|
|
return `LBRY_${version}.dmg`;
|
|
case 'linux':
|
|
return `LBRY_${version}.deb`;
|
|
case 'win32':
|
|
return `LBRY_${version}.exe`;
|
|
default:
|
|
throw Error('Unknown platform');
|
|
}
|
|
});
|
|
|
|
export const selectDownloadProgress = (state) => selectState(state).downloadProgress;
|
|
export const selectDownloadComplete = (state) => selectState(state).upgradeDownloadCompleted;
|
|
export const selectIsUpgradeSkipped = (state) => selectState(state).isUpgradeSkipped;
|
|
export const selectUpgradeDownloadPath = (state) => selectState(state).downloadPath;
|
|
export const selectUpgradeDownloadItem = (state) => selectState(state).downloadItem;
|
|
export const selectAutoUpdateDownloaded = (state) => selectState(state).autoUpdateDownloaded;
|
|
export const selectAutoUpdateDeclined = (state) => selectState(state).autoUpdateDeclined;
|
|
export const selectDaemonVersionMatched = (state) => selectState(state).daemonVersionMatched;
|
|
export const selectVolume = (state) => selectState(state).volume;
|
|
export const selectMute = (state) => selectState(state).muted;
|
|
export const selectUpgradeTimer = (state) => selectState(state).checkUpgradeTimer;
|
|
const selectModalId = (state) => selectState(state).modal;
|
|
const selectModalProps = (state) => selectState(state).modalProps;
|
|
|
|
export const selectModal = createSelector(selectModalId, selectModalProps, (id, modalProps) => {
|
|
return id ? { id, modalProps } : null;
|
|
});
|
|
|
|
export const selectSearchOptionsExpanded = (state) => selectState(state).searchOptionsExpanded;
|
|
export const selectWelcomeVersion = (state) => selectState(state).welcomeVersion;
|
|
export const selectHasNavigated = (state) => selectState(state).hasNavigated;
|
|
export const selectAllowAnalytics = (state) => selectState(state).allowAnalytics;
|
|
export const selectScrollStartingPosition = (state) => selectState(state).currentScroll;
|
|
export const selectIsPasswordSaved = (state) => selectState(state).isPasswordSaved;
|
|
export const selectInterestedInYoutubeSync = (state) => selectState(state).interestedInYoutubeSync;
|
|
export const selectSplashAnimationEnabled = (state) => selectState(state).splashAnimationEnabled;
|
|
export const selectActiveChannelId = (state) => selectState(state).activeChannel;
|
|
|
|
export const selectActiveChannelClaim = createSelector(
|
|
(state) => selectClaimWithId(state, selectActiveChannelId(state)), // i.e. 'byId[activeChannelId]' specifically, instead of just 'byId'.
|
|
(state) => selectUserEmail(state),
|
|
(state) => selectClaimWithId(state, selectClientSetting(state, SETTINGS.ACTIVE_CHANNEL_CLAIM)),
|
|
selectMyChannelClaims,
|
|
(activeChannelClaim, userEmail, storedChannel, myChannelClaims) => {
|
|
// Null: has none. Undefined: not resolved, default state, could have or not
|
|
if (!userEmail || myChannelClaims === null) {
|
|
return null;
|
|
} else if (!myChannelClaims || !myChannelClaims.length) {
|
|
return undefined;
|
|
}
|
|
|
|
if (activeChannelClaim) return activeChannelClaim;
|
|
|
|
if (storedChannel) return storedChannel;
|
|
|
|
const myChannelClaimsByEffectiveAmount = myChannelClaims.slice().sort((a, b) => {
|
|
const effectiveAmountA = (a.meta && Number(a.meta.effective_amount)) || 0;
|
|
const effectiveAmountB = (b.meta && Number(b.meta.effective_amount)) || 0;
|
|
if (effectiveAmountA === effectiveAmountB) {
|
|
return 0;
|
|
} else if (effectiveAmountA > effectiveAmountB) {
|
|
return -1;
|
|
} else {
|
|
return 1;
|
|
}
|
|
});
|
|
|
|
return myChannelClaimsByEffectiveAmount[0];
|
|
}
|
|
);
|
|
|
|
export const selectActiveChannelStakedLevel = (state) => {
|
|
const activeChannelClaim = selectActiveChannelClaim(state);
|
|
if (!activeChannelClaim) {
|
|
return 0;
|
|
}
|
|
|
|
const uri = activeChannelClaim.permanent_url;
|
|
return selectStakedLevelForChannelUri(state, uri);
|
|
};
|
|
|
|
export const selectIncognito = (state) => selectState(state).incognito;
|
|
|
|
export const selectAdBlockerFound = (state) => selectState(state).adBlockerFound;
|
|
export const selectAppDrawerOpen = (state) => selectState(state).appDrawerOpen;
|