Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: Bump Preact version #490

Merged
merged 5 commits into from
Oct 7, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 5 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,8 @@
"dev:serve": "vite test-e2e/fixtures --port 8100",
"run:chrome": "node tools/build.mjs --browser chrome --debug && mkdir -p ./profiles/chrome && node tools/run-chrome.js",
"run:firefox": "node tools/build.mjs --browser firefox --debug && mkdir -p ./profiles/firefox && web-ext run --source-dir ./dist/firefox-debug/ --start-url https://preactjs.com --firefox-profile=./profiles/firefox --keep-profile-changes",
"release": "node tools/release.js"
"release": "node tools/release.js",
"postinstall": "patch-package"
},
"repository": {
"type": "git",
Expand Down Expand Up @@ -79,8 +80,10 @@
"lint-staged": "^10.4.0",
"mochette": "^1.0.1",
"mri": "^1.2.0",
"patch-package": "^8.0.0",
"playwright-chromium": "^1.28.0",
"preact": "^10.10.6",
"postinstall-postinstall": "^2.1.0",
"preact": "^10.24.1",
"prettier": "^3.2.5",
"tar": "^6.1.11",
"ts-node": "^10.9.2",
Expand Down
16 changes: 16 additions & 0 deletions patches/preact+10.24.1.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
diff --git a/node_modules/preact/src/internal.d.ts b/node_modules/preact/src/internal.d.ts
index 60e8d63..96fc2db 100644
--- a/node_modules/preact/src/internal.d.ts
+++ b/node_modules/preact/src/internal.d.ts
@@ -1,6 +1,5 @@
import * as preact from './index';

-declare global {
export enum HookType {
useState = 1,
useReducer = 2,
@@ -191,4 +190,3 @@ declare global {
_id: string;
_defaultValue: any;
}
-}
2 changes: 2 additions & 0 deletions src/adapter/shared/serialize.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -78,11 +78,13 @@ describe("cleanProps", () => {
});

it("should filter out __source", () => {
// @ts-expect-error
const vnode = h("div", { __source: "foo", foo: 1 });
expect(cleanProps(vnode.props)).to.deep.equal({ foo: 1 });
});

it("should filter out __self", () => {
// @ts-expect-error
const vnode = h("div", { __self: "foo", foo: 1 });
expect(cleanProps(vnode.props)).to.deep.equal({ foo: 1 });
});
Expand Down
54 changes: 27 additions & 27 deletions src/view/components/devtools.css
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@
z-index: 2;
}

.icon-btn:not([disabled])[data-active] .icon-btn-inner,
.icon-btn:not([disabled])[data-active="true"] .icon-btn-inner,
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Helpful ripgrep pattern: $ rg 'data-[\w-]+]'

.icon-btn:focus .icon-btn-inner,
.icon-btn:not([disabled]):active .icon-btn-inner {
color: var(--color-selected-text);
Expand All @@ -184,7 +184,7 @@
z-index: -1;
}

.icon-btn:not([disabled])[data-active] .icon-btn-bg {
.icon-btn:not([disabled])[data-active="true"] .icon-btn-bg {
display: block;
content: "";
position: absolute;
Expand Down Expand Up @@ -299,34 +299,34 @@
white-space: nowrap;
}

.tree-view:focus-within .tree-view-item[data-selected] {
.tree-view:focus-within .tree-view-item[data-selected="true"] {
background: var(--color-selected-bg);
color: var(--color-selected-text);
}

.tree-view:focus-within .tree-view-item[data-selected] :global(.hoc-item) {
.tree-view:focus-within .tree-view-item[data-selected="true"] :global(.hoc-item) {
background: var(--color-hoc-selected-bg);
color: var(--color-hoc-selected-text);
}

.tree-view:focus-within .tree-view-item[data-selected]::after {
.tree-view:focus-within .tree-view-item[data-selected="true"]::after {
background: var(--color-selected-bg);
}

.tree-view .tree-view-item[data-selected]::after {
.tree-view .tree-view-item[data-selected="true"]::after {
background: var(--color-selected-inactive-bg);
}

.tree-view-item[data-selected] {
.tree-view-item[data-selected="true"] {
background: var(--color-selected-inactive-bg);
color: var(--color-selected-inactive-text);
}

.tree-view-item:not([data-selected]):hover {
.tree-view-item:not([data-selected="true"]):hover {
background: var(--color-hover);
}

.tree-view-item:not([data-selected]):hover::after {
.tree-view-item:not([data-selected="true"]):hover::after {
background: var(--color-hover);
}

Expand Down Expand Up @@ -354,11 +354,11 @@
transition: transform 0.3s;
}

.tree-view-item[data-selected] .tree-view-collapse {
.tree-view-item[data-selected="true"] .tree-view-collapse {
color: var(--color-toggle-selected);
}

[data-collapsed].tree-view-collapse svg {
[data-collapsed="true"].tree-view-collapse svg {
transform: rotate(-90deg);
}

Expand Down Expand Up @@ -389,29 +389,29 @@
color: var(--color-key-label);
}

.tree-view:not(:focus-within) [data-selected] .tree-view-key-label {
.tree-view:not(:focus-within) [data-selected="true"] .tree-view-key-label {
color: var(--color-key-label-selected-no-focus);
}
.tree-view:focus-within [data-selected] .tree-view-key-label {
.tree-view:focus-within [data-selected="true"] .tree-view-key-label {
color: var(--color-key-label-selected);
}

.tree-view-key {
color: var(--color-key-value);
}

.tree-view:not(:focus-within) [data-selected] .tree-view-key {
.tree-view:not(:focus-within) [data-selected="true"] .tree-view-key {
color: var(--color-key-value-selected);
}
.tree-view:focus-within [data-selected] .tree-view-key {
.tree-view:focus-within [data-selected="true"] .tree-view-key {
color: var(--color-key-value-selected-focus);
}

/* Marker */
.mark {
background: var(--color-marker);
}
.mark[data-marked] {
.mark[data-marked="true"] {
background: var(--color-marker-selected);
}

Expand Down Expand Up @@ -452,7 +452,7 @@
.rendered-at-item:hover {
background: var(--color-dim-bg);
}
.rendered-at-item[data-active] {
.rendered-at-item[data-active="true"] {
color: var(--color-selected-text);
background: var(--color-selected-bg);
}
Expand Down Expand Up @@ -704,7 +704,7 @@
margin-left: 0.1rem;
}

.commit-timeline-item[data-selected]::after {
.commit-timeline-item[data-selected="true"]::after {
content: "";
height: 0.1875rem;
width: 100%;
Expand Down Expand Up @@ -1013,46 +1013,46 @@
background: var(--color-profiler-old);
}

.flamegraph-node[data-overflow] .flamegraph-text {
.flamegraph-node[data-overflow="true"] .flamegraph-text {
display: none;
}

.flamegraph-node[data-visible] {
.flamegraph-node[data-visible="true"] {
transition-property: all;
}
.flamegraph-node:not([data-visible]) {
.flamegraph-node:not([data-visible="true"]) {
transition-property: opacity;
transition-duration: 0.2s;
opacity: 0;
pointer-events: none;
}
.flamegraph-node[data-visible]:not([data-maximized]) {
.flamegraph-node[data-visible="true"]:not([data-maximized="true"]) {
opacity: 1;
}

.flamegraph-node[data-weight="-1"]:not([data-commit-parent]) {
.flamegraph-node[data-weight="-1"]:not([data-commit-parent="true"]) {
color: var(--color-bystander-text);
}
.flamegraph-node[data-weight="-1"]:not([data-commit-parent])::after {
.flamegraph-node[data-weight="-1"]:not([data-commit-parent="true"])::after {
/* inline-pattern */
background-image: url("");
background-repeat: repeat;
background-color: transparent;
background-size: 0.25rem 0.25rem;
}

.flamegraph-node[data-weight="-1"]:not([data-commit-parent])
.flamegraph-node[data-weight="-1"]:not([data-commit-parent="true"])
[data-testid="hoc-labels"]
> * {
background: var(--color-hoc-not-rendered);
}

:global(.dark)
.flamegraph-node[data-weight="-1"]:not([data-commit-parent])::after {
.flamegraph-node[data-weight="-1"]:not([data-commit-parent="true"])::after {
opacity: 0.5;
}

.flamegraph-node[data-maximized][data-visible]:not([data-selected]) {
.flamegraph-node[data-maximized="true"][data-visible="true"]:not([data-selected="true"]) {
opacity: 0.5;
}

Expand Down
2 changes: 1 addition & 1 deletion src/view/components/elements/TreeBar.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
color: var(--color-text);
}

.btnIcon[data-active] {
.btnIcon[data-active="true"] {
color: var(--color-button-active);
color: var(--color-button-active);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ function calcSize(
viewport - selOffset - (selected < count - 1 ? itemWidth / 2 : 0),
paneWidth - viewport,
// eslint-disable-next-line no-mixed-spaces-and-tabs
)
)
: 0;

paneContainer.current.style.width = org;
Expand Down Expand Up @@ -93,7 +93,7 @@ export function CommitTimeline(props: CommitTimelineProps) {

useEffect(() => {
if (pane.current) {
const active = pane.current.querySelector("[data-selected]");
const active = pane.current.querySelector('[data-selected="true"]');
// JSDOM doesn't support scrollIntoView
if (active && active.scrollIntoView) active.scrollIntoView();
}
Expand Down
8 changes: 6 additions & 2 deletions test-e2e/fixtures/apps/islands-order-virtual.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ function createRootFragment(parent, replaceNode) {
removeChild: function (c) {
parent.removeChild(c);
},
contains: function (c) {
return parent.contains(c);
},
});
}

Expand All @@ -38,7 +41,8 @@ const Virtual1 = () => <h1>Virtual1</h1>;
const Virtual2 = () => <h1>Virtual2</h1>;

render(<App2 />, app2);
render(<Virtual1 />, createRootFragment(app2, app2.children));
render(<Virtual2 />, createRootFragment(app2, app2.children));
render(<Virtual1 />, createRootFragment(app2, app2.children[0]));

render(<Virtual2 />, createRootFragment(app2, app2.children[0]));
render(<App3 />, app3);
render(<App1 />, app);
2 changes: 1 addition & 1 deletion test-e2e/tests/inspect-select.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ test("Should inspect during picking", async ({ page }) => {
// Should select new node in element tree
await page.click(target);
active = await devtools.locator(inspect).getAttribute("data-active");
expect(active).toEqual(null);
expect(active).toEqual("false");

// ...and display the newly inspected data
await expect(devtools.locator(prop)).toHaveCount(1);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ test("Not rendered nodes that are not parents of the current commit should be st
.allTextContents();
expect(nodes.map(n => n.split(" ")[0])).toEqual(["Counter", "Display"]);
nodes = await devtools
.locator('[data-type="flamegraph"] [data-commit-parent]')
.locator('[data-type="flamegraph"] [data-commit-parent="true"]')
.allTextContents();
expect(nodes.map(n => n.split(" ")[0])).toEqual(["Fragment", "App"]);
});
4 changes: 2 additions & 2 deletions test-e2e/tests/profiler/flamegraph/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,12 @@ export async function getFlameNodes(page: Frame) {
return await page.$$eval(selector, els => {
return els.map(el => {
return {
maximized: el.hasAttribute("data-maximized"),
maximized: el.getAttribute("data-maximized") === "true",
name: el.getAttribute("data-name") || "",
hocs: Array.from(el.querySelectorAll(".hoc-item")).map(
el => el.textContent,
),
visible: el.hasAttribute("data-visible"),
visible: el.getAttribute("data-visible") === "true",
};
});
});
Expand Down
10 changes: 6 additions & 4 deletions test-e2e/tests/profiler/rendered-at.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,22 +32,24 @@ test("Show in which commit a node rendered", async ({ page }) => {
.evaluateAll(els =>
Array.from(els).map(el => el.getAttribute("data-selected")),
);
expect(commits).toEqual(["true", null, null, null]);
expect(commits).toEqual(["true", "false", "false", "false"]);

const btns = await devtools
.locator('[data-testid="rendered-at"] button')
.evaluateAll(els =>
Array.from(els).map(el => el.getAttribute("data-active")),
);

expect(btns).toEqual(["true", null]);
expect(btns).toEqual(["true", "false"]);

await devtools.click('[data-testid="rendered-at"] button:not([data-active])');
await devtools.click(
'[data-testid="rendered-at"] button:not([data-active="true"])',
);

commits = await devtools
.locator('[data-testid="commit-item"]')
.evaluateAll(els =>
Array.from(els).map(el => el.getAttribute("data-selected")),
);
expect(commits).toEqual([null, null, "true", null]);
expect(commits).toEqual(["false", "false", "true", "false"]);
});
4 changes: 3 additions & 1 deletion test-e2e/tests/sync-selection.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,7 @@ test("Sync selection from profiler", async ({ page }) => {
await devtools.click(locateFlame("Display"));

await devtools.click(locateTab("ELEMENTS"));
await devtools.locator('[data-selected]:has-text("Display")').waitFor();
await devtools
.locator('[data-selected="true"]:has-text("Display")')
.waitFor();
});
Loading
Loading