Merge branch 'main' into feat/ext

This commit is contained in:
Simon
2026-01-22 15:31:07 +08:00
15 changed files with 61 additions and 43 deletions

View File

@@ -40,7 +40,7 @@
```html
<script
src="https://registry.npmmirror.com/page-agent/1.0.0-beta.4/files/dist/iife/page-agent.demo.js"
src="https://registry.npmmirror.com/page-agent/1.0.0-beta.5/files/dist/iife/page-agent.demo.js"
crossorigin="true"
></script>
```
@@ -50,8 +50,8 @@
| 镜像 | URL |
| ------ | ----------------------------------------------------------------------------------------- |
| Global | https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.4/dist/iife/page-agent.demo.js |
| China | https://registry.npmmirror.com/page-agent/1.0.0-beta.4/files/dist/iife/page-agent.demo.js |
| Global | https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.5/dist/iife/page-agent.demo.js |
| China | https://registry.npmmirror.com/page-agent/1.0.0-beta.5/files/dist/iife/page-agent.demo.js |
### NPM 安装

View File

@@ -40,7 +40,7 @@ Fastest way to try PageAgent with our free Demo LLM:
```html
<script
src="https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.4/dist/iife/page-agent.demo.js"
src="https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.5/dist/iife/page-agent.demo.js"
crossorigin="true"
></script>
```
@@ -50,8 +50,8 @@ Fastest way to try PageAgent with our free Demo LLM:
| Mirrors | URL |
| ------- | ----------------------------------------------------------------------------------------- |
| Global | https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.4/dist/iife/page-agent.demo.js |
| China | https://registry.npmmirror.com/page-agent/1.0.0-beta.4/files/dist/iife/page-agent.demo.js |
| Global | https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.5/dist/iife/page-agent.demo.js |
| China | https://registry.npmmirror.com/page-agent/1.0.0-beta.5/files/dist/iife/page-agent.demo.js |
### NPM Installation

28
package-lock.json generated
View File

@@ -1,12 +1,12 @@
{
"name": "root",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "root",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT",
"workspaces": [
"packages/page-controller",
@@ -11292,11 +11292,11 @@
},
"packages/core": {
"name": "@page-agent/core",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT",
"dependencies": {
"@page-agent/llms": "1.0.0-beta.4",
"@page-agent/page-controller": "1.0.0-beta.4",
"@page-agent/llms": "1.0.0-beta.5",
"@page-agent/page-controller": "1.0.0-beta.5",
"chalk": "^5.6.2",
"zod": "^4.3.5"
}
@@ -11348,7 +11348,7 @@
},
"packages/llms": {
"name": "@page-agent/llms",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT",
"dependencies": {
"chalk": "^5.6.2",
@@ -11356,20 +11356,20 @@
}
},
"packages/page-agent": {
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT",
"dependencies": {
"@page-agent/core": "1.0.0-beta.4",
"@page-agent/llms": "1.0.0-beta.4",
"@page-agent/page-controller": "1.0.0-beta.4",
"@page-agent/ui": "1.0.0-beta.4",
"@page-agent/core": "1.0.0-beta.5",
"@page-agent/llms": "1.0.0-beta.5",
"@page-agent/page-controller": "1.0.0-beta.5",
"@page-agent/ui": "1.0.0-beta.5",
"chalk": "^5.6.2",
"zod": "^4.3.5"
}
},
"packages/page-controller": {
"name": "@page-agent/page-controller",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT",
"dependencies": {
"ai-motion": "^0.4.8"
@@ -11377,12 +11377,12 @@
},
"packages/ui": {
"name": "@page-agent/ui",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"license": "MIT"
},
"packages/website": {
"name": "@page-agent/website",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"dependencies": {
"@radix-ui/react-icons": "^1.3.2",
"@radix-ui/react-separator": "^1.1.8",

View File

@@ -1,7 +1,7 @@
{
"name": "root",
"private": true,
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"workspaces": [
"packages/page-controller",

View File

@@ -1,7 +1,7 @@
{
"name": "@page-agent/core",
"private": false,
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"main": "./dist/esm/page-agent-core.js",
"module": "./dist/esm/page-agent-core.js",
@@ -45,7 +45,7 @@
"dependencies": {
"chalk": "^5.6.2",
"zod": "^4.3.5",
"@page-agent/llms": "1.0.0-beta.4",
"@page-agent/page-controller": "1.0.0-beta.4"
"@page-agent/llms": "1.0.0-beta.5",
"@page-agent/page-controller": "1.0.0-beta.5"
}
}

View File

@@ -99,8 +99,7 @@ export class PageAgentCore extends EventTarget {
this.emitActivity({ type: 'retrying', attempt, maxAttempts })
// Also push to history for panel rendering
this.history.push({
type: 'error',
errorType: 'retry',
type: 'retry',
message: `LLM retry attempt ${attempt} of ${maxAttempts}`,
attempt,
maxAttempts,
@@ -114,7 +113,6 @@ export class PageAgentCore extends EventTarget {
// Also push to history for panel rendering
this.history.push({
type: 'error',
errorType: 'error',
message,
rawResponse: (error as InvokeError).rawResponse,
})

View File

@@ -69,14 +69,21 @@ export interface UserTakeoverEvent {
}
/**
* Error event (retry or error from LLM)
* Retry event - LLM call is being retried
*/
export interface RetryEvent {
type: 'retry'
message: string
attempt: number
maxAttempts: number
}
/**
* Error event - fatal error from LLM or execution
*/
export interface AgentErrorEvent {
type: 'error'
errorType: 'retry' | 'error'
message: string
attempt?: number
maxAttempts?: number
rawResponse?: unknown
}
@@ -87,6 +94,7 @@ export type HistoricalEvent =
| AgentStepEvent
| ObservationEvent
| UserTakeoverEvent
| RetryEvent
| AgentErrorEvent
/**

View File

@@ -1,6 +1,6 @@
{
"name": "@page-agent/llms",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"main": "./dist/lib/page-agent-llms.js",
"module": "./dist/lib/page-agent-llms.js",

View File

@@ -1,7 +1,7 @@
{
"name": "page-agent",
"private": false,
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"main": "./dist/esm/page-agent.js",
"module": "./dist/esm/page-agent.js",
@@ -46,9 +46,9 @@
"dependencies": {
"chalk": "^5.6.2",
"zod": "^4.3.5",
"@page-agent/llms": "1.0.0-beta.4",
"@page-agent/page-controller": "1.0.0-beta.4",
"@page-agent/core": "1.0.0-beta.4",
"@page-agent/ui": "1.0.0-beta.4"
"@page-agent/llms": "1.0.0-beta.5",
"@page-agent/page-controller": "1.0.0-beta.5",
"@page-agent/core": "1.0.0-beta.5",
"@page-agent/ui": "1.0.0-beta.5"
}
}

View File

@@ -1,6 +1,6 @@
{
"name": "@page-agent/page-controller",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"main": "./dist/lib/page-controller.js",
"module": "./dist/lib/page-controller.js",

View File

@@ -1,6 +1,6 @@
{
"name": "@page-agent/ui",
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"main": "./dist/lib/page-agent-ui.js",
"module": "./dist/lib/page-agent-ui.js",

View File

@@ -608,6 +608,13 @@ export class Panel {
)
} else if (event.type === 'user_takeover') {
cards.push(createCard({ icon: '👤', content: 'User takeover', meta, type: 'input' }))
} else if (event.type === 'retry') {
const retryInfo = `${event.message || 'Retrying'} (${event.attempt}/${event.maxAttempts})`
cards.push(createCard({ icon: '🔄', content: retryInfo, meta, type: 'observation' }))
} else if (event.type === 'error') {
cards.push(
createCard({ icon: '❌', content: event.message || 'Error', meta, type: 'observation' })
)
}
return cards

View File

@@ -33,7 +33,7 @@ export interface PanelAgentAdapter extends EventTarget {
/** History of agent events */
readonly history: readonly {
type: 'step' | 'observation' | 'user_takeover' | 'error'
type: 'step' | 'observation' | 'user_takeover' | 'retry' | 'error'
stepIndex?: number
/** For 'step' type */
reflection?: {
@@ -49,6 +49,11 @@ export interface PanelAgentAdapter extends EventTarget {
}
/** For 'observation' type */
content?: string
/** For 'retry' type */
attempt?: number
maxAttempts?: number
/** For 'retry' and 'error' types */
message?: string
}[]
/** Current task being executed */

View File

@@ -1,7 +1,7 @@
{
"name": "@page-agent/website",
"private": true,
"version": "1.0.0-beta.4",
"version": "1.0.0-beta.5",
"type": "module",
"scripts": {
"dev": "vite --host 0.0.0.0",

View File

@@ -1,8 +1,8 @@
// Demo build (auto-init with demo LLM, for quick testing)
export const CDN_DEMO_URL =
'https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.4/dist/iife/page-agent.demo.js'
'https://cdn.jsdelivr.net/npm/page-agent@1.0.0-beta.5/dist/iife/page-agent.demo.js'
export const CDN_DEMO_CN_URL =
'https://registry.npmmirror.com/page-agent/1.0.0-beta.4/files/dist/iife/page-agent.demo.js'
'https://registry.npmmirror.com/page-agent/1.0.0-beta.5/files/dist/iife/page-agent.demo.js'
// Demo LLM for website testing
export const DEMO_MODEL = 'PAGE-AGENT-FREE-TESTING-RANDOM'