File "selectors.js"

Full Path: /home/warrior1/public_html/plugins/jetpack/jetpack_vendor/automattic/jetpack-videopress/src/client/state/selectors.js
File size: 2.81 KB
MIME-type: text/plain
Charset: utf-8

export const getVideos = state => {
	return state?.videos?.items || [];
};

export const getUploadingVideos = state => {
	const items = state?.videos?._meta?.items || {};
	return Object.keys( items || {} )
		.map( id => ( { ...items[ id ], id } ) )
		.filter( item => item.uploading );
};

export const getVideosQuery = state => {
	return state?.videos?.query;
};

export const getPagination = state => {
	return state?.videos?.pagination;
};

export const getVideosFilter = state => {
	return state?.videos?.filter;
};

export const getUploadedVideoCount = state => {
	return state?.videos?.uploadedVideoCount;
};

export const getUploadedLocalVideoCount = state => {
	return state?.localVideos?.uploadedVideoCount;
};

export const getIsFetching = state => {
	return state?.videos?.isFetching;
};

export const getIsFetchingUploadedVideoCount = state => {
	return state?.videos?.isFetchingUploadedVideoCount;
};

export const getStorageUsed = state => {
	return {
		storageUsed: state?.videos?.storageUsed,
	};
};

// Single Video stuff
export const getVideo = ( state, id ) => {
	const videos = getVideos( state );
	const video = videos.find( ( { id: videoId } ) => videoId === id );
	return video;
};

export const getVideoStateMetadata = ( state, id ) => {
	const _metaItems = state?.videos?._meta?.items || {};
	const _metaVideo = _metaItems[ id ] || {};
	return _metaVideo;
};

export const isFetchingPurchases = state => {
	return state?.purchases?.isFetching;
};

export const getPurchases = state => {
	return state?.purchases?.items || [];
};

export const getLocalVideos = state => {
	return state?.localVideos?.items || [];
};

export const getIsFetchingLocalVideos = state => {
	return state?.localVideos?.isFetching;
};

export const getLocalVideosQuery = state => {
	return state?.localVideos?.query;
};

export const getLocalPagination = state => {
	return state?.localVideos?.pagination;
};

export const getUsers = state => {
	return state?.users?.items || [];
};

export const getUsersPagination = state => {
	return state?.users?.pagination;
};

export const getPlaybackToken = ( state, guid ) => {
	const tokens = state?.playbackTokens?.items || [];
	const token = tokens.find( t => t?.guid === guid );
	return token;
};

export const isFetchingPlaybackToken = state => {
	return state?.playbackTokens?.isFetching;
};

const selectors = {
	// VideoPress videos
	getVideos,
	getUploadingVideos,
	getVideosQuery,
	getPagination,
	getVideosFilter,
	getUploadedVideoCount,
	getIsFetching,
	getIsFetchingUploadedVideoCount,
	getStorageUsed,

	// Local videos
	getLocalVideos,
	getIsFetchingLocalVideos,
	getLocalVideosQuery,
	getLocalPagination,
	getUploadedLocalVideoCount,

	getVideo,
	getVideoStateMetadata,

	getUsers,
	getUsersPagination,

	getPurchases,
	isFetchingPurchases,

	getPlaybackToken,
	isFetchingPlaybackToken,
};

export default selectors;