Skip to content

Commit

Permalink
Fix grid caching (#5200)
Browse files Browse the repository at this point in the history
* clear stale lookers

* simplify spotlight render state, filter duplicated ids for linked reversals

* lint render

* rm noop
  • Loading branch information
benjaminpkane authored Dec 2, 2024
1 parent 4937680 commit e3e7cba
Show file tree
Hide file tree
Showing 6 changed files with 28 additions and 29 deletions.
8 changes: 3 additions & 5 deletions app/packages/core/src/components/Grid/Grid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,11 +70,9 @@ function Grid() {
retainItems: true,
rowAspectRatioThreshold: threshold,
get: (next) => page(next),
render: (id, element, dimensions, soft, hide) => {
render: (id, element, dimensions, zooming) => {
if (lookerStore.has(id.description)) {
const looker = lookerStore.get(id.description);
hide ? looker?.disable() : looker?.attach(element, dimensions);

lookerStore.get(id.description)?.attach(element, dimensions);
return;
}

Expand All @@ -84,7 +82,7 @@ function Grid() {
throw new Error("bad data");
}

if (soft) {
if (zooming) {
// we are scrolling fast, skip creation
return;
}
Expand Down
1 change: 0 additions & 1 deletion app/packages/core/src/components/Grid/useRefreshers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import { useRecoilValue } from "recoil";
import { gridAt, gridOffset, gridPage } from "./recoil";

const MAX_LRU_CACHE_ITEMS = 510;
const MAX_LRU_CACHE_SIZE = 1e9;

export default function useRefreshers() {
const cropToContent = useRecoilValue(fos.cropToContent(false));
Expand Down
14 changes: 13 additions & 1 deletion app/packages/core/src/components/Grid/useSelect.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,25 @@ export default function useSelect(
useEffect(() => {
deferred(() => {
const fontSize = getFontSize();
const retained = new Set<string>();
spotlight?.updateItems((id) => {
store.get(id.description)?.updateOptions({
const instance = store.get(id.description);
if (!instance) {
return;
}

retained.add(id.description);
instance.updateOptions({
...options,
fontSize,
selected: selected.has(id.description),
});
});

for (const id of store.keys()) {
if (retained.has(id)) continue;
store.delete(id);
}
});
}, [deferred, getFontSize, options, selected, spotlight, store]);

Expand Down
12 changes: 2 additions & 10 deletions app/packages/spotlight/src/row.ts
Original file line number Diff line number Diff line change
Expand Up @@ -147,18 +147,10 @@ export default class Row<K, V> {

show(
element: HTMLDivElement,
hidden: boolean,
attr: typeof BOTTOM | typeof TOP,
soft: boolean,
zooming: boolean,
config: SpotlightConfig<K, V>
): void {
if (hidden !== this.#hidden) {
hidden
? this.#container.classList.add(styles.spotlightRowHidden)
: this.#container.classList.remove(styles.spotlightRowHidden);
this.#hidden = hidden;
}

if (!this.attached) {
this.#container.style[attr] = `${this.#from}px`;
this.#container.style[attr === BOTTOM ? TOP : BOTTOM] = UNSET;
Expand All @@ -171,7 +163,7 @@ export default class Row<K, V> {

for (const { element, item } of this.#row) {
const width = item.aspectRatio * this.height;
config.render(item.id, element, [width, this.height], soft, hidden);
config.render(item.id, element, [width, this.height], zooming);
}
}

Expand Down
19 changes: 9 additions & 10 deletions app/packages/spotlight/src/section.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,8 @@ export default class Section<K, V> {
readonly #width: number;

#direction: DIRECTION;
#dirty: Set<Row<K, V>> = new Set();
#end: Edge<K, V>;
#itemIds = new Set<string>();
#nextMap: WeakMap<ID, ID> = new WeakMap();
#previousMap: WeakMap<ID, ID> = new WeakMap();
#shown: Set<Row<K, V>> = new Set();
Expand Down Expand Up @@ -129,7 +129,6 @@ export default class Section<K, V> {
target,
threshold,
top,
updater,
zooming,
}: {
config: SpotlightConfig<K, V>;
Expand Down Expand Up @@ -181,14 +180,8 @@ export default class Section<K, V> {
break;
}

if (this.#dirty.has(row) && !zooming && updater) {
row.updateItems(updater);
this.#dirty.delete(row);
}

row.show(
this.#container,
this.#dirty.has(row) && zooming,
this.#direction === DIRECTION.FORWARD ? TOP : BOTTOM,
zooming,
config
Expand Down Expand Up @@ -225,7 +218,6 @@ export default class Section<K, V> {

updateItems(updater: (id: ID) => void) {
for (const row of this.#shown) row.updateItems(updater);
for (const row of this.#rows) !this.#shown.has(row) && this.#dirty.add(row);
}

async first(
Expand Down Expand Up @@ -308,7 +300,9 @@ export default class Section<K, V> {

renderer(() => {
const { rows, remainder } = this.#tile(
[...end.remainder, ...data.items],
[...end.remainder, ...data.items].filter(
(i) => !this.#itemIds.has(i.id.description)
),
this.#height,
data.next === null,
data.focus,
Expand Down Expand Up @@ -350,6 +344,7 @@ export default class Section<K, V> {
edge: newEnd,
width: this.#width,
});

this.#end = this.#start;
this.#start = newEnd;

Expand Down Expand Up @@ -452,6 +447,10 @@ export default class Section<K, V> {
rowItems.reverse();
}

for (const i of rowItems) {
this.#itemIds.add(i.id.description);
}

const row = new Row({
config: this.#config,
dangle:
Expand Down
3 changes: 1 addition & 2 deletions app/packages/spotlight/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,8 +38,7 @@ export type Render = (
id: ID,
element: HTMLDivElement,
dimensions: [number, number],
soft: boolean,
disable: boolean
zooming: boolean
) => void;

export interface Response<K, V> {
Expand Down

0 comments on commit e3e7cba

Please sign in to comment.