Skip to content

Commit

Permalink
explorer: Optimize auto re-renders of relative times
Browse files Browse the repository at this point in the history
- avoid extra re-renders
- re-render only the needed bits
- add `RelativeTime` component to abstract the logic
- add option to avoid re-renders in `Rerender` when the content is the same

Resolves #2059
  • Loading branch information
ascartabelli committed Aug 5, 2024
1 parent fa4ebf1 commit 916c1ef
Show file tree
Hide file tree
Showing 36 changed files with 1,012 additions and 457 deletions.
2 changes: 2 additions & 0 deletions explorer/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Update Statistics Panel separator lines color [#2039]
- Update Statistics Panel labels for clarity [#2034]
- Update font-display to swap for custom fonts to improve performance [#2025]
- Optimize auto re-renders of relative times [#2059]

## [0.1.0] - 2024-07-24

Expand All @@ -34,6 +35,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
[#2036]: https://github.com/dusk-network/rusk/issues/2036
[#2037]: https://github.com/dusk-network/rusk/issues/2037
[#2039]: https://github.com/dusk-network/rusk/issues/2039
[#2059]: https://github.com/dusk-network/rusk/issues/2059

<!-- VERSIONS -->

Expand Down
44 changes: 42 additions & 2 deletions explorer/src/lib/components/__tests__/BlocksList.spec.js
Original file line number Diff line number Diff line change
@@ -1,14 +1,27 @@
import { afterAll, afterEach, describe, expect, it, vi } from "vitest";
import { cleanup, render } from "@testing-library/svelte";
import { BlocksList } from "..";
import { setPathIn } from "lamb";

import { gqlBlock } from "$lib/mock-data";
import { transformBlock } from "$lib/chain-info";

import { BlocksList } from "..";

/** @param {HTMLElement} container */
function getTimeElement(container) {
return /** @type {HTMLTimeElement} */ (container.querySelector("time"));
}

describe("Blocks List", () => {
vi.useFakeTimers();
vi.setSystemTime(new Date(2024, 4, 20));

const baseProps = { data: transformBlock(gqlBlock.block) };
const block = transformBlock(gqlBlock.block);

/** @type {import("svelte").ComponentProps<BlocksList>} */
const baseProps = { data: block };

const timeRefreshInterval = 1000;

afterEach(cleanup);

Expand All @@ -21,4 +34,31 @@ describe("Blocks List", () => {

expect(container.firstChild).toMatchSnapshot();
});

it("should auto-refresh relative times when the related prop is set to true", async () => {
const props = {
...baseProps,
data: setPathIn(block, "header.date", new Date()),
};
const { container, rerender } = render(BlocksList, props);
const timeElement = getTimeElement(container);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"now"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval * 3);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"now"`);

await rerender({ ...props, autoRefreshTime: true });

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"3 seconds ago"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"4 seconds ago"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"5 seconds ago"`);
});
});
18 changes: 0 additions & 18 deletions explorer/src/lib/components/__tests__/Rerender.spec.js

This file was deleted.

45 changes: 43 additions & 2 deletions explorer/src/lib/components/__tests__/TransactionsList.spec.js
Original file line number Diff line number Diff line change
@@ -1,19 +1,30 @@
import { afterAll, afterEach, describe, expect, it, vi } from "vitest";
import { cleanup, render } from "@testing-library/svelte";
import { TransactionsList } from "..";

import { gqlTransaction } from "$lib/mock-data";
import { transformTransaction } from "$lib/chain-info";

import { TransactionsList } from "..";

/** @param {HTMLElement} container */
function getTimeElement(container) {
return /** @type {HTMLTimeElement} */ (container.querySelector("time"));
}

describe("Transactions List", () => {
vi.useFakeTimers();
vi.setSystemTime(new Date(2024, 4, 20));

const transaction = transformTransaction(gqlTransaction.tx);

/** @type {import("svelte").ComponentProps<TransactionsList>} */
const baseProps = {
data: transformTransaction(gqlTransaction.tx),
data: transaction,
mode: "full",
};

const timeRefreshInterval = 1000;

afterEach(cleanup);

afterAll(() => {
Expand All @@ -36,4 +47,34 @@ describe("Transactions List", () => {

expect(container.firstChild).toMatchSnapshot();
});

it("should auto-refresh relative times when the related prop is set to true", async () => {
const props = {
...baseProps,
data: {
...transaction,
date: new Date(),
},
};
const { container, rerender } = render(TransactionsList, props);
const timeElement = getTimeElement(container);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"now"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval * 3);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"now"`);

await rerender({ ...props, autoRefreshTime: true });

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"3 seconds ago"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"4 seconds ago"`);

await vi.advanceTimersByTimeAsync(timeRefreshInterval);

expect(timeElement.innerHTML).toMatchInlineSnapshot(`"5 seconds ago"`);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -140,13 +140,12 @@ exports[`Block Details > renders the Block Details component 1`] = `
class="details-list__definition"
>
<time
class="block-details__list-timestamp"
class="dusk-relative-time block-details__list-timestamp"
datetime="2024-04-16T20:07:02.000Z"
slot="definition"
>
Tue, 16 Apr 2024 20:07:02 GMT (last month)
</time>
</dd>
<dt
Expand Down
Loading

0 comments on commit 916c1ef

Please sign in to comment.