2018-02-12 17:42:38 +00:00
|
|
|
// @flow
|
|
|
|
|
2022-05-06 10:18:57 +00:00
|
|
|
import conferenceStyles from '../conference/components/native/styles';
|
2021-08-20 23:32:38 +00:00
|
|
|
|
2021-08-23 23:02:41 +00:00
|
|
|
import { SET_TILE_VIEW_DIMENSIONS } from './actionTypes';
|
2022-05-06 10:18:57 +00:00
|
|
|
import { styles } from './components';
|
2021-08-20 23:32:38 +00:00
|
|
|
import { SQUARE_TILE_ASPECT_RATIO, TILE_MARGIN } from './constants';
|
2022-05-06 10:18:57 +00:00
|
|
|
import { getColumnCount } from './functions';
|
|
|
|
import { getTileViewParticipantCount } from './functions.native';
|
2017-05-23 18:58:07 +00:00
|
|
|
|
2021-08-23 23:02:41 +00:00
|
|
|
export * from './actions.any';
|
2020-07-15 20:30:44 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the dimensions of the tile view grid. The action is only partially implemented on native as not all
|
|
|
|
* of the values are currently used. Check the description of {@link SET_TILE_VIEW_DIMENSIONS} for the full set
|
|
|
|
* of properties.
|
|
|
|
*
|
2021-08-20 23:32:38 +00:00
|
|
|
* @returns {Function}
|
2020-07-15 20:30:44 +00:00
|
|
|
*/
|
2021-08-20 23:32:38 +00:00
|
|
|
export function setTileViewDimensions() {
|
|
|
|
return (dispatch: Function, getState: Function) => {
|
|
|
|
const state = getState();
|
2022-05-06 10:18:57 +00:00
|
|
|
const participantCount = getTileViewParticipantCount(state);
|
|
|
|
const { clientHeight: height, clientWidth: width, safeAreaInsets = {} } = state['features/base/responsive-ui'];
|
|
|
|
const { left = 0, right = 0, top = 0, bottom = 0 } = safeAreaInsets;
|
2021-08-20 23:32:38 +00:00
|
|
|
const columns = getColumnCount(state);
|
2022-05-06 10:18:57 +00:00
|
|
|
const rows = Math.ceil(participantCount / columns);
|
|
|
|
const conferenceBorder = conferenceStyles.conference.borderWidth || 0;
|
|
|
|
const heightToUse = height - top - (2 * conferenceBorder);
|
|
|
|
const widthToUse = width - (TILE_MARGIN * 2) - left - right - (2 * conferenceBorder);
|
2021-08-20 23:32:38 +00:00
|
|
|
let tileWidth;
|
|
|
|
|
|
|
|
// If there is going to be at least two rows, ensure that at least two
|
|
|
|
// rows display fully on screen.
|
2022-05-06 10:18:57 +00:00
|
|
|
if (rows / columns > 1) {
|
2021-08-20 23:32:38 +00:00
|
|
|
tileWidth = Math.min(widthToUse / columns, heightToUse / 2);
|
|
|
|
} else {
|
|
|
|
tileWidth = Math.min(widthToUse / columns, heightToUse);
|
2020-07-15 20:30:44 +00:00
|
|
|
}
|
2021-08-20 23:32:38 +00:00
|
|
|
|
|
|
|
const tileHeight = Math.floor(tileWidth / SQUARE_TILE_ASPECT_RATIO);
|
|
|
|
|
|
|
|
tileWidth = Math.floor(tileWidth);
|
|
|
|
|
2022-05-06 10:18:57 +00:00
|
|
|
// Adding safeAreaInsets.bottom to the total height of all thumbnails because we add it as a padding to the
|
|
|
|
// thumbnails container.
|
|
|
|
const hasScroll = heightToUse < ((tileHeight + (2 * styles.thumbnail.margin)) * rows) + bottom;
|
2021-08-20 23:32:38 +00:00
|
|
|
|
|
|
|
dispatch({
|
|
|
|
type: SET_TILE_VIEW_DIMENSIONS,
|
|
|
|
dimensions: {
|
|
|
|
columns,
|
|
|
|
thumbnailSize: {
|
|
|
|
height: tileHeight,
|
|
|
|
width: tileWidth
|
2022-05-06 10:18:57 +00:00
|
|
|
},
|
|
|
|
hasScroll
|
2021-08-20 23:32:38 +00:00
|
|
|
}
|
|
|
|
});
|
2020-07-15 20:30:44 +00:00
|
|
|
};
|
|
|
|
}
|