expxagents 0.25.1 → 0.25.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/agents/_catalog.yaml +35 -0
- package/assets/agents/accounting/accountant.agent.md +41 -0
- package/assets/agents/accounting/audit-analyst.agent.md +41 -0
- package/assets/agents/accounting/financial-reporting.agent.md +41 -0
- package/assets/agents/accounting/fiscal-analyst.agent.md +41 -0
- package/assets/agents/accounting/payroll-specialist.agent.md +41 -0
- package/assets/agents/accounting/tax-compliance.agent.md +41 -0
- package/assets/agents/administrative/document-controller.agent.md +41 -0
- package/assets/agents/administrative/office-manager.agent.md +41 -0
- package/assets/agents/administrative/process-documentation-officer.agent.md +41 -0
- package/assets/agents/administrative/procurement-specialist.agent.md +41 -0
- package/assets/agents/board/board-report-writer.agent.md +41 -0
- package/assets/agents/board/business-intelligence.agent.md +41 -0
- package/assets/agents/board/governance-officer.agent.md +41 -0
- package/assets/agents/board/okr-manager.agent.md +41 -0
- package/assets/agents/board/risk-analyst.agent.md +41 -0
- package/assets/agents/board/strategic-advisor.agent.md +41 -0
- package/assets/agents/commercial/account-executive.agent.md +41 -0
- package/assets/agents/commercial/crm-manager.agent.md +41 -0
- package/assets/agents/commercial/pricing-strategist.agent.md +41 -0
- package/assets/agents/commercial/proposal-writer.agent.md +41 -0
- package/assets/agents/commercial/sdr.agent.md +41 -0
- package/assets/agents/compliance/compliance-officer.agent.md +41 -0
- package/assets/agents/compliance/data-privacy-specialist.agent.md +41 -0
- package/assets/agents/compliance/internal-auditor.agent.md +41 -0
- package/assets/agents/compliance/regulatory-monitor.agent.md +41 -0
- package/assets/agents/customer-success/churn-prevention.agent.md +41 -0
- package/assets/agents/customer-success/csm.agent.md +41 -0
- package/assets/agents/customer-success/expansion-manager.agent.md +41 -0
- package/assets/agents/customer-success/nps-analyst.agent.md +41 -0
- package/assets/agents/customer-success/renewal-manager.agent.md +41 -0
- package/assets/agents/development/android-developer.agent.md +41 -0
- package/assets/agents/development/backend-developer.agent.md +42 -0
- package/assets/agents/development/business-analyst.agent.md +41 -0
- package/assets/agents/development/code-reviewer.agent.md +41 -0
- package/assets/agents/development/cross-platform-mobile.agent.md +41 -0
- package/assets/agents/development/dba.agent.md +41 -0
- package/assets/agents/development/desktop-developer.agent.md +41 -0
- package/assets/agents/development/devops-engineer.agent.md +41 -0
- package/assets/agents/development/frontend-developer.agent.md +103 -0
- package/assets/agents/development/ios-developer.agent.md +41 -0
- package/assets/agents/development/product-manager.agent.md +41 -0
- package/assets/agents/development/qa-engineer.agent.md +41 -0
- package/assets/agents/development/scrum-master.agent.md +41 -0
- package/assets/agents/development/security-analyst.agent.md +41 -0
- package/assets/agents/development/tech-lead.agent.md +42 -0
- package/assets/agents/development/tech-writer.agent.md +41 -0
- package/assets/agents/development/ux-design-expert.agent.md +108 -0
- package/assets/agents/development/ux-designer.agent.md +41 -0
- package/assets/agents/finance/accounts-manager.agent.md +41 -0
- package/assets/agents/finance/billing-analyst.agent.md +41 -0
- package/assets/agents/finance/budget-planner.agent.md +41 -0
- package/assets/agents/finance/financial-controller.agent.md +41 -0
- package/assets/agents/hr/benefits-manager.agent.md +41 -0
- package/assets/agents/hr/hr-onboarding.agent.md +41 -0
- package/assets/agents/hr/interview-coordinator.agent.md +41 -0
- package/assets/agents/hr/people-culture.agent.md +41 -0
- package/assets/agents/hr/performance-analyst.agent.md +41 -0
- package/assets/agents/hr/recruiter.agent.md +41 -0
- package/assets/agents/implantation/deployment-manager.agent.md +41 -0
- package/assets/agents/implantation/environment-specialist.agent.md +41 -0
- package/assets/agents/implantation/go-live-coordinator.agent.md +41 -0
- package/assets/agents/implantation/integration-specialist.agent.md +41 -0
- package/assets/agents/implantation/migration-specialist.agent.md +41 -0
- package/assets/agents/legal/contract-manager.agent.md +41 -0
- package/assets/agents/legal/ip-specialist.agent.md +41 -0
- package/assets/agents/legal/labor-attorney.agent.md +41 -0
- package/assets/agents/legal/legal-counsel.agent.md +41 -0
- package/assets/agents/marketing/brand-guardian.agent.md +40 -0
- package/assets/agents/marketing/content-creator.agent.md +41 -0
- package/assets/agents/marketing/email-marketing.agent.md +41 -0
- package/assets/agents/marketing/landing-page-builder.agent.md +138 -0
- package/assets/agents/marketing/marketing-analyst.agent.md +41 -0
- package/assets/agents/marketing/paid-ads-manager.agent.md +41 -0
- package/assets/agents/marketing/seo-specialist.agent.md +41 -0
- package/assets/agents/marketing/social-media-manager.agent.md +41 -0
- package/assets/agents/rnd/benchmark-analyst.agent.md +41 -0
- package/assets/agents/rnd/innovation-scout.agent.md +41 -0
- package/assets/agents/rnd/market-researcher.agent.md +41 -0
- package/assets/agents/rnd/product-analyst.agent.md +41 -0
- package/assets/agents/rnd/prototype-builder.agent.md +41 -0
- package/assets/agents/support/knowledge-base-manager.agent.md +41 -0
- package/assets/agents/support/l1-support.agent.md +41 -0
- package/assets/agents/support/l2-support.agent.md +41 -0
- package/assets/agents/support/l3-support.agent.md +41 -0
- package/assets/agents/support/sla-monitor.agent.md +41 -0
- package/assets/agents/training/assessment-creator.agent.md +41 -0
- package/assets/agents/training/onboarding-coach.agent.md +41 -0
- package/assets/agents/training/training-designer.agent.md +41 -0
- package/assets/agents/training/workshop-facilitator.agent.md +41 -0
- package/assets/core/best-practices/_catalog.yaml +91 -0
- package/assets/core/best-practices/api-documentation.md +137 -0
- package/assets/core/best-practices/blog-post.md +86 -0
- package/assets/core/best-practices/blog-seo.md +91 -0
- package/assets/core/best-practices/code-review.md +97 -0
- package/assets/core/best-practices/copywriting.md +75 -0
- package/assets/core/best-practices/data-analysis.md +93 -0
- package/assets/core/best-practices/deploy-checklist.md +99 -0
- package/assets/core/best-practices/email-newsletter.md +84 -0
- package/assets/core/best-practices/email-sales.md +91 -0
- package/assets/core/best-practices/fullstack-page-generation.md +936 -0
- package/assets/core/best-practices/image-design.md +78 -0
- package/assets/core/best-practices/instagram-feed.md +70 -0
- package/assets/core/best-practices/instagram-reels.md +75 -0
- package/assets/core/best-practices/instagram-stories.md +68 -0
- package/assets/core/best-practices/landing-page-react.md +2263 -0
- package/assets/core/best-practices/landing-page.md +279 -0
- package/assets/core/best-practices/linkedin-article.md +83 -0
- package/assets/core/best-practices/linkedin-post.md +84 -0
- package/assets/core/best-practices/researching.md +89 -0
- package/assets/core/best-practices/review.md +95 -0
- package/assets/core/best-practices/sprint-planning.md +91 -0
- package/assets/core/best-practices/strategist.md +95 -0
- package/assets/core/best-practices/technical-writing.md +104 -0
- package/assets/core/best-practices/twitter-post.md +75 -0
- package/assets/core/best-practices/twitter-thread.md +92 -0
- package/assets/core/best-practices/whatsapp-broadcast.md +95 -0
- package/assets/core/best-practices/youtube-script.md +80 -0
- package/assets/core/best-practices/youtube-shorts.md +76 -0
- package/assets/core/prompts/insight-hunter.prompt.md +62 -0
- package/assets/core/runner.pipeline.md +200 -0
- package/assets/core/skills.engine.md +65 -0
- package/assets/core/solution-architect.agent.md +329 -0
- package/assets/mcps/_catalog.yaml +17 -0
- package/assets/mcps/figma.mcp.yaml +35 -0
- package/assets/mcps/github.mcp.yaml +44 -0
- package/assets/mcps/linear.mcp.yaml +37 -0
- package/assets/mcps/notion.mcp.yaml +37 -0
- package/assets/mcps/pencil.mcp.yaml +32 -0
- package/assets/mcps/postgresql.mcp.yaml +39 -0
- package/assets/mcps/sentry.mcp.yaml +41 -0
- package/assets/mcps/slack.mcp.yaml +37 -0
- package/assets/mcps/vercel.mcp.yaml +39 -0
- package/assets/templates/_expxagents/_memory/company.md +25 -0
- package/assets/templates/_expxagents/_memory/preferences.md +6 -0
- package/assets/templates/squads/_memory/memories.md +16 -0
- package/dist/cli/src/commands/info.d.ts +2 -1
- package/dist/cli/src/commands/login.d.ts +2 -1
- package/dist/cli/src/commands/logout.d.ts +2 -1
- package/dist/cli/src/commands/outdated.d.ts +2 -1
- package/dist/cli/src/commands/publish.d.ts +2 -1
- package/dist/cli/src/commands/registry-install.d.ts +2 -1
- package/dist/cli/src/commands/search.d.ts +2 -1
- package/dist/cli/src/commands/update.d.ts +2 -1
- package/dist/cli/src/commands/whoami.d.ts +2 -1
- package/dist/cli/src/utils/server-paths.js +17 -5
- package/dist/dashboard/assets/BufferResource-D79vaoFm.js +185 -0
- package/dist/dashboard/assets/CanvasRenderer-BUoxTNKV.js +1 -0
- package/dist/dashboard/assets/JarvisView-DSN7xWMz.js +1 -0
- package/dist/dashboard/assets/RenderTargetSystem-B7rwTXA1.js +172 -0
- package/dist/dashboard/assets/ThreeBackground-BQTdScX-.js +1 -0
- package/dist/dashboard/assets/WebGLRenderer-DgdVNsZ9.js +156 -0
- package/dist/dashboard/assets/WebGPURenderer-DnQNvjEQ.js +41 -0
- package/dist/dashboard/assets/browserAll-Cbsk7DE4.js +14 -0
- package/dist/dashboard/assets/index-CrlhoBta.js +783 -0
- package/dist/dashboard/assets/index-DtbIzZ5n.css +1 -0
- package/dist/dashboard/assets/three-BZk_I9Ly.js +4057 -0
- package/dist/dashboard/assets/webworkerAll-BLmfReEj.js +83 -0
- package/dist/dashboard/index.html +13 -0
- package/dist/server/api/__tests__/cost-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/cost-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/cost-routes.test.js +54 -0
- package/dist/server/api/__tests__/cost-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/files-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/files-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/files-routes.test.js +85 -0
- package/dist/server/api/__tests__/files-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/graph-routes.test.js +105 -0
- package/dist/server/api/__tests__/graph-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/health-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/health-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/health-routes.test.js +22 -0
- package/dist/server/api/__tests__/health-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.js +243 -0
- package/dist/server/api/__tests__/integration-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/kanban-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/kanban-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/kanban-routes.test.js +316 -0
- package/dist/server/api/__tests__/kanban-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/log-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/log-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/log-routes.test.js +35 -0
- package/dist/server/api/__tests__/log-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/orgchart-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/orgchart-routes.test.js +161 -0
- package/dist/server/api/__tests__/orgchart-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/settings-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/settings-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/settings-routes.test.js +177 -0
- package/dist/server/api/__tests__/settings-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/system-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/system-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/system-routes.test.js +79 -0
- package/dist/server/api/__tests__/system-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.js +116 -0
- package/dist/server/api/__tests__/team-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/webhook-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/webhook-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/webhook-routes.test.js +111 -0
- package/dist/server/api/__tests__/webhook-routes.test.js.map +1 -0
- package/dist/server/api/activity-routes.d.ts +8 -0
- package/dist/server/api/activity-routes.d.ts.map +1 -0
- package/dist/server/api/activity-routes.js +34 -0
- package/dist/server/api/activity-routes.js.map +1 -0
- package/dist/server/api/chat-api-routes.d.ts +4 -0
- package/dist/server/api/chat-api-routes.d.ts.map +1 -0
- package/dist/server/api/chat-api-routes.js +28 -0
- package/dist/server/api/chat-api-routes.js.map +1 -0
- package/dist/server/api/cost-routes.d.ts +8 -0
- package/dist/server/api/cost-routes.d.ts.map +1 -0
- package/dist/server/api/cost-routes.js +39 -0
- package/dist/server/api/cost-routes.js.map +1 -0
- package/dist/server/api/dashboard-routes.d.ts +10 -0
- package/dist/server/api/dashboard-routes.d.ts.map +1 -0
- package/dist/server/api/dashboard-routes.js +128 -0
- package/dist/server/api/dashboard-routes.js.map +1 -0
- package/dist/server/api/files-routes.d.ts +5 -0
- package/dist/server/api/files-routes.d.ts.map +1 -0
- package/dist/server/api/files-routes.js +218 -0
- package/dist/server/api/files-routes.js.map +1 -0
- package/dist/server/api/graph-routes.d.ts +24 -0
- package/dist/server/api/graph-routes.d.ts.map +1 -0
- package/dist/server/api/graph-routes.js +208 -0
- package/dist/server/api/graph-routes.js.map +1 -0
- package/dist/server/api/health-routes.d.ts +9 -0
- package/dist/server/api/health-routes.d.ts.map +1 -0
- package/dist/server/api/health-routes.js +46 -0
- package/dist/server/api/health-routes.js.map +1 -0
- package/dist/server/api/integration-routes.d.ts +23 -0
- package/dist/server/api/integration-routes.d.ts.map +1 -0
- package/dist/server/api/integration-routes.js +326 -0
- package/dist/server/api/integration-routes.js.map +1 -0
- package/dist/server/api/kanban-routes.d.ts +8 -0
- package/dist/server/api/kanban-routes.d.ts.map +1 -0
- package/dist/server/api/kanban-routes.js +128 -0
- package/dist/server/api/kanban-routes.js.map +1 -0
- package/dist/server/api/knowledge-routes.d.ts +8 -0
- package/dist/server/api/knowledge-routes.d.ts.map +1 -0
- package/dist/server/api/knowledge-routes.js +82 -0
- package/dist/server/api/knowledge-routes.js.map +1 -0
- package/dist/server/api/log-routes.d.ts +8 -0
- package/dist/server/api/log-routes.d.ts.map +1 -0
- package/dist/server/api/log-routes.js +31 -0
- package/dist/server/api/log-routes.js.map +1 -0
- package/dist/server/api/orgchart-routes.d.ts +7 -0
- package/dist/server/api/orgchart-routes.d.ts.map +1 -0
- package/dist/server/api/orgchart-routes.js +154 -0
- package/dist/server/api/orgchart-routes.js.map +1 -0
- package/dist/server/api/permissions-routes.d.ts +8 -0
- package/dist/server/api/permissions-routes.d.ts.map +1 -0
- package/dist/server/api/permissions-routes.js +37 -0
- package/dist/server/api/permissions-routes.js.map +1 -0
- package/dist/server/api/registry-routes.d.ts +7 -0
- package/dist/server/api/registry-routes.d.ts.map +1 -0
- package/dist/server/api/registry-routes.js +51 -0
- package/dist/server/api/registry-routes.js.map +1 -0
- package/dist/server/api/settings-routes.d.ts +11 -0
- package/dist/server/api/settings-routes.d.ts.map +1 -0
- package/dist/server/api/settings-routes.js +167 -0
- package/dist/server/api/settings-routes.js.map +1 -0
- package/dist/server/api/squads-routes.d.ts +9 -0
- package/dist/server/api/squads-routes.d.ts.map +1 -0
- package/dist/server/api/squads-routes.js +171 -0
- package/dist/server/api/squads-routes.js.map +1 -0
- package/dist/server/api/system-routes.d.ts +9 -0
- package/dist/server/api/system-routes.d.ts.map +1 -0
- package/dist/server/api/system-routes.js +241 -0
- package/dist/server/api/system-routes.js.map +1 -0
- package/dist/server/api/team-routes.d.ts +8 -0
- package/dist/server/api/team-routes.d.ts.map +1 -0
- package/dist/server/api/team-routes.js +55 -0
- package/dist/server/api/team-routes.js.map +1 -0
- package/dist/server/api/users-routes.d.ts +8 -0
- package/dist/server/api/users-routes.d.ts.map +1 -0
- package/dist/server/api/users-routes.js +65 -0
- package/dist/server/api/users-routes.js.map +1 -0
- package/dist/server/api/webhook-routes.d.ts +9 -0
- package/dist/server/api/webhook-routes.d.ts.map +1 -0
- package/dist/server/api/webhook-routes.js +82 -0
- package/dist/server/api/webhook-routes.js.map +1 -0
- package/dist/server/app.d.ts +9 -0
- package/dist/server/app.d.ts.map +1 -0
- package/dist/server/app.js +265 -0
- package/dist/server/app.js.map +1 -0
- package/dist/server/auth/auth-middleware.d.ts +13 -0
- package/dist/server/auth/auth-middleware.d.ts.map +1 -0
- package/dist/server/auth/auth-middleware.js +25 -0
- package/dist/server/auth/auth-middleware.js.map +1 -0
- package/dist/server/auth/auth-routes.d.ts +9 -0
- package/dist/server/auth/auth-routes.d.ts.map +1 -0
- package/dist/server/auth/auth-routes.js +152 -0
- package/dist/server/auth/auth-routes.js.map +1 -0
- package/dist/server/auth/jwt.d.ts +14 -0
- package/dist/server/auth/jwt.d.ts.map +1 -0
- package/dist/server/auth/jwt.js +16 -0
- package/dist/server/auth/jwt.js.map +1 -0
- package/dist/server/auth/password.d.ts +3 -0
- package/dist/server/auth/password.d.ts.map +1 -0
- package/dist/server/auth/password.js +9 -0
- package/dist/server/auth/password.js.map +1 -0
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/chat-handler.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/chat-handler.test.js +143 -0
- package/dist/server/bridge/__tests__/chat-handler.test.js.map +1 -0
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/chat-integration.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/chat-integration.test.js +129 -0
- package/dist/server/bridge/__tests__/chat-integration.test.js.map +1 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.js +300 -0
- package/dist/server/bridge/__tests__/claude-bridge.test.js.map +1 -0
- package/dist/server/bridge/__tests__/conversation.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/conversation.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/conversation.test.js +168 -0
- package/dist/server/bridge/__tests__/conversation.test.js.map +1 -0
- package/dist/server/bridge/__tests__/registry.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/registry.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/registry.test.js +45 -0
- package/dist/server/bridge/__tests__/registry.test.js.map +1 -0
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts +2 -0
- package/dist/server/bridge/__tests__/stream-parser.test.d.ts.map +1 -0
- package/dist/server/bridge/__tests__/stream-parser.test.js +66 -0
- package/dist/server/bridge/__tests__/stream-parser.test.js.map +1 -0
- package/dist/server/bridge/chat-handler.d.ts +32 -0
- package/dist/server/bridge/chat-handler.d.ts.map +1 -0
- package/dist/server/bridge/chat-handler.js +356 -0
- package/dist/server/bridge/chat-handler.js.map +1 -0
- package/dist/server/bridge/claude-bridge.d.ts +21 -0
- package/dist/server/bridge/claude-bridge.d.ts.map +1 -0
- package/dist/server/bridge/claude-bridge.js +273 -0
- package/dist/server/bridge/claude-bridge.js.map +1 -0
- package/dist/server/bridge/conversation.d.ts +45 -0
- package/dist/server/bridge/conversation.d.ts.map +1 -0
- package/dist/server/bridge/conversation.js +78 -0
- package/dist/server/bridge/conversation.js.map +1 -0
- package/dist/server/bridge/engine-manager.d.ts +13 -0
- package/dist/server/bridge/engine-manager.d.ts.map +1 -0
- package/dist/server/bridge/engine-manager.js +54 -0
- package/dist/server/bridge/engine-manager.js.map +1 -0
- package/dist/server/bridge/engine.d.ts +37 -0
- package/dist/server/bridge/engine.d.ts.map +1 -0
- package/dist/server/bridge/engine.js +2 -0
- package/dist/server/bridge/engine.js.map +1 -0
- package/dist/server/bridge/factory.d.ts +4 -0
- package/dist/server/bridge/factory.d.ts.map +1 -0
- package/dist/server/bridge/factory.js +18 -0
- package/dist/server/bridge/factory.js.map +1 -0
- package/dist/server/bridge/opencode-bridge.d.ts +27 -0
- package/dist/server/bridge/opencode-bridge.d.ts.map +1 -0
- package/dist/server/bridge/opencode-bridge.js +163 -0
- package/dist/server/bridge/opencode-bridge.js.map +1 -0
- package/dist/server/bridge/registry.d.ts +19 -0
- package/dist/server/bridge/registry.d.ts.map +1 -0
- package/dist/server/bridge/registry.js +29 -0
- package/dist/server/bridge/registry.js.map +1 -0
- package/dist/server/bridge/session-journal.d.ts +25 -0
- package/dist/server/bridge/session-journal.d.ts.map +1 -0
- package/dist/server/bridge/session-journal.js +69 -0
- package/dist/server/bridge/session-journal.js.map +1 -0
- package/dist/server/bridge/stream-parser.d.ts +14 -0
- package/dist/server/bridge/stream-parser.d.ts.map +1 -0
- package/dist/server/bridge/stream-parser.js +26 -0
- package/dist/server/bridge/stream-parser.js.map +1 -0
- package/dist/server/config/engine-config.d.ts +4 -0
- package/dist/server/config/engine-config.d.ts.map +1 -0
- package/dist/server/config/engine-config.js +24 -0
- package/dist/server/config/engine-config.js.map +1 -0
- package/dist/server/config.d.ts +17 -0
- package/dist/server/config.d.ts.map +1 -0
- package/dist/server/config.js +39 -0
- package/dist/server/config.js.map +1 -0
- package/dist/server/db/__tests__/chat-tables.test.d.ts +2 -0
- package/dist/server/db/__tests__/chat-tables.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/chat-tables.test.js +82 -0
- package/dist/server/db/__tests__/chat-tables.test.js.map +1 -0
- package/dist/server/db/__tests__/email-schema.test.d.ts +2 -0
- package/dist/server/db/__tests__/email-schema.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/email-schema.test.js +53 -0
- package/dist/server/db/__tests__/email-schema.test.js.map +1 -0
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts +2 -0
- package/dist/server/db/__tests__/scheduler-schema.test.d.ts.map +1 -0
- package/dist/server/db/__tests__/scheduler-schema.test.js +52 -0
- package/dist/server/db/__tests__/scheduler-schema.test.js.map +1 -0
- package/dist/server/db/connection.d.ts +4 -0
- package/dist/server/db/connection.d.ts.map +1 -0
- package/dist/server/db/connection.js +40 -0
- package/dist/server/db/connection.js.map +1 -0
- package/dist/server/db/migrations.d.ts +4 -0
- package/dist/server/db/migrations.d.ts.map +1 -0
- package/dist/server/db/migrations.js +47 -0
- package/dist/server/db/migrations.js.map +1 -0
- package/dist/server/db/schema.d.ts +2 -0
- package/dist/server/db/schema.d.ts.map +1 -0
- package/dist/server/db/schema.js +288 -0
- package/dist/server/db/schema.js.map +1 -0
- package/dist/server/email/__tests__/campaign-routes.test.d.ts +2 -0
- package/dist/server/email/__tests__/campaign-routes.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/campaign-routes.test.js +216 -0
- package/dist/server/email/__tests__/campaign-routes.test.js.map +1 -0
- package/dist/server/email/__tests__/campaign-service.test.d.ts +2 -0
- package/dist/server/email/__tests__/campaign-service.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/campaign-service.test.js +79 -0
- package/dist/server/email/__tests__/campaign-service.test.js.map +1 -0
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts +2 -0
- package/dist/server/email/__tests__/email-queue-worker.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/email-queue-worker.test.js +93 -0
- package/dist/server/email/__tests__/email-queue-worker.test.js.map +1 -0
- package/dist/server/email/__tests__/email-utils.test.d.ts +2 -0
- package/dist/server/email/__tests__/email-utils.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/email-utils.test.js +36 -0
- package/dist/server/email/__tests__/email-utils.test.js.map +1 -0
- package/dist/server/email/__tests__/lead-routes.test.d.ts +2 -0
- package/dist/server/email/__tests__/lead-routes.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/lead-routes.test.js +180 -0
- package/dist/server/email/__tests__/lead-routes.test.js.map +1 -0
- package/dist/server/email/__tests__/lead-service.test.d.ts +2 -0
- package/dist/server/email/__tests__/lead-service.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/lead-service.test.js +113 -0
- package/dist/server/email/__tests__/lead-service.test.js.map +1 -0
- package/dist/server/email/__tests__/ses-client.test.d.ts +2 -0
- package/dist/server/email/__tests__/ses-client.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/ses-client.test.js +48 -0
- package/dist/server/email/__tests__/ses-client.test.js.map +1 -0
- package/dist/server/email/__tests__/sns-webhook.test.d.ts +2 -0
- package/dist/server/email/__tests__/sns-webhook.test.d.ts.map +1 -0
- package/dist/server/email/__tests__/sns-webhook.test.js +40 -0
- package/dist/server/email/__tests__/sns-webhook.test.js.map +1 -0
- package/dist/server/email/campaign-routes.d.ts +8 -0
- package/dist/server/email/campaign-routes.d.ts.map +1 -0
- package/dist/server/email/campaign-routes.js +65 -0
- package/dist/server/email/campaign-routes.js.map +1 -0
- package/dist/server/email/campaign-service.d.ts +55 -0
- package/dist/server/email/campaign-service.d.ts.map +1 -0
- package/dist/server/email/campaign-service.js +89 -0
- package/dist/server/email/campaign-service.js.map +1 -0
- package/dist/server/email/email-queue-worker.d.ts +27 -0
- package/dist/server/email/email-queue-worker.d.ts.map +1 -0
- package/dist/server/email/email-queue-worker.js +119 -0
- package/dist/server/email/email-queue-worker.js.map +1 -0
- package/dist/server/email/email-utils.d.ts +5 -0
- package/dist/server/email/email-utils.d.ts.map +1 -0
- package/dist/server/email/email-utils.js +24 -0
- package/dist/server/email/email-utils.js.map +1 -0
- package/dist/server/email/lead-routes.d.ts +8 -0
- package/dist/server/email/lead-routes.d.ts.map +1 -0
- package/dist/server/email/lead-routes.js +56 -0
- package/dist/server/email/lead-routes.js.map +1 -0
- package/dist/server/email/lead-service.d.ts +66 -0
- package/dist/server/email/lead-service.d.ts.map +1 -0
- package/dist/server/email/lead-service.js +138 -0
- package/dist/server/email/lead-service.js.map +1 -0
- package/dist/server/email/ses-client.d.ts +27 -0
- package/dist/server/email/ses-client.d.ts.map +1 -0
- package/dist/server/email/ses-client.js +44 -0
- package/dist/server/email/ses-client.js.map +1 -0
- package/dist/server/email/sns-webhook.d.ts +10 -0
- package/dist/server/email/sns-webhook.d.ts.map +1 -0
- package/dist/server/email/sns-webhook.js +73 -0
- package/dist/server/email/sns-webhook.js.map +1 -0
- package/dist/server/index.d.ts +2 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +36 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/mcp/expxagents-mcp.d.ts +2 -0
- package/dist/server/mcp/expxagents-mcp.d.ts.map +1 -0
- package/dist/server/mcp/expxagents-mcp.js +230 -0
- package/dist/server/mcp/expxagents-mcp.js.map +1 -0
- package/dist/server/routes/__tests__/conversations.test.d.ts +2 -0
- package/dist/server/routes/__tests__/conversations.test.d.ts.map +1 -0
- package/dist/server/routes/__tests__/conversations.test.js +111 -0
- package/dist/server/routes/__tests__/conversations.test.js.map +1 -0
- package/dist/server/routes/conversations.d.ts +8 -0
- package/dist/server/routes/conversations.d.ts.map +1 -0
- package/dist/server/routes/conversations.js +36 -0
- package/dist/server/routes/conversations.js.map +1 -0
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/job-runner.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/job-runner.test.js +488 -0
- package/dist/server/scheduler/__tests__/job-runner.test.js.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js +167 -0
- package/dist/server/scheduler/__tests__/scheduler-routes.test.js.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts +2 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.d.ts.map +1 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.js +207 -0
- package/dist/server/scheduler/__tests__/scheduler-service.test.js.map +1 -0
- package/dist/server/scheduler/job-runner.d.ts +73 -0
- package/dist/server/scheduler/job-runner.d.ts.map +1 -0
- package/dist/server/scheduler/job-runner.js +407 -0
- package/dist/server/scheduler/job-runner.js.map +1 -0
- package/dist/server/scheduler/scheduler-routes.d.ts +10 -0
- package/dist/server/scheduler/scheduler-routes.d.ts.map +1 -0
- package/dist/server/scheduler/scheduler-routes.js +105 -0
- package/dist/server/scheduler/scheduler-routes.js.map +1 -0
- package/dist/server/scheduler/scheduler-service.d.ts +55 -0
- package/dist/server/scheduler/scheduler-service.d.ts.map +1 -0
- package/dist/server/scheduler/scheduler-service.js +271 -0
- package/dist/server/scheduler/scheduler-service.js.map +1 -0
- package/dist/server/services/__tests__/cost-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/cost-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/cost-service.test.js +72 -0
- package/dist/server/services/__tests__/cost-service.test.js.map +1 -0
- package/dist/server/services/__tests__/execution-log-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/execution-log-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/execution-log-service.test.js +40 -0
- package/dist/server/services/__tests__/execution-log-service.test.js.map +1 -0
- package/dist/server/services/__tests__/integration-registry.test.d.ts +2 -0
- package/dist/server/services/__tests__/integration-registry.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/integration-registry.test.js +28 -0
- package/dist/server/services/__tests__/integration-registry.test.js.map +1 -0
- package/dist/server/services/__tests__/log-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/log-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/log-service.test.js +49 -0
- package/dist/server/services/__tests__/log-service.test.js.map +1 -0
- package/dist/server/services/__tests__/permissions-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/permissions-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/permissions-service.test.js +46 -0
- package/dist/server/services/__tests__/permissions-service.test.js.map +1 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.js +268 -0
- package/dist/server/services/__tests__/pipeline-task-service.test.js.map +1 -0
- package/dist/server/services/__tests__/state-service.test.d.ts +2 -0
- package/dist/server/services/__tests__/state-service.test.d.ts.map +1 -0
- package/dist/server/services/__tests__/state-service.test.js +136 -0
- package/dist/server/services/__tests__/state-service.test.js.map +1 -0
- package/dist/server/services/activity-service.d.ts +35 -0
- package/dist/server/services/activity-service.d.ts.map +1 -0
- package/dist/server/services/activity-service.js +92 -0
- package/dist/server/services/activity-service.js.map +1 -0
- package/dist/server/services/cost-service.d.ts +55 -0
- package/dist/server/services/cost-service.d.ts.map +1 -0
- package/dist/server/services/cost-service.js +59 -0
- package/dist/server/services/cost-service.js.map +1 -0
- package/dist/server/services/execution-log-service.d.ts +20 -0
- package/dist/server/services/execution-log-service.d.ts.map +1 -0
- package/dist/server/services/execution-log-service.js +17 -0
- package/dist/server/services/execution-log-service.js.map +1 -0
- package/dist/server/services/integration-registry.d.ts +9 -0
- package/dist/server/services/integration-registry.d.ts.map +1 -0
- package/dist/server/services/integration-registry.js +14 -0
- package/dist/server/services/integration-registry.js.map +1 -0
- package/dist/server/services/log-service.d.ts +28 -0
- package/dist/server/services/log-service.d.ts.map +1 -0
- package/dist/server/services/log-service.js +34 -0
- package/dist/server/services/log-service.js.map +1 -0
- package/dist/server/services/permissions-service.d.ts +10 -0
- package/dist/server/services/permissions-service.d.ts.map +1 -0
- package/dist/server/services/permissions-service.js +48 -0
- package/dist/server/services/permissions-service.js.map +1 -0
- package/dist/server/services/pipeline-task-service.d.ts +79 -0
- package/dist/server/services/pipeline-task-service.d.ts.map +1 -0
- package/dist/server/services/pipeline-task-service.js +122 -0
- package/dist/server/services/pipeline-task-service.js.map +1 -0
- package/dist/server/services/squad-registry.d.ts +35 -0
- package/dist/server/services/squad-registry.d.ts.map +1 -0
- package/dist/server/services/squad-registry.js +141 -0
- package/dist/server/services/squad-registry.js.map +1 -0
- package/dist/server/services/state-service.d.ts +22 -0
- package/dist/server/services/state-service.d.ts.map +1 -0
- package/dist/server/services/state-service.js +114 -0
- package/dist/server/services/state-service.js.map +1 -0
- package/dist/server/types/a2ui.d.ts +27 -0
- package/dist/server/types/a2ui.d.ts.map +1 -0
- package/dist/server/types/a2ui.js +2 -0
- package/dist/server/types/a2ui.js.map +1 -0
- package/dist/server/utils/find-free-port.d.ts +2 -0
- package/dist/server/utils/find-free-port.d.ts.map +1 -0
- package/dist/server/utils/find-free-port.js +17 -0
- package/dist/server/utils/find-free-port.js.map +1 -0
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts +2 -0
- package/dist/server/watcher/__tests__/file-watcher.test.d.ts.map +1 -0
- package/dist/server/watcher/__tests__/file-watcher.test.js +81 -0
- package/dist/server/watcher/__tests__/file-watcher.test.js.map +1 -0
- package/dist/server/watcher/file-watcher.d.ts +19 -0
- package/dist/server/watcher/file-watcher.d.ts.map +1 -0
- package/dist/server/watcher/file-watcher.js +105 -0
- package/dist/server/watcher/file-watcher.js.map +1 -0
- package/dist/server/watcher/state-parser.d.ts +77 -0
- package/dist/server/watcher/state-parser.d.ts.map +1 -0
- package/dist/server/watcher/state-parser.js +78 -0
- package/dist/server/watcher/state-parser.js.map +1 -0
- package/dist/server/ws/ws-auth.d.ts +4 -0
- package/dist/server/ws/ws-auth.d.ts.map +1 -0
- package/dist/server/ws/ws-auth.js +42 -0
- package/dist/server/ws/ws-auth.js.map +1 -0
- package/dist/server/ws/ws-handler.d.ts +12 -0
- package/dist/server/ws/ws-handler.d.ts.map +1 -0
- package/dist/server/ws/ws-handler.js +171 -0
- package/dist/server/ws/ws-handler.js.map +1 -0
- package/dist/server/ws/ws-rooms.d.ts +12 -0
- package/dist/server/ws/ws-rooms.d.ts.map +1 -0
- package/dist/server/ws/ws-rooms.js +52 -0
- package/dist/server/ws/ws-rooms.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/config.d.ts +4 -0
- package/node_modules/expxagents-knowledge/dist/config.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/config.js +37 -0
- package/node_modules/expxagents-knowledge/dist/config.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/connection.d.ts +6 -0
- package/node_modules/expxagents-knowledge/dist/db/connection.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/connection.js +69 -0
- package/node_modules/expxagents-knowledge/dist/db/connection.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/migrations.d.ts +3 -0
- package/node_modules/expxagents-knowledge/dist/db/migrations.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/migrations.js +46 -0
- package/node_modules/expxagents-knowledge/dist/db/migrations.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/schema.d.ts +3 -0
- package/node_modules/expxagents-knowledge/dist/db/schema.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/db/schema.js +79 -0
- package/node_modules/expxagents-knowledge/dist/db/schema.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/index.d.ts +16 -0
- package/node_modules/expxagents-knowledge/dist/index.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/index.js +16 -0
- package/node_modules/expxagents-knowledge/dist/index.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.d.ts +10 -0
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.js +221 -0
- package/node_modules/expxagents-knowledge/dist/ingest/chunker.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.d.ts +4 -0
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.js +56 -0
- package/node_modules/expxagents-knowledge/dist/ingest/document-loader.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.d.ts +4 -0
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.js +25 -0
- package/node_modules/expxagents-knowledge/dist/ingest/embedder.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.d.ts +21 -0
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.js +54 -0
- package/node_modules/expxagents-knowledge/dist/ingest/entity-extractor.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.d.ts +16 -0
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.js +49 -0
- package/node_modules/expxagents-knowledge/dist/ingest/extraction-queue.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.d.ts +9 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.js +116 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pdf-extractor.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.d.ts +27 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.js +92 -0
- package/node_modules/expxagents-knowledge/dist/ingest/pipeline.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.d.ts +41 -0
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.js +62 -0
- package/node_modules/expxagents-knowledge/dist/query/graph-traversal.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.d.ts +31 -0
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.js +106 -0
- package/node_modules/expxagents-knowledge/dist/query/knowledge-query.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/vector-search.d.ts +26 -0
- package/node_modules/expxagents-knowledge/dist/query/vector-search.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/query/vector-search.js +57 -0
- package/node_modules/expxagents-knowledge/dist/query/vector-search.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.d.ts +10 -0
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.js +29 -0
- package/node_modules/expxagents-knowledge/dist/sources/agent-output.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/sources/watcher.d.ts +6 -0
- package/node_modules/expxagents-knowledge/dist/sources/watcher.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/sources/watcher.js +42 -0
- package/node_modules/expxagents-knowledge/dist/sources/watcher.js.map +1 -0
- package/node_modules/expxagents-knowledge/dist/types.d.ts +138 -0
- package/node_modules/expxagents-knowledge/dist/types.d.ts.map +1 -0
- package/node_modules/expxagents-knowledge/dist/types.js +2 -0
- package/node_modules/expxagents-knowledge/dist/types.js.map +1 -0
- package/node_modules/expxagents-knowledge/package.json +7 -0
- package/package.json +3 -3
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
<!-- NOT CONFIGURED -->
|
|
2
|
+
# Company Profile
|
|
3
|
+
|
|
4
|
+
## Company
|
|
5
|
+
- **Name:**
|
|
6
|
+
- **Website:**
|
|
7
|
+
- **Sector:**
|
|
8
|
+
- **Description:**
|
|
9
|
+
|
|
10
|
+
## Target Audience
|
|
11
|
+
- **Primary:**
|
|
12
|
+
- **Secondary:**
|
|
13
|
+
|
|
14
|
+
## Tone of Voice
|
|
15
|
+
- **Style:**
|
|
16
|
+
- **Keywords:**
|
|
17
|
+
|
|
18
|
+
## Social Media
|
|
19
|
+
- **Instagram:**
|
|
20
|
+
- **LinkedIn:**
|
|
21
|
+
- **Twitter:**
|
|
22
|
+
- **YouTube:**
|
|
23
|
+
|
|
24
|
+
## Products/Services
|
|
25
|
+
-
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# Squad Memories
|
|
2
|
+
|
|
3
|
+
> Updated automatically after each pipeline execution.
|
|
4
|
+
> Contains learnings, user preferences, and decisions from past runs.
|
|
5
|
+
|
|
6
|
+
## Execution History
|
|
7
|
+
|
|
8
|
+
(No runs yet)
|
|
9
|
+
|
|
10
|
+
## User Preferences
|
|
11
|
+
|
|
12
|
+
(No preferences recorded yet)
|
|
13
|
+
|
|
14
|
+
## Key Learnings
|
|
15
|
+
|
|
16
|
+
(No learnings recorded yet)
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const infoCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const loginCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const logoutCommand: Command;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
1
2
|
import { RegistryClient } from '@expxagents/registry-client';
|
|
2
3
|
export interface InstalledSquad {
|
|
3
4
|
fullName: string;
|
|
@@ -10,4 +11,4 @@ export interface OutdatedResult {
|
|
|
10
11
|
latest: string;
|
|
11
12
|
}
|
|
12
13
|
export declare function checkOutdated(client: RegistryClient, squads: InstalledSquad[]): Promise<OutdatedResult[]>;
|
|
13
|
-
export declare const outdatedCommand:
|
|
14
|
+
export declare const outdatedCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const publishCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const registryInstallCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const searchCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const updateCommand: Command;
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export declare const whoamiCommand: Command;
|
|
@@ -21,9 +21,21 @@ export function resolveServerPaths() {
|
|
|
21
21
|
const projectRoot = process.cwd();
|
|
22
22
|
const monoServer = path.join(projectRoot, 'server', 'dist', 'index.js');
|
|
23
23
|
const monoDashboard = path.join(projectRoot, 'dashboard', 'dist');
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
24
|
+
if (fs.existsSync(monoServer) && fs.existsSync(monoDashboard)) {
|
|
25
|
+
return {
|
|
26
|
+
serverEntry: monoServer,
|
|
27
|
+
dashboardDist: monoDashboard,
|
|
28
|
+
cwd: path.join(projectRoot, 'server'),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
// Neither bundled nor monorepo paths found — give a clear error
|
|
32
|
+
const checkedPaths = [
|
|
33
|
+
` - ${bundledServer}`,
|
|
34
|
+
` - ${monoServer}`,
|
|
35
|
+
].join('\n');
|
|
36
|
+
throw new Error(`Could not find ExpxAgents server files.\n\n` +
|
|
37
|
+
`Checked:\n${checkedPaths}\n\n` +
|
|
38
|
+
`This usually means the npm package was published without the server build.\n` +
|
|
39
|
+
`Try: npx expxagents@latest server\n` +
|
|
40
|
+
`Or reinstall: npm cache clean --force && npx --yes expxagents server`);
|
|
29
41
|
}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import{w as U,g,S as c,e as S,B as _,f as m,E as I,h as p}from"./index-CrlhoBta.js";const x={name:"local-uniform-bit",vertex:{header:`
|
|
2
|
+
|
|
3
|
+
struct LocalUniforms {
|
|
4
|
+
uTransformMatrix:mat3x3<f32>,
|
|
5
|
+
uColor:vec4<f32>,
|
|
6
|
+
uRound:f32,
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
@group(1) @binding(0) var<uniform> localUniforms : LocalUniforms;
|
|
10
|
+
`,main:`
|
|
11
|
+
vColor *= localUniforms.uColor;
|
|
12
|
+
modelMatrix *= localUniforms.uTransformMatrix;
|
|
13
|
+
`,end:`
|
|
14
|
+
if(localUniforms.uRound == 1)
|
|
15
|
+
{
|
|
16
|
+
vPosition = vec4(roundPixels(vPosition.xy, globalUniforms.uResolution), vPosition.zw);
|
|
17
|
+
}
|
|
18
|
+
`}},C={...x,vertex:{...x.vertex,header:x.vertex.header.replace("group(1)","group(2)")}},D={name:"local-uniform-bit",vertex:{header:`
|
|
19
|
+
|
|
20
|
+
uniform mat3 uTransformMatrix;
|
|
21
|
+
uniform vec4 uColor;
|
|
22
|
+
uniform float uRound;
|
|
23
|
+
`,main:`
|
|
24
|
+
vColor *= uColor;
|
|
25
|
+
modelMatrix = uTransformMatrix;
|
|
26
|
+
`,end:`
|
|
27
|
+
if(uRound == 1.)
|
|
28
|
+
{
|
|
29
|
+
gl_Position.xy = roundPixels(gl_Position.xy, uResolution);
|
|
30
|
+
}
|
|
31
|
+
`}},O={name:"texture-bit",vertex:{header:`
|
|
32
|
+
|
|
33
|
+
struct TextureUniforms {
|
|
34
|
+
uTextureMatrix:mat3x3<f32>,
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
@group(2) @binding(2) var<uniform> textureUniforms : TextureUniforms;
|
|
38
|
+
`,main:`
|
|
39
|
+
uv = (textureUniforms.uTextureMatrix * vec3(uv, 1.0)).xy;
|
|
40
|
+
`},fragment:{header:`
|
|
41
|
+
@group(2) @binding(0) var uTexture: texture_2d<f32>;
|
|
42
|
+
@group(2) @binding(1) var uSampler: sampler;
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
`,main:`
|
|
46
|
+
outColor = textureSample(uTexture, uSampler, vUV);
|
|
47
|
+
`}},R={name:"texture-bit",vertex:{header:`
|
|
48
|
+
uniform mat3 uTextureMatrix;
|
|
49
|
+
`,main:`
|
|
50
|
+
uv = (uTextureMatrix * vec3(uv, 1.0)).xy;
|
|
51
|
+
`},fragment:{header:`
|
|
52
|
+
uniform sampler2D uTexture;
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
`,main:`
|
|
56
|
+
outColor = texture(uTexture, vUV);
|
|
57
|
+
`}};function A(e,t){for(const a in e.attributes){const s=e.attributes[a],r=t[a];r?(s.format??(s.format=r.format),s.offset??(s.offset=r.offset),s.instance??(s.instance=r.instance)):U(`Attribute ${a} is not present in the shader, but is present in the geometry. Unable to infer attribute details.`)}M(e)}function M(e){const{buffers:t,attributes:a}=e,s={},r={};for(const n in t){const o=t[n];s[o.uid]=0,r[o.uid]=0}for(const n in a){const o=a[n];s[o.buffer.uid]+=g(o.format).stride}for(const n in a){const o=a[n];o.stride??(o.stride=s[o.buffer.uid]),o.start??(o.start=r[o.buffer.uid]),r[o.buffer.uid]+=g(o.format).stride}}const l=[];l[c.NONE]=void 0;l[c.DISABLED]={stencilWriteMask:0,stencilReadMask:0};l[c.RENDERING_MASK_ADD]={stencilFront:{compare:"equal",passOp:"increment-clamp"},stencilBack:{compare:"equal",passOp:"increment-clamp"}};l[c.RENDERING_MASK_REMOVE]={stencilFront:{compare:"equal",passOp:"decrement-clamp"},stencilBack:{compare:"equal",passOp:"decrement-clamp"}};l[c.MASK_ACTIVE]={stencilWriteMask:0,stencilFront:{compare:"equal",passOp:"keep"},stencilBack:{compare:"equal",passOp:"keep"}};l[c.INVERSE_MASK_ACTIVE]={stencilWriteMask:0,stencilFront:{compare:"not-equal",passOp:"keep"},stencilBack:{compare:"not-equal",passOp:"keep"}};class B{constructor(t){this._syncFunctionHash=Object.create(null),this._adaptor=t,this._systemCheck()}_systemCheck(){if(!S())throw new Error("Current environment does not allow unsafe-eval, please use pixi.js/unsafe-eval module to enable support.")}ensureUniformGroup(t){const a=this.getUniformGroupData(t);t.buffer||(t.buffer=new _({data:new Float32Array(a.layout.size/4),usage:m.UNIFORM|m.COPY_DST}))}getUniformGroupData(t){return this._syncFunctionHash[t._signature]||this._initUniformGroup(t)}_initUniformGroup(t){const a=t._signature;let s=this._syncFunctionHash[a];if(!s){const r=Object.keys(t.uniformStructures).map(d=>t.uniformStructures[d]),n=this._adaptor.createUboElements(r),o=this._generateUboSync(n.uboElements);s=this._syncFunctionHash[a]={layout:n,syncFunction:o}}return this._syncFunctionHash[a]}_generateUboSync(t){return this._adaptor.generateUboSync(t)}syncUniformGroup(t,a,s){const r=this.getUniformGroupData(t);t.buffer||(t.buffer=new _({data:new Float32Array(r.layout.size/4),usage:m.UNIFORM|m.COPY_DST}));let n=null;return a||(a=t.buffer.data,n=t.buffer.dataInt32),s||(s=0),r.syncFunction(t.uniforms,a,n,s),!0}updateUniformGroup(t){if(t.isStatic&&!t._dirtyId)return!1;t._dirtyId=0;const a=this.syncUniformGroup(t);return t.buffer.update(),a}destroy(){this._syncFunctionHash=null}}const h=[{type:"mat3x3<f32>",test:e=>e.value.a!==void 0,ubo:`
|
|
58
|
+
var matrix = uv[name].toArray(true);
|
|
59
|
+
data[offset] = matrix[0];
|
|
60
|
+
data[offset + 1] = matrix[1];
|
|
61
|
+
data[offset + 2] = matrix[2];
|
|
62
|
+
data[offset + 4] = matrix[3];
|
|
63
|
+
data[offset + 5] = matrix[4];
|
|
64
|
+
data[offset + 6] = matrix[5];
|
|
65
|
+
data[offset + 8] = matrix[6];
|
|
66
|
+
data[offset + 9] = matrix[7];
|
|
67
|
+
data[offset + 10] = matrix[8];
|
|
68
|
+
`,uniform:`
|
|
69
|
+
gl.uniformMatrix3fv(ud[name].location, false, uv[name].toArray(true));
|
|
70
|
+
`},{type:"vec4<f32>",test:e=>e.type==="vec4<f32>"&&e.size===1&&e.value.width!==void 0,ubo:`
|
|
71
|
+
v = uv[name];
|
|
72
|
+
data[offset] = v.x;
|
|
73
|
+
data[offset + 1] = v.y;
|
|
74
|
+
data[offset + 2] = v.width;
|
|
75
|
+
data[offset + 3] = v.height;
|
|
76
|
+
`,uniform:`
|
|
77
|
+
cv = ud[name].value;
|
|
78
|
+
v = uv[name];
|
|
79
|
+
if (cv[0] !== v.x || cv[1] !== v.y || cv[2] !== v.width || cv[3] !== v.height) {
|
|
80
|
+
cv[0] = v.x;
|
|
81
|
+
cv[1] = v.y;
|
|
82
|
+
cv[2] = v.width;
|
|
83
|
+
cv[3] = v.height;
|
|
84
|
+
gl.uniform4f(ud[name].location, v.x, v.y, v.width, v.height);
|
|
85
|
+
}
|
|
86
|
+
`},{type:"vec2<f32>",test:e=>e.type==="vec2<f32>"&&e.size===1&&e.value.x!==void 0,ubo:`
|
|
87
|
+
v = uv[name];
|
|
88
|
+
data[offset] = v.x;
|
|
89
|
+
data[offset + 1] = v.y;
|
|
90
|
+
`,uniform:`
|
|
91
|
+
cv = ud[name].value;
|
|
92
|
+
v = uv[name];
|
|
93
|
+
if (cv[0] !== v.x || cv[1] !== v.y) {
|
|
94
|
+
cv[0] = v.x;
|
|
95
|
+
cv[1] = v.y;
|
|
96
|
+
gl.uniform2f(ud[name].location, v.x, v.y);
|
|
97
|
+
}
|
|
98
|
+
`},{type:"vec4<f32>",test:e=>e.type==="vec4<f32>"&&e.size===1&&e.value.red!==void 0,ubo:`
|
|
99
|
+
v = uv[name];
|
|
100
|
+
data[offset] = v.red;
|
|
101
|
+
data[offset + 1] = v.green;
|
|
102
|
+
data[offset + 2] = v.blue;
|
|
103
|
+
data[offset + 3] = v.alpha;
|
|
104
|
+
`,uniform:`
|
|
105
|
+
cv = ud[name].value;
|
|
106
|
+
v = uv[name];
|
|
107
|
+
if (cv[0] !== v.red || cv[1] !== v.green || cv[2] !== v.blue || cv[3] !== v.alpha) {
|
|
108
|
+
cv[0] = v.red;
|
|
109
|
+
cv[1] = v.green;
|
|
110
|
+
cv[2] = v.blue;
|
|
111
|
+
cv[3] = v.alpha;
|
|
112
|
+
gl.uniform4f(ud[name].location, v.red, v.green, v.blue, v.alpha);
|
|
113
|
+
}
|
|
114
|
+
`},{type:"vec3<f32>",test:e=>e.type==="vec3<f32>"&&e.size===1&&e.value.red!==void 0,ubo:`
|
|
115
|
+
v = uv[name];
|
|
116
|
+
data[offset] = v.red;
|
|
117
|
+
data[offset + 1] = v.green;
|
|
118
|
+
data[offset + 2] = v.blue;
|
|
119
|
+
`,uniform:`
|
|
120
|
+
cv = ud[name].value;
|
|
121
|
+
v = uv[name];
|
|
122
|
+
if (cv[0] !== v.red || cv[1] !== v.green || cv[2] !== v.blue) {
|
|
123
|
+
cv[0] = v.red;
|
|
124
|
+
cv[1] = v.green;
|
|
125
|
+
cv[2] = v.blue;
|
|
126
|
+
gl.uniform3f(ud[name].location, v.red, v.green, v.blue);
|
|
127
|
+
}
|
|
128
|
+
`}];function k(e,t,a,s){const r=[`
|
|
129
|
+
var v = null;
|
|
130
|
+
var v2 = null;
|
|
131
|
+
var t = 0;
|
|
132
|
+
var index = 0;
|
|
133
|
+
var name = null;
|
|
134
|
+
var arrayOffset = null;
|
|
135
|
+
`];let n=0;for(let d=0;d<e.length;d++){const f=e[d],b=f.data.name;let y=!1,i=0;for(let u=0;u<h.length;u++)if(h[u].test(f.data)){i=f.offset/4,r.push(`name = "${b}";`,`offset += ${i-n};`,h[u][t]||h[u].ubo),y=!0;break}if(!y)if(f.data.size>1)i=f.offset/4,r.push(a(f,i-n));else{const u=s[f.data.type];i=f.offset/4,r.push(`
|
|
136
|
+
v = uv.${b};
|
|
137
|
+
offset += ${i-n};
|
|
138
|
+
${u};
|
|
139
|
+
`)}n=i}const o=r.join(`
|
|
140
|
+
`);return new Function("uv","data","dataInt32","offset",o)}function v(e,t){return`
|
|
141
|
+
for (let i = 0; i < ${e*t}; i++) {
|
|
142
|
+
data[offset + (((i / ${e})|0) * 4) + (i % ${e})] = v[i];
|
|
143
|
+
}
|
|
144
|
+
`}const F={f32:`
|
|
145
|
+
data[offset] = v;`,i32:`
|
|
146
|
+
dataInt32[offset] = v;`,"vec2<f32>":`
|
|
147
|
+
data[offset] = v[0];
|
|
148
|
+
data[offset + 1] = v[1];`,"vec3<f32>":`
|
|
149
|
+
data[offset] = v[0];
|
|
150
|
+
data[offset + 1] = v[1];
|
|
151
|
+
data[offset + 2] = v[2];`,"vec4<f32>":`
|
|
152
|
+
data[offset] = v[0];
|
|
153
|
+
data[offset + 1] = v[1];
|
|
154
|
+
data[offset + 2] = v[2];
|
|
155
|
+
data[offset + 3] = v[3];`,"vec2<i32>":`
|
|
156
|
+
dataInt32[offset] = v[0];
|
|
157
|
+
dataInt32[offset + 1] = v[1];`,"vec3<i32>":`
|
|
158
|
+
dataInt32[offset] = v[0];
|
|
159
|
+
dataInt32[offset + 1] = v[1];
|
|
160
|
+
dataInt32[offset + 2] = v[2];`,"vec4<i32>":`
|
|
161
|
+
dataInt32[offset] = v[0];
|
|
162
|
+
dataInt32[offset + 1] = v[1];
|
|
163
|
+
dataInt32[offset + 2] = v[2];
|
|
164
|
+
dataInt32[offset + 3] = v[3];`,"mat2x2<f32>":`
|
|
165
|
+
data[offset] = v[0];
|
|
166
|
+
data[offset + 1] = v[1];
|
|
167
|
+
data[offset + 4] = v[2];
|
|
168
|
+
data[offset + 5] = v[3];`,"mat3x3<f32>":`
|
|
169
|
+
data[offset] = v[0];
|
|
170
|
+
data[offset + 1] = v[1];
|
|
171
|
+
data[offset + 2] = v[2];
|
|
172
|
+
data[offset + 4] = v[3];
|
|
173
|
+
data[offset + 5] = v[4];
|
|
174
|
+
data[offset + 6] = v[5];
|
|
175
|
+
data[offset + 8] = v[6];
|
|
176
|
+
data[offset + 9] = v[7];
|
|
177
|
+
data[offset + 10] = v[8];`,"mat4x4<f32>":`
|
|
178
|
+
for (let i = 0; i < 16; i++) {
|
|
179
|
+
data[offset + i] = v[i];
|
|
180
|
+
}`,"mat3x2<f32>":v(3,2),"mat4x2<f32>":v(4,2),"mat2x3<f32>":v(2,3),"mat4x3<f32>":v(4,3),"mat2x4<f32>":v(2,4),"mat3x4<f32>":v(3,4)},w={...F,"mat2x2<f32>":`
|
|
181
|
+
data[offset] = v[0];
|
|
182
|
+
data[offset + 1] = v[1];
|
|
183
|
+
data[offset + 2] = v[2];
|
|
184
|
+
data[offset + 3] = v[3];
|
|
185
|
+
`};class P extends I{constructor({buffer:t,offset:a,size:s}){super(),this.uid=p("buffer"),this._resourceType="bufferResource",this._touched=0,this._resourceId=p("resource"),this._bufferResource=!0,this.destroyed=!1,this.buffer=t,this.offset=a|0,this.size=s,this.buffer.on("change",this.onBufferChange,this)}onBufferChange(){this._resourceId=p("resource"),this.emit("change",this)}destroy(t=!1){this.destroyed=!0,t&&this.buffer.destroy(),this.emit("change",this),this.buffer=null,this.removeAllListeners()}}export{P as B,l as G,B as U,x as a,F as b,k as c,h as d,A as e,D as f,R as g,C as l,O as t,w as u};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{D as E,C as ee,i as D,k as Re,m as ce,M as F,l as R,G as Xe,w as $e,T as He,n as ze,o as Je,p as Ke,F as Qe,q as Ze,t as et,A as tt,R as nt,v as he}from"./index-CrlhoBta.js";import{R as at,S as st,B as ot,a as rt,b as it,c as ct,A as lt,C as ht}from"./RenderTargetSystem-B7rwTXA1.js";let Z;function Ae(o){const e=E.get().createCanvas(6,1),t=e.getContext("2d");return t.fillStyle=o,t.fillRect(0,0,6,1),e}function Be(){if(Z!==void 0)return Z;try{const o=Ae("#ff00ff"),e=Ae("#ffff00"),a=E.get().createCanvas(6,1).getContext("2d");a.globalCompositeOperation="multiply",a.drawImage(o,0,0),a.drawImage(e,2,0);const n=a.getImageData(2,0,1,1);if(!n)Z=!1;else{const s=n.data;Z=s[0]===255&&s[1]===0&&s[2]===0}}catch{Z=!1}return Z}const d={canvas:null,convertTintToImage:!1,cacheStepsPerColorChannel:8,canUseMultiply:Be(),tintMethod:null,_canvasSourceCache:new WeakMap,_unpremultipliedCache:new WeakMap,getCanvasSource:o=>{const e=o.source,t=e==null?void 0:e.resource;if(!t)return null;const a=e.alphaMode==="premultiplied-alpha",n=e.resourceWidth??e.pixelWidth,s=e.resourceHeight??e.pixelHeight,r=n!==e.pixelWidth||s!==e.pixelHeight;if(a){if((t instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&t instanceof OffscreenCanvas)&&!r)return t;const i=d._unpremultipliedCache.get(e);if((i==null?void 0:i.resourceId)===e._resourceId)return i.canvas}if(t instanceof Uint8Array||t instanceof Uint8ClampedArray||t instanceof Int8Array||t instanceof Uint16Array||t instanceof Int16Array||t instanceof Uint32Array||t instanceof Int32Array||t instanceof Float32Array||t instanceof ArrayBuffer){const i=d._canvasSourceCache.get(e);if((i==null?void 0:i.resourceId)===e._resourceId)return i.canvas;const c=E.get().createCanvas(e.pixelWidth,e.pixelHeight),h=c.getContext("2d"),l=h.createImageData(e.pixelWidth,e.pixelHeight),f=l.data,x=t instanceof ArrayBuffer?new Uint8Array(t):new Uint8Array(t.buffer,t.byteOffset,t.byteLength);if(e.format==="bgra8unorm")for(let p=0;p<f.length&&p+3<x.length;p+=4)f[p]=x[p+2],f[p+1]=x[p+1],f[p+2]=x[p],f[p+3]=x[p+3];else f.set(x.subarray(0,f.length));return h.putImageData(l,0,0),d._canvasSourceCache.set(e,{canvas:c,resourceId:e._resourceId}),c}if(a){const i=E.get().createCanvas(e.pixelWidth,e.pixelHeight),c=i.getContext("2d",{willReadFrequently:!0});i.width=e.pixelWidth,i.height=e.pixelHeight,c.drawImage(t,0,0);const h=c.getImageData(0,0,i.width,i.height),l=h.data;for(let f=0;f<l.length;f+=4){const x=l[f+3];if(x>0){const p=255/x;l[f]=Math.min(255,l[f]*p+.5),l[f+1]=Math.min(255,l[f+1]*p+.5),l[f+2]=Math.min(255,l[f+2]*p+.5)}}return c.putImageData(h,0,0),d._unpremultipliedCache.set(e,{canvas:i,resourceId:e._resourceId}),i}if(r){const i=d._canvasSourceCache.get(e);if((i==null?void 0:i.resourceId)===e._resourceId)return i.canvas;const c=E.get().createCanvas(e.pixelWidth,e.pixelHeight),h=c.getContext("2d");return c.width=e.pixelWidth,c.height=e.pixelHeight,h.drawImage(t,0,0),d._canvasSourceCache.set(e,{canvas:c,resourceId:e._resourceId}),c}return t},getTintedCanvas:(o,e)=>{const t=o.texture,a=ee.shared.setValue(e).toHex(),n=t.tintCache||(t.tintCache={}),s=n[a],r=t.source._resourceId;if((s==null?void 0:s.tintId)===r)return s;const i=s&&"getContext"in s?s:E.get().createCanvas();return d.tintMethod(t,e,i),i.tintId=r,n[a]=i,n[a]},getTintedPattern:(o,e)=>{const t=ee.shared.setValue(e).toHex(),a=o.patternCache||(o.patternCache={}),n=o.source._resourceId;let s=a[t];return(s==null?void 0:s.tintId)===n||(d.canvas||(d.canvas=E.get().createCanvas()),d.tintMethod(o,e,d.canvas),s=d.canvas.getContext("2d").createPattern(d.canvas,"repeat"),s.tintId=n,a[t]=s),s},applyPatternTransform:(o,e,t=!0)=>{if(!e)return;const a=o;if(!a.setTransform)return;const n=globalThis.DOMMatrix;if(!n)return;const s=new n([e.a,e.b,e.c,e.d,e.tx,e.ty]);a.setTransform(t?s.inverse():s)},tintWithMultiply:(o,e,t)=>{const a=t.getContext("2d"),n=o.frame.clone(),s=o.source._resolution??o.source.resolution??1,r=o.rotate;n.x*=s,n.y*=s,n.width*=s,n.height*=s;const i=D.isVertical(r),c=i?n.height:n.width,h=i?n.width:n.height;t.width=Math.ceil(c),t.height=Math.ceil(h),a.save(),a.fillStyle=ee.shared.setValue(e).toHex(),a.fillRect(0,0,c,h),a.globalCompositeOperation="multiply";const l=d.getCanvasSource(o);if(!l){a.restore();return}r&&d._applyInverseRotation(a,r,n.width,n.height),a.drawImage(l,n.x,n.y,n.width,n.height,0,0,n.width,n.height),a.globalCompositeOperation="destination-atop",a.drawImage(l,n.x,n.y,n.width,n.height,0,0,n.width,n.height),a.restore()},tintWithOverlay:(o,e,t)=>{const a=t.getContext("2d"),n=o.frame.clone(),s=o.source._resolution??o.source.resolution??1,r=o.rotate;n.x*=s,n.y*=s,n.width*=s,n.height*=s;const i=D.isVertical(r),c=i?n.height:n.width,h=i?n.width:n.height;t.width=Math.ceil(c),t.height=Math.ceil(h),a.save(),a.globalCompositeOperation="copy",a.fillStyle=ee.shared.setValue(e).toHex(),a.fillRect(0,0,c,h),a.globalCompositeOperation="destination-atop";const l=d.getCanvasSource(o);if(!l){a.restore();return}r&&d._applyInverseRotation(a,r,n.width,n.height),a.drawImage(l,n.x,n.y,n.width,n.height,0,0,n.width,n.height),a.restore()},tintWithPerPixel:(o,e,t)=>{const a=t.getContext("2d"),n=o.frame.clone(),s=o.source._resolution??o.source.resolution??1,r=o.rotate;n.x*=s,n.y*=s,n.width*=s,n.height*=s;const i=D.isVertical(r),c=i?n.height:n.width,h=i?n.width:n.height;t.width=Math.ceil(c),t.height=Math.ceil(h),a.save(),a.globalCompositeOperation="copy";const l=d.getCanvasSource(o);if(!l){a.restore();return}r&&d._applyInverseRotation(a,r,n.width,n.height),a.drawImage(l,n.x,n.y,n.width,n.height,0,0,n.width,n.height),a.restore();const f=e>>16&255,x=e>>8&255,p=e&255,y=a.getImageData(0,0,c,h),T=y.data;for(let v=0;v<T.length;v+=4)T[v]=T[v]*f/255,T[v+1]=T[v+1]*x/255,T[v+2]=T[v+2]*p/255;a.putImageData(y,0,0)},_applyInverseRotation:(o,e,t,a)=>{const n=D.inv(e),s=D.uX(n),r=D.uY(n),i=D.vX(n),c=D.vY(n),h=-Math.min(0,s*t,i*a,s*t+i*a),l=-Math.min(0,r*t,c*a,r*t+c*a);o.transform(s,r,i,c,h,l)}};d.tintMethod=d.canUseMultiply?d.tintWithMultiply:d.tintWithPerPixel;const xe=class z{static _getPatternRepeat(e,t){const a=e&&e!=="clamp-to-edge",n=t&&t!=="clamp-to-edge";return a&&n?"repeat":a?"repeat-x":n?"repeat-y":"no-repeat"}start(e,t,a){}execute(e,t){var i,c,h,l;const a=t.elements;if(!a||!a.length)return;const n=e.renderer,s=n.canvasContext,r=s.activeContext;for(let f=0;f<a.length;f++){const x=a[f];if(!x.packAsQuad)continue;const p=x,y=p.texture,T=y?d.getCanvasSource(y):null;if(!T)continue;const v=y.source.style,H=s.smoothProperty,V=v.scaleMode!=="nearest";r[H]!==V&&(r[H]=V),s.setBlendMode(t.blendMode);const G=((i=n.globalUniforms.globalUniformData)==null?void 0:i.worldColor)??4294967295,b=p.color,P=(G>>>24&255)/255,X=(b>>>24&255)/255,se=((c=n.filter)==null?void 0:c.alphaMultiplier)??1,te=P*X*se;if(te<=0)continue;r.globalAlpha=te;const ne=G&16777215,J=b&16777215,w=Re(ce(J,ne)),S=y.frame,I=v.addressModeU??v.addressMode,de=v.addressModeV??v.addressMode,ae=z._getPatternRepeat(I,de),q=y.source._resolution??y.source.resolution??1,$=(l=(h=p.renderable)==null?void 0:h.renderGroup)==null?void 0:l.isCachedAsTexture,m=S.x*q,C=S.y*q,_=S.width*q,L=S.height*q,A=p.bounds,k=n.renderTarget.renderTarget.isRoot,U=A.minX,O=A.minY,B=A.maxX-A.minX,W=A.maxY-A.minY,N=y.rotate,u=y.uvs,Y=Math.min(u.x0,u.x1,u.x2,u.x3,u.y0,u.y1,u.y2,u.y3),j=Math.max(u.x0,u.x1,u.x2,u.x3,u.y0,u.y1,u.y2,u.y3),M=ae!=="no-repeat"&&(Y<0||j>1),pe=N&&!(!M&&(w!==16777215||N));pe?(z._tempPatternMatrix.copyFrom(p.transform),D.matrixAppendRotationInv(z._tempPatternMatrix,N,U,O,B,W),s.setContextTransform(z._tempPatternMatrix,p.roundPixels===1,void 0,$&&k)):s.setContextTransform(p.transform,p.roundPixels===1,void 0,$&&k);const oe=pe?0:U,re=pe?0:O,ue=B,fe=W;if(M){let ge=T;const K=w!==16777215&&!N,Q=S.width<=y.source.width&&S.height<=y.source.height;K&&Q&&(ge=d.getTintedCanvas({texture:y},w));const me=r.createPattern(ge,ae);if(!me)continue;const _e=ue,Pe=fe;if(_e===0||Pe===0)continue;const Me=1/_e,be=1/Pe,we=(u.x1-u.x0)*Me,ke=(u.y1-u.y0)*Me,Se=(u.x3-u.x0)*be,Ie=(u.y3-u.y0)*be,Ye=u.x0-we*oe-Se*re,je=u.y0-ke*oe-Ie*re,ve=y.source.pixelWidth,ye=y.source.pixelHeight;z._tempPatternMatrix.set(we*ve,ke*ye,Se*ve,Ie*ye,Ye*ve,je*ye),d.applyPatternTransform(me,z._tempPatternMatrix),r.fillStyle=me,r.fillRect(oe,re,ue,fe)}else{const K=w!==16777215||N?d.getTintedCanvas({texture:y},w):T,Q=K!==T;r.drawImage(K,Q?0:m,Q?0:C,Q?K.width:_,Q?K.height:L,oe,re,ue,fe)}}}};xe._tempPatternMatrix=new F;xe.extension={type:[R.CanvasPipesAdaptor],name:"batch"};let dt=xe;class We{constructor(e){this._colorStack=[],this._colorStackIndex=0,this._currentColor=0,this._renderer=e}buildStart(){this._colorStack[0]=15,this._colorStackIndex=1,this._currentColor=15}push(e,t,a){this._renderer.renderPipes.batch.break(a);const n=this._colorStack;n[this._colorStackIndex]=n[this._colorStackIndex-1]&e.mask;const s=this._colorStack[this._colorStackIndex];s!==this._currentColor&&(this._currentColor=s,a.add({renderPipeId:"colorMask",colorMask:s,canBundle:!1})),this._colorStackIndex++}pop(e,t,a){this._renderer.renderPipes.batch.break(a);const n=this._colorStack;this._colorStackIndex--;const s=n[this._colorStackIndex-1];s!==this._currentColor&&(this._currentColor=s,a.add({renderPipeId:"colorMask",colorMask:s,canBundle:!1}))}execute(e){}destroy(){this._renderer=null,this._colorStack=null}}We.extension={type:[R.CanvasPipes],name:"colorMask"};function pt(o,e,t,a,n,s){s=Math.max(0,Math.min(s,Math.min(a,n)/2)),o.moveTo(e+s,t),o.lineTo(e+a-s,t),o.quadraticCurveTo(e+a,t,e+a,t+s),o.lineTo(e+a,t+n-s),o.quadraticCurveTo(e+a,t+n,e+a-s,t+n),o.lineTo(e+s,t+n),o.quadraticCurveTo(e,t+n,e,t+n-s),o.lineTo(e,t+s),o.quadraticCurveTo(e,t,e+s,t)}function De(o,e){switch(e.type){case"rectangle":{const t=e;o.rect(t.x,t.y,t.width,t.height);break}case"roundedRectangle":{const t=e;pt(o,t.x,t.y,t.width,t.height,t.radius);break}case"circle":{const t=e;o.moveTo(t.x+t.radius,t.y),o.arc(t.x,t.y,t.radius,0,Math.PI*2);break}case"ellipse":{const t=e;o.ellipse?(o.moveTo(t.x+t.halfWidth,t.y),o.ellipse(t.x,t.y,t.halfWidth,t.halfHeight,0,0,Math.PI*2)):(o.save(),o.translate(t.x,t.y),o.scale(t.halfWidth,t.halfHeight),o.moveTo(1,0),o.arc(0,0,1,0,Math.PI*2),o.restore());break}case"triangle":{const t=e;o.moveTo(t.x,t.y),o.lineTo(t.x2,t.y2),o.lineTo(t.x3,t.y3),o.closePath();break}case"polygon":default:{const t=e,a=t.points;if(!(a!=null&&a.length))break;o.moveTo(a[0],a[1]);for(let n=2;n<a.length;n+=2)o.lineTo(a[n],a[n+1]);t.closePath&&o.closePath();break}}}function ut(o,e){if(!(e!=null&&e.length))return!1;for(let t=0;t<e.length;t++){const a=e[t];if(!(a!=null&&a.shape))continue;const n=a.transform,s=n&&!n.isIdentity();s&&(o.save(),o.transform(n.a,n.b,n.c,n.d,n.tx,n.ty)),De(o,a.shape),s&&o.restore()}return!0}class Ge{constructor(e){this._warnedMaskTypes=new Set,this._canvasMaskStack=[],this._renderer=e}push(e,t,a){this._renderer.renderPipes.batch.break(a),a.add({renderPipeId:"stencilMask",action:"pushMaskBegin",mask:e,inverse:t._maskOptions.inverse,canBundle:!1})}pop(e,t,a){this._renderer.renderPipes.batch.break(a),a.add({renderPipeId:"stencilMask",action:"popMaskEnd",mask:e,inverse:t._maskOptions.inverse,canBundle:!1})}execute(e){var l,f,x;if(e.action!=="pushMaskBegin"&&e.action!=="popMaskEnd")return;const t=this._renderer,a=t.canvasContext,n=a==null?void 0:a.activeContext;if(!n)return;if(e.action==="popMaskEnd"){this._canvasMaskStack.pop()&&n.restore();return}e.inverse&&this._warnOnce("inverse","CanvasRenderer: inverse masks are not supported on Canvas2D; ignoring inverse flag.");const s=e.mask.mask;if(!(s instanceof Xe)){this._warnOnce("nonGraphics","CanvasRenderer: only Graphics masks are supported in Canvas2D; skipping mask."),this._canvasMaskStack.push(!1);return}const r=s,i=(l=r.context)==null?void 0:l.instructions;if(!(i!=null&&i.length)){this._canvasMaskStack.push(!1);return}n.save(),a.setContextTransform(r.groupTransform,(t._roundPixels|r._roundPixels)===1),n.beginPath();let c=!1,h=!1;for(let p=0;p<i.length;p++){const y=i[p],T=y.action;if(T!=="fill"&&T!=="stroke")continue;const v=y.data,H=(f=v==null?void 0:v.path)==null?void 0:f.shapePath;if(!((x=H==null?void 0:H.shapePrimitives)!=null&&x.length))continue;const V=H.shapePrimitives;for(let G=0;G<V.length;G++){const b=V[G];if(!(b!=null&&b.shape))continue;const P=b.transform,X=P&&!P.isIdentity();X&&(n.save(),n.transform(P.a,P.b,P.c,P.d,P.tx,P.ty)),De(n,b.shape),h=ut(n,b.holes)||h,c=!0,X&&n.restore()}}if(!c){n.restore(),this._canvasMaskStack.push(!1);return}h?n.clip("evenodd"):n.clip(),this._canvasMaskStack.push(!0)}destroy(){this._renderer=null,this._warnedMaskTypes=null,this._canvasMaskStack=null}_warnOnce(e,t){this._warnedMaskTypes.has(e)||(this._warnedMaskTypes.add(e),$e(t))}}Ge.extension={type:[R.CanvasPipes],name:"stencilMask"};const g="source-over";function ft(){const o=Be(),e=Object.create(null);return e.inherit=g,e.none=g,e.normal="source-over",e.add="lighter",e.multiply=o?"multiply":g,e.screen=o?"screen":g,e.overlay=o?"overlay":g,e.darken=o?"darken":g,e.lighten=o?"lighten":g,e["color-dodge"]=o?"color-dodge":g,e["color-burn"]=o?"color-burn":g,e["hard-light"]=o?"hard-light":g,e["soft-light"]=o?"soft-light":g,e.difference=o?"difference":g,e.exclusion=o?"exclusion":g,e.saturation=o?"saturation":g,e.color=o?"color":g,e.luminosity=o?"luminosity":g,e["linear-burn"]=o?"color-burn":g,e["linear-dodge"]=o?"color-dodge":g,e["linear-light"]=o?"hard-light":g,e["pin-light"]=o?"hard-light":g,e["vivid-light"]=o?"hard-light":g,e["hard-mix"]=g,e.negation=o?"difference":g,e["normal-npm"]=e.normal,e["add-npm"]=e.add,e["screen-npm"]=e.screen,e.erase="destination-out",e.subtract=g,e.divide=g,e.min=g,e.max=g,e}const gt=new F;class Ue{constructor(e){this.activeResolution=1,this.smoothProperty="imageSmoothingEnabled",this.blendModes=ft(),this._activeBlendMode="normal",this._projTransform=null,this._outerBlend=!1,this._warnedBlendModes=new Set,this._renderer=e}resolutionChange(e){this.activeResolution=e}init(){const e=this._renderer.background.alpha<1;if(this.rootContext=this._renderer.canvas.getContext("2d",{alpha:e}),this.activeContext=this.rootContext,this.activeResolution=this._renderer.resolution,!this.rootContext.imageSmoothingEnabled){const t=this.rootContext;t.webkitImageSmoothingEnabled?this.smoothProperty="webkitImageSmoothingEnabled":t.mozImageSmoothingEnabled?this.smoothProperty="mozImageSmoothingEnabled":t.oImageSmoothingEnabled?this.smoothProperty="oImageSmoothingEnabled":t.msImageSmoothingEnabled&&(this.smoothProperty="msImageSmoothingEnabled")}}setContextTransform(e,t,a,n){var h;const s=n?F.IDENTITY:((h=this._renderer.globalUniforms.globalUniformData)==null?void 0:h.worldTransformMatrix)||F.IDENTITY;let r=gt;r.copyFrom(s),r.append(e);const i=this._projTransform,c=this.activeResolution;if(a=a||c,i){const l=F.shared;l.copyFrom(r),l.prepend(i),r=l}t?this.activeContext.setTransform(r.a*a,r.b*a,r.c*a,r.d*a,r.tx*c|0,r.ty*c|0):this.activeContext.setTransform(r.a*a,r.b*a,r.c*a,r.d*a,r.tx*c,r.ty*c)}clear(e,t){const a=this.activeContext,n=this._renderer;if(a.clearRect(0,0,n.width,n.height),e){const s=ee.shared.setValue(e);a.globalAlpha=t??s.alpha,a.fillStyle=s.toHex(),a.fillRect(0,0,n.width,n.height),a.globalAlpha=1}}setBlendMode(e){if(this._activeBlendMode===e)return;this._activeBlendMode=e,this._outerBlend=!1;const t=this.blendModes[e];if(!t){this._warnedBlendModes.has(e)||(console.warn(`CanvasRenderer: blend mode "${e}" is not supported in Canvas2D; falling back to "source-over".`),this._warnedBlendModes.add(e)),this.activeContext.globalCompositeOperation="source-over";return}this.activeContext.globalCompositeOperation=t}destroy(){this.rootContext=null,this.activeContext=null,this._warnedBlendModes.clear()}}Ue.extension={type:[R.CanvasSystem],name:"canvasContext"};class Oe{constructor(){this.maxTextures=16,this.maxBatchableTextures=16,this.maxUniformBindings=0}init(){}}Oe.extension={type:[R.CanvasSystem],name:"limits"};const mt="#808080",ie=new F,vt=new F,yt=new F,Ce=new F;function Ct(o,e,t){o.beginPath();for(let a=0;a<t.length;a+=3){const n=t[a]*2,s=t[a+1]*2,r=t[a+2]*2;o.moveTo(e[n],e[n+1]),o.lineTo(e[s],e[s+1]),o.lineTo(e[r],e[r+1]),o.closePath()}o.fill()}function xt(o){return`#${(o&16777215).toString(16).padStart(6,"0")}`}function Tt(o,e,t,a,n,s){s=Math.max(0,Math.min(s,Math.min(a,n)/2)),o.moveTo(e+s,t),o.lineTo(e+a-s,t),o.quadraticCurveTo(e+a,t,e+a,t+s),o.lineTo(e+a,t+n-s),o.quadraticCurveTo(e+a,t+n,e+a-s,t+n),o.lineTo(e+s,t+n),o.quadraticCurveTo(e,t+n,e,t+n-s),o.lineTo(e,t+s),o.quadraticCurveTo(e,t,e+s,t)}function le(o,e){switch(e.type){case"rectangle":{const t=e;o.rect(t.x,t.y,t.width,t.height);break}case"roundedRectangle":{const t=e;Tt(o,t.x,t.y,t.width,t.height,t.radius);break}case"circle":{const t=e;o.arc(t.x,t.y,t.radius,0,Math.PI*2);break}case"ellipse":{const t=e;o.ellipse?o.ellipse(t.x,t.y,t.halfWidth,t.halfHeight,0,0,Math.PI*2):(o.save(),o.translate(t.x,t.y),o.scale(t.halfWidth,t.halfHeight),o.arc(0,0,1,0,Math.PI*2),o.restore());break}case"triangle":{const t=e;o.moveTo(t.x,t.y),o.lineTo(t.x2,t.y2),o.lineTo(t.x3,t.y3),o.closePath();break}case"polygon":default:{const t=e,a=t.points;if(!(a!=null&&a.length))break;o.moveTo(a[0],a[1]);for(let n=2;n<a.length;n+=2)o.lineTo(a[n],a[n+1]);t.closePath&&o.closePath();break}}}function _t(o,e){if(!(e!=null&&e.length))return!1;for(let t=0;t<e.length;t++){const a=e[t];if(!(a!=null&&a.shape))continue;const n=a.transform,s=n&&!n.isIdentity();s&&(o.save(),o.transform(n.a,n.b,n.c,n.d,n.tx,n.ty)),le(o,a.shape),s&&o.restore()}return!0}function Pt(o,e,t,a){const n=o.fill;if(n instanceof Qe){n.buildGradient();const r=n.texture;if(r){const i=d.getTintedPattern(r,e),c=t?Ce.copyFrom(t).scale(r.source.pixelWidth,r.source.pixelHeight):Ce.copyFrom(n.transform);return a&&!o.textureSpace&&c.append(a),d.applyPatternTransform(i,c),i}}if(n instanceof Ze){const r=d.getTintedPattern(n.texture,e);return d.applyPatternTransform(r,n.transform),r}const s=o.texture;if(s&&s!==He.WHITE){if(!s.source.resource)return mt;const r=d.getTintedPattern(s,e),i=t?Ce.copyFrom(t).scale(s.source.pixelWidth,s.source.pixelHeight):o.matrix;return d.applyPatternTransform(r,i),r}return xt(e)}class Ee{constructor(){this.shader=null}contextChange(e){}execute(e,t){var V,G,b,P,X,se,te;const a=e.renderer,n=a.canvasContext,s=n.activeContext,r=t.groupTransform,i=((V=a.globalUniforms.globalUniformData)==null?void 0:V.worldColor)??4294967295,c=t.groupColorAlpha,h=(i>>>24&255)/255,l=(c>>>24&255)/255,f=((G=a.filter)==null?void 0:G.alphaMultiplier)??1,x=h*l*f;if(x<=0)return;const p=i&16777215,y=c&16777215,T=Re(ce(y,p)),v=a._roundPixels|t._roundPixels;s.save(),n.setContextTransform(r,v===1),n.setBlendMode(t.groupBlendMode);const H=t.context.instructions;for(let ne=0;ne<H.length;ne++){const J=H[ne];if(J.action==="texture"){const m=J.data,C=m.image,_=C?d.getCanvasSource(C):null;if(!_)continue;const L=m.alpha*x;if(L<=0)continue;const A=ce(m.style,T);s.globalAlpha=L;let k=_;A!==16777215&&(k=d.getTintedCanvas({texture:C},A));const U=C.frame,O=C.source._resolution??C.source.resolution??1;let B=U.x*O,W=U.y*O;const N=U.width*O,u=U.height*O;k!==_&&(B=0,W=0);const Y=m.transform,j=Y&&!Y.isIdentity(),M=C.rotate;j||M?(ie.copyFrom(r),j&&ie.append(Y),M&&D.matrixAppendRotationInv(ie,M,m.dx,m.dy,m.dw,m.dh),n.setContextTransform(ie,v===1)):n.setContextTransform(r,v===1),s.drawImage(k,B,W,k===_?N:k.width,k===_?u:k.height,M?0:m.dx,M?0:m.dy,m.dw,m.dh),(j||M)&&n.setContextTransform(r,v===1);continue}const w=J.data,S=(b=w==null?void 0:w.path)==null?void 0:b.shapePath;if(!((P=S==null?void 0:S.shapePrimitives)!=null&&P.length))continue;const I=w.style,de=ce(I.color,T),ae=I.alpha*x;if(ae<=0)continue;const q=J.action==="stroke";if(s.globalAlpha=ae,q){const m=I;s.lineWidth=m.width,s.lineCap=m.cap,s.lineJoin=m.join,s.miterLimit=m.miterLimit}const $=S.shapePrimitives;if(!q&&((te=(se=(X=w.hole)==null?void 0:X.shapePath)==null?void 0:se.shapePrimitives)!=null&&te.length)){const m=$[$.length-1];m.holes=w.hole.shapePath.shapePrimitives}for(let m=0;m<$.length;m++){const C=$[m];if(!(C!=null&&C.shape))continue;const _=C.transform,L=_&&!_.isIdentity(),A=I.texture&&I.texture!==He.WHITE,k=I.textureSpace==="global"?_:null,U=A?ze(vt,I,C.shape,k):null,O=L?yt.copyFrom(r).append(_):r,B=Pt(I,de,U,O);if(L&&(s.save(),s.transform(_.a,_.b,_.c,_.d,_.tx,_.ty)),q){const W=I;if(W.alignment!==.5&&!W.pixelLine){const u=[],Y=[],j=[],M=Je[C.shape.type];if(M!=null&&M.build(C.shape,u)){const Te=C.shape.closePath??!0;Ke(u,W,!1,Te,Y,j),s.fillStyle=B,Ct(s,Y,j)}else s.strokeStyle=B,s.beginPath(),le(s,C.shape),s.stroke()}else s.strokeStyle=B,s.beginPath(),le(s,C.shape),s.stroke()}else s.fillStyle=B,s.beginPath(),le(s,C.shape),_t(s,C.holes)?s.fill("evenodd"):s.fill();L&&s.restore()}}s.restore()}destroy(){this.shader=null}}Ee.extension={type:[R.CanvasPipesAdaptor],name:"graphics"};class Mt{init(e,t){this._renderer=e,this._renderTargetSystem=t}initGpuRenderTarget(e){const t=e.colorTexture,{canvas:a,context:n}=this._ensureCanvas(t);return{canvas:a,context:n,width:a.width,height:a.height}}resizeGpuRenderTarget(e){const t=e.colorTexture,{canvas:a}=this._ensureCanvas(t);a.width=e.pixelWidth,a.height=e.pixelHeight}startRenderPass(e,t,a,n){const s=this._renderTargetSystem.getGpuRenderTarget(e);this._renderer.canvasContext.activeContext=s.context,this._renderer.canvasContext.activeResolution=e.resolution,t&&this.clear(e,t,a,n)}clear(e,t,a,n){const r=this._renderTargetSystem.getGpuRenderTarget(e).context,i=n||{x:0,y:0,width:e.pixelWidth,height:e.pixelHeight};if(r.setTransform(1,0,0,1,0,0),r.clearRect(i.x,i.y,i.width,i.height),a){const c=ee.shared.setValue(a);c.alpha>0&&(r.globalAlpha=c.alpha,r.fillStyle=c.toHex(),r.fillRect(i.x,i.y,i.width,i.height),r.globalAlpha=1)}}finishRenderPass(){}copyToTexture(e,t,a,n,s){const i=this._renderTargetSystem.getGpuRenderTarget(e).canvas,c=t.source,{context:h}=this._ensureCanvas(c),l=(s==null?void 0:s.x)??0,f=(s==null?void 0:s.y)??0;return h.drawImage(i,a.x,a.y,n.width,n.height,l,f,n.width,n.height),c.update(),t}destroyGpuRenderTarget(e){}_ensureCanvas(e){let t=e.resource;(!t||!et.test(t))&&(t=E.get().createCanvas(e.pixelWidth,e.pixelHeight),e.resource=t),(t.width!==e.pixelWidth||t.height!==e.pixelHeight)&&(t.width=e.pixelWidth,t.height=e.pixelHeight);const a=t.getContext("2d");return{canvas:t,context:a}}}class Fe extends at{constructor(e){super(e),this.adaptor=new Mt,this.adaptor.init(e,this)}}Fe.extension={type:[R.CanvasSystem],name:"renderTarget"};class Ve{constructor(e){}init(){}initSource(e){}generateCanvas(e){const t=E.get().createCanvas(),a=t.getContext("2d"),n=d.getCanvasSource(e);if(!n)return t;const s=e.frame,r=e.source._resolution??e.source.resolution??1,i=s.x*r,c=s.y*r,h=s.width*r,l=s.height*r;return t.width=Math.ceil(h),t.height=Math.ceil(l),a.drawImage(n,i,c,h,l,0,0,h,l),t}getPixels(e){const t=this.generateCanvas(e);return{pixels:t.getContext("2d",{willReadFrequently:!0}).getImageData(0,0,t.width,t.height).data,width:t.width,height:t.height}}destroy(){}}Ve.extension={type:[R.CanvasSystem],name:"texture"};const bt=[...st,Ue,Oe,Ve,Fe],wt=[ot,rt,it,ct,lt,Ge,We,ht],kt=[dt,Ee],qe=[],Le=[],Ne=[];he.handleByNamedList(R.CanvasSystem,qe);he.handleByNamedList(R.CanvasPipes,Le);he.handleByNamedList(R.CanvasPipesAdaptor,Ne);he.add(...bt,...wt,...kt);class At extends tt{constructor(){const e={name:"canvas",type:nt.CANVAS,systems:qe,renderPipes:Le,renderPipeAdaptors:Ne};super(e)}}export{At as CanvasRenderer};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var W=Object.defineProperty;var G=(c,a,o)=>a in c?W(c,a,{enumerable:!0,configurable:!0,writable:!0,value:o}):c[a]=o;var k=(c,a,o)=>G(c,typeof a!="symbol"?a+"":a,o);import{r as g,J as b,a as u,b as m,c as B,d as I,j as w,s as O}from"./index-CrlhoBta.js";const N=/\bava\b/i;function U(c){return N.test(c)}function q(c){if(!c)return[];if(c.length<=b.ttsSplitLength)return[c];const a=c.match(/[^.!?]+[.!?]+\s*/g)||[c],o=[];let n="";for(const e of a)n.length+e.length>b.ttsSplitLength&&n?(o.push(n.trim()),n=e):n+=e;return n.trim()&&o.push(n.trim()),o}function D(c){const a=globalThis.SpeechRecognition||globalThis.webkitSpeechRecognition,o=!!a;let n=null,e=null,s=null,t=null,i=!1,d=!1;function l(){if(a&&!(n!=null&&n._started)){d=!1,n=new a,n.continuous=!0,n.interimResults=!0,n.lang="pt-BR",n.onresult=p=>{var P;const r=p.results[p.resultIndex];if(!r)return;const f=((P=r[0])==null?void 0:P.transcript)??"",h=r.isFinal;if(i&&h){const R=f.replace(N,"").trim();R&&(i=!1,c.onUtterance(R));return}if(U(f)&&!d){const R=f.replace(/^.*?\bava\b\s*/i,"").trim();R&&h?(d=!0,c.onWakeWord(R)):R?h&&(d=!0,c.onWakeWord(R)):(d=!0,c.onWakeWord(""),i=!0)}},n.onend=()=>{if(n)try{n.start()}catch{}},n.onerror=()=>{};try{n.start()}catch{}}}function x(){if(n){const p=n;n=null;try{p.stop()}catch{}}}async function S(){try{t=await navigator.mediaDevices.getUserMedia({audio:!0}),s=new AudioContext;const p=s.createMediaStreamSource(t);e=s.createAnalyser(),e.fftSize=256,p.connect(e)}catch{e=null}}function T(p){x(),speechSynthesis.cancel();const y=q(p);if(y.length===0){c.onTTSEnd(),l();return}y.forEach((r,f)=>{const h=new SpeechSynthesisUtterance(r);h.lang="pt-BR",h.rate=1.05,h.pitch=1.25;const R=speechSynthesis.getVoices().filter(v=>v.lang.startsWith("pt")),M=R.find(v=>/female|femin|luciana|joana|francisca|fernanda|raquel|google.*br/i.test(v.name)&&!/male|masculin|felipe|daniel|luciano|ricardo/i.test(v.name))??R.find(v=>/luciana|francisca|fernanda/i.test(v.name));h.voice=M??R[0]??null,f===y.length-1&&(h.onend=()=>{c.onTTSEnd(),l()},h.onerror=()=>{c.onTTSEnd(),l()}),speechSynthesis.speak(h)})}function A(){speechSynthesis.cancel()}return{start:()=>{l(),typeof navigator<"u"&&navigator.mediaDevices&&S()},stop:()=>{x(),A(),t&&(t.getTracks().forEach(p=>p.stop()),t=null),s&&(s.close(),s=null),e=null},speak:T,cancelSpeech:A,isSupported:o,getAnalyser:()=>e}}function L(c){const a=g.useRef(null),o=g.useRef(c);o.current=c,g.useEffect(()=>{const t=D({onWakeWord:i=>o.current.onWakeWord(i),onUtterance:i=>o.current.onUtterance(i),onTTSEnd:()=>o.current.onTTSEnd()});return a.current=t,t.start(),()=>t.stop()},[]);const n=g.useCallback(t=>{var i;(i=a.current)==null||i.speak(t)},[]),e=g.useCallback(()=>{var t;(t=a.current)==null||t.cancelSpeech()},[]),s=g.useCallback(()=>{var t;return((t=a.current)==null?void 0:t.getAnalyser())??null},[]);return{speak:n,cancelSpeech:e,getAnalyser:s,isSupported:!!(globalThis.SpeechRecognition||globalThis.webkitSpeechRecognition)}}const j={STANDBY:u.orbStandby,GREETING:u.orbListening,LISTENING:u.orbListening,PROCESSING:u.orbProcessing,SPEAKING:u.orbSpeaking};class F{constructor(a){k(this,"canvas");k(this,"ctx");k(this,"particles");k(this,"destroyed",!1);this.canvas=a,this.ctx=a.getContext("2d"),this.particles=this.initParticles()}getParticleCount(){return this.particles.length}initParticles(){const a=b.particleCount,o=[];for(let n=0;n<a;n++)o.push({x:Math.random()*this.canvas.width,y:Math.random()*this.canvas.height,vx:(Math.random()-.5)*.5,vy:(Math.random()-.5)*.5,radius:b.particleMinRadius+Math.random()*(b.particleMaxRadius-b.particleMinRadius),alpha:.2+Math.random()*.6});return o}render(a){if(this.destroyed)return;const{ctx:o,canvas:n}=this,e=n.width,s=n.height,t=e/2,i=s/2;o.clearRect(0,0,e,s),o.fillStyle=u.background,o.fillRect(0,0,e,s),this.drawGrid(e,s,a.time),this.updateAndDrawParticles(a.mode,e,s),this.drawOrb(t,i,a),a.mode==="LISTENING"&&a.amplitudes&&this.drawWaveform(t,i,a.amplitudes),this.drawSquadsPanel(a.squads,s),this.drawStatusPanel(a,e,s),this.drawTranscript(a.transcript,t,s),o.fillStyle=u.textAccent,o.font="11px monospace",o.textAlign="center",o.textBaseline="bottom",o.globalAlpha=.5,o.fillText("── EXPXAGENTS AVA v1 ──",t,s-8),o.globalAlpha=1}drawGrid(a,o,n){const e=this.ctx,s=b.gridSpacing;e.strokeStyle=u.grid,e.lineWidth=.5,e.beginPath();for(let t=0;t<a;t+=s)e.moveTo(t,0),e.lineTo(t,o);e.stroke(),e.beginPath();for(let t=0;t<o;t+=s)e.moveTo(0,t),e.lineTo(a,t);e.stroke()}updateAndDrawParticles(a,o,n){const e=this.ctx,s=a==="LISTENING"||a==="PROCESSING"?2:1;for(const t of this.particles)t.x+=t.vx*s,t.y+=t.vy*s,t.x<0&&(t.x=o),t.x>o&&(t.x=0),t.y<0&&(t.y=n),t.y>n&&(t.y=0),e.beginPath(),e.arc(t.x,t.y,t.radius,0,Math.PI*2),e.fillStyle=u.particleStart,e.globalAlpha=t.alpha,e.fill();e.globalAlpha=1}drawOrb(a,o,n){const e=this.ctx,s=b.orbRadius,t=j[n.mode];e.save(),e.shadowBlur=n.mode==="STANDBY"?20:40,e.shadowColor=t;const i=e.createRadialGradient(a,o,0,a,o,s);if(i.addColorStop(0,t),i.addColorStop(1,"transparent"),e.fillStyle=i,e.beginPath(),e.arc(a,o,s,0,Math.PI*2),e.fill(),e.strokeStyle=t,e.lineWidth=b.orbRingWidth,e.beginPath(),n.mode==="PROCESSING"){const l=n.time/500%(Math.PI*2);e.arc(a,o,s+8,l,l+Math.PI*1.5)}else e.arc(a,o,s+8,0,Math.PI*2);if(e.stroke(),n.mode==="STANDBY"){const l=.5+.3*Math.sin(n.time/1500);e.globalAlpha=l,e.beginPath(),e.arc(a,o,s+4,0,Math.PI*2),e.fillStyle=t,e.fill(),e.globalAlpha=1}if(n.mode==="SPEAKING"){const l=.6+.4*Math.sin(n.time/200);e.globalAlpha=l,e.beginPath(),e.arc(a,o,s*(.9+.1*Math.sin(n.time/300)),0,Math.PI*2),e.fillStyle=t,e.fill(),e.globalAlpha=1}e.restore(),e.fillStyle=t,e.font="bold 12px monospace",e.textAlign="center",e.textBaseline="top";const d=n.mode==="PROCESSING"?"Processando...":n.mode;e.fillText(d,a,o+s+20),e.fillStyle=u.textPrimary,e.font="bold 16px monospace",e.fillText("AVA",a,o-s-30)}drawWaveform(a,o,n){const e=this.ctx,s=b.waveformBars,t=b.waveformMaxHeight,i=b.orbRadius+16;e.strokeStyle=u.orbListening,e.lineWidth=2;for(let d=0;d<s;d++){const l=d/s*Math.PI*2-Math.PI/2,x=Math.floor(d/s*n.length),S=(n[x]??0)/255,T=S*t,A=a+Math.cos(l)*i,p=o+Math.sin(l)*i,y=a+Math.cos(l)*(i+T),r=o+Math.sin(l)*(i+T);e.beginPath(),e.moveTo(A,p),e.lineTo(y,r),e.globalAlpha=.6+S*.4,e.stroke()}e.globalAlpha=1}drawSquadsPanel(a,o){const n=this.ctx,e=b.panelWidth,s=b.panelPadding,t=Math.max(200,a.length*28+60),i=(o-t)/2;n.fillStyle=u.panelBg,n.fillRect(s,i,e,t),n.strokeStyle=u.panelBorder,n.lineWidth=1,n.strokeRect(s,i,e,t),n.fillStyle=u.textAccent,n.font="bold 13px monospace",n.textAlign="left",n.textBaseline="top",n.fillText("SQUADS",s+10,i+10),n.font="12px monospace",a.forEach((d,l)=>{const x=i+40+l*28,S=d.active?"●":"○";n.fillStyle=d.active?u.orbSpeaking:u.textPrimary,n.fillText(`${S} ${d.name}`,s+10,x)})}drawStatusPanel(a,o,n){var p;const e=this.ctx,s=b.panelWidth,t=b.panelPadding,i=200,d=(n-i)/2,l=o-s-t;e.fillStyle=u.panelBg,e.fillRect(l,d,s,i),e.strokeStyle=u.panelBorder,e.lineWidth=1,e.strokeRect(l,d,s,i),e.fillStyle=u.textAccent,e.font="bold 13px monospace",e.textAlign="left",e.textBaseline="top",e.fillText("STATUS",l+10,d+10),e.font="12px monospace";const x=Math.floor(a.time/1e3),S=String(Math.floor(x/60)).padStart(2,"0"),T=String(x%60).padStart(2,"0"),A=[`Mode: ${a.mode}`,"Mic: ON",`Squad: ${((p=a.squads.find(y=>y.active))==null?void 0:p.name)??"---"}`,`Time: ${S}:${T}`];a.userName&&A.push(`User: ${a.userName}`),A.forEach((y,r)=>{e.fillStyle=u.textPrimary,e.fillText(y,l+10,d+40+r*24)})}drawTranscript(a,o,n){const e=this.ctx,s=a.slice(-10);if(s.length===0)return;const t=b.transcriptLineHeight,i=Math.min(700,this.canvas.width-100),d=s.length*t+24,l=o-i/2,x=n-d-40;e.fillStyle=u.panelBg,e.fillRect(l,x,i,d),e.strokeStyle=u.panelBorder,e.lineWidth=1,e.strokeRect(l,x,i,d),e.font="12px monospace",e.textAlign="left",e.textBaseline="top",s.forEach((S,T)=>{const A=x+12+T*t,p=S.role==="user"?"User: ":"Ava: ";e.fillStyle=S.role==="user"?u.textAccent:u.textAva;const y=Math.floor((i-20)/7),r=p+(S.text.length>y?S.text.slice(0,y-3)+"...":S.text);e.fillText(r,l+10,A)})}destroy(){this.destroyed=!0}}function _(){const c=g.useRef(null),a=g.useRef(null),o=g.useRef(0),n=g.useRef(Date.now()),[e,s]=g.useState(""),t=m(r=>r.messages);m(r=>r.userName);const i=B(r=>r.user);I(r=>r.squads),g.useEffect(()=>{i!=null&&i.username&&m.getState().setUserName(i.username)},[i==null?void 0:i.username]);const d=g.useRef(0);g.useEffect(()=>{if(t.length>d.current){const r=t[t.length-1];r.role==="assistant"&&m.getState().mode==="PROCESSING"&&(m.getState().setMode("SPEAKING"),S.current.speak(r.content))}d.current=t.length},[t]);const l=g.useCallback(r=>{const f=["Certo, vou verificar isso agora.","Entendido, deixa comigo.","Um momento, já estou processando.","Certo, já estou buscando a informação."],h=f[Math.floor(Math.random()*f.length)];S.current.speak(h)},[]),x=g.useCallback(r=>{const f=m.getState().selectedSquad??"_jarvis";m.getState().addMessage("user",r),l(r),m.getState().setMode("PROCESSING"),m.getState().clearStandbyTimer(),O(f,r)},[l]),S=g.useRef({speak:r=>{}}),{speak:T,getAnalyser:A,isSupported:p}=L({onWakeWord:r=>{const f=m.getState().mode;if(!(f==="PROCESSING"||f==="SPEAKING"))if(r)x(r);else{m.getState().setMode("GREETING");const h=m.getState().userName||"";T(h?`Olá ${h}, como posso ajudar?`:"Olá, como posso ajudar?")}},onUtterance:r=>{const f=m.getState().mode;f==="PROCESSING"||f==="SPEAKING"||x(r)},onTTSEnd:()=>{const r=m.getState().mode;(r==="GREETING"||r==="SPEAKING")&&(m.getState().setMode("LISTENING"),m.getState().startStandbyTimer())}});S.current.speak=T,g.useEffect(()=>{const r=c.current;if(!r)return;const f=()=>{r.width=window.innerWidth,r.height=window.innerHeight};f(),window.addEventListener("resize",f);const h=new F(r);a.current=h;const P=()=>{const R=A();let M=null;if(R){const E=new ArrayBuffer(R.frequencyBinCount);M=new Uint8Array(E),R.getByteFrequencyData(M)}const v=m.getState(),C=I.getState().squads;h.render({mode:v.mode,time:Date.now()-n.current,amplitudes:M,squads:C.map(E=>({name:E.code,active:E.code===v.selectedSquad})),transcript:v.messages.map(E=>({role:E.role,text:E.content})),userName:v.userName}),o.current=requestAnimationFrame(P)};return o.current=requestAnimationFrame(P),()=>{cancelAnimationFrame(o.current),h.destroy(),window.removeEventListener("resize",f)}},[A]),g.useEffect(()=>()=>{m.getState().clearStandbyTimer()},[]);const y=r=>{r.preventDefault(),e.trim()&&(x(e.trim()),s(""))};return w.jsxs("div",{style:{position:"fixed",inset:0,background:u.background,zIndex:1e3},children:[w.jsx("canvas",{ref:c,style:{display:"block",width:"100%",height:"100%"}}),!p&&w.jsx("div",{style:{position:"absolute",top:20,left:"50%",transform:"translateX(-50%)",color:u.orbProcessing,fontFamily:"monospace",fontSize:13,background:"rgba(255, 140, 0, 0.1)",border:"1px solid rgba(255, 140, 0, 0.3)",borderRadius:4,padding:"8px 16px",zIndex:1001},children:"Speech recognition not available. Use text input below."}),w.jsxs("form",{onSubmit:y,style:{position:"absolute",bottom:30,left:"50%",transform:"translateX(-50%)",display:"flex",gap:8,zIndex:1001},children:[w.jsx("input",{type:"text",value:e,onChange:r=>s(r.target.value),placeholder:p?"Or type a message...":"Type a message...",style:{width:400,padding:"8px 12px",background:"rgba(0, 200, 255, 0.08)",border:"1px solid rgba(0, 200, 255, 0.25)",borderRadius:4,color:u.textPrimary,fontFamily:"monospace",fontSize:13,outline:"none"}}),w.jsx("button",{type:"submit",style:{padding:"8px 16px",background:"rgba(0, 200, 255, 0.15)",border:"1px solid rgba(0, 200, 255, 0.25)",borderRadius:4,color:u.textAccent,fontFamily:"monospace",fontSize:13,cursor:"pointer"},children:"Send"})]})]})}export{_ as JarvisView};
|