Merge branch 'grid-interactions' into livekit-experiment
This commit is contained in:
commit
ae5b1a367d
2 changed files with 32 additions and 0 deletions
|
@ -49,6 +49,7 @@ import {
|
||||||
addItems,
|
addItems,
|
||||||
tryMoveTile,
|
tryMoveTile,
|
||||||
resize,
|
resize,
|
||||||
|
promoteSpeakers,
|
||||||
} from "./model";
|
} from "./model";
|
||||||
import { TileWrapper } from "./TileWrapper";
|
import { TileWrapper } from "./TileWrapper";
|
||||||
|
|
||||||
|
@ -99,6 +100,9 @@ const useGridState = (
|
||||||
const newItems = items.filter((i) => !existingItemIds.has(i.id));
|
const newItems = items.filter((i) => !existingItemIds.has(i.id));
|
||||||
const grid3 = addItems(newItems, grid2);
|
const grid3 = addItems(newItems, grid2);
|
||||||
|
|
||||||
|
// Step 4: Promote speakers to the top
|
||||||
|
promoteSpeakers(grid3);
|
||||||
|
|
||||||
return { ...grid3, generation: prevGrid.generation + 1 };
|
return { ...grid3, generation: prevGrid.generation + 1 };
|
||||||
},
|
},
|
||||||
[columns, items]
|
[columns, items]
|
||||||
|
|
|
@ -668,3 +668,31 @@ export function resize(g: Grid, columns: number): Grid {
|
||||||
|
|
||||||
return fillGaps(result);
|
return fillGaps(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Promotes speakers to the first page of the grid.
|
||||||
|
*/
|
||||||
|
export function promoteSpeakers(g: Grid) {
|
||||||
|
// This is all a bit of a hack right now, because we don't know if the designs
|
||||||
|
// will stick with this approach in the long run
|
||||||
|
// We assume that 4 rows are probably about 1 page
|
||||||
|
const firstPageEnd = g.columns * 4;
|
||||||
|
|
||||||
|
for (let from = firstPageEnd; from < g.cells.length; from++) {
|
||||||
|
const fromCell = g.cells[from];
|
||||||
|
// Don't bother trying to promote enlarged tiles
|
||||||
|
if (
|
||||||
|
fromCell?.item.isSpeaker &&
|
||||||
|
fromCell.columns === 1 &&
|
||||||
|
fromCell.rows === 1
|
||||||
|
) {
|
||||||
|
// Promote this tile by making 10 attempts to place it on the first page
|
||||||
|
for (let j = 0; j < 10; j++) {
|
||||||
|
const to = Math.floor(Math.random() * firstPageEnd);
|
||||||
|
const toCell = g.cells[to];
|
||||||
|
if (toCell === undefined || (toCell.columns === 1 && toCell.rows === 1))
|
||||||
|
moveTile(g, from, to);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue