2020-01-24 16:28:47 +00:00
|
|
|
// @flow
|
|
|
|
|
2021-01-26 08:33:31 +00:00
|
|
|
import { toState } from '../base/redux';
|
2020-03-09 11:54:54 +00:00
|
|
|
import { CHAT_SIZE } from '../chat/constants';
|
|
|
|
|
2020-01-24 16:28:47 +00:00
|
|
|
import { SET_HORIZONTAL_VIEW_DIMENSIONS, SET_TILE_VIEW_DIMENSIONS } from './actionTypes';
|
|
|
|
import { calculateThumbnailSizeForHorizontalView, calculateThumbnailSizeForTileView } from './functions';
|
|
|
|
|
|
|
|
/**
|
2020-12-17 13:38:14 +00:00
|
|
|
* The size of the side margins for the entire tile view area.
|
2020-01-24 16:28:47 +00:00
|
|
|
*/
|
2020-12-17 13:38:14 +00:00
|
|
|
const TILE_VIEW_SIDE_MARGINS = 20;
|
2020-01-24 16:28:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the dimensions of the tile view grid.
|
|
|
|
*
|
|
|
|
* @param {Object} dimensions - Whether the filmstrip is visible.
|
|
|
|
* @param {Object} windowSize - The size of the window.
|
2021-01-26 08:33:31 +00:00
|
|
|
* @param {Object | Function} stateful - An object or function that can be
|
|
|
|
* resolved to Redux state using the {@code toState} function.
|
2020-01-24 16:28:47 +00:00
|
|
|
* @returns {{
|
|
|
|
* type: SET_TILE_VIEW_DIMENSIONS,
|
|
|
|
* dimensions: Object
|
|
|
|
* }}
|
|
|
|
*/
|
2021-01-26 08:33:31 +00:00
|
|
|
export function setTileViewDimensions(dimensions: Object, windowSize: Object, stateful: Object | Function) {
|
|
|
|
const state = toState(stateful);
|
2020-03-09 11:54:54 +00:00
|
|
|
const { clientWidth, clientHeight } = windowSize;
|
2020-12-17 13:38:14 +00:00
|
|
|
const heightToUse = clientHeight;
|
2020-03-09 11:54:54 +00:00
|
|
|
let widthToUse = clientWidth;
|
2021-01-26 08:33:31 +00:00
|
|
|
const { isOpen } = state['features/chat'];
|
|
|
|
const { disableResponsiveTiles } = state['features/base/config'];
|
2020-03-09 11:54:54 +00:00
|
|
|
|
2021-01-26 08:33:31 +00:00
|
|
|
if (isOpen) {
|
2020-03-09 11:54:54 +00:00
|
|
|
widthToUse -= CHAT_SIZE;
|
|
|
|
}
|
|
|
|
|
2020-01-24 16:28:47 +00:00
|
|
|
const thumbnailSize = calculateThumbnailSizeForTileView({
|
|
|
|
...dimensions,
|
2020-03-09 11:54:54 +00:00
|
|
|
clientWidth: widthToUse,
|
2021-01-26 08:33:31 +00:00
|
|
|
clientHeight: heightToUse,
|
|
|
|
disableResponsiveTiles
|
2020-01-24 16:28:47 +00:00
|
|
|
});
|
|
|
|
const filmstripWidth = dimensions.columns * (TILE_VIEW_SIDE_MARGINS + thumbnailSize.width);
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: SET_TILE_VIEW_DIMENSIONS,
|
|
|
|
dimensions: {
|
|
|
|
gridDimensions: dimensions,
|
|
|
|
thumbnailSize,
|
|
|
|
filmstripWidth
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the dimensions of the thumbnails in horizontal view.
|
|
|
|
*
|
|
|
|
* @param {number} clientHeight - The height of the window.
|
|
|
|
* @returns {{
|
|
|
|
* type: SET_HORIZONTAL_VIEW_DIMENSIONS,
|
|
|
|
* dimensions: Object
|
|
|
|
* }}
|
|
|
|
*/
|
|
|
|
export function setHorizontalViewDimensions(clientHeight: number = 0) {
|
|
|
|
return {
|
|
|
|
type: SET_HORIZONTAL_VIEW_DIMENSIONS,
|
|
|
|
dimensions: calculateThumbnailSizeForHorizontalView(clientHeight)
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export * from './actions.native';
|