Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
bit-pm
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
燕伟桐
bit-pm
Commits
c069599d
Unverified
提交
c069599d
authored
5月 02, 2025
作者:
Will Chen
提交者:
GitHub
5月 02, 2025
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update iframe message to be strictly typed & preserve backwards compat (note:…
Update iframe message to be strictly typed & preserve backwards compat (note: add upgrade guide) (#70)
上级
18846946
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
21 行增加
和
6 行删除
+21
-6
PreviewIframe.tsx
src/components/preview_panel/PreviewIframe.tsx
+21
-6
没有找到文件。
src/components/preview_panel/PreviewIframe.tsx
浏览文件 @
c069599d
...
...
@@ -157,7 +157,20 @@ export const PreviewIframe = ({ loading }: { loading: boolean }) => {
return
;
}
const
{
type
,
payload
}
=
event
.
data
;
const
{
type
,
payload
}
=
event
.
data
as
{
type
:
|
"window-error"
|
"unhandled-rejection"
|
"iframe-sourcemapped-error"
|
"pushState"
|
"replaceState"
;
payload
?:
{
message
?:
string
;
stack
?:
string
;
reason
?:
string
;
newUrl
?:
string
;
};
};
if
(
type
===
"window-error"
||
...
...
@@ -166,9 +179,11 @@ export const PreviewIframe = ({ loading }: { loading: boolean }) => {
)
{
const
stack
=
type
===
"iframe-sourcemapped-error"
?
payload
.
stack
.
split
(
"
\
n"
).
slice
(
0
,
1
).
join
(
"
\
n"
)
:
payload
.
stack
;
const
errorMessage
=
`Error
${
payload
.
message
}
\nStack trace:
${
stack
}
`
;
?
payload
?.
stack
?.
split
(
"
\
n"
).
slice
(
0
,
1
).
join
(
"
\
n"
)
:
payload
?.
stack
;
const
errorMessage
=
`Error
${
payload
?.
message
||
payload
?.
reason
}
\
nStack
trace
:
$
{
stack
}
`;
console.error("Iframe error:", errorMessage);
setErrorMessage(errorMessage);
setAppOutput((prev) => [
...
...
@@ -184,7 +199,7 @@ export const PreviewIframe = ({ loading }: { loading: boolean }) => {
console
.
debug
(
`Navigation event:
${
type
}
`
,
payload
);
// Update navigation history based on the type of state change
if
(
type
===
"pushState"
)
{
if
(
type
===
"pushState"
&&
payload
?.
newUrl
)
{
// For pushState, we trim any forward history and add the new URL
const
newHistory
=
[
...
navigationHistory
.
slice
(
0
,
currentHistoryPosition
+
1
),
...
...
@@ -192,7 +207,7 @@ export const PreviewIframe = ({ loading }: { loading: boolean }) => {
];
setNavigationHistory
(
newHistory
);
setCurrentHistoryPosition
(
newHistory
.
length
-
1
);
}
else
if
(
type
===
"replaceState"
)
{
}
else
if
(
type
===
"replaceState"
&&
payload
?.
newUrl
)
{
// For replaceState, we replace the current URL
const
newHistory
=
[...
navigationHistory
];
newHistory
[
currentHistoryPosition
]
=
payload
.
newUrl
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论