specrails-desktop 2.0.0
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/.claude/commands/specrails/batch-implement.md +287 -0
- package/.claude/commands/specrails/compat-check.md +271 -0
- package/.claude/commands/specrails/doctor.md +62 -0
- package/.claude/commands/specrails/enrich.md +1635 -0
- package/.claude/commands/specrails/explore-spec.md +173 -0
- package/.claude/commands/specrails/health-check.md +527 -0
- package/.claude/commands/specrails/implement.md +1457 -0
- package/.claude/commands/specrails/memory-inspect.md +259 -0
- package/.claude/commands/specrails/opsx-diff.md +419 -0
- package/.claude/commands/specrails/propose-spec.md +102 -0
- package/.claude/commands/specrails/reconfig.md +89 -0
- package/.claude/commands/specrails/refactor-recommender.md +212 -0
- package/.claude/commands/specrails/retry.md +363 -0
- package/.claude/commands/specrails/telemetry.md +552 -0
- package/.claude/commands/specrails/why.md +96 -0
- package/LICENSE +21 -0
- package/README.md +290 -0
- package/cli/dist/specrails-desktop.js +1098 -0
- package/client/dist/assets/ActivityFeedPage-Gy4x8dBt.js +1 -0
- package/client/dist/assets/AgentsPage-CPgu--Fb.js +86 -0
- package/client/dist/assets/AnalyticsPage-B5sJEee2.js +1 -0
- package/client/dist/assets/BarChart-7IMQ8HY1.js +33 -0
- package/client/dist/assets/CodePage-CBdFvbwe.js +2 -0
- package/client/dist/assets/DesktopAnalyticsPage-w0rdTq4w.js +1 -0
- package/client/dist/assets/DocsDialog-BZUYM7wm.js +11 -0
- package/client/dist/assets/DocsPage-9QglWl46.js +11 -0
- package/client/dist/assets/ExportDropdown-BLZFXtNi.js +1 -0
- package/client/dist/assets/IntegrationsPage-BxBE4y99.js +3 -0
- package/client/dist/assets/JobDetailPage-DydWx_5S.js +16 -0
- package/client/dist/assets/JobsPage-20ibw0IO.js +1 -0
- package/client/dist/assets/abap-Bw6f2wDG.js +1 -0
- package/client/dist/assets/activity-BEIp_Y1A.js +1 -0
- package/client/dist/assets/activity-BdrPln96.js +1 -0
- package/client/dist/assets/activity-CpkRS8Sx.js +1 -0
- package/client/dist/assets/activity-DKCpESPt.js +1 -0
- package/client/dist/assets/activity-DOUVEjJi.js +1 -0
- package/client/dist/assets/activity-DRwkql_y.js +1 -0
- package/client/dist/assets/activity-DcDQ7tjw.js +1 -0
- package/client/dist/assets/activity-Dv6H7wEr.js +1 -0
- package/client/dist/assets/addon-image-3WCl5Vhd.js +1 -0
- package/client/dist/assets/addon-ligatures-C5OdliKs.js +2 -0
- package/client/dist/assets/addon-webgl-BbX6pSjl.js +44 -0
- package/client/dist/assets/addspec-B5yl4Loj.js +1 -0
- package/client/dist/assets/addspec-BEeF5-zc.js +1 -0
- package/client/dist/assets/addspec-D33ocMxf.js +1 -0
- package/client/dist/assets/addspec-DFswZ0jK.js +1 -0
- package/client/dist/assets/addspec-DRE-jZv7.js +1 -0
- package/client/dist/assets/addspec-DVZ15Jp8.js +1 -0
- package/client/dist/assets/addspec-Fkv91Opc.js +1 -0
- package/client/dist/assets/addspec-GWm4ffKl.js +1 -0
- package/client/dist/assets/agents-1nCDWRmP.js +1 -0
- package/client/dist/assets/agents-Bm9rPqnt.js +1 -0
- package/client/dist/assets/agents-CMxtJMLD.js +1 -0
- package/client/dist/assets/agents-DK-Dlc0i.js +1 -0
- package/client/dist/assets/agents-Q6Ldfpxx.js +1 -0
- package/client/dist/assets/agents-TeOSy-ax.js +1 -0
- package/client/dist/assets/agents-iTqjRajS.js +1 -0
- package/client/dist/assets/agents-s87sMGzL.js +1 -0
- package/client/dist/assets/agentstudio-B6Wb59E7.js +1 -0
- package/client/dist/assets/agentstudio-BADhZ41e.js +1 -0
- package/client/dist/assets/agentstudio-BSnWLR63.js +1 -0
- package/client/dist/assets/agentstudio-BdidyBzZ.js +1 -0
- package/client/dist/assets/agentstudio-CxlUllqI.js +1 -0
- package/client/dist/assets/agentstudio-D3I62TLJ.js +1 -0
- package/client/dist/assets/agentstudio-DuH9TogZ.js +1 -0
- package/client/dist/assets/agentstudio-Kw88_dUF.js +1 -0
- package/client/dist/assets/aiedit-BWxHGsYA.js +1 -0
- package/client/dist/assets/aiedit-D2ji6Qy0.js +1 -0
- package/client/dist/assets/aiedit-DAhZTvtk.js +1 -0
- package/client/dist/assets/aiedit-DJMny-D5.js +1 -0
- package/client/dist/assets/aiedit-DOcxERkU.js +1 -0
- package/client/dist/assets/aiedit-DvrcbwGv.js +1 -0
- package/client/dist/assets/aiedit-TTwzL1TS.js +1 -0
- package/client/dist/assets/aiedit-WBSjT_C1.js +1 -0
- package/client/dist/assets/analytics-BIdr0YfL.js +1 -0
- package/client/dist/assets/analytics-C6EzgtdE.js +1 -0
- package/client/dist/assets/analytics-C9Zc-rkM.js +1 -0
- package/client/dist/assets/analytics-CVx3YOc0.js +1 -0
- package/client/dist/assets/analytics-CYj0tfj7.js +1 -0
- package/client/dist/assets/analytics-CnY4kNG3.js +1 -0
- package/client/dist/assets/analytics-CrPCZRJ-.js +1 -0
- package/client/dist/assets/analytics-DMCto-TF.js +1 -0
- package/client/dist/assets/apex-Cw8_REBo.js +1 -0
- package/client/dist/assets/atom-one-dark-B-oHczHB.css +1 -0
- package/client/dist/assets/attachments-BIsSSnHJ.js +1 -0
- package/client/dist/assets/attachments-BW4L3l2L.js +1 -0
- package/client/dist/assets/attachments-Bcf6BG6V.js +1 -0
- package/client/dist/assets/attachments-Bke8sCU4.js +1 -0
- package/client/dist/assets/attachments-COcrGRFz.js +1 -0
- package/client/dist/assets/attachments-DYHGA2Dj.js +1 -0
- package/client/dist/assets/attachments-Dd92KpUH.js +1 -0
- package/client/dist/assets/attachments-DzdU6DV6.js +1 -0
- package/client/dist/assets/azcli-Cz6HAoOw.js +1 -0
- package/client/dist/assets/bat-CcJ-xyqL.js +1 -0
- package/client/dist/assets/bicep-z1WDCKYz.js +2 -0
- package/client/dist/assets/browser-5ErDlJoR.js +1 -0
- package/client/dist/assets/browser-Bc-YdlVg.js +1 -0
- package/client/dist/assets/browser-BlYF4OOq.js +1 -0
- package/client/dist/assets/browser-CT-ReZGt.js +1 -0
- package/client/dist/assets/browser-DGITz3fC.js +1 -0
- package/client/dist/assets/browser-JsAIGCEW.js +1 -0
- package/client/dist/assets/browser-M5-rbPlw.js +1 -0
- package/client/dist/assets/browser-Qya9cARy.js +1 -0
- package/client/dist/assets/cameligo-BRewOpfa.js +1 -0
- package/client/dist/assets/chat-BEGuC03z.js +1 -0
- package/client/dist/assets/chat-BEW60P_u.js +1 -0
- package/client/dist/assets/chat-BQNMD0PL.js +1 -0
- package/client/dist/assets/chat-BsbNGPW9.js +1 -0
- package/client/dist/assets/chat-CboQguCi.js +1 -0
- package/client/dist/assets/chat-DRCa9pOt.js +1 -0
- package/client/dist/assets/chat-DwUm6W9z.js +1 -0
- package/client/dist/assets/chat-yoXwguQu.js +1 -0
- package/client/dist/assets/chunk-CilyBKbf.js +1 -0
- package/client/dist/assets/clojure-DBjRWN6g.js +1 -0
- package/client/dist/assets/clsx-DnqN-uhr.js +1 -0
- package/client/dist/assets/code-AL1rVIMb.js +1 -0
- package/client/dist/assets/code-C0BKpkht.js +1 -0
- package/client/dist/assets/code-C0FTS3ew.js +1 -0
- package/client/dist/assets/code-CPcHxzxw.js +1 -0
- package/client/dist/assets/code-D3ryDniw.js +1 -0
- package/client/dist/assets/code-D3zVVQTj.js +1 -0
- package/client/dist/assets/code-PCmfS3dn.js +1 -0
- package/client/dist/assets/code-exI0G5Wd.js +1 -0
- package/client/dist/assets/codicon-ngg6Pgfi.ttf +0 -0
- package/client/dist/assets/coffee-Cfk_XHGR.js +1 -0
- package/client/dist/assets/commands-B772IyDa.js +1 -0
- package/client/dist/assets/commands-BDDp6xFG.js +1 -0
- package/client/dist/assets/commands-CJxCry-o.js +1 -0
- package/client/dist/assets/commands-CfgY-_of.js +1 -0
- package/client/dist/assets/commands-DLrvnPNg.js +1 -0
- package/client/dist/assets/commands-IXMOKBYt.js +1 -0
- package/client/dist/assets/commands-UD1NzmwX.js +1 -0
- package/client/dist/assets/commands-sqrqsxyE.js +1 -0
- package/client/dist/assets/common-DCr6VzJ7.js +1 -0
- package/client/dist/assets/common-Dard9UNH.js +1 -0
- package/client/dist/assets/common-DeDELLZJ.js +1 -0
- package/client/dist/assets/common-DltqHaAe.js +1 -0
- package/client/dist/assets/common-Dmm1GhdD.js +1 -0
- package/client/dist/assets/common-DnjcgkPH.js +1 -0
- package/client/dist/assets/common-GbpxfPG8.js +1 -0
- package/client/dist/assets/common-wA36jmj1.js +1 -0
- package/client/dist/assets/cpp-BVob6BaP.js +1 -0
- package/client/dist/assets/csharp-C4fbRuOu.js +1 -0
- package/client/dist/assets/csp-DthFP_vT.js +1 -0
- package/client/dist/assets/css-CGMH0hcW.js +3 -0
- package/client/dist/assets/css.worker-Wv5dxAWO.js +89 -0
- package/client/dist/assets/cssMode-Cc6ozl-J.js +1 -0
- package/client/dist/assets/cypher-Pnf68BRV.js +1 -0
- package/client/dist/assets/dart-PMMOtxZX.js +1 -0
- package/client/dist/assets/dashboard-B4ixDVk8.js +1 -0
- package/client/dist/assets/dashboard-BZBADHSj.js +1 -0
- package/client/dist/assets/dashboard-C1MfeUHs.js +1 -0
- package/client/dist/assets/dashboard-C7SK6xu5.js +1 -0
- package/client/dist/assets/dashboard-CB6Le1yN.js +1 -0
- package/client/dist/assets/dashboard-CoTpMOBM.js +1 -0
- package/client/dist/assets/dashboard-Duo4DDCW.js +1 -0
- package/client/dist/assets/dashboard-I19DXBxw.js +1 -0
- package/client/dist/assets/dist-js-BY-Fv_fg.js +1 -0
- package/client/dist/assets/dist-js-Bakc4uxT.js +1 -0
- package/client/dist/assets/dockerfile-di1nsJCc.js +1 -0
- package/client/dist/assets/ecl-D_WVcB5M.js +1 -0
- package/client/dist/assets/editor-Br_kD0ds.css +1 -0
- package/client/dist/assets/editor.api2-XLGzZfbc.js +872 -0
- package/client/dist/assets/editor.main-CfXxHimg.js +6 -0
- package/client/dist/assets/editor.worker-Bd9IXS8d.js +26 -0
- package/client/dist/assets/elixir-OAdJEMOn.js +1 -0
- package/client/dist/assets/explore-4mFpnrKU.js +1 -0
- package/client/dist/assets/explore-A8Ltoblq.js +1 -0
- package/client/dist/assets/explore-B9A3iN2W.js +1 -0
- package/client/dist/assets/explore-BV5Xxlsn.js +1 -0
- package/client/dist/assets/explore-BrBJvfjP.js +1 -0
- package/client/dist/assets/explore-C3FSE42C.js +1 -0
- package/client/dist/assets/explore-D2EFgt8J.js +1 -0
- package/client/dist/assets/explore-hFc3HFcp.js +1 -0
- package/client/dist/assets/flow9-D3QEZjgn.js +1 -0
- package/client/dist/assets/format-command-CwGuwzGA.js +1 -0
- package/client/dist/assets/freemarker2-DP7J1gG3.js +3 -0
- package/client/dist/assets/fsharp-BF0k_8N8.js +1 -0
- package/client/dist/assets/go-BAQO5Jsz.js +1 -0
- package/client/dist/assets/graphql-hdFVFkiV.js +1 -0
- package/client/dist/assets/handlebars-BjRlucw6.js +1 -0
- package/client/dist/assets/hcl-DWnl1o-X.js +1 -0
- package/client/dist/assets/html-OumBQJ-U.js +1 -0
- package/client/dist/assets/html.worker-CQP8QQsS.js +502 -0
- package/client/dist/assets/htmlMode-CStc3zXM.js +1 -0
- package/client/dist/assets/index-CimDRRi7.css +2 -0
- package/client/dist/assets/index-XGZaKl_u.js +142 -0
- package/client/dist/assets/ini-CB-6OVu3.js +1 -0
- package/client/dist/assets/integrations-C3p12Ms6.js +1 -0
- package/client/dist/assets/integrations-Cr6hH7XR.js +1 -0
- package/client/dist/assets/integrations-Cublz3m6.js +1 -0
- package/client/dist/assets/integrations-D28q1kF6.js +1 -0
- package/client/dist/assets/integrations-DRdbki5W.js +1 -0
- package/client/dist/assets/integrations-DaC4SzzL.js +1 -0
- package/client/dist/assets/integrations-DmQYCUvN.js +1 -0
- package/client/dist/assets/integrations-HIlUxXVs.js +1 -0
- package/client/dist/assets/java-d1CmfiHX.js +1 -0
- package/client/dist/assets/javascript-CMk--e7g.js +1 -0
- package/client/dist/assets/jobs-BE1siB0M.js +1 -0
- package/client/dist/assets/jobs-BHcQ_Faf.js +1 -0
- package/client/dist/assets/jobs-CFfc2dNX.js +1 -0
- package/client/dist/assets/jobs-CSi5n8X_.js +1 -0
- package/client/dist/assets/jobs-Dc3X86PY.js +1 -0
- package/client/dist/assets/jobs-De5tASex.js +1 -0
- package/client/dist/assets/jobs-DsoXEdo7.js +1 -0
- package/client/dist/assets/jobs-Wl-ApPMb.js +1 -0
- package/client/dist/assets/json.worker-DzV-CpCQ.js +58 -0
- package/client/dist/assets/jsonMode-C2h3ZcjZ.js +7 -0
- package/client/dist/assets/julia-Bgv08lKa.js +1 -0
- package/client/dist/assets/kotlin-u98kaVTf.js +1 -0
- package/client/dist/assets/less-CjYwpgg5.js +2 -0
- package/client/dist/assets/lexon-YTjaAFBB.js +1 -0
- package/client/dist/assets/lib-CPxTMOAq.js +7 -0
- package/client/dist/assets/liquid-mI3KJrBE.js +1 -0
- package/client/dist/assets/lspLanguageFeatures-DU09ggWi.js +4 -0
- package/client/dist/assets/lua-BzmkWv27.js +1 -0
- package/client/dist/assets/m3-CFwk9fw0.js +1 -0
- package/client/dist/assets/markdown-CR5iMpSZ.js +1 -0
- package/client/dist/assets/mdx-C41VDTR_.js +1 -0
- package/client/dist/assets/mips-CcEalc17.js +1 -0
- package/client/dist/assets/monaco.contribution-CPObAXMC.js +2 -0
- package/client/dist/assets/msdax-BQbkawnr.js +1 -0
- package/client/dist/assets/mysql-GTlaaW_P.js +1 -0
- package/client/dist/assets/nav-0fwkrgHt.js +1 -0
- package/client/dist/assets/nav-BEL3MTwK.js +1 -0
- package/client/dist/assets/nav-B_G-TJDW.js +1 -0
- package/client/dist/assets/nav-C2YXcbZS.js +1 -0
- package/client/dist/assets/nav-ClzOE4mA.js +1 -0
- package/client/dist/assets/nav-CtYwmMgu.js +1 -0
- package/client/dist/assets/nav-D2bOGSEg.js +1 -0
- package/client/dist/assets/nav-iH1V5j6o.js +1 -0
- package/client/dist/assets/objective-c-Byu1T5if.js +1 -0
- package/client/dist/assets/pascal-BrfzBfRm.js +1 -0
- package/client/dist/assets/pascaligo-BXXKFUeo.js +1 -0
- package/client/dist/assets/perl-B3OikKq-.js +1 -0
- package/client/dist/assets/pgsql-CTsa0Acc.js +1 -0
- package/client/dist/assets/php-DiQh3FUW.js +1 -0
- package/client/dist/assets/pla-92uH8Fzm.js +1 -0
- package/client/dist/assets/postiats-BbeWkKUr.js +1 -0
- package/client/dist/assets/powerquery-DgDMzpsm.js +1 -0
- package/client/dist/assets/powershell-BfdUUzaG.js +1 -0
- package/client/dist/assets/preload-helper-DSXbuxSR.js +1 -0
- package/client/dist/assets/protobuf-BojW2ftW.js +2 -0
- package/client/dist/assets/pug-BxqTg3IU.js +1 -0
- package/client/dist/assets/python-Y27rKQtk.js +1 -0
- package/client/dist/assets/qsharp-BX_A-MW9.js +1 -0
- package/client/dist/assets/r-D9BMnxvJ.js +1 -0
- package/client/dist/assets/razor-Cd5-q9Bp.js +1 -0
- package/client/dist/assets/redis-5cJqEQJJ.js +1 -0
- package/client/dist/assets/redshift-d8BBqiwb.js +1 -0
- package/client/dist/assets/restructuredtext-C8a6yIcZ.js +1 -0
- package/client/dist/assets/ruby-egeh-6KX.js +1 -0
- package/client/dist/assets/rust-a3r9IInB.js +1 -0
- package/client/dist/assets/sb-y8iRIDei.js +1 -0
- package/client/dist/assets/scala-BPDK2AmK.js +1 -0
- package/client/dist/assets/scheme-BIWUEoOs.js +1 -0
- package/client/dist/assets/scss-CA-PSzwg.js +3 -0
- package/client/dist/assets/settings-55oDcbSh.js +1 -0
- package/client/dist/assets/settings-Bd4Tq1RB.js +1 -0
- package/client/dist/assets/settings-CCSM-Fhn.js +1 -0
- package/client/dist/assets/settings-D3e_bDoW.js +1 -0
- package/client/dist/assets/settings-DKbTkbn7.js +1 -0
- package/client/dist/assets/settings-Dxpo6_w7.js +1 -0
- package/client/dist/assets/settings-bt84e3Aa.js +1 -0
- package/client/dist/assets/settings-nu68QukM.js +1 -0
- package/client/dist/assets/setup-BMqwfbW9.js +1 -0
- package/client/dist/assets/setup-Bb5LcG28.js +1 -0
- package/client/dist/assets/setup-BeEx2_da.js +1 -0
- package/client/dist/assets/setup-CCCrB53Q.js +1 -0
- package/client/dist/assets/setup-CJA0ATmd.js +1 -0
- package/client/dist/assets/setup-CeiDbZcb.js +1 -0
- package/client/dist/assets/setup-Cus7TApA.js +1 -0
- package/client/dist/assets/setup-D9qOs2Xo.js +1 -0
- package/client/dist/assets/shell--LiT1Bja.js +1 -0
- package/client/dist/assets/solidity-DdqZccZg.js +1 -0
- package/client/dist/assets/sophia-S6-YxNG_.js +1 -0
- package/client/dist/assets/sparql-BSf5kMp2.js +1 -0
- package/client/dist/assets/specs-BFfu3u-a.js +1 -0
- package/client/dist/assets/specs-B__C8-8a.js +1 -0
- package/client/dist/assets/specs-CZ1PsXsC.js +1 -0
- package/client/dist/assets/specs-D2FzlLn9.js +1 -0
- package/client/dist/assets/specs-DaUTrNF9.js +1 -0
- package/client/dist/assets/specs-Dyc5hYeE.js +1 -0
- package/client/dist/assets/specs-cKEh2LXt.js +1 -0
- package/client/dist/assets/specs-k0PyLDVt.js +1 -0
- package/client/dist/assets/sql-D7KgjR8G.js +1 -0
- package/client/dist/assets/st-BnoDa-Ml.js +1 -0
- package/client/dist/assets/swift-DEUHTkUX.js +1 -0
- package/client/dist/assets/systemverilog-Tqb_KPnW.js +1 -0
- package/client/dist/assets/tcl-BmBFS2qq.js +1 -0
- package/client/dist/assets/terminal-80yDMgMF.js +1 -0
- package/client/dist/assets/terminal-Bje4ziIa.js +1 -0
- package/client/dist/assets/terminal-C2WYcFHF.js +1 -0
- package/client/dist/assets/terminal-CSONJOex.js +1 -0
- package/client/dist/assets/terminal-DEqzGtcr.js +1 -0
- package/client/dist/assets/terminal-DeWzh6ys.js +1 -0
- package/client/dist/assets/terminal-YOlsJCQj.js +1 -0
- package/client/dist/assets/terminal-lkZYR4wJ.js +1 -0
- package/client/dist/assets/tickets-CB7N30gm.js +1 -0
- package/client/dist/assets/tickets-CF2PYelu.js +1 -0
- package/client/dist/assets/tickets-DNOANUXr.js +1 -0
- package/client/dist/assets/tickets-DU1aqsbr.js +1 -0
- package/client/dist/assets/tickets-DYvafSaY.js +1 -0
- package/client/dist/assets/tickets-DlpC_iTg.js +1 -0
- package/client/dist/assets/tickets-DucYgtdl.js +1 -0
- package/client/dist/assets/tickets-clefmXLv.js +1 -0
- package/client/dist/assets/ts.worker-METxwbDZ.js +67719 -0
- package/client/dist/assets/tsMode-B0y_xEci.js +11 -0
- package/client/dist/assets/twig-BQV8igWC.js +1 -0
- package/client/dist/assets/typescript-BzK0OgwW.js +1 -0
- package/client/dist/assets/typespec-DlFroUGY.js +1 -0
- package/client/dist/assets/useProjectCache-DSaiGFjV.js +1 -0
- package/client/dist/assets/vb-BlrJpIMX.js +1 -0
- package/client/dist/assets/wgsl-BWgIc6FZ.js +298 -0
- package/client/dist/assets/workers-rt--R2Qy.js +1 -0
- package/client/dist/assets/xml-eX9QXAmI.js +1 -0
- package/client/dist/assets/yaml-fcsNkpOt.js +1 -0
- package/client/dist/index.html +246 -0
- package/docs/README.md +54 -0
- package/docs/cli.md +198 -0
- package/docs/codex.md +210 -0
- package/docs/creating-specs.md +197 -0
- package/docs/customizing.md +197 -0
- package/docs/getting-started.md +140 -0
- package/docs/internals/README.md +25 -0
- package/docs/internals/adding-a-provider.md +238 -0
- package/docs/internals/api-reference.md +634 -0
- package/docs/internals/architecture.md +332 -0
- package/docs/internals/configuration.md +172 -0
- package/docs/internals/openspec-workflow.md +282 -0
- package/docs/internals/operations-runbook.md +198 -0
- package/docs/internals/profiles.md +152 -0
- package/docs/platforms/macos.md +130 -0
- package/docs/platforms/windows.md +81 -0
- package/docs/running-pipelines.md +240 -0
- package/docs/terminal.md +138 -0
- package/docs/tracking-cost.md +155 -0
- package/package.json +82 -0
- package/server/dist/agent-generator.js +232 -0
- package/server/dist/agent-refine-db.js +124 -0
- package/server/dist/agent-refine-manager.js +526 -0
- package/server/dist/ai-invocations.js +111 -0
- package/server/dist/attachment-manager.js +299 -0
- package/server/dist/auth.js +207 -0
- package/server/dist/binary-probe.js +35 -0
- package/server/dist/browser-capture-manager.js +576 -0
- package/server/dist/browser-capture-types.js +28 -0
- package/server/dist/browser-network.js +149 -0
- package/server/dist/browser-playwright.js +888 -0
- package/server/dist/build-dirs.js +44 -0
- package/server/dist/changes-reader.js +120 -0
- package/server/dist/chat-manager.js +1060 -0
- package/server/dist/chromium-resolver.js +311 -0
- package/server/dist/code-explorer-router.js +788 -0
- package/server/dist/codex-otel-bridge.js +235 -0
- package/server/dist/command-resolver.js +102 -0
- package/server/dist/config.js +306 -0
- package/server/dist/context-budget.js +113 -0
- package/server/dist/context-scope.js +279 -0
- package/server/dist/contract-refine-runner.js +521 -0
- package/server/dist/core-compat.js +207 -0
- package/server/dist/core-package.js +14 -0
- package/server/dist/db.js +1034 -0
- package/server/dist/desktop-analytics.js +156 -0
- package/server/dist/desktop-db.js +456 -0
- package/server/dist/desktop-router.js +735 -0
- package/server/dist/docs-router.js +207 -0
- package/server/dist/explore-contract-refine.js +421 -0
- package/server/dist/explore-cwd-manager.js +242 -0
- package/server/dist/explore-draft-title.js +47 -0
- package/server/dist/explore-smash.js +450 -0
- package/server/dist/feature-flags.js +17 -0
- package/server/dist/file-provenance.js +382 -0
- package/server/dist/file-summary-generator.js +221 -0
- package/server/dist/file-summary-manager.js +689 -0
- package/server/dist/hooks.js +102 -0
- package/server/dist/ids.js +7 -0
- package/server/dist/index.js +586 -0
- package/server/dist/metrics.js +136 -0
- package/server/dist/mobile/index.js +16 -0
- package/server/dist/mobile/mobile-admin-router.js +84 -0
- package/server/dist/mobile/mobile-auth.js +67 -0
- package/server/dist/mobile/mobile-devices.js +80 -0
- package/server/dist/mobile/mobile-event-bus.js +39 -0
- package/server/dist/mobile/mobile-gateway.js +285 -0
- package/server/dist/mobile/mobile-mdns.js +81 -0
- package/server/dist/mobile/mobile-pairing.js +179 -0
- package/server/dist/mobile/mobile-redact.js +53 -0
- package/server/dist/mobile/mobile-router.js +411 -0
- package/server/dist/mobile/mobile-tls.js +86 -0
- package/server/dist/mobile/mobile-types.js +9 -0
- package/server/dist/mobile/mobile-ws.js +275 -0
- package/server/dist/path-resolver.js +298 -0
- package/server/dist/plugin-manager.js +617 -0
- package/server/dist/plugins/claude-approval.js +179 -0
- package/server/dist/plugins/claude-md-mutation.js +146 -0
- package/server/dist/plugins/codex-mcp.js +108 -0
- package/server/dist/plugins/contributors.js +72 -0
- package/server/dist/plugins/drift.js +58 -0
- package/server/dist/plugins/index.js +14 -0
- package/server/dist/plugins/json-mutation.js +120 -0
- package/server/dist/plugins/manager.js +32 -0
- package/server/dist/plugins/ownership.js +86 -0
- package/server/dist/plugins/paths.js +37 -0
- package/server/dist/plugins/prereq-installer.js +104 -0
- package/server/dist/plugins/rail-integration.js +79 -0
- package/server/dist/plugins/serena/index.js +13 -0
- package/server/dist/plugins/serena/install.js +91 -0
- package/server/dist/plugins/serena/instructions-content.js +21 -0
- package/server/dist/plugins/serena/manifest.js +111 -0
- package/server/dist/plugins/serena/verify.js +78 -0
- package/server/dist/plugins-router.js +215 -0
- package/server/dist/pricing.js +89 -0
- package/server/dist/profile-manager.js +310 -0
- package/server/dist/profiles-router.js +759 -0
- package/server/dist/project-registry.js +443 -0
- package/server/dist/project-router.js +4016 -0
- package/server/dist/proposal-manager.js +291 -0
- package/server/dist/provider-selection.js +69 -0
- package/server/dist/providers/claude-adapter.js +281 -0
- package/server/dist/providers/codex-adapter.js +264 -0
- package/server/dist/providers/index.js +23 -0
- package/server/dist/providers/registry.js +37 -0
- package/server/dist/providers/types.js +22 -0
- package/server/dist/queue-manager.js +1511 -0
- package/server/dist/rails-router.js +362 -0
- package/server/dist/rails-store.js +116 -0
- package/server/dist/result-event.js +106 -0
- package/server/dist/schemas/profile.v1.json +151 -0
- package/server/dist/setup-manager.js +1165 -0
- package/server/dist/setup-prerequisites.js +372 -0
- package/server/dist/smash-runner.js +663 -0
- package/server/dist/spec-draft-parser.js +133 -0
- package/server/dist/spec-launcher-manager.js +174 -0
- package/server/dist/spec-models.js +32 -0
- package/server/dist/specrails-tech-client.js +82 -0
- package/server/dist/spending.js +448 -0
- package/server/dist/telemetry-compactor.js +180 -0
- package/server/dist/telemetry-export.js +317 -0
- package/server/dist/telemetry-receiver.js +224 -0
- package/server/dist/terminal-manager.js +633 -0
- package/server/dist/terminal-marks-store.js +117 -0
- package/server/dist/terminal-osc-parser.js +159 -0
- package/server/dist/terminal-settings.js +282 -0
- package/server/dist/terminal-shell-integration.js +196 -0
- package/server/dist/ticket-broadcast.js +47 -0
- package/server/dist/ticket-store.js +397 -0
- package/server/dist/ticket-watcher.js +117 -0
- package/server/dist/types.js +10 -0
- package/server/dist/user-mcp-config.js +117 -0
- package/server/dist/util/cli-prompt.js +181 -0
- package/server/dist/util/secure-fs.js +50 -0
- package/server/dist/util/win-spawn.js +43 -0
- package/server/dist/webhook-manager.js +89 -0
- package/server/dist/ws-routing.js +47 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`正在加载 Agent…`,modeCreate:`新建自定义 Agent`,modeEdit:`编辑自定义 Agent`,create:`创建`,unsaved:`● 未保存`,resumeAiEdit:`继续 AI 编辑`,resumeAiEditTitle:`将此草稿交还给 AI 编辑浮层`,loadingAiDraft:`正在加载 AI 草稿…`,testButton:`测试`,testButtonTitle:`用示例任务测试此 Agent`,historyButton:`历史`,historyButtonTitle:`版本历史`,deleteConfirm:{title:`删除 Agent“{{agentId}}”?`,description:`这会从磁盘上删除该 .md 文件。版本历史仍保留在数据库中——若日后需要恢复内容,可新建一个自定义 Agent。`},errors:{loadDraftFailed:`加载草稿失败:{{status}}`,loadFailed:`加载失败:{{status}}`,saveFailed:`保存失败:{{status}}`,deleteFailed:`删除失败:{{status}}`,testFailed:`测试失败:{{status}}`},toasts:{agentCreated:`Agent 已创建`,agentSaved:`Agent 已保存`,agentDeleted:`Agent 已删除`,createFailed:`创建 Agent 失败`,saveFailed:`保存 Agent 失败`,deleteFailed:`删除 Agent 失败`},validation:{namePattern:`名称必须以 <code>custom-</code> 开头,且只能包含小写字母、数字和连字符。`,missingFrontmatter:`缺少 YAML frontmatter(第一行需要起始的 <code>---</code>)。`},sampleTasks:{pick:`—— 选择一个示例任务 ——`,terraform:`Terraform:公开的 S3 存储桶`,sqlInjection:`代码评审:SQL 注入`,accessibility:`前端:无障碍`,schemaChange:`数据:schema 变更`,slowQuery:`性能:慢查询`},testPane:{header:`测试 Agent`,sampleTaskLabel:`示例任务`,placeholder:`描述该 Agent 应该做什么,或在上方选择一个示例。`,run:`运行`,running:`运行中…`,sandboxNote:`沙箱运行;不写入任何文件。`,tokens_one:`<mono>{{count}}</mono> 个 token`,tokens_other:`<mono>{{count}}</mono> 个 token`,emptyHint:`针对当前草稿运行一个示例任务,输出会显示在这里。`},versions:{header:`版本历史`,empty:`此 Agent 暂无历史版本记录。`,restoreHint:`点击某个版本可将其内容恢复到编辑器中(仍需手动保存)。`}},t={eyebrow:`AI 编辑`,headline:`优化你的 Agent`,streamingHeadline:`正在优化你的 Agent…`,placeholderInitial:`描述如何优化此 Agent…`,placeholderFollowUp:`发送后续优化指令…`,viewCurrentBody:`查看当前 Agent 正文`,appliedAsVersion:`已应用为版本 {{version}}。`,openInStudio:`在 Studio 中打开草稿进行手动编辑`,chips:{tightenTools:`收紧工具列表`,stricterPersonality:`让人格设定更严格`,workflowSection:`添加 Workflow 协议章节`,sharpenDescription:`精简并锐化描述`,matchDeveloperStyle:`对齐 sr-developer 的风格`}},n={validation:{missingBaseline:`缺少必需的基线 Agent:{{agent}}`,multipleDefaultRules:`路由最多只能有一条默认规则(发现 {{found}} 条)`,defaultRuleNotLast:`默认路由规则必须是最后一条`,unknownRoutingAgent:`路由引用了不在链中的 Agent:{{agent}}`,invalidTags:`路由规则 {{agent}} 包含无效标签:{{tags}}(请使用小写 kebab-case)`},validationSummary_one:`{{count}} 个校验问题`,validationSummary_other:`{{count}} 个校验问题`,nameLabel:`名称`,descriptionLabel:`描述`,descriptionPlaceholder:`这个 Profile 用来做什么?`,orchestrator:{heading:`编排器`,description:`两个命令共用的顶层模型。batch-implement 会按 feature 委派给 implement,因此它启动的每条 rail 都会继承此 Profile 的 Agent 链。`},agentChain:{heading:`Agent 链({{n}})`,addTitle:`从目录中添加 Agent`,addDisabledTitle:`目录中的所有 Agent 都已在链中`,pickFromCatalog:`从目录选择({{n}} 个可用)`,emptyCatalog:`目录中没有更多 Agent。请在 Agent 目录标签页中添加自定义 Agent。`,kind:{upstream:`上游`,custom:`自定义`}},routing:{heading:`路由({{n}})`,addDefault:`添加默认规则`,addRule:`添加规则`,needAgentsTitle:`请先添加至少一个 Agent,再创建路由规则`,explainer:`首条匹配的规则生效。规则可编辑、可删除;存在默认兜底规则时它始终位于最后。如果路由留空,流水线会回退到链中第一个开发者类型的 Agent。`,untargetedTitle:`链中存在未被路由指向的 Agent`,untargetedDetail:`没有路由规则指向:<mono>{{agents}}</mono>。如需让它们运行,请添加标签规则或调整默认规则的目标。`},agentRow:{dragTitle:`拖动以重新排序`,dragHandleAria:`拖动手柄`,pinnedFirst:`首位`,pinnedFirstTitle:`固定在首位——流水线始终从 sr-architect 开始`,pinnedLast:`末位`,pinnedLastTitle:`固定在末位——合并阶段始终最后运行`,required:`必需`,requiredRemoveTitle:`必需的基线 Agent——流水线依赖此行`},routingRow:{everythingElse:`其余所有`,defaultTargetAria:`默认路由目标(核心,只读)`,defaultTargetTitle:`核心兜底——不可编辑`,targetAria:`规则 {{ordinal}} 的路由目标`,editTitle:`编辑规则`,editAria:`编辑规则 {{ordinal}}`,moveDown:`下移`,moveUp:`上移`,coreDefaultBadge:`核心 · 默认`,coreDefaultTitle:`核心兜底——流水线的最终兜底规则,固定指向 sr-developer`}},r={selectedCount:`已选择 {{selected}} / {{total}} 个 Agent`,selectAll:`全选`,coreBadge:`核心`,categories:{architecture:`架构`,development:`开发`,review:`评审`,product:`产品`,utilities:`工具`},agents:{"sr-architect":{name:`架构师`,description:`架构设计、变更 spec、实现规划`},"sr-developer":{name:`开发者`,description:`覆盖所有层的全栈实现`},"sr-frontend-developer":{name:`前端开发`,description:`前端实现(React、Vue、Angular 等)`},"sr-backend-developer":{name:`后端开发`,description:`后端专精(API、数据库、服务)`},"sr-reviewer":{name:`评审员`,description:`通用代码评审——最终质量门禁`},"sr-frontend-reviewer":{name:`前端评审`,description:`前端评审(UI、无障碍、性能)`},"sr-backend-reviewer":{name:`后端评审`,description:`后端评审(API、安全、可扩展性)`},"sr-security-reviewer":{name:`安全评审`,description:`安全分析——OWASP、漏洞、安全加固`},"sr-performance-reviewer":{name:`性能评审`,description:`性能分析——性能剖析、瓶颈、优化`},"sr-product-manager":{name:`产品经理`,description:`产品探索、VPC 用户画像、backlog 管理`},"sr-product-analyst":{name:`产品分析师`,description:`Backlog 分析、spec 缺口分析、报告`},"sr-test-writer":{name:`测试编写者`,description:`全面的测试生成(单元、集成、E2E)`},"sr-doc-sync":{name:`文档同步`,description:`文档同步——保持文档与代码一致`},"sr-merge-resolver":{name:`合并冲突解决器`,description:`具备上下文感知的合并冲突解决`}}},i={"security-reviewer":{label:`安全评审员`,blurb:`在 diff 交付前发现认证、注入与数据泄露问题。`},"performance-profiler":{label:`性能剖析师`,blurb:`发现热点路径、N+1 查询、无界循环、bundle 膨胀。`},"data-engineer":{label:`数据工程师`,blurb:`Schema 迁移、ETL 流水线、数据转换。`},"ui-ux-polisher":{label:`UI / UX 打磨师`,blurb:`无障碍、间距、空状态、错误处理。`},"api-designer":{label:`API 设计师`,blurb:`版本管理、分页、错误结构、向后兼容。`},"database-architect":{label:`数据库架构师`,blurb:`索引、规范化与反规范化、查询模式。`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD、可观测性、事故响应准备、运维手册。`},"mobile-engineer":{label:`移动端工程师`,blurb:`iOS + Android 模式、离线优先、电量友好。`},"ml-engineer":{label:`机器学习工程师`,blurb:`流水线、评估、可复现性、漂移监控。`},"accessibility-auditor":{label:`无障碍审计员`,blurb:`WCAG 2.2 评审:对比度、焦点、ARIA、键盘。`},"qa-test-strategist":{label:`QA 测试策略师`,blurb:`测试计划:单元 / 集成 / E2E 划分、覆盖率缺口。`},"load-tester":{label:`负载 / 压力测试员`,blurb:`容量规划、k6 / Locust 场景、瓶颈排查。`},"integration-tester":{label:`集成测试员`,blurb:`跨服务契约、测试夹具、减少偶发失败。`},"regression-hunter":{label:`回归猎手`,blurb:`二分定位、复现问题、先写出会失败的测试。`},"data-analyst":{label:`数据分析师`,blurb:`把模糊的问题变成查询和可读的结论。`},"etl-reviewer":{label:`ETL 流水线评审`,blurb:`幂等性、数据回填、迟到数据。`},"dashboard-designer":{label:`仪表盘设计师`,blurb:`一眼看懂的仪表盘、诚实的坐标轴、每张图对应一个行动。`},"iac-reviewer":{label:`IaC / 云评审`,blurb:`Terraform / CloudFormation:IAM、公网暴露、成本。`},"compliance-reviewer":{label:`合规评审`,blurb:`针对数据流的 GDPR / SOC2 / HIPAA 相关检查。`},"threat-modeler":{label:`威胁建模师`,blurb:`对架构图进行 STRIDE / LINDDUN 分析。`},"product-manager":{label:`产品经理`,blurb:`问题界定、PRD、优先级排序。`},"ux-researcher":{label:`UX 研究员`,blurb:`访谈脚本、可用性测试计划、结果综合。`},"technical-writer":{label:`技术写作者`,blurb:`真正有人读的文档——教程、参考、更新日志。`},"design-reviewer":{label:`设计系统评审`,blurb:`Token 漂移、组件误用、跨流程一致性。`},"financial-analyst":{label:`财务分析师`,blurb:`单位经济模型、同期群模型、情景分析。`},"pricing-strategist":{label:`定价策略师`,blurb:`分层、打包、支付意愿研究。`},"market-researcher":{label:`市场研究员`,blurb:`TAM/SAM/SOM、竞争格局图、客户细分。`},"ops-optimizer":{label:`运营优化师`,blurb:`周期时间、瓶颈定位、自动化候选项。`},"seo-auditor":{label:`SEO 审计员`,blurb:`技术 + 内容 SEO:可索引性、信息架构、意图匹配。`},"growth-hacker":{label:`增长实验师`,blurb:`漏斗诊断、提升实验、激活闭环。`},"social-strategist":{label:`社交媒体策略师`,blurb:`适配渠道的内容、编辑日历、语调一致性。`},"literature-reviewer":{label:`文献综述员`,blurb:`系统性综述摘要、引用图谱、矛盾发现。`},"experiment-designer":{label:`实验设计师`,blurb:`假设、对照、样本量、预注册。`},"statistical-analyst":{label:`统计分析师`,blurb:`选对检验方法,报告效应量而不只是 p 值。`},"scientific-writer":{label:`科学写作者`,blurb:`IMRaD 结构、坦诚的局限性、可读的摘要。`},"curriculum-designer":{label:`课程设计师`,blurb:`学习目标 → 教学活动 → 评估。`},"assessment-author":{label:`测评编写者`,blurb:`衡量理解而非记忆的题目。`},"tutor-explainer":{label:`导师 / 讲解者`,blurb:`费曼式的简明讲解,配有完整例题。`},"clinical-guideline-reviewer":{label:`临床指南评审`,blurb:`将临床实践与最新循证指南对照。`},"medical-summarizer":{label:`医学文献摘要员`,blurb:`面向临床医生的摘要:变化点与证据质量。`},"protocol-designer":{label:`方案设计师`,blurb:`临床方案:终点指标、入组标准、安全性。`},"contract-reviewer":{label:`合同评审`,blurb:`标记高风险条款,并解释其实际含义。`},"privacy-counsel":{label:`隐私顾问`,blurb:`将 GDPR / CCPA / LGPD 应用到具体流程。`},"copy-editor":{label:`文字编辑`,blurb:`逐行润色:语气、节奏,删减 30% 而不失原意。`},"brand-voice-guardian":{label:`品牌语调守护者`,blurb:`执行语调规则,捕捉偏离品牌的措辞。`},"creative-brainstormer":{label:`创意头脑风暴师`,blurb:`先发散后收敛,礼貌地挑战固有观念。`},"hiring-interviewer":{label:`招聘面试官`,blurb:`结构化面试,聚焦信号,规避偏见。`},"strategic-planner":{label:`战略规划师`,blurb:`目标 → 押注 → 指标;剔除个人偏好项目。`},"coach-1on1":{label:`1:1 教练`,blurb:`帮助组织反馈、规划职业成长、应对艰难对话。`},"meeting-facilitator":{label:`会议主持人`,blurb:`产出决策而非汇报的会议议程。`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`Agent wird geladen…`,modeCreate:`Neuer Custom-Agent`,modeEdit:`Custom-Agent bearbeiten`,create:`Erstellen`,unsaved:`● ungespeichert`,resumeAiEdit:`AI Edit fortsetzen`,resumeAiEditTitle:`Diesen Entwurf zurück an das AI-Edit-Overlay übergeben`,loadingAiDraft:`KI-Entwurf wird geladen…`,testButton:`Testen`,testButtonTitle:`Diesen Agent mit einer Beispielaufgabe testen`,historyButton:`Verlauf`,historyButtonTitle:`Versionsverlauf`,deleteConfirm:{title:`Agent „{{agentId}}“ löschen?`,description:`Entfernt die .md-Datei von der Festplatte. Der Versionsverlauf bleibt in der DB erhalten – verwenden Sie einen neuen Custom-Agent, um den Inhalt später wiederherzustellen.`},errors:{loadDraftFailed:`Entwurf konnte nicht geladen werden: {{status}}`,loadFailed:`Laden fehlgeschlagen: {{status}}`,saveFailed:`Speichern fehlgeschlagen: {{status}}`,deleteFailed:`Löschen fehlgeschlagen: {{status}}`,testFailed:`Test fehlgeschlagen: {{status}}`},toasts:{agentCreated:`Agent erstellt`,agentSaved:`Agent gespeichert`,agentDeleted:`Agent gelöscht`,createFailed:`Agent konnte nicht erstellt werden`,saveFailed:`Agent konnte nicht gespeichert werden`,deleteFailed:`Agent konnte nicht gelöscht werden`},validation:{namePattern:`Der Name muss mit <code>custom-</code> beginnen und darf nur Kleinbuchstaben, Ziffern und Bindestriche enthalten.`,missingFrontmatter:`YAML-Frontmatter fehlt (benötigt öffnendes <code>---</code> in der ersten Zeile).`},sampleTasks:{pick:`– Beispielaufgabe wählen –`,terraform:`Terraform: öffentlicher S3-Bucket`,sqlInjection:`Code-Review: SQL-Injection`,accessibility:`Frontend: Barrierefreiheit`,schemaChange:`Daten: Schemaänderung`,slowQuery:`Performance: langsame Query`},testPane:{header:`Agent testen`,sampleTaskLabel:`Beispielaufgabe`,placeholder:`Beschreiben Sie, was der Agent tun soll, oder wählen Sie oben ein Beispiel.`,run:`Ausführen`,running:`Läuft…`,sandboxNote:`Sandbox-Modus; es werden keine Dateien geschrieben.`,tokens_one:`<mono>{{count}}</mono> Token`,tokens_other:`<mono>{{count}}</mono> Tokens`,emptyHint:`Führen Sie eine Beispielaufgabe gegen den aktuellen Entwurf aus. Die Ausgabe erscheint hier.`},versions:{header:`Versionsverlauf`,empty:`Keine früheren Versionen für diesen Agent vorhanden.`,restoreHint:`Klicken Sie auf eine Version, um ihren Inhalt in den Editor zu übernehmen (Speichern ist weiterhin nötig).`}},t={eyebrow:`AI Edit`,headline:`Agent verfeinern`,streamingHeadline:`Agent wird verfeinert…`,placeholderInitial:`Beschreiben Sie, wie dieser Agent verfeinert werden soll…`,placeholderFollowUp:`Weitere Verfeinerung senden…`,viewCurrentBody:`Aktuellen Agent-Inhalt anzeigen`,appliedAsVersion:`Als Version {{version}} übernommen.`,openInStudio:`Entwurf im Studio zur manuellen Bearbeitung öffnen`,chips:{tightenTools:`Tool-Liste straffen`,stricterPersonality:`Persönlichkeit strenger machen`,workflowSection:`Abschnitt mit Workflow-Protokoll hinzufügen`,sharpenDescription:`Beschreibung kürzen und schärfen`,matchDeveloperStyle:`An den sr-developer-Stil angleichen`}},n={validation:{missingBaseline:`Erforderlicher Baseline-Agent fehlt: {{agent}}`,multipleDefaultRules:`Routing darf höchstens eine Standardregel haben ({{found}} gefunden)`,defaultRuleNotLast:`Die Standard-Routing-Regel muss der letzte Eintrag sein`,unknownRoutingAgent:`Routing verweist auf einen Agent, der nicht in der Kette ist: {{agent}}`,invalidTags:`Routing-Regel {{agent}} hat ungültige Tags: {{tags}} (Kleinbuchstaben in kebab-case verwenden)`},validationSummary_one:`{{count}} Validierungsproblem`,validationSummary_other:`{{count}} Validierungsprobleme`,nameLabel:`Name`,descriptionLabel:`Beschreibung`,descriptionPlaceholder:`Wofür ist dieses Profil?`,orchestrator:{heading:`Orchestrator`,description:`Top-Level-Modell für beide Befehle. batch-implement delegiert pro Feature an implement, daher erbt jede gestartete Rail die Agenten-Kette dieses Profils.`},agentChain:{heading:`Agenten-Kette ({{n}})`,addTitle:`Agent aus dem Katalog hinzufügen`,addDisabledTitle:`Alle Katalog-Agenten sind bereits in der Kette`,pickFromCatalog:`Aus Katalog wählen ({{n}} verfügbar)`,emptyCatalog:`Keine weiteren Agenten im Katalog. Fügen Sie Custom-Agenten über den Tab „Agenten-Katalog“ hinzu.`,kind:{upstream:`upstream`,custom:`custom`}},routing:{heading:`Routing ({{n}})`,addDefault:`Standard hinzufügen`,addRule:`Regel hinzufügen`,needAgentsTitle:`Fügen Sie mindestens einen Agent hinzu, bevor Sie Routing-Regeln erstellen`,explainer:`Die erste passende Regel gewinnt. Regeln sind bearbeitbar und entfernbar; die Standard-Catch-all-Regel bleibt am Ende, sofern vorhanden. Bleibt das Routing leer, fällt die Pipeline auf den ersten Developer-artigen Agent in der Kette zurück.`,untargetedTitle:`Nicht angesteuerte Agenten in der Kette`,untargetedDetail:`Keine Routing-Regel zeigt auf: <mono>{{agents}}</mono>. Fügen Sie eine Tag-Regel hinzu oder ändern Sie das Ziel der Standardregel, damit sie ausgeführt werden.`},agentRow:{dragTitle:`Zum Umsortieren ziehen`,dragHandleAria:`Ziehgriff`,pinnedFirst:`Anfang`,pinnedFirstTitle:`An erster Position fixiert – die Pipeline beginnt immer mit sr-architect`,pinnedLast:`Ende`,pinnedLastTitle:`An letzter Position fixiert – die Merge-Phase läuft immer zuletzt`,required:`erforderlich`,requiredRemoveTitle:`Erforderlicher Baseline-Agent – die Pipeline hängt von dieser Zeile ab`},routingRow:{everythingElse:`alles andere`,defaultTargetAria:`Standard-Routing-Ziel (Core, schreibgeschützt)`,defaultTargetTitle:`Core-Fallback – nicht bearbeitbar`,targetAria:`Routing-Ziel für Regel {{ordinal}}`,editTitle:`Regel bearbeiten`,editAria:`Regel {{ordinal}} bearbeiten`,moveDown:`Nach unten`,moveUp:`Nach oben`,coreDefaultBadge:`Core · Standard`,coreDefaultTitle:`Core-Fallback – die letzte Auffangregel der Pipeline, fest auf sr-developer`}},r={selectedCount:`{{selected}} / {{total}} Agenten ausgewählt`,selectAll:`Alle auswählen`,coreBadge:`core`,categories:{architecture:`Architektur`,development:`Entwicklung`,review:`Review`,product:`Produkt`,utilities:`Werkzeuge`},agents:{"sr-architect":{name:`Architekt`,description:`Architekturdesign, Change-Specs, Implementierungsplanung`},"sr-developer":{name:`Entwickler`,description:`Full-Stack-Implementierung über alle Schichten`},"sr-frontend-developer":{name:`Frontend-Dev`,description:`Frontend-Implementierung (React, Vue, Angular usw.)`},"sr-backend-developer":{name:`Backend-Dev`,description:`Backend-Spezialisierung (APIs, Datenbanken, Services)`},"sr-reviewer":{name:`Reviewer`,description:`Allgemeines Code-Review – das letzte Quality-Gate`},"sr-frontend-reviewer":{name:`Frontend-Reviewer`,description:`Frontend-Review (UI, Barrierefreiheit, Performance)`},"sr-backend-reviewer":{name:`Backend-Reviewer`,description:`Backend-Review (APIs, Sicherheit, Skalierbarkeit)`},"sr-security-reviewer":{name:`Security-Reviewer`,description:`Sicherheitsanalyse – OWASP, Schwachstellen, Härtung`},"sr-performance-reviewer":{name:`Perf-Reviewer`,description:`Performance-Analyse – Profiling, Engpässe, Optimierung`},"sr-product-manager":{name:`Product Manager`,description:`Product Discovery, VPC-Personas, Backlog-Management`},"sr-product-analyst":{name:`Product Analyst`,description:`Backlog-Analyse, Spec-Gap-Analyse, Reporting`},"sr-test-writer":{name:`Test Writer`,description:`Umfassende Testgenerierung (Unit, Integration, E2E)`},"sr-doc-sync":{name:`Doc Sync`,description:`Dokumentations-Sync – hält Docs mit dem Code synchron`},"sr-merge-resolver":{name:`Merge Resolver`,description:`Auflösung von Merge-Konflikten mit Kontextbewusstsein`}}},i={"security-reviewer":{label:`Security-Reviewer`,blurb:`Findet Auth-, Injection- und Datenleck-Bugs in einem Diff, bevor er ausgeliefert wird.`},"performance-profiler":{label:`Performance-Profiler`,blurb:`Findet Hot Paths, N+1-Queries, unbegrenzte Schleifen, Bundle-Bloat.`},"data-engineer":{label:`Data Engineer`,blurb:`Schema-Migrationen, ETL-Pipelines, Datentransformationen.`},"ui-ux-polisher":{label:`UI-/UX-Polisher`,blurb:`Barrierefreiheit, Abstände, Leerzustände, Fehlerbehandlung.`},"api-designer":{label:`API-Designer`,blurb:`Versionierung, Pagination, Fehlerformate, Abwärtskompatibilität.`},"database-architect":{label:`Datenbank-Architekt`,blurb:`Indizes, Normalisierung vs. Denormalisierung, Query-Formen.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, Observability, Incident-Bereitschaft, Runbooks.`},"mobile-engineer":{label:`Mobile Engineer`,blurb:`iOS- und Android-Patterns, Offline-first, akkuschonend.`},"ml-engineer":{label:`ML Engineer`,blurb:`Pipelines, Evaluation, Reproduzierbarkeit, Drift-Monitoring.`},"accessibility-auditor":{label:`Accessibility-Auditor`,blurb:`WCAG-2.2-Review: Kontrast, Fokus, ARIA, Tastatur.`},"qa-test-strategist":{label:`QA-Test-Stratege`,blurb:`Testpläne: Aufteilung Unit / Integration / E2E, Coverage-Lücken.`},"load-tester":{label:`Last-/Stresstester`,blurb:`Kapazitätsplanung, k6-/Locust-Szenarien, Engpasssuche.`},"integration-tester":{label:`Integrationstester`,blurb:`Service-übergreifende Contracts, Fixtures, weniger Flaky-Tests.`},"regression-hunter":{label:`Regressionsjäger`,blurb:`Bisektiert, reproduziert, schreibt zuerst den fehlschlagenden Test.`},"data-analyst":{label:`Data Analyst`,blurb:`Macht aus vagen Fragen Queries und lesbare Erkenntnisse.`},"etl-reviewer":{label:`ETL-Pipeline-Reviewer`,blurb:`Idempotenz, Backfills, verspätet eintreffende Daten.`},"dashboard-designer":{label:`Dashboard-Designer`,blurb:`Dashboards auf einen Blick, ehrliche Achsen, eine Aktion pro Chart.`},"iac-reviewer":{label:`IaC-/Cloud-Reviewer`,blurb:`Terraform / CloudFormation: IAM, öffentliche Exposition, Kosten.`},"compliance-reviewer":{label:`Compliance-Reviewer`,blurb:`DSGVO- / SOC2- / HIPAA-nahe Prüfungen von Datenflüssen.`},"threat-modeler":{label:`Threat Modeler`,blurb:`STRIDE / LINDDUN über Architekturdiagramme.`},"product-manager":{label:`Product Manager`,blurb:`Problem-Framing, PRDs, Priorisierung.`},"ux-researcher":{label:`UX-Researcher`,blurb:`Interviewleitfäden, Usability-Testpläne, Synthese.`},"technical-writer":{label:`Technical Writer`,blurb:`Doku, die wirklich gelesen wird – Tutorials, Referenzen, Changelogs.`},"design-reviewer":{label:`Designsystem-Reviewer`,blurb:`Token-Drift, Komponenten-Fehlgebrauch, Konsistenz über Flows hinweg.`},"financial-analyst":{label:`Finanzanalyst`,blurb:`Unit Economics, Kohortenmodelle, Szenarioanalysen.`},"pricing-strategist":{label:`Pricing-Stratege`,blurb:`Tiering, Packaging, Zahlungsbereitschaftsstudien.`},"market-researcher":{label:`Marktforscher`,blurb:`TAM/SAM/SOM, Wettbewerbskarten, Kundensegmente.`},"ops-optimizer":{label:`Operations-Optimierer`,blurb:`Durchlaufzeiten, Engpasssuche, Automatisierungskandidaten.`},"seo-auditor":{label:`SEO-Auditor`,blurb:`Technisches und Content-SEO: Indexierbarkeit, IA, Suchintention.`},"growth-hacker":{label:`Growth-Experimentierer`,blurb:`Funnel-Diagnose, Lift-Experimente, Aktivierungsschleifen.`},"social-strategist":{label:`Social-Media-Stratege`,blurb:`Kanalgerechter Content, Redaktionskalender, konsistente Stimme.`},"literature-reviewer":{label:`Literatur-Reviewer`,blurb:`Zusammenfassungen systematischer Reviews, Zitationsgraphen, Konflikte.`},"experiment-designer":{label:`Experiment-Designer`,blurb:`Hypothesen, Kontrollgruppen, Stichprobengröße, Präregistrierung.`},"statistical-analyst":{label:`Statistik-Analyst`,blurb:`Wählt den richtigen Test, berichtet Effektstärken statt nur p-Werte.`},"scientific-writer":{label:`Wissenschaftsautor`,blurb:`IMRaD-Struktur, ehrliche Limitationen, lesbare Abstracts.`},"curriculum-designer":{label:`Curriculum-Designer`,blurb:`Lernziele → Aktivitäten → Bewertung.`},"assessment-author":{label:`Prüfungsautor`,blurb:`Aufgaben, die Verständnis messen, nicht Auswendiglernen.`},"tutor-explainer":{label:`Tutor / Erklärer`,blurb:`Einfache Erklärungen im Feynman-Stil mit durchgerechneten Beispielen.`},"clinical-guideline-reviewer":{label:`Reviewer klinischer Leitlinien`,blurb:`Gleicht die Praxis mit den neuesten evidenzbasierten Leitlinien ab.`},"medical-summarizer":{label:`Zusammenfasser medizinischer Literatur`,blurb:`Abstracts für Klinikpersonal: was sich geändert hat, Evidenzqualität.`},"protocol-designer":{label:`Protokoll-Designer`,blurb:`Klinische Protokolle: Endpunkte, Einschlusskriterien, Sicherheit.`},"contract-reviewer":{label:`Vertragsprüfer`,blurb:`Markiert riskante Klauseln und erklärt, was sie wirklich bedeuten.`},"privacy-counsel":{label:`Datenschutzberater`,blurb:`DSGVO / CCPA / LGPD angewendet auf konkrete Datenflüsse.`},"copy-editor":{label:`Lektor`,blurb:`Zeilenlektorat: Stimme, Rhythmus, 30 % kürzen ohne Bedeutungsverlust.`},"brand-voice-guardian":{label:`Markenstimme-Wächter`,blurb:`Setzt Voice-Regeln durch; erkennt markenfremde Formulierungen.`},"creative-brainstormer":{label:`Kreativ-Brainstormer`,blurb:`Erst divergent, dann konvergent; schlachtet heilige Kühe höflich.`},"hiring-interviewer":{label:`Hiring-Interviewer`,blurb:`Strukturierte Interviews, signalfokussiert, bias-bewusst.`},"strategic-planner":{label:`Strategieplaner`,blurb:`Ziele → Wetten → Metriken; streicht Lieblingsprojekte.`},"coach-1on1":{label:`1:1-Coach`,blurb:`Hilft bei Feedback, Karriereentwicklung und schwierigen Gesprächen.`},"meeting-facilitator":{label:`Meeting-Moderator`,blurb:`Agenden, die Entscheidungen liefern statt Status-Updates.`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`Chargement de l'agent…`,modeCreate:`Nouvel agent personnalisé`,modeEdit:`Modifier l'agent personnalisé`,create:`Créer`,unsaved:`● non enregistré`,resumeAiEdit:`Reprendre l'Édition IA`,resumeAiEditTitle:`Renvoyer ce brouillon vers l'overlay Édition IA`,loadingAiDraft:`chargement du brouillon IA…`,testButton:`Tester`,testButtonTitle:`Tester cet agent sur une tâche d'exemple`,historyButton:`Historique`,historyButtonTitle:`Historique des versions`,deleteConfirm:{title:`Supprimer l'agent « {{agentId}} » ?`,description:`Supprime le fichier .md du disque. L'historique des versions reste en base — créez un nouvel agent personnalisé si vous voulez récupérer le corps plus tard.`},errors:{loadDraftFailed:`Échec du chargement du brouillon : {{status}}`,loadFailed:`Échec du chargement : {{status}}`,saveFailed:`Échec de l'enregistrement : {{status}}`,deleteFailed:`Échec de la suppression : {{status}}`,testFailed:`Échec du test : {{status}}`},toasts:{agentCreated:`Agent créé`,agentSaved:`Agent enregistré`,agentDeleted:`Agent supprimé`,createFailed:`Échec de la création de l'agent`,saveFailed:`Échec de l'enregistrement de l'agent`,deleteFailed:`Échec de la suppression de l'agent`},validation:{namePattern:`Le nom doit commencer par <code>custom-</code> et ne contenir que des lettres minuscules, des chiffres et des tirets.`,missingFrontmatter:`Frontmatter YAML manquant (il faut un <code>---</code> d'ouverture sur la première ligne).`},sampleTasks:{pick:`— choisir une tâche d'exemple —`,terraform:`Terraform : bucket S3 public`,sqlInjection:`Revue de code : injection SQL`,accessibility:`Frontend : accessibilité`,schemaChange:`Données : changement de schéma`,slowQuery:`Performance : requête lente`},testPane:{header:`Tester l'agent`,sampleTaskLabel:`Tâche d'exemple`,placeholder:`Décrivez ce que l'agent doit faire, ou choisissez un exemple ci-dessus.`,run:`Exécuter`,running:`Exécution…`,sandboxNote:`Exécution en sandbox ; aucun fichier écrit.`,tokens_one:`<mono>{{count}}</mono> token`,tokens_other:`<mono>{{count}}</mono> tokens`,emptyHint:`Exécutez une tâche d'exemple sur le brouillon actuel. La sortie s'affiche ici.`},versions:{header:`Historique des versions`,empty:`Aucune version antérieure enregistrée pour cet agent.`,restoreHint:`Cliquez sur une version pour restaurer son corps dans l'éditeur (il faudra ensuite Enregistrer).`}},t={eyebrow:`Édition IA`,headline:`Affinez votre agent`,streamingHeadline:`Affinage de votre agent…`,placeholderInitial:`Décrivez comment affiner cet agent…`,placeholderFollowUp:`Envoyez un affinage complémentaire…`,viewCurrentBody:`Voir le corps actuel de l'agent`,appliedAsVersion:`Appliqué comme version {{version}}.`,openInStudio:`Ouvrir le brouillon dans le Studio pour l'éditer manuellement`,chips:{tightenTools:`Resserrer la liste d'outils`,stricterPersonality:`Rendre la personnalité plus stricte`,workflowSection:`Ajouter une section de protocole Workflow`,sharpenDescription:`Raccourcir et affûter la description`,matchDeveloperStyle:`S'aligner sur le style de sr-developer`}},n={validation:{missingBaseline:`Agent de base requis manquant : {{agent}}`,multipleDefaultRules:`Le routage admet au plus une règle par défaut ({{found}} trouvées)`,defaultRuleNotLast:`La règle de routage par défaut doit être la dernière entrée`,unknownRoutingAgent:`Le routage référence un agent absent de la chaîne : {{agent}}`,invalidTags:`La règle de routage {{agent}} a des tags invalides : {{tags}} (utilisez du kebab-case en minuscules)`},validationSummary_one:`{{count}} problème de validation`,validationSummary_other:`{{count}} problèmes de validation`,nameLabel:`Nom`,descriptionLabel:`Description`,descriptionPlaceholder:`À quoi sert ce profil ?`,orchestrator:{heading:`Orchestrateur`,description:`Modèle de premier niveau pour les deux commandes. batch-implement délègue à implement pour chaque fonctionnalité, donc chaque rail qu'il lance hérite de la chaîne d'agents de ce profil.`},agentChain:{heading:`Chaîne d'agents ({{n}})`,addTitle:`Ajouter un agent depuis le catalogue`,addDisabledTitle:`Tous les agents du catalogue sont déjà dans la chaîne`,pickFromCatalog:`Choisir dans le catalogue ({{n}} disponibles)`,emptyCatalog:`Plus aucun agent dans le catalogue. Ajoutez des agents personnalisés depuis l'onglet Catalogue d'agents.`,kind:{upstream:`upstream`,custom:`personnalisé`}},routing:{heading:`Routage ({{n}})`,addDefault:`Ajouter la règle par défaut`,addRule:`Ajouter une règle`,needAgentsTitle:`Ajoutez au moins un agent avant de créer des règles de routage`,explainer:`La première règle correspondante l'emporte. Les règles sont modifiables et supprimables, et la règle fourre-tout par défaut reste en dernier quand elle existe. Si le routage est vide, le pipeline se rabat sur le premier agent de type développeur de la chaîne.`,untargetedTitle:`Agents non ciblés dans la chaîne`,untargetedDetail:`Aucune règle de routage ne pointe vers : <mono>{{agents}}</mono>. Ajoutez une règle de tag ou reciblez la règle par défaut si vous voulez qu'ils s'exécutent.`},agentRow:{dragTitle:`Glisser pour réordonner`,dragHandleAria:`Poignée de glissement`,pinnedFirst:`premier`,pinnedFirstTitle:`Épinglé en première position — le pipeline commence toujours par sr-architect`,pinnedLast:`dernier`,pinnedLastTitle:`Épinglé en dernière position — la phase de merge s'exécute toujours en dernier`,required:`requis`,requiredRemoveTitle:`Agent de base requis — le pipeline dépend de cette ligne`},routingRow:{everythingElse:`tout le reste`,defaultTargetAria:`Cible de routage par défaut (core, lecture seule)`,defaultTargetTitle:`Repli core — non modifiable`,targetAria:`Cible de routage pour la règle {{ordinal}}`,editTitle:`Modifier la règle`,editAria:`Modifier la règle {{ordinal}}`,moveDown:`Descendre`,moveUp:`Monter`,coreDefaultBadge:`core · défaut`,coreDefaultTitle:`Repli core — la règle de dernier recours du pipeline, épinglée sur sr-developer`}},r={selectedCount:`{{selected}} / {{total}} agents sélectionnés`,selectAll:`Tout sélectionner`,coreBadge:`core`,categories:{architecture:`Architecture`,development:`Développement`,review:`Revue`,product:`Produit`,utilities:`Utilitaires`},agents:{"sr-architect":{name:`Architecte`,description:`Conception d'architecture, specs de changement, planification d'implémentation`},"sr-developer":{name:`Développeur`,description:`Implémentation full-stack sur toutes les couches`},"sr-frontend-developer":{name:`Dév Frontend`,description:`Implémentation frontend (React, Vue, Angular, etc.)`},"sr-backend-developer":{name:`Dév Backend`,description:`Spécialisation backend (API, bases de données, services)`},"sr-reviewer":{name:`Relecteur`,description:`Revue de code générale — l'ultime contrôle qualité`},"sr-frontend-reviewer":{name:`Relecteur Frontend`,description:`Revue frontend (UI, accessibilité, performance)`},"sr-backend-reviewer":{name:`Relecteur Backend`,description:`Revue backend (API, sécurité, scalabilité)`},"sr-security-reviewer":{name:`Relecteur Sécurité`,description:`Analyse de sécurité — OWASP, vulnérabilités, durcissement`},"sr-performance-reviewer":{name:`Relecteur Perf`,description:`Analyse de performance — profiling, goulots d'étranglement, optimisation`},"sr-product-manager":{name:`Product Manager`,description:`Découverte produit, personas VPC, gestion du backlog`},"sr-product-analyst":{name:`Analyste Produit`,description:`Analyse du backlog, analyse des écarts de spec, reporting`},"sr-test-writer":{name:`Rédacteur de tests`,description:`Génération complète de tests (unitaires, intégration, E2E)`},"sr-doc-sync":{name:`Doc Sync`,description:`Synchronisation de la documentation — garde les docs alignées avec le code`},"sr-merge-resolver":{name:`Résolveur de merge`,description:`Résolution des conflits de merge avec prise en compte du contexte`}}},i={"security-reviewer":{label:`Relecteur Sécurité`,blurb:`Détecte les bugs d'authentification, d'injection et d'exposition de données dans un diff avant livraison.`},"performance-profiler":{label:`Profileur de performance`,blurb:`Repère les hot paths, les requêtes N+1, les boucles non bornées, le gonflement du bundle.`},"data-engineer":{label:`Data Engineer`,blurb:`Migrations de schéma, pipelines ETL, transformations de données.`},"ui-ux-polisher":{label:`Polisseur UI / UX`,blurb:`Accessibilité, espacement, états vides, gestion des erreurs.`},"api-designer":{label:`Concepteur d'API`,blurb:`Versionnage, pagination, formats d'erreur, rétrocompatibilité.`},"database-architect":{label:`Architecte base de données`,blurb:`Index, normalisation vs dénormalisation, formes de requêtes.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, observabilité, préparation aux incidents, runbooks.`},"mobile-engineer":{label:`Ingénieur Mobile`,blurb:`Patterns iOS + Android, offline-first, sobriété batterie.`},"ml-engineer":{label:`Ingénieur ML`,blurb:`Pipelines, éval, reproductibilité, surveillance du drift.`},"accessibility-auditor":{label:`Auditeur Accessibilité`,blurb:`Revue WCAG 2.2 : contraste, focus, ARIA, clavier.`},"qa-test-strategist":{label:`Stratège de tests QA`,blurb:`Plans de test : répartition unitaires / intégration / E2E, lacunes de couverture.`},"load-tester":{label:`Testeur de charge / stress`,blurb:`Planification de capacité, scénarios k6 / Locust, chasse aux goulots d'étranglement.`},"integration-tester":{label:`Testeur d'intégration`,blurb:`Contrats inter-services, fixtures, réduction des tests flaky.`},"regression-hunter":{label:`Chasseur de régressions`,blurb:`Bisecte, reproduit, écrit d'abord le test qui échoue.`},"data-analyst":{label:`Data Analyst`,blurb:`Transforme des questions vagues en requêtes + conclusions lisibles.`},"etl-reviewer":{label:`Relecteur de pipeline ETL`,blurb:`Idempotence, backfills, données tardives.`},"dashboard-designer":{label:`Concepteur de dashboards`,blurb:`Dashboards lisibles d'un coup d'œil, axes honnêtes, une action par graphique.`},"iac-reviewer":{label:`Relecteur IaC / Cloud`,blurb:`Terraform / CloudFormation : IAM, exposition publique, coûts.`},"compliance-reviewer":{label:`Relecteur Conformité`,blurb:`Contrôles type RGPD / SOC2 / HIPAA sur les flux de données.`},"threat-modeler":{label:`Modélisateur de menaces`,blurb:`STRIDE / LINDDUN sur les diagrammes d'architecture.`},"product-manager":{label:`Product Manager`,blurb:`Cadrage du problème, PRD, priorisation.`},"ux-researcher":{label:`Chercheur UX`,blurb:`Scripts d'entretien, plans de tests d'utilisabilité, synthèse.`},"technical-writer":{label:`Rédacteur technique`,blurb:`Des docs qu'on lit vraiment — tutoriels, références, changelogs.`},"design-reviewer":{label:`Relecteur Design System`,blurb:`Dérive des tokens, mauvais usage des composants, cohérence entre les flux.`},"financial-analyst":{label:`Analyste financier`,blurb:`Unit economics, modèles de cohortes, analyse de scénarios.`},"pricing-strategist":{label:`Stratège Pricing`,blurb:`Paliers, packaging, études de disposition à payer.`},"market-researcher":{label:`Chargé d'études de marché`,blurb:`TAM/SAM/SOM, cartographies concurrentielles, segments clients.`},"ops-optimizer":{label:`Optimiseur des opérations`,blurb:`Temps de cycle, détection des goulots, candidats à l'automatisation.`},"seo-auditor":{label:`Auditeur SEO`,blurb:`SEO technique + contenu : indexabilité, architecture de l'information, adéquation à l'intention.`},"growth-hacker":{label:`Expérimentateur Growth`,blurb:`Diagnostic de funnel, expériences d'uplift, boucles d'activation.`},"social-strategist":{label:`Stratège réseaux sociaux`,blurb:`Contenu adapté au canal, calendrier éditorial, cohérence de la voix.`},"literature-reviewer":{label:`Relecteur de littérature`,blurb:`Synthèses de revues systématiques, graphes de citations, conflits.`},"experiment-designer":{label:`Concepteur d'expériences`,blurb:`Hypothèses, contrôles, taille d'échantillon, préenregistrement.`},"statistical-analyst":{label:`Analyste statistique`,blurb:`Choisit le bon test, rapporte les tailles d'effet, pas seulement les p-values.`},"scientific-writer":{label:`Rédacteur scientifique`,blurb:`Structure IMRaD, limites honnêtes, abstracts lisibles.`},"curriculum-designer":{label:`Concepteur de cursus`,blurb:`Objectifs d'apprentissage → activités → évaluation.`},"assessment-author":{label:`Auteur d'évaluations`,blurb:`Des questions qui mesurent la compréhension, pas la mémorisation.`},"tutor-explainer":{label:`Tuteur / Vulgarisateur`,blurb:`Explications simples façon Feynman, avec exemples corrigés.`},"clinical-guideline-reviewer":{label:`Relecteur de recommandations cliniques`,blurb:`Confronte la pratique aux dernières recommandations fondées sur les preuves.`},"medical-summarizer":{label:`Synthétiseur de littérature médicale`,blurb:`Des abstracts pour les cliniciens : ce qui change, qualité des preuves.`},"protocol-designer":{label:`Concepteur de protocoles`,blurb:`Protocoles cliniques : critères de jugement, critères d'inclusion, sécurité.`},"contract-reviewer":{label:`Relecteur de contrats`,blurb:`Signale les clauses à risque ; explique ce qu'elles veulent vraiment dire.`},"privacy-counsel":{label:`Conseil en confidentialité`,blurb:`RGPD / CCPA / LGPD appliqués à des flux concrets.`},"copy-editor":{label:`Réviseur éditorial`,blurb:`Corrections fines : voix, rythme, couper 30 % sans perdre le sens.`},"brand-voice-guardian":{label:`Gardien de la voix de marque`,blurb:`Fait respecter les règles de ton ; repère les formulations hors marque.`},"creative-brainstormer":{label:`Brainstormer créatif`,blurb:`Divergent puis convergent ; tue les vaches sacrées avec tact.`},"hiring-interviewer":{label:`Intervieweur de recrutement`,blurb:`Entretiens structurés, axés sur le signal, attentifs aux biais.`},"strategic-planner":{label:`Planificateur stratégique`,blurb:`Objectifs → paris → métriques ; élague les projets fétiches.`},"coach-1on1":{label:`Coach 1:1`,blurb:`Aide à cadrer le feedback, l'évolution de carrière, les conversations difficiles.`},"meeting-facilitator":{label:`Facilitateur de réunions`,blurb:`Des ordres du jour qui produisent des décisions, pas des points d'étape.`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`エージェントを読み込み中…`,modeCreate:`新規カスタムエージェント`,modeEdit:`カスタムエージェントを編集`,create:`作成`,unsaved:`● 未保存`,resumeAiEdit:`AI編集を再開`,resumeAiEditTitle:`このドラフトをAI編集オーバーレイに戻す`,loadingAiDraft:`AIドラフトを読み込み中…`,testButton:`テスト`,testButtonTitle:`サンプルタスクでこのエージェントをテスト`,historyButton:`履歴`,historyButtonTitle:`バージョン履歴`,deleteConfirm:{title:`エージェント「{{agentId}}」を削除しますか?`,description:`ディスクから .md を削除します。バージョン履歴は DB に残ります — 後で本文を復元したい場合は新しいカスタムエージェントを作成してください。`},errors:{loadDraftFailed:`ドラフトの読み込みに失敗しました: {{status}}`,loadFailed:`読み込みに失敗しました: {{status}}`,saveFailed:`保存に失敗しました: {{status}}`,deleteFailed:`削除に失敗しました: {{status}}`,testFailed:`テストに失敗しました: {{status}}`},toasts:{agentCreated:`エージェントを作成しました`,agentSaved:`エージェントを保存しました`,agentDeleted:`エージェントを削除しました`,createFailed:`エージェントの作成に失敗しました`,saveFailed:`エージェントの保存に失敗しました`,deleteFailed:`エージェントの削除に失敗しました`},validation:{namePattern:`名前は <code>custom-</code> で始まり、小文字・数字・ハイフンのみ使用できます。`,missingFrontmatter:`YAML フロントマターがありません(1行目に <code>---</code> が必要です)。`},sampleTasks:{pick:`— サンプルタスクを選択 —`,terraform:`Terraform: 公開 S3 バケット`,sqlInjection:`コードレビュー: SQL インジェクション`,accessibility:`フロントエンド: アクセシビリティ`,schemaChange:`データ: スキーマ変更`,slowQuery:`パフォーマンス: 遅いクエリ`},testPane:{header:`エージェントをテスト`,sampleTaskLabel:`サンプルタスク`,placeholder:`エージェントに実行させたい内容を記述するか、上のサンプルを選択してください。`,run:`実行`,running:`実行中…`,sandboxNote:`サンドボックス実行。ファイルへの書き込みはありません。`,tokens_one:`<mono>{{count}}</mono> トークン`,tokens_other:`<mono>{{count}}</mono> トークン`,emptyHint:`現在のドラフトに対してサンプルタスクを実行します。出力はここに表示されます。`},versions:{header:`バージョン履歴`,empty:`このエージェントの過去のバージョンはありません。`,restoreHint:`バージョンをクリックすると本文がエディタに復元されます(保存は別途必要です)。`}},t={eyebrow:`AI編集`,headline:`エージェントを改良`,streamingHeadline:`エージェントを改良中…`,placeholderInitial:`このエージェントをどう改良するか記述してください…`,placeholderFollowUp:`追加の改良指示を送信…`,viewCurrentBody:`現在のエージェント本文を表示`,appliedAsVersion:`バージョン {{version}} として適用しました。`,openInStudio:`Studio でドラフトを開いて手動編集`,chips:{tightenTools:`ツールリストを絞り込む`,stricterPersonality:`パーソナリティをより厳格に`,workflowSection:`ワークフロープロトコルのセクションを追加`,sharpenDescription:`説明を短く鋭く`,matchDeveloperStyle:`sr-developer のスタイルに合わせる`}},n={validation:{missingBaseline:`必須のベースラインエージェントがありません: {{agent}}`,multipleDefaultRules:`ルーティングのデフォルトルールは1つまでです({{found}} 件見つかりました)`,defaultRuleNotLast:`デフォルトのルーティングルールは最後に配置する必要があります`,unknownRoutingAgent:`ルーティングがチェーンにないエージェントを参照しています: {{agent}}`,invalidTags:`ルーティングルール {{agent}} に不正なタグがあります: {{tags}}(小文字のケバブケースを使用してください)`},validationSummary_one:`{{count}} 件の検証の問題`,validationSummary_other:`{{count}} 件の検証の問題`,nameLabel:`名前`,descriptionLabel:`説明`,descriptionPlaceholder:`このプロファイルの用途は?`,orchestrator:{heading:`オーケストレーター`,description:`両コマンドの最上位モデルです。batch-implement はフィーチャーごとに implement に委譲するため、起動されるすべてのレールがこのプロファイルのエージェントチェーンを継承します。`},agentChain:{heading:`エージェントチェーン({{n}})`,addTitle:`カタログからエージェントを追加`,addDisabledTitle:`カタログの全エージェントが既にチェーンに含まれています`,pickFromCatalog:`カタログから選択({{n}} 件利用可能)`,emptyCatalog:`カタログに追加できるエージェントがありません。エージェントカタログタブからカスタムエージェントを追加してください。`,kind:{upstream:`アップストリーム`,custom:`カスタム`}},routing:{heading:`ルーティング({{n}})`,addDefault:`デフォルトを追加`,addRule:`ルールを追加`,needAgentsTitle:`ルーティングルールを作成する前にエージェントを1つ以上追加してください`,explainer:`最初に一致したルールが適用されます。ルールは編集・削除でき、デフォルトのキャッチオールは存在する場合は常に最後に配置されます。ルーティングが空の場合、パイプラインはチェーン内の最初の developer 系エージェントにフォールバックします。`,untargetedTitle:`チェーン内の未割り当てエージェント`,untargetedDetail:`どのルーティングルールも <mono>{{agents}}</mono> を指していません。実行させたい場合はタグルールを追加するか、デフォルトルールのターゲットを変更してください。`},agentRow:{dragTitle:`ドラッグして並べ替え`,dragHandleAria:`ドラッグハンドル`,pinnedFirst:`先頭`,pinnedFirstTitle:`先頭に固定 — パイプラインは常に sr-architect から開始します`,pinnedLast:`末尾`,pinnedLastTitle:`末尾に固定 — マージフェーズは常に最後に実行されます`,required:`必須`,requiredRemoveTitle:`必須のベースラインエージェント — パイプラインはこの行に依存しています`},routingRow:{everythingElse:`その他すべて`,defaultTargetAria:`デフォルトのルーティングターゲット(コア、読み取り専用)`,defaultTargetTitle:`コアのフォールバック — 編集不可`,targetAria:`ルール {{ordinal}} のルーティングターゲット`,editTitle:`ルールを編集`,editAria:`ルール {{ordinal}} を編集`,moveDown:`下へ移動`,moveUp:`上へ移動`,coreDefaultBadge:`コア · デフォルト`,coreDefaultTitle:`コアのフォールバック — パイプラインの最終手段のルールで、sr-developer に固定されています`}},r={selectedCount:`{{selected}} / {{total}} エージェントを選択中`,selectAll:`すべて選択`,coreBadge:`コア`,categories:{architecture:`アーキテクチャ`,development:`開発`,review:`レビュー`,product:`プロダクト`,utilities:`ユーティリティ`},agents:{"sr-architect":{name:`アーキテクト`,description:`アーキテクチャ設計、変更スペック、実装計画`},"sr-developer":{name:`デベロッパー`,description:`全レイヤーにわたるフルスタック実装`},"sr-frontend-developer":{name:`フロントエンド開発`,description:`フロントエンド実装(React、Vue、Angular など)`},"sr-backend-developer":{name:`バックエンド開発`,description:`バックエンド特化(API、データベース、サービス)`},"sr-reviewer":{name:`レビュアー`,description:`一般的なコードレビュー — 最終品質ゲート`},"sr-frontend-reviewer":{name:`フロントエンドレビュアー`,description:`フロントエンドレビュー(UI、アクセシビリティ、パフォーマンス)`},"sr-backend-reviewer":{name:`バックエンドレビュアー`,description:`バックエンドレビュー(API、セキュリティ、スケーラビリティ)`},"sr-security-reviewer":{name:`セキュリティレビュアー`,description:`セキュリティ分析 — OWASP、脆弱性、ハードニング`},"sr-performance-reviewer":{name:`パフォーマンスレビュアー`,description:`パフォーマンス分析 — プロファイリング、ボトルネック、最適化`},"sr-product-manager":{name:`プロダクトマネージャー`,description:`プロダクト発見、VPC ペルソナ、バックログ管理`},"sr-product-analyst":{name:`プロダクトアナリスト`,description:`バックログ分析、スペックギャップ分析、レポーティング`},"sr-test-writer":{name:`テストライター`,description:`包括的なテスト生成(ユニット、統合、E2E)`},"sr-doc-sync":{name:`ドキュメント同期`,description:`ドキュメント同期 — ドキュメントをコードと整合させます`},"sr-merge-resolver":{name:`マージリゾルバー`,description:`コンテキストを考慮したマージコンフリクトの解決`}}},i={"security-reviewer":{label:`セキュリティレビュアー`,blurb:`リリース前の diff から認証、インジェクション、データ漏洩のバグを発見します。`},"performance-profiler":{label:`パフォーマンスプロファイラー`,blurb:`ホットパス、N+1 クエリ、上限のないループ、バンドル肥大化を発見します。`},"data-engineer":{label:`データエンジニア`,blurb:`スキーママイグレーション、ETL パイプライン、データ変換。`},"ui-ux-polisher":{label:`UI / UX ポリッシャー`,blurb:`アクセシビリティ、スペーシング、空状態、エラーハンドリング。`},"api-designer":{label:`API デザイナー`,blurb:`バージョニング、ページネーション、エラー形式、後方互換性。`},"database-architect":{label:`データベースアーキテクト`,blurb:`インデックス、正規化 vs 非正規化、クエリ形状。`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD、可観測性、インシデント対応準備、ランブック。`},"mobile-engineer":{label:`モバイルエンジニア`,blurb:`iOS + Android のパターン、オフラインファースト、バッテリー配慮。`},"ml-engineer":{label:`ML エンジニア`,blurb:`パイプライン、評価、再現性、ドリフト監視。`},"accessibility-auditor":{label:`アクセシビリティ監査者`,blurb:`WCAG 2.2 レビュー: コントラスト、フォーカス、ARIA、キーボード。`},"qa-test-strategist":{label:`QA テストストラテジスト`,blurb:`テスト計画: ユニット / 統合 / E2E の配分、カバレッジの欠落。`},"load-tester":{label:`負荷 / ストレステスター`,blurb:`キャパシティプランニング、k6 / Locust シナリオ、ボトルネック探索。`},"integration-tester":{label:`統合テスター`,blurb:`サービス間コントラクト、フィクスチャ、フレーキーテストの削減。`},"regression-hunter":{label:`リグレッションハンター`,blurb:`バイセクトと再現を行い、まず失敗するテストを書きます。`},"data-analyst":{label:`データアナリスト`,blurb:`曖昧な質問をクエリと読みやすい知見に変換します。`},"etl-reviewer":{label:`ETL パイプラインレビュアー`,blurb:`冪等性、バックフィル、遅延到着データ。`},"dashboard-designer":{label:`ダッシュボードデザイナー`,blurb:`一目で分かるダッシュボード、正直な軸、チャートごとのアクション。`},"iac-reviewer":{label:`IaC / クラウドレビュアー`,blurb:`Terraform / CloudFormation: IAM、公開露出、コスト。`},"compliance-reviewer":{label:`コンプライアンスレビュアー`,blurb:`データフローに対する GDPR / SOC2 / HIPAA 関連のチェック。`},"threat-modeler":{label:`脅威モデラー`,blurb:`アーキテクチャ図に対する STRIDE / LINDDUN。`},"product-manager":{label:`プロダクトマネージャー`,blurb:`課題設定、PRD、優先順位付け。`},"ux-researcher":{label:`UX リサーチャー`,blurb:`インタビュースクリプト、ユーザビリティテスト計画、結果の統合。`},"technical-writer":{label:`テクニカルライター`,blurb:`実際に読まれるドキュメント — チュートリアル、リファレンス、変更履歴。`},"design-reviewer":{label:`デザインシステムレビュアー`,blurb:`トークンのドリフト、コンポーネントの誤用、フロー間の一貫性。`},"financial-analyst":{label:`ファイナンシャルアナリスト`,blurb:`ユニットエコノミクス、コホートモデル、シナリオ分析。`},"pricing-strategist":{label:`プライシングストラテジスト`,blurb:`ティアリング、パッケージング、支払い意欲調査。`},"market-researcher":{label:`マーケットリサーチャー`,blurb:`TAM/SAM/SOM、競合マップ、顧客セグメント。`},"ops-optimizer":{label:`オペレーション最適化担当`,blurb:`サイクルタイム、ボトルネック発見、自動化候補。`},"seo-auditor":{label:`SEO 監査者`,blurb:`テクニカル + コンテンツ SEO: インデックス可能性、情報設計、検索意図の一致。`},"growth-hacker":{label:`グロース実験担当`,blurb:`ファネル診断、リフト実験、アクティベーションループ。`},"social-strategist":{label:`ソーシャルメディアストラテジスト`,blurb:`チャネルに合ったコンテンツ、編集カレンダー、ボイスの一貫性。`},"literature-reviewer":{label:`文献レビュアー`,blurb:`システマティックレビューの要約、引用グラフ、相反の検出。`},"experiment-designer":{label:`実験デザイナー`,blurb:`仮説、対照群、サンプルサイズ、事前登録。`},"statistical-analyst":{label:`統計アナリスト`,blurb:`適切な検定を選び、p 値だけでなく効果量を報告します。`},"scientific-writer":{label:`サイエンティフィックライター`,blurb:`IMRaD 構成、誠実な限界の記述、読みやすい要旨。`},"curriculum-designer":{label:`カリキュラムデザイナー`,blurb:`学習成果 → アクティビティ → 評価。`},"assessment-author":{label:`評価項目作成者`,blurb:`暗記ではなく理解を測る設問。`},"tutor-explainer":{label:`チューター / 解説者`,blurb:`ファインマン流のシンプルな説明と例題。`},"clinical-guideline-reviewer":{label:`臨床ガイドラインレビュアー`,blurb:`最新のエビデンスに基づくガイドラインと診療を照合します。`},"medical-summarizer":{label:`医学文献要約者`,blurb:`臨床医向けの要約: 何が変わったか、エビデンスの質。`},"protocol-designer":{label:`プロトコルデザイナー`,blurb:`臨床プロトコル: エンドポイント、選択基準、安全性。`},"contract-reviewer":{label:`契約レビュアー`,blurb:`リスクの高い条項にフラグを立て、実際の意味を説明します。`},"privacy-counsel":{label:`プライバシーカウンセル`,blurb:`具体的なフローに適用する GDPR / CCPA / LGPD。`},"copy-editor":{label:`コピーエディター`,blurb:`行単位の編集: ボイス、リズム、意味を保ったまま 30% 削減。`},"brand-voice-guardian":{label:`ブランドボイスガーディアン`,blurb:`ボイスルールを徹底し、ブランドから外れた表現を検出します。`},"creative-brainstormer":{label:`クリエイティブブレインストーマー`,blurb:`発散してから収束。聖域も丁寧に切り捨てます。`},"hiring-interviewer":{label:`採用面接官`,blurb:`構造化面接、シグナル重視、バイアスに配慮。`},"strategic-planner":{label:`戦略プランナー`,blurb:`目標 → 賭け → 指標。お気に入りプロジェクトを剪定します。`},"coach-1on1":{label:`1:1 コーチ`,blurb:`フィードバック、キャリア成長、難しい対話の組み立てを支援します。`},"meeting-facilitator":{label:`ミーティングファシリテーター`,blurb:`報告ではなく意思決定を生むアジェンダ。`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./chunk-CilyBKbf.js";var t=e({agentSelector:()=>a,default:()=>s,profileEditor:()=>i,refine:()=>r,studio:()=>n,templates:()=>o}),n={loadingAgent:`Loading agent…`,modeCreate:`New custom agent`,modeEdit:`Edit custom agent`,create:`Create`,unsaved:`● unsaved`,resumeAiEdit:`Resume AI Edit`,resumeAiEditTitle:`Hand this draft back to the AI Edit overlay`,loadingAiDraft:`loading AI draft…`,testButton:`Test`,testButtonTitle:`Test this agent against a sample task`,historyButton:`History`,historyButtonTitle:`Version history`,deleteConfirm:{title:`Delete agent "{{agentId}}"?`,description:`This removes the .md from disk. Version history stays in the DB — use a fresh custom agent if you want to recover the body later.`},errors:{loadDraftFailed:`Load draft failed: {{status}}`,loadFailed:`Load failed: {{status}}`,saveFailed:`Save failed: {{status}}`,deleteFailed:`Delete failed: {{status}}`,testFailed:`Test failed: {{status}}`},toasts:{agentCreated:`Agent created`,agentSaved:`Agent saved`,agentDeleted:`Agent deleted`,createFailed:`Failed to create agent`,saveFailed:`Failed to save agent`,deleteFailed:`Failed to delete agent`},validation:{namePattern:`Name must start with <code>custom-</code> and contain only lowercase letters, digits, and hyphens.`,missingFrontmatter:`Missing YAML frontmatter (needs opening <code>---</code> on the first line).`},sampleTasks:{pick:`— pick a sample task —`,terraform:`Terraform: public S3 bucket`,sqlInjection:`Code review: SQL injection`,accessibility:`Frontend: accessibility`,schemaChange:`Data: schema change`,slowQuery:`Performance: slow query`},testPane:{header:`Test agent`,sampleTaskLabel:`Sample task`,placeholder:`Describe what the agent should do, or pick a sample above.`,run:`Run`,running:`Running…`,sandboxNote:`Sandboxed; no files written.`,tokens_one:`<mono>{{count}}</mono> token`,tokens_other:`<mono>{{count}}</mono> tokens`,emptyHint:`Run a sample task against the current draft. Output appears here.`},versions:{header:`Version history`,empty:`No prior versions recorded for this agent.`,restoreHint:`Click a version to restore its body into the editor (you still need to Save).`}},r={eyebrow:`AI Edit`,headline:`Refine your agent`,streamingHeadline:`Refining your agent…`,placeholderInitial:`Describe how to refine this agent…`,placeholderFollowUp:`Send a follow-up refinement…`,viewCurrentBody:`View current agent body`,appliedAsVersion:`Applied as version {{version}}.`,openInStudio:`Open draft in Studio for manual editing`,chips:{tightenTools:`Tighten the tool list`,stricterPersonality:`Make the personality stricter`,workflowSection:`Add a Workflow protocol section`,sharpenDescription:`Shorten and sharpen the description`,matchDeveloperStyle:`Match the sr-developer style`}},i={validation:{missingBaseline:`Missing required baseline agent: {{agent}}`,multipleDefaultRules:`Routing may have at most one default rule (found {{found}})`,defaultRuleNotLast:`The default routing rule must be the last entry`,unknownRoutingAgent:`Routing references agent not in the chain: {{agent}}`,invalidTags:`Routing rule {{agent}} has invalid tags: {{tags}} (use lowercase kebab-case)`},validationSummary_one:`{{count}} validation issue`,validationSummary_other:`{{count}} validation issues`,nameLabel:`Name`,descriptionLabel:`Description`,descriptionPlaceholder:`What is this profile for?`,orchestrator:{heading:`Orchestrator`,description:`Top-level model for both commands. batch-implement delegates to implement per feature, so every rail it spawns inherits this profile's agent chain.`},agentChain:{heading:`Agent chain ({{n}})`,addTitle:`Add an agent from the catalog`,addDisabledTitle:`All catalog agents are already in the chain`,pickFromCatalog:`Pick from catalog ({{n}} available)`,emptyCatalog:`No more agents in the catalog. Add custom agents from the Agents Catalog tab.`,kind:{upstream:`upstream`,custom:`custom`}},routing:{heading:`Routing ({{n}})`,addDefault:`Add default`,addRule:`Add rule`,needAgentsTitle:`Add at least one agent before creating routing rules`,explainer:`First matching rule wins. Rules are editable and removable, and the default catch-all stays last when present. If you leave routing empty, the pipeline falls back to the first developer-shaped agent in the chain.`,untargetedTitle:`Untargeted agents in the chain`,untargetedDetail:`No routing rule points to: <mono>{{agents}}</mono>. Add a tag rule or retarget the default rule if you want them to run.`},agentRow:{dragTitle:`Drag to reorder`,dragHandleAria:`Drag handle`,pinnedFirst:`first`,pinnedFirstTitle:`Pinned to first position — pipeline always starts with sr-architect`,pinnedLast:`last`,pinnedLastTitle:`Pinned to last position — merge phase always runs last`,required:`required`,requiredRemoveTitle:`Required baseline agent — the pipeline depends on this row`},routingRow:{everythingElse:`everything else`,defaultTargetAria:`Default routing target (core, read-only)`,defaultTargetTitle:`Core fallback — not editable`,targetAria:`Routing target for rule {{ordinal}}`,editTitle:`Edit rule`,editAria:`Edit rule {{ordinal}}`,moveDown:`Move down`,moveUp:`Move up`,coreDefaultBadge:`core · default`,coreDefaultTitle:`Core fallback — the pipeline's last-resort rule, pinned to sr-developer`}},a={selectedCount:`{{selected}} / {{total}} agents selected`,selectAll:`Select all`,coreBadge:`core`,categories:{architecture:`Architecture`,development:`Development`,review:`Review`,product:`Product`,utilities:`Utilities`},agents:{"sr-architect":{name:`Architect`,description:`Architecture design, change specs, implementation planning`},"sr-developer":{name:`Developer`,description:`Full-stack implementation across all layers`},"sr-frontend-developer":{name:`Frontend Dev`,description:`Frontend implementation (React, Vue, Angular, etc.)`},"sr-backend-developer":{name:`Backend Dev`,description:`Backend specialization (APIs, databases, services)`},"sr-reviewer":{name:`Reviewer`,description:`General code review — the final quality gate`},"sr-frontend-reviewer":{name:`Frontend Reviewer`,description:`Frontend review (UI, accessibility, performance)`},"sr-backend-reviewer":{name:`Backend Reviewer`,description:`Backend review (APIs, security, scalability)`},"sr-security-reviewer":{name:`Security Reviewer`,description:`Security analysis — OWASP, vulnerabilities, hardening`},"sr-performance-reviewer":{name:`Perf Reviewer`,description:`Performance analysis — profiling, bottlenecks, optimization`},"sr-product-manager":{name:`Product Manager`,description:`Product discovery, VPC personas, backlog management`},"sr-product-analyst":{name:`Product Analyst`,description:`Backlog analysis, spec gap analysis, reporting`},"sr-test-writer":{name:`Test Writer`,description:`Comprehensive test generation (unit, integration, E2E)`},"sr-doc-sync":{name:`Doc Sync`,description:`Documentation sync — keeps docs aligned with code`},"sr-merge-resolver":{name:`Merge Resolver`,description:`Merge conflict resolution with context awareness`}}},o={"security-reviewer":{label:`Security Reviewer`,blurb:`Finds auth, injection, and data-exposure bugs in a diff before it ships.`},"performance-profiler":{label:`Performance Profiler`,blurb:`Finds hot paths, N+1 queries, unbounded loops, bundle bloat.`},"data-engineer":{label:`Data Engineer`,blurb:`Schema migrations, ETL pipelines, data transformations.`},"ui-ux-polisher":{label:`UI / UX Polisher`,blurb:`Accessibility, spacing, empty states, error handling.`},"api-designer":{label:`API Designer`,blurb:`Versioning, pagination, error shapes, backward compatibility.`},"database-architect":{label:`Database Architect`,blurb:`Indexes, normalization vs denormalization, query shapes.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, observability, incident-readiness, runbooks.`},"mobile-engineer":{label:`Mobile Engineer`,blurb:`iOS + Android patterns, offline-first, battery-aware.`},"ml-engineer":{label:`ML Engineer`,blurb:`Pipelines, eval, reproducibility, drift monitoring.`},"accessibility-auditor":{label:`Accessibility Auditor`,blurb:`WCAG 2.2 review: contrast, focus, ARIA, keyboard.`},"qa-test-strategist":{label:`QA Test Strategist`,blurb:`Test plans: unit / integration / E2E split, coverage gaps.`},"load-tester":{label:`Load / Stress Tester`,blurb:`Capacity planning, k6 / Locust scenarios, bottleneck hunting.`},"integration-tester":{label:`Integration Tester`,blurb:`Cross-service contracts, fixtures, flake reduction.`},"regression-hunter":{label:`Regression Hunter`,blurb:`Bisects, repros, writes the failing test first.`},"data-analyst":{label:`Data Analyst`,blurb:`Turns vague questions into queries + readable findings.`},"etl-reviewer":{label:`ETL Pipeline Reviewer`,blurb:`Idempotency, backfills, late-arriving data.`},"dashboard-designer":{label:`Dashboard Designer`,blurb:`One-glance dashboards, honest axes, action-per-chart.`},"iac-reviewer":{label:`IaC / Cloud Reviewer`,blurb:`Terraform / CloudFormation: IAM, public exposure, costs.`},"compliance-reviewer":{label:`Compliance Reviewer`,blurb:`GDPR / SOC2 / HIPAA-adjacent checks on data flows.`},"threat-modeler":{label:`Threat Modeler`,blurb:`STRIDE / LINDDUN over architecture diagrams.`},"product-manager":{label:`Product Manager`,blurb:`Problem framing, PRDs, prioritization.`},"ux-researcher":{label:`UX Researcher`,blurb:`Interview scripts, usability test plans, synthesis.`},"technical-writer":{label:`Technical Writer`,blurb:`Docs that are actually read — tutorials, references, changelogs.`},"design-reviewer":{label:`Design System Reviewer`,blurb:`Token drift, component misuse, consistency across flows.`},"financial-analyst":{label:`Financial Analyst`,blurb:`Unit economics, cohort models, scenario analysis.`},"pricing-strategist":{label:`Pricing Strategist`,blurb:`Tiering, packaging, willingness-to-pay studies.`},"market-researcher":{label:`Market Researcher`,blurb:`TAM/SAM/SOM, competitive maps, customer segments.`},"ops-optimizer":{label:`Operations Optimizer`,blurb:`Cycle-time, bottleneck-finding, automation candidates.`},"seo-auditor":{label:`SEO Auditor`,blurb:`Technical + content SEO: indexability, IA, intent match.`},"growth-hacker":{label:`Growth Experimenter`,blurb:`Funnel diagnosis, lift experiments, activation loops.`},"social-strategist":{label:`Social Media Strategist`,blurb:`Channel-fit content, editorial calendar, voice consistency.`},"literature-reviewer":{label:`Literature Reviewer`,blurb:`Systematic review summaries, citation graphs, conflicts.`},"experiment-designer":{label:`Experiment Designer`,blurb:`Hypotheses, controls, sample size, pre-registration.`},"statistical-analyst":{label:`Statistical Analyst`,blurb:`Chooses the right test, reports effect sizes, not just p-values.`},"scientific-writer":{label:`Scientific Writer`,blurb:`IMRaD structure, honest limits, readable abstracts.`},"curriculum-designer":{label:`Curriculum Designer`,blurb:`Learning outcomes → activities → assessment.`},"assessment-author":{label:`Assessment Author`,blurb:`Items that measure understanding, not recall.`},"tutor-explainer":{label:`Tutor / Explainer`,blurb:`Feynman-style simple explanations with worked examples.`},"clinical-guideline-reviewer":{label:`Clinical Guideline Reviewer`,blurb:`Map practice against latest evidence-based guidelines.`},"medical-summarizer":{label:`Medical Literature Summarizer`,blurb:`Abstracts to clinicians: what changed, evidence quality.`},"protocol-designer":{label:`Protocol Designer`,blurb:`Clinical protocols: endpoints, inclusion criteria, safety.`},"contract-reviewer":{label:`Contract Reviewer`,blurb:`Flags risky clauses; explains what they actually mean.`},"privacy-counsel":{label:`Privacy Counsel`,blurb:`GDPR / CCPA / LGPD applied to concrete flows.`},"copy-editor":{label:`Copy Editor`,blurb:`Line edits: voice, cadence, cut 30% without losing meaning.`},"brand-voice-guardian":{label:`Brand Voice Guardian`,blurb:`Enforces voice rules; catches off-brand phrasing.`},"creative-brainstormer":{label:`Creative Brainstormer`,blurb:`Divergent then convergent; kills sacred cows politely.`},"hiring-interviewer":{label:`Hiring Interviewer`,blurb:`Structured interviews, signal-focused, bias-aware.`},"strategic-planner":{label:`Strategic Planner`,blurb:`Goals → bets → metrics; prunes pet projects.`},"coach-1on1":{label:`1:1 Coach`,blurb:`Helps frame feedback, career growth, difficult conversations.`},"meeting-facilitator":{label:`Meeting Facilitator`,blurb:`Agendas that produce decisions, not updates.`}},s={studio:n,refine:r,profileEditor:i,agentSelector:a,templates:o};export{t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`A carregar agente…`,modeCreate:`Novo agente personalizado`,modeEdit:`Editar agente personalizado`,create:`Criar`,unsaved:`● não guardado`,resumeAiEdit:`Retomar AI Edit`,resumeAiEditTitle:`Devolver este rascunho ao overlay de AI Edit`,loadingAiDraft:`a carregar rascunho de IA…`,testButton:`Testar`,testButtonTitle:`Testar este agente com uma tarefa de exemplo`,historyButton:`Histórico`,historyButtonTitle:`Histórico de versões`,deleteConfirm:{title:`Eliminar o agente "{{agentId}}"?`,description:`Isto remove o .md do disco. O histórico de versões mantém-se na BD — use um novo agente personalizado se quiser recuperar o corpo mais tarde.`},errors:{loadDraftFailed:`Falha ao carregar o rascunho: {{status}}`,loadFailed:`Falha ao carregar: {{status}}`,saveFailed:`Falha ao guardar: {{status}}`,deleteFailed:`Falha ao eliminar: {{status}}`,testFailed:`Falha no teste: {{status}}`},toasts:{agentCreated:`Agente criado`,agentSaved:`Agente guardado`,agentDeleted:`Agente eliminado`,createFailed:`Falha ao criar o agente`,saveFailed:`Falha ao guardar o agente`,deleteFailed:`Falha ao eliminar o agente`},validation:{namePattern:`O nome deve começar por <code>custom-</code> e conter apenas letras minúsculas, dígitos e hífenes.`,missingFrontmatter:`Falta o frontmatter YAML (requer <code>---</code> de abertura na primeira linha).`},sampleTasks:{pick:`— escolha uma tarefa de exemplo —`,terraform:`Terraform: bucket S3 público`,sqlInjection:`Revisão de código: injeção de SQL`,accessibility:`Frontend: acessibilidade`,schemaChange:`Dados: alteração de schema`,slowQuery:`Desempenho: query lenta`},testPane:{header:`Testar agente`,sampleTaskLabel:`Tarefa de exemplo`,placeholder:`Descreva o que o agente deve fazer, ou escolha um exemplo acima.`,run:`Executar`,running:`A executar…`,sandboxNote:`Em sandbox; nenhum ficheiro é escrito.`,tokens_one:`<mono>{{count}}</mono> token`,tokens_other:`<mono>{{count}}</mono> tokens`,emptyHint:`Execute uma tarefa de exemplo contra o rascunho atual. O resultado aparece aqui.`},versions:{header:`Histórico de versões`,empty:`Não há versões anteriores registadas para este agente.`,restoreHint:`Clique numa versão para restaurar o respetivo corpo no editor (ainda é preciso Guardar).`}},t={eyebrow:`AI Edit`,headline:`Refine o seu agente`,streamingHeadline:`A refinar o seu agente…`,placeholderInitial:`Descreva como refinar este agente…`,placeholderFollowUp:`Envie um refinamento de seguimento…`,viewCurrentBody:`Ver o corpo atual do agente`,appliedAsVersion:`Aplicado como versão {{version}}.`,openInStudio:`Abrir rascunho no Studio para edição manual`,chips:{tightenTools:`Restringir a lista de ferramentas`,stricterPersonality:`Tornar a personalidade mais rigorosa`,workflowSection:`Adicionar uma secção de protocolo de Workflow`,sharpenDescription:`Encurtar e afinar a descrição`,matchDeveloperStyle:`Alinhar com o estilo do sr-developer`}},n={validation:{missingBaseline:`Falta o agente base obrigatório: {{agent}}`,multipleDefaultRules:`O routing pode ter no máximo uma regra default (encontradas {{found}})`,defaultRuleNotLast:`A regra de routing default tem de ser a última entrada`,unknownRoutingAgent:`O routing referencia um agente que não está na cadeia: {{agent}}`,invalidTags:`A regra de routing {{agent}} tem tags inválidas: {{tags}} (use kebab-case em minúsculas)`},validationSummary_one:`{{count}} problema de validação`,validationSummary_other:`{{count}} problemas de validação`,nameLabel:`Nome`,descriptionLabel:`Descrição`,descriptionPlaceholder:`Para que serve este perfil?`,orchestrator:{heading:`Orquestrador`,description:`Modelo de topo para ambos os comandos. O batch-implement delega no implement por feature, pelo que cada rail que lança herda a cadeia de agentes deste perfil.`},agentChain:{heading:`Cadeia de agentes ({{n}})`,addTitle:`Adicionar um agente do catálogo`,addDisabledTitle:`Todos os agentes do catálogo já estão na cadeia`,pickFromCatalog:`Escolher do catálogo ({{n}} disponíveis)`,emptyCatalog:`Não há mais agentes no catálogo. Adicione agentes personalizados no separador Catálogo de Agentes.`,kind:{upstream:`upstream`,custom:`personalizado`}},routing:{heading:`Routing ({{n}})`,addDefault:`Adicionar default`,addRule:`Adicionar regra`,needAgentsTitle:`Adicione pelo menos um agente antes de criar regras de routing`,explainer:`Vence a primeira regra correspondente. As regras são editáveis e removíveis, e o catch-all default fica em último quando presente. Se deixar o routing vazio, o pipeline recorre ao primeiro agente de tipo developer na cadeia.`,untargetedTitle:`Agentes sem destino na cadeia`,untargetedDetail:`Nenhuma regra de routing aponta para: <mono>{{agents}}</mono>. Adicione uma regra de tag ou redirecione a regra default se quiser que sejam executados.`},agentRow:{dragTitle:`Arraste para reordenar`,dragHandleAria:`Pega de arrasto`,pinnedFirst:`primeiro`,pinnedFirstTitle:`Fixado na primeira posição — o pipeline começa sempre com o sr-architect`,pinnedLast:`último`,pinnedLastTitle:`Fixado na última posição — a fase de merge é sempre a última a executar`,required:`obrigatório`,requiredRemoveTitle:`Agente base obrigatório — o pipeline depende desta linha`},routingRow:{everythingElse:`tudo o resto`,defaultTargetAria:`Destino de routing default (core, só de leitura)`,defaultTargetTitle:`Fallback core — não editável`,targetAria:`Destino de routing da regra {{ordinal}}`,editTitle:`Editar regra`,editAria:`Editar regra {{ordinal}}`,moveDown:`Mover para baixo`,moveUp:`Mover para cima`,coreDefaultBadge:`core · default`,coreDefaultTitle:`Fallback core — a regra de último recurso do pipeline, fixada no sr-developer`}},r={selectedCount:`{{selected}} / {{total}} agentes selecionados`,selectAll:`Selecionar todos`,coreBadge:`core`,categories:{architecture:`Arquitetura`,development:`Desenvolvimento`,review:`Revisão`,product:`Produto`,utilities:`Utilitários`},agents:{"sr-architect":{name:`Arquiteto`,description:`Design de arquitetura, specs de alterações, planeamento da implementação`},"sr-developer":{name:`Developer`,description:`Implementação full-stack em todas as camadas`},"sr-frontend-developer":{name:`Dev Frontend`,description:`Implementação frontend (React, Vue, Angular, etc.)`},"sr-backend-developer":{name:`Dev Backend`,description:`Especialização backend (APIs, bases de dados, serviços)`},"sr-reviewer":{name:`Revisor`,description:`Revisão de código geral — o gate de qualidade final`},"sr-frontend-reviewer":{name:`Revisor Frontend`,description:`Revisão frontend (UI, acessibilidade, desempenho)`},"sr-backend-reviewer":{name:`Revisor Backend`,description:`Revisão backend (APIs, segurança, escalabilidade)`},"sr-security-reviewer":{name:`Revisor de Segurança`,description:`Análise de segurança — OWASP, vulnerabilidades, hardening`},"sr-performance-reviewer":{name:`Revisor de Desempenho`,description:`Análise de desempenho — profiling, gargalos, otimização`},"sr-product-manager":{name:`Product Manager`,description:`Discovery de produto, personas VPC, gestão de backlog`},"sr-product-analyst":{name:`Analista de Produto`,description:`Análise de backlog, análise de lacunas em specs, relatórios`},"sr-test-writer":{name:`Escritor de Testes`,description:`Geração abrangente de testes (unitários, integração, E2E)`},"sr-doc-sync":{name:`Doc Sync`,description:`Sincronização de documentação — mantém a documentação alinhada com o código`},"sr-merge-resolver":{name:`Merge Resolver`,description:`Resolução de conflitos de merge com consciência do contexto`}}},i={"security-reviewer":{label:`Revisor de Segurança`,blurb:`Encontra bugs de autenticação, injeção e exposição de dados num diff antes do envio.`},"performance-profiler":{label:`Profiler de Desempenho`,blurb:`Encontra hot paths, queries N+1, loops sem limite, bundles inchados.`},"data-engineer":{label:`Engenheiro de Dados`,blurb:`Migrações de schema, pipelines ETL, transformações de dados.`},"ui-ux-polisher":{label:`Polidor de UI / UX`,blurb:`Acessibilidade, espaçamento, estados vazios, tratamento de erros.`},"api-designer":{label:`Designer de API`,blurb:`Versionamento, paginação, formatos de erro, retrocompatibilidade.`},"database-architect":{label:`Arquiteto de Base de Dados`,blurb:`Índices, normalização vs desnormalização, formatos de queries.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, observabilidade, preparação para incidentes, runbooks.`},"mobile-engineer":{label:`Engenheiro Mobile`,blurb:`Padrões iOS + Android, offline-first, atenção à bateria.`},"ml-engineer":{label:`Engenheiro de ML`,blurb:`Pipelines, avaliação, reprodutibilidade, monitorização de drift.`},"accessibility-auditor":{label:`Auditor de Acessibilidade`,blurb:`Revisão WCAG 2.2: contraste, foco, ARIA, teclado.`},"qa-test-strategist":{label:`Estratega de Testes QA`,blurb:`Planos de teste: divisão unitários / integração / E2E, lacunas de cobertura.`},"load-tester":{label:`Tester de Carga / Stress`,blurb:`Planeamento de capacidade, cenários k6 / Locust, caça aos gargalos.`},"integration-tester":{label:`Tester de Integração`,blurb:`Contratos entre serviços, fixtures, redução de testes instáveis.`},"regression-hunter":{label:`Caçador de Regressões`,blurb:`Faz bisect, reproduz e escreve primeiro o teste que falha.`},"data-analyst":{label:`Analista de Dados`,blurb:`Transforma perguntas vagas em queries + conclusões legíveis.`},"etl-reviewer":{label:`Revisor de Pipelines ETL`,blurb:`Idempotência, backfills, dados que chegam tarde.`},"dashboard-designer":{label:`Designer de Dashboards`,blurb:`Dashboards de leitura imediata, eixos honestos, uma ação por gráfico.`},"iac-reviewer":{label:`Revisor de IaC / Cloud`,blurb:`Terraform / CloudFormation: IAM, exposição pública, custos.`},"compliance-reviewer":{label:`Revisor de Conformidade`,blurb:`Verificações no âmbito do RGPD / SOC2 / HIPAA sobre fluxos de dados.`},"threat-modeler":{label:`Modelador de Ameaças`,blurb:`STRIDE / LINDDUN sobre diagramas de arquitetura.`},"product-manager":{label:`Product Manager`,blurb:`Enquadramento do problema, PRDs, priorização.`},"ux-researcher":{label:`Investigador de UX`,blurb:`Guiões de entrevista, planos de testes de usabilidade, síntese.`},"technical-writer":{label:`Redator Técnico`,blurb:`Documentação que realmente se lê — tutoriais, referências, changelogs.`},"design-reviewer":{label:`Revisor de Design System`,blurb:`Desvio de tokens, mau uso de componentes, consistência entre fluxos.`},"financial-analyst":{label:`Analista Financeiro`,blurb:`Unit economics, modelos de coortes, análise de cenários.`},"pricing-strategist":{label:`Estratega de Preços`,blurb:`Níveis, empacotamento, estudos de disposição a pagar.`},"market-researcher":{label:`Investigador de Mercado`,blurb:`TAM/SAM/SOM, mapas competitivos, segmentos de clientes.`},"ops-optimizer":{label:`Otimizador de Operações`,blurb:`Tempo de ciclo, deteção de gargalos, candidatos a automação.`},"seo-auditor":{label:`Auditor de SEO`,blurb:`SEO técnico + de conteúdo: indexabilidade, IA, correspondência de intenção.`},"growth-hacker":{label:`Experimentador de Growth`,blurb:`Diagnóstico de funil, experiências de lift, loops de ativação.`},"social-strategist":{label:`Estratega de Redes Sociais`,blurb:`Conteúdo adequado ao canal, calendário editorial, consistência de voz.`},"literature-reviewer":{label:`Revisor de Literatura`,blurb:`Resumos de revisões sistemáticas, grafos de citações, conflitos.`},"experiment-designer":{label:`Designer de Experiências`,blurb:`Hipóteses, controlos, tamanho da amostra, pré-registo.`},"statistical-analyst":{label:`Analista Estatístico`,blurb:`Escolhe o teste certo, reporta tamanhos de efeito, não apenas p-values.`},"scientific-writer":{label:`Redator Científico`,blurb:`Estrutura IMRaD, limites honestos, abstracts legíveis.`},"curriculum-designer":{label:`Designer de Currículos`,blurb:`Objetivos de aprendizagem → atividades → avaliação.`},"assessment-author":{label:`Autor de Avaliações`,blurb:`Itens que medem compreensão, não memorização.`},"tutor-explainer":{label:`Tutor / Explicador`,blurb:`Explicações simples à Feynman com exemplos resolvidos.`},"clinical-guideline-reviewer":{label:`Revisor de Diretrizes Clínicas`,blurb:`Compara a prática com as mais recentes diretrizes baseadas na evidência.`},"medical-summarizer":{label:`Sintetizador de Literatura Médica`,blurb:`Abstracts para clínicos: o que mudou, qualidade da evidência.`},"protocol-designer":{label:`Designer de Protocolos`,blurb:`Protocolos clínicos: endpoints, critérios de inclusão, segurança.`},"contract-reviewer":{label:`Revisor de Contratos`,blurb:`Sinaliza cláusulas de risco; explica o que realmente significam.`},"privacy-counsel":{label:`Consultor de Privacidade`,blurb:`RGPD / CCPA / LGPD aplicados a fluxos concretos.`},"copy-editor":{label:`Editor de Texto`,blurb:`Edições linha a linha: voz, cadência, cortar 30% sem perder o sentido.`},"brand-voice-guardian":{label:`Guardião da Voz da Marca`,blurb:`Aplica as regras de voz; deteta formulações fora da marca.`},"creative-brainstormer":{label:`Brainstormer Criativo`,blurb:`Divergente e depois convergente; mata vacas sagradas com delicadeza.`},"hiring-interviewer":{label:`Entrevistador de Recrutamento`,blurb:`Entrevistas estruturadas, focadas no sinal, conscientes de vieses.`},"strategic-planner":{label:`Planeador Estratégico`,blurb:`Objetivos → apostas → métricas; poda projetos de estimação.`},"coach-1on1":{label:`Coach de 1:1`,blurb:`Ajuda a enquadrar feedback, progressão de carreira, conversas difíceis.`},"meeting-facilitator":{label:`Facilitador de Reuniões`,blurb:`Agendas que produzem decisões, não atualizações.`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`Cargando agente…`,modeCreate:`Nuevo agente personalizado`,modeEdit:`Editar agente personalizado`,create:`Crear`,unsaved:`● sin guardar`,resumeAiEdit:`Reanudar AI Edit`,resumeAiEditTitle:`Devolver este borrador al panel de AI Edit`,loadingAiDraft:`cargando borrador de IA…`,testButton:`Probar`,testButtonTitle:`Probar este agente con una tarea de ejemplo`,historyButton:`Historial`,historyButtonTitle:`Historial de versiones`,deleteConfirm:{title:`¿Eliminar el agente "{{agentId}}"?`,description:`Esto elimina el .md del disco. El historial de versiones se conserva en la BD — usa un nuevo agente personalizado si quieres recuperar el cuerpo más adelante.`},errors:{loadDraftFailed:`Error al cargar el borrador: {{status}}`,loadFailed:`Error al cargar: {{status}}`,saveFailed:`Error al guardar: {{status}}`,deleteFailed:`Error al eliminar: {{status}}`,testFailed:`Error en la prueba: {{status}}`},toasts:{agentCreated:`Agente creado`,agentSaved:`Agente guardado`,agentDeleted:`Agente eliminado`,createFailed:`No se pudo crear el agente`,saveFailed:`No se pudo guardar el agente`,deleteFailed:`No se pudo eliminar el agente`},validation:{namePattern:`El nombre debe empezar por <code>custom-</code> y contener solo minúsculas, dígitos y guiones.`,missingFrontmatter:`Falta el frontmatter YAML (necesita un <code>---</code> de apertura en la primera línea).`},sampleTasks:{pick:`— elige una tarea de ejemplo —`,terraform:`Terraform: bucket S3 público`,sqlInjection:`Revisión de código: inyección SQL`,accessibility:`Frontend: accesibilidad`,schemaChange:`Datos: cambio de esquema`,slowQuery:`Rendimiento: consulta lenta`},testPane:{header:`Probar agente`,sampleTaskLabel:`Tarea de ejemplo`,placeholder:`Describe qué debe hacer el agente o elige un ejemplo arriba.`,run:`Ejecutar`,running:`Ejecutando…`,sandboxNote:`En sandbox; no se escriben archivos.`,tokens_one:`<mono>{{count}}</mono> token`,tokens_other:`<mono>{{count}}</mono> tokens`,emptyHint:`Ejecuta una tarea de ejemplo contra el borrador actual. El resultado aparece aquí.`},versions:{header:`Historial de versiones`,empty:`No hay versiones anteriores registradas para este agente.`,restoreHint:`Haz clic en una versión para restaurar su cuerpo en el editor (aún tendrás que guardar).`}},t={eyebrow:`AI Edit`,headline:`Refina tu agente`,streamingHeadline:`Refinando tu agente…`,placeholderInitial:`Describe cómo refinar este agente…`,placeholderFollowUp:`Envía un refinamiento adicional…`,viewCurrentBody:`Ver el cuerpo actual del agente`,appliedAsVersion:`Aplicado como versión {{version}}.`,openInStudio:`Abrir el borrador en Studio para editarlo manualmente`,chips:{tightenTools:`Acota la lista de herramientas`,stricterPersonality:`Haz la personalidad más estricta`,workflowSection:`Añade una sección de protocolo de workflow`,sharpenDescription:`Acorta y afina la descripción`,matchDeveloperStyle:`Imita el estilo de sr-developer`}},n={validation:{missingBaseline:`Falta el agente base obligatorio: {{agent}}`,multipleDefaultRules:`El enrutado solo puede tener una regla por defecto (se encontraron {{found}})`,defaultRuleNotLast:`La regla de enrutado por defecto debe ser la última entrada`,unknownRoutingAgent:`El enrutado referencia un agente que no está en la cadena: {{agent}}`,invalidTags:`La regla de enrutado {{agent}} tiene tags no válidos: {{tags}} (usa kebab-case en minúsculas)`},validationSummary_one:`{{count}} problema de validación`,validationSummary_other:`{{count}} problemas de validación`,nameLabel:`Nombre`,descriptionLabel:`Descripción`,descriptionPlaceholder:`¿Para qué sirve este perfil?`,orchestrator:{heading:`Orquestador`,description:`Modelo de nivel superior para ambos comandos. batch-implement delega en implement por cada feature, así que cada rail que lanza hereda la cadena de agentes de este perfil.`},agentChain:{heading:`Cadena de agentes ({{n}})`,addTitle:`Añadir un agente del catálogo`,addDisabledTitle:`Todos los agentes del catálogo ya están en la cadena`,pickFromCatalog:`Elegir del catálogo ({{n}} disponibles)`,emptyCatalog:`No quedan agentes en el catálogo. Añade agentes personalizados desde la pestaña Catálogo de agentes.`,kind:{upstream:`upstream`,custom:`personalizado`}},routing:{heading:`Enrutado ({{n}})`,addDefault:`Añadir por defecto`,addRule:`Añadir regla`,needAgentsTitle:`Añade al menos un agente antes de crear reglas de enrutado`,explainer:`Gana la primera regla que coincida. Las reglas se pueden editar y eliminar, y la regla por defecto se mantiene en último lugar cuando existe. Si dejas el enrutado vacío, el pipeline recurre al primer agente de tipo developer de la cadena.`,untargetedTitle:`Agentes de la cadena sin regla`,untargetedDetail:`Ninguna regla de enrutado apunta a: <mono>{{agents}}</mono>. Añade una regla de tags o redirige la regla por defecto si quieres que se ejecuten.`},agentRow:{dragTitle:`Arrastra para reordenar`,dragHandleAria:`Asa de arrastre`,pinnedFirst:`primero`,pinnedFirstTitle:`Fijado en primera posición — el pipeline siempre empieza con sr-architect`,pinnedLast:`último`,pinnedLastTitle:`Fijado en última posición — la fase de merge siempre se ejecuta al final`,required:`obligatorio`,requiredRemoveTitle:`Agente base obligatorio — el pipeline depende de esta fila`},routingRow:{everythingElse:`todo lo demás`,defaultTargetAria:`Destino de enrutado por defecto (core, solo lectura)`,defaultTargetTitle:`Fallback del core — no editable`,targetAria:`Destino de enrutado para la regla {{ordinal}}`,editTitle:`Editar regla`,editAria:`Editar regla {{ordinal}}`,moveDown:`Bajar`,moveUp:`Subir`,coreDefaultBadge:`core · por defecto`,coreDefaultTitle:`Fallback del core — la regla de último recurso del pipeline, fijada a sr-developer`}},r={selectedCount:`{{selected}} / {{total}} agentes seleccionados`,selectAll:`Seleccionar todo`,coreBadge:`core`,categories:{architecture:`Arquitectura`,development:`Desarrollo`,review:`Revisión`,product:`Producto`,utilities:`Utilidades`},agents:{"sr-architect":{name:`Arquitecto`,description:`Diseño de arquitectura, specs de cambios, planificación de la implementación`},"sr-developer":{name:`Desarrollador`,description:`Implementación full-stack en todas las capas`},"sr-frontend-developer":{name:`Dev frontend`,description:`Implementación de frontend (React, Vue, Angular, etc.)`},"sr-backend-developer":{name:`Dev backend`,description:`Especialización en backend (APIs, bases de datos, servicios)`},"sr-reviewer":{name:`Revisor`,description:`Revisión general de código — el último control de calidad`},"sr-frontend-reviewer":{name:`Revisor frontend`,description:`Revisión de frontend (UI, accesibilidad, rendimiento)`},"sr-backend-reviewer":{name:`Revisor backend`,description:`Revisión de backend (APIs, seguridad, escalabilidad)`},"sr-security-reviewer":{name:`Revisor de seguridad`,description:`Análisis de seguridad — OWASP, vulnerabilidades, hardening`},"sr-performance-reviewer":{name:`Revisor de rendimiento`,description:`Análisis de rendimiento — profiling, cuellos de botella, optimización`},"sr-product-manager":{name:`Product Manager`,description:`Descubrimiento de producto, personas VPC, gestión del backlog`},"sr-product-analyst":{name:`Analista de producto`,description:`Análisis del backlog, detección de huecos en las specs, informes`},"sr-test-writer":{name:`Redactor de tests`,description:`Generación completa de tests (unitarios, integración, E2E)`},"sr-doc-sync":{name:`Sincronizador de docs`,description:`Sincronización de documentación — mantiene los docs alineados con el código`},"sr-merge-resolver":{name:`Resolutor de merges`,description:`Resolución de conflictos de merge teniendo en cuenta el contexto`}}},i={"security-reviewer":{label:`Revisor de seguridad`,blurb:`Encuentra bugs de autenticación, inyección y exposición de datos en un diff antes de publicarlo.`},"performance-profiler":{label:`Perfilador de rendimiento`,blurb:`Encuentra hot paths, consultas N+1, bucles sin límite y bundles hinchados.`},"data-engineer":{label:`Ingeniero de datos`,blurb:`Migraciones de esquema, pipelines ETL, transformaciones de datos.`},"ui-ux-polisher":{label:`Pulidor de UI / UX`,blurb:`Accesibilidad, espaciado, estados vacíos, gestión de errores.`},"api-designer":{label:`Diseñador de APIs`,blurb:`Versionado, paginación, formatos de error, retrocompatibilidad.`},"database-architect":{label:`Arquitecto de bases de datos`,blurb:`Índices, normalización frente a desnormalización, patrones de consulta.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, observabilidad, preparación ante incidentes, runbooks.`},"mobile-engineer":{label:`Ingeniero móvil`,blurb:`Patrones de iOS y Android, offline-first, cuidado con la batería.`},"ml-engineer":{label:`Ingeniero de ML`,blurb:`Pipelines, evaluación, reproducibilidad, monitorización de drift.`},"accessibility-auditor":{label:`Auditor de accesibilidad`,blurb:`Revisión WCAG 2.2: contraste, foco, ARIA, teclado.`},"qa-test-strategist":{label:`Estratega de tests QA`,blurb:`Planes de test: reparto unitarios / integración / E2E, huecos de cobertura.`},"load-tester":{label:`Tester de carga / estrés`,blurb:`Planificación de capacidad, escenarios k6 / Locust, caza de cuellos de botella.`},"integration-tester":{label:`Tester de integración`,blurb:`Contratos entre servicios, fixtures, reducción de tests flaky.`},"regression-hunter":{label:`Cazador de regresiones`,blurb:`Biseca, reproduce y escribe primero el test que falla.`},"data-analyst":{label:`Analista de datos`,blurb:`Convierte preguntas vagas en consultas + conclusiones legibles.`},"etl-reviewer":{label:`Revisor de pipelines ETL`,blurb:`Idempotencia, backfills, datos que llegan tarde.`},"dashboard-designer":{label:`Diseñador de dashboards`,blurb:`Dashboards de un vistazo, ejes honestos, una acción por gráfico.`},"iac-reviewer":{label:`Revisor de IaC / cloud`,blurb:`Terraform / CloudFormation: IAM, exposición pública, costes.`},"compliance-reviewer":{label:`Revisor de cumplimiento`,blurb:`Comprobaciones cercanas a RGPD / SOC2 / HIPAA sobre flujos de datos.`},"threat-modeler":{label:`Modelador de amenazas`,blurb:`STRIDE / LINDDUN sobre diagramas de arquitectura.`},"product-manager":{label:`Product Manager`,blurb:`Encuadre de problemas, PRDs, priorización.`},"ux-researcher":{label:`Investigador UX`,blurb:`Guiones de entrevista, planes de test de usabilidad, síntesis.`},"technical-writer":{label:`Redactor técnico`,blurb:`Docs que de verdad se leen — tutoriales, referencias, changelogs.`},"design-reviewer":{label:`Revisor de design system`,blurb:`Deriva de tokens, mal uso de componentes, consistencia entre flujos.`},"financial-analyst":{label:`Analista financiero`,blurb:`Unit economics, modelos de cohortes, análisis de escenarios.`},"pricing-strategist":{label:`Estratega de precios`,blurb:`Niveles, empaquetado, estudios de disposición a pagar.`},"market-researcher":{label:`Investigador de mercado`,blurb:`TAM/SAM/SOM, mapas competitivos, segmentos de clientes.`},"ops-optimizer":{label:`Optimizador de operaciones`,blurb:`Tiempos de ciclo, detección de cuellos de botella, candidatos a automatización.`},"seo-auditor":{label:`Auditor SEO`,blurb:`SEO técnico y de contenido: indexabilidad, arquitectura de la información, ajuste a la intención.`},"growth-hacker":{label:`Experimentador de growth`,blurb:`Diagnóstico de funnels, experimentos de mejora, bucles de activación.`},"social-strategist":{label:`Estratega de redes sociales`,blurb:`Contenido adaptado al canal, calendario editorial, consistencia de voz.`},"literature-reviewer":{label:`Revisor de literatura`,blurb:`Resúmenes de revisión sistemática, grafos de citas, conflictos.`},"experiment-designer":{label:`Diseñador de experimentos`,blurb:`Hipótesis, controles, tamaño muestral, prerregistro.`},"statistical-analyst":{label:`Analista estadístico`,blurb:`Elige el test correcto e informa tamaños de efecto, no solo p-valores.`},"scientific-writer":{label:`Redactor científico`,blurb:`Estructura IMRaD, límites honestos, abstracts legibles.`},"curriculum-designer":{label:`Diseñador curricular`,blurb:`Resultados de aprendizaje → actividades → evaluación.`},"assessment-author":{label:`Autor de evaluaciones`,blurb:`Ítems que miden comprensión, no memorización.`},"tutor-explainer":{label:`Tutor / explicador`,blurb:`Explicaciones sencillas al estilo Feynman con ejemplos resueltos.`},"clinical-guideline-reviewer":{label:`Revisor de guías clínicas`,blurb:`Contrasta la práctica con las últimas guías basadas en la evidencia.`},"medical-summarizer":{label:`Resumidor de literatura médica`,blurb:`Abstracts para clínicos: qué ha cambiado, calidad de la evidencia.`},"protocol-designer":{label:`Diseñador de protocolos`,blurb:`Protocolos clínicos: endpoints, criterios de inclusión, seguridad.`},"contract-reviewer":{label:`Revisor de contratos`,blurb:`Señala cláusulas de riesgo y explica qué significan en realidad.`},"privacy-counsel":{label:`Asesor de privacidad`,blurb:`RGPD / CCPA / LGPD aplicados a flujos concretos.`},"copy-editor":{label:`Editor de estilo`,blurb:`Ediciones línea a línea: voz, cadencia, recortar un 30 % sin perder significado.`},"brand-voice-guardian":{label:`Guardián de la voz de marca`,blurb:`Aplica las reglas de voz; caza frases fuera de marca.`},"creative-brainstormer":{label:`Brainstormer creativo`,blurb:`Diverge y luego converge; mata vacas sagradas con educación.`},"hiring-interviewer":{label:`Entrevistador de contratación`,blurb:`Entrevistas estructuradas, centradas en la señal, conscientes del sesgo.`},"strategic-planner":{label:`Planificador estratégico`,blurb:`Objetivos → apuestas → métricas; poda los proyectos capricho.`},"coach-1on1":{label:`Coach de 1:1`,blurb:`Ayuda a enmarcar el feedback, el crecimiento profesional y las conversaciones difíciles.`},"meeting-facilitator":{label:`Facilitador de reuniones`,blurb:`Agendas que producen decisiones, no actualizaciones.`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={loadingAgent:`Caricamento agente…`,modeCreate:`Nuovo agente personalizzato`,modeEdit:`Modifica agente personalizzato`,create:`Crea`,unsaved:`● non salvato`,resumeAiEdit:`Riprendi AI Edit`,resumeAiEditTitle:`Riconsegna questa bozza all'overlay AI Edit`,loadingAiDraft:`caricamento bozza AI…`,testButton:`Test`,testButtonTitle:`Testa questo agente su un task di esempio`,historyButton:`Cronologia`,historyButtonTitle:`Cronologia versioni`,deleteConfirm:{title:`Eliminare l'agente "{{agentId}}"?`,description:`Rimuove il file .md dal disco. La cronologia versioni resta nel DB — usa un nuovo agente personalizzato se in seguito vuoi recuperare il corpo.`},errors:{loadDraftFailed:`Caricamento bozza non riuscito: {{status}}`,loadFailed:`Caricamento non riuscito: {{status}}`,saveFailed:`Salvataggio non riuscito: {{status}}`,deleteFailed:`Eliminazione non riuscita: {{status}}`,testFailed:`Test non riuscito: {{status}}`},toasts:{agentCreated:`Agente creato`,agentSaved:`Agente salvato`,agentDeleted:`Agente eliminato`,createFailed:`Creazione dell'agente non riuscita`,saveFailed:`Salvataggio dell'agente non riuscito`,deleteFailed:`Eliminazione dell'agente non riuscita`},validation:{namePattern:`Il nome deve iniziare con <code>custom-</code> e contenere solo lettere minuscole, cifre e trattini.`,missingFrontmatter:`Frontmatter YAML mancante (serve <code>---</code> di apertura sulla prima riga).`},sampleTasks:{pick:`— scegli un task di esempio —`,terraform:`Terraform: bucket S3 pubblico`,sqlInjection:`Code review: SQL injection`,accessibility:`Frontend: accessibilità`,schemaChange:`Dati: modifica dello schema`,slowQuery:`Performance: query lenta`},testPane:{header:`Testa l'agente`,sampleTaskLabel:`Task di esempio`,placeholder:`Descrivi cosa deve fare l'agente, oppure scegli un esempio qui sopra.`,run:`Esegui`,running:`In esecuzione…`,sandboxNote:`In sandbox; nessun file scritto.`,tokens_one:`<mono>{{count}}</mono> token`,tokens_other:`<mono>{{count}}</mono> token`,emptyHint:`Esegui un task di esempio sulla bozza corrente. L'output appare qui.`},versions:{header:`Cronologia versioni`,empty:`Nessuna versione precedente registrata per questo agente.`,restoreHint:`Clicca una versione per ripristinarne il corpo nell'editor (devi comunque salvare).`}},t={eyebrow:`AI Edit`,headline:`Rifinisci il tuo agente`,streamingHeadline:`Rifinitura dell'agente in corso…`,placeholderInitial:`Descrivi come rifinire questo agente…`,placeholderFollowUp:`Invia un'ulteriore rifinitura…`,viewCurrentBody:`Vedi il corpo attuale dell'agente`,appliedAsVersion:`Applicato come versione {{version}}.`,openInStudio:`Apri la bozza nello Studio per la modifica manuale`,chips:{tightenTools:`Restringi l'elenco dei tool`,stricterPersonality:`Rendi la personalità più rigorosa`,workflowSection:`Aggiungi una sezione di protocollo Workflow`,sharpenDescription:`Accorcia e affina la descrizione`,matchDeveloperStyle:`Allinea allo stile di sr-developer`}},n={validation:{missingBaseline:`Agente baseline obbligatorio mancante: {{agent}}`,multipleDefaultRules:`Il routing può avere al massimo una regola di default (trovate {{found}})`,defaultRuleNotLast:`La regola di routing di default deve essere l'ultima voce`,unknownRoutingAgent:`Il routing fa riferimento a un agente non presente nella catena: {{agent}}`,invalidTags:`La regola di routing {{agent}} ha tag non validi: {{tags}} (usa kebab-case minuscolo)`},validationSummary_one:`{{count}} problema di validazione`,validationSummary_other:`{{count}} problemi di validazione`,nameLabel:`Nome`,descriptionLabel:`Descrizione`,descriptionPlaceholder:`A cosa serve questo profilo?`,orchestrator:{heading:`Orchestratore`,description:`Modello di primo livello per entrambi i comandi. batch-implement delega a implement per ogni feature, quindi ogni rail che genera eredita la catena di agenti di questo profilo.`},agentChain:{heading:`Catena di agenti ({{n}})`,addTitle:`Aggiungi un agente dal catalogo`,addDisabledTitle:`Tutti gli agenti del catalogo sono già nella catena`,pickFromCatalog:`Scegli dal catalogo ({{n}} disponibili)`,emptyCatalog:`Nessun altro agente nel catalogo. Aggiungi agenti personalizzati dalla scheda Catalogo agenti.`,kind:{upstream:`upstream`,custom:`personalizzato`}},routing:{heading:`Routing ({{n}})`,addDefault:`Aggiungi default`,addRule:`Aggiungi regola`,needAgentsTitle:`Aggiungi almeno un agente prima di creare regole di routing`,explainer:`Vince la prima regola corrispondente. Le regole sono modificabili e rimovibili, e il catch-all di default resta ultimo quando presente. Se lasci il routing vuoto, la pipeline ricade sul primo agente di tipo developer nella catena.`,untargetedTitle:`Agenti senza target nella catena`,untargetedDetail:`Nessuna regola di routing punta a: <mono>{{agents}}</mono>. Aggiungi una regola con tag o cambia il target della regola di default se vuoi che vengano eseguiti.`},agentRow:{dragTitle:`Trascina per riordinare`,dragHandleAria:`Maniglia di trascinamento`,pinnedFirst:`primo`,pinnedFirstTitle:`Bloccato in prima posizione — la pipeline inizia sempre con sr-architect`,pinnedLast:`ultimo`,pinnedLastTitle:`Bloccato in ultima posizione — la fase di merge viene sempre eseguita per ultima`,required:`obbligatorio`,requiredRemoveTitle:`Agente baseline obbligatorio — la pipeline dipende da questa riga`},routingRow:{everythingElse:`tutto il resto`,defaultTargetAria:`Target di routing di default (core, sola lettura)`,defaultTargetTitle:`Fallback core — non modificabile`,targetAria:`Target di routing per la regola {{ordinal}}`,editTitle:`Modifica regola`,editAria:`Modifica regola {{ordinal}}`,moveDown:`Sposta giù`,moveUp:`Sposta su`,coreDefaultBadge:`core · default`,coreDefaultTitle:`Fallback core — la regola di ultima istanza della pipeline, fissata su sr-developer`}},r={selectedCount:`{{selected}} / {{total}} agenti selezionati`,selectAll:`Seleziona tutto`,coreBadge:`core`,categories:{architecture:`Architettura`,development:`Sviluppo`,review:`Review`,product:`Prodotto`,utilities:`Utilità`},agents:{"sr-architect":{name:`Architetto`,description:`Progettazione dell'architettura, spec di modifica, pianificazione dell'implementazione`},"sr-developer":{name:`Developer`,description:`Implementazione full-stack su tutti i layer`},"sr-frontend-developer":{name:`Dev Frontend`,description:`Implementazione frontend (React, Vue, Angular, ecc.)`},"sr-backend-developer":{name:`Dev Backend`,description:`Specializzazione backend (API, database, servizi)`},"sr-reviewer":{name:`Reviewer`,description:`Code review generale — l'ultimo quality gate`},"sr-frontend-reviewer":{name:`Reviewer Frontend`,description:`Review frontend (UI, accessibilità, performance)`},"sr-backend-reviewer":{name:`Reviewer Backend`,description:`Review backend (API, sicurezza, scalabilità)`},"sr-security-reviewer":{name:`Security Reviewer`,description:`Analisi di sicurezza — OWASP, vulnerabilità, hardening`},"sr-performance-reviewer":{name:`Perf Reviewer`,description:`Analisi delle performance — profiling, colli di bottiglia, ottimizzazione`},"sr-product-manager":{name:`Product Manager`,description:`Product discovery, persona VPC, gestione del backlog`},"sr-product-analyst":{name:`Product Analyst`,description:`Analisi del backlog, gap analysis delle spec, reportistica`},"sr-test-writer":{name:`Test Writer`,description:`Generazione completa di test (unit, integration, E2E)`},"sr-doc-sync":{name:`Doc Sync`,description:`Sincronizzazione della documentazione — mantiene i doc allineati al codice`},"sr-merge-resolver":{name:`Merge Resolver`,description:`Risoluzione dei conflitti di merge con consapevolezza del contesto`}}},i={"security-reviewer":{label:`Security Reviewer`,blurb:`Trova bug di auth, injection ed esposizione di dati in un diff prima della release.`},"performance-profiler":{label:`Performance Profiler`,blurb:`Trova hot path, query N+1, loop senza limiti, bundle gonfiati.`},"data-engineer":{label:`Data Engineer`,blurb:`Migrazioni di schema, pipeline ETL, trasformazioni di dati.`},"ui-ux-polisher":{label:`Rifinitore UI / UX`,blurb:`Accessibilità, spaziature, stati vuoti, gestione degli errori.`},"api-designer":{label:`API Designer`,blurb:`Versioning, paginazione, formati di errore, retrocompatibilità.`},"database-architect":{label:`Architetto Database`,blurb:`Indici, normalizzazione vs denormalizzazione, forma delle query.`},"devops-sre":{label:`DevOps / SRE`,blurb:`CI/CD, observability, preparazione agli incident, runbook.`},"mobile-engineer":{label:`Mobile Engineer`,blurb:`Pattern iOS + Android, offline-first, attenzione alla batteria.`},"ml-engineer":{label:`ML Engineer`,blurb:`Pipeline, eval, riproducibilità, monitoraggio del drift.`},"accessibility-auditor":{label:`Auditor Accessibilità`,blurb:`Review WCAG 2.2: contrasto, focus, ARIA, tastiera.`},"qa-test-strategist":{label:`Stratega Test QA`,blurb:`Piani di test: suddivisione unit / integration / E2E, lacune di copertura.`},"load-tester":{label:`Load / Stress Tester`,blurb:`Capacity planning, scenari k6 / Locust, caccia ai colli di bottiglia.`},"integration-tester":{label:`Tester di Integrazione`,blurb:`Contratti tra servizi, fixture, riduzione dei test flaky.`},"regression-hunter":{label:`Cacciatore di Regressioni`,blurb:`Biseca, riproduce, scrive prima il test che fallisce.`},"data-analyst":{label:`Data Analyst`,blurb:`Trasforma domande vaghe in query + risultati leggibili.`},"etl-reviewer":{label:`Reviewer Pipeline ETL`,blurb:`Idempotenza, backfill, dati che arrivano in ritardo.`},"dashboard-designer":{label:`Dashboard Designer`,blurb:`Dashboard a colpo d'occhio, assi onesti, un'azione per grafico.`},"iac-reviewer":{label:`Reviewer IaC / Cloud`,blurb:`Terraform / CloudFormation: IAM, esposizione pubblica, costi.`},"compliance-reviewer":{label:`Compliance Reviewer`,blurb:`Controlli in ambito GDPR / SOC2 / HIPAA sui flussi di dati.`},"threat-modeler":{label:`Threat Modeler`,blurb:`STRIDE / LINDDUN sui diagrammi di architettura.`},"product-manager":{label:`Product Manager`,blurb:`Inquadramento del problema, PRD, prioritizzazione.`},"ux-researcher":{label:`UX Researcher`,blurb:`Script per interviste, piani di test di usabilità, sintesi.`},"technical-writer":{label:`Technical Writer`,blurb:`Doc che vengono letti davvero — tutorial, riferimenti, changelog.`},"design-reviewer":{label:`Reviewer Design System`,blurb:`Drift dei token, uso improprio dei componenti, coerenza tra i flussi.`},"financial-analyst":{label:`Analista Finanziario`,blurb:`Unit economics, modelli di coorte, analisi di scenario.`},"pricing-strategist":{label:`Stratega di Pricing`,blurb:`Tier, packaging, studi sulla disponibilità a pagare.`},"market-researcher":{label:`Ricercatore di Mercato`,blurb:`TAM/SAM/SOM, mappe competitive, segmenti di clientela.`},"ops-optimizer":{label:`Ottimizzatore di Operations`,blurb:`Tempi di ciclo, individuazione dei colli di bottiglia, candidati all'automazione.`},"seo-auditor":{label:`SEO Auditor`,blurb:`SEO tecnica + di contenuto: indicizzabilità, IA, match con l'intento.`},"growth-hacker":{label:`Sperimentatore di Growth`,blurb:`Diagnosi del funnel, esperimenti di lift, loop di attivazione.`},"social-strategist":{label:`Stratega Social Media`,blurb:`Contenuti adatti al canale, calendario editoriale, coerenza di voce.`},"literature-reviewer":{label:`Revisore di Letteratura`,blurb:`Sintesi di revisioni sistematiche, grafi di citazioni, conflitti.`},"experiment-designer":{label:`Progettista di Esperimenti`,blurb:`Ipotesi, controlli, dimensione del campione, pre-registrazione.`},"statistical-analyst":{label:`Analista Statistico`,blurb:`Sceglie il test giusto, riporta gli effect size, non solo i p-value.`},"scientific-writer":{label:`Redattore Scientifico`,blurb:`Struttura IMRaD, limiti onesti, abstract leggibili.`},"curriculum-designer":{label:`Progettista di Curriculum`,blurb:`Obiettivi di apprendimento → attività → valutazione.`},"assessment-author":{label:`Autore di Valutazioni`,blurb:`Item che misurano la comprensione, non la memoria.`},"tutor-explainer":{label:`Tutor / Divulgatore`,blurb:`Spiegazioni semplici in stile Feynman con esempi svolti.`},"clinical-guideline-reviewer":{label:`Revisore di Linee Guida Cliniche`,blurb:`Confronta la pratica con le ultime linee guida evidence-based.`},"medical-summarizer":{label:`Sintetizzatore di Letteratura Medica`,blurb:`Abstract per i clinici: cosa è cambiato, qualità dell'evidenza.`},"protocol-designer":{label:`Progettista di Protocolli`,blurb:`Protocolli clinici: endpoint, criteri di inclusione, sicurezza.`},"contract-reviewer":{label:`Revisore di Contratti`,blurb:`Segnala le clausole rischiose; spiega cosa significano davvero.`},"privacy-counsel":{label:`Consulente Privacy`,blurb:`GDPR / CCPA / LGPD applicati a flussi concreti.`},"copy-editor":{label:`Copy Editor`,blurb:`Editing riga per riga: voce, ritmo, taglia il 30% senza perdere significato.`},"brand-voice-guardian":{label:`Guardiano della Brand Voice`,blurb:`Fa rispettare le regole di voce; intercetta le frasi off-brand.`},"creative-brainstormer":{label:`Brainstormer Creativo`,blurb:`Prima divergente, poi convergente; abbatte i tabù con garbo.`},"hiring-interviewer":{label:`Intervistatore di Selezione`,blurb:`Colloqui strutturati, focalizzati sul segnale, attenti ai bias.`},"strategic-planner":{label:`Pianificatore Strategico`,blurb:`Obiettivi → scommesse → metriche; sfoltisce i pet project.`},"coach-1on1":{label:`Coach 1:1`,blurb:`Aiuta a impostare feedback, crescita professionale, conversazioni difficili.`},"meeting-facilitator":{label:`Facilitatore di Riunioni`,blurb:`Agende che producono decisioni, non aggiornamenti.`}},a={studio:e,refine:t,profileEditor:n,agentSelector:r,templates:i};export{r as agentSelector,a as default,n as profileEditor,t as refine,e as studio,i as templates};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`Atrás (Esc)`,apply:`Aplicar`,somethingWentWrong:`Algo ha salido mal`,quickPrompts:`Prompts rápidos`,workingOnRefinement:`Trabajando en tu refinamiento…`,history:`Historial`,viewCurrentContent:`Ver contenido actual`,conversation:`Conversación`,applied:`Aplicado.`,you:`Tú`,autoTestResult:`Resultado del auto-test`,ai:`IA`,refinementReady:`Refinamiento listo — revisa el diff a la derecha.`,diffPreview:`Vista previa del diff`,proposedChanges:`Cambios propuestos`,wordLevelDiff:`diff a nivel de palabra`,forceApply:`Forzar aplicación`,conflict:{diskChanged:`El archivo cambió en disco mientras editabas. Se ha bloqueado la aplicación.`,nameChanged:`La IA ha cambiado el nombre del agente. Renombrar es una acción explícita aparte — ajusta el borrador o renómbralo en Studio.`},discardDialog:{ariaLabel:`¿Descartar cambios?`,title:`¿Descartar el refinamiento?`,body:`El borrador actual se cancelará y no se aplicará.`,keepEditing:`Seguir editando`},composer:{sendAriaLabel:`Enviar (⌘⏎)`,kbdSubmit:`enviar`,kbdCancel:`cancelar`}},t={title:`AI Edit`,placeholder:`Describe los cambios que quieres…`,submit:`Enviar`,unsupportedFileType:`Tipo de archivo no compatible: {{name}}`,uploadFailed:`Error al subir {{name}}: {{message}}`},n={inserted:`insertado`,removed:`eliminado`},r={serverError:`Error del servidor ({{status}})`,connectionFailed:`Fallo de conexión: {{message}}`,applyFailed:`Error al aplicar ({{status}})`,loadAgentFailed:`No se pudo cargar el agente ({{status}})`,loadSessionFailed:`No se pudo cargar la sesión ({{status}})`,rehydrateFailed:`No se pudo restaurar la sesión: {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`Zurück (Esc)`,apply:`Anwenden`,somethingWentWrong:`Etwas ist schiefgelaufen`,quickPrompts:`Schnell-Prompts`,workingOnRefinement:`Arbeite an deiner Verfeinerung…`,history:`Verlauf`,viewCurrentContent:`Aktuellen Inhalt anzeigen`,conversation:`Unterhaltung`,applied:`Angewendet.`,you:`Du`,autoTestResult:`Auto-Test-Ergebnis`,ai:`KI`,refinementReady:`Verfeinerung bereit – prüfe den Diff rechts.`,diffPreview:`Diff-Vorschau`,proposedChanges:`Vorgeschlagene Änderungen`,wordLevelDiff:`Diff auf Wortebene`,forceApply:`Anwenden erzwingen`,conflict:{diskChanged:`Die Datei wurde während der Bearbeitung auf dem Datenträger geändert. Anwenden wurde blockiert.`,nameChanged:`Die KI hat den Agentennamen geändert. Umbenennen ist eine separate, explizite Aktion – passe den Entwurf an oder benenne im Studio um.`},discardDialog:{ariaLabel:`Änderungen verwerfen?`,title:`Verfeinerung verwerfen?`,body:`Der aktuelle Entwurf wird abgebrochen und nicht angewendet.`,keepEditing:`Weiter bearbeiten`},composer:{sendAriaLabel:`Senden (⌘⏎)`,kbdSubmit:`senden`,kbdCancel:`abbrechen`}},t={title:`AI Edit`,placeholder:`Beschreibe die gewünschten Änderungen…`,submit:`Absenden`,unsupportedFileType:`Nicht unterstützter Dateityp: {{name}}`,uploadFailed:`Upload fehlgeschlagen für {{name}}: {{message}}`},n={inserted:`eingefügt`,removed:`entfernt`},r={serverError:`Serverfehler ({{status}})`,connectionFailed:`Verbindung fehlgeschlagen: {{message}}`,applyFailed:`Anwenden fehlgeschlagen ({{status}})`,loadAgentFailed:`Agent konnte nicht geladen werden ({{status}})`,loadSessionFailed:`Session konnte nicht geladen werden ({{status}})`,rehydrateFailed:`Session konnte nicht wiederhergestellt werden: {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`戻る (Esc)`,apply:`適用`,somethingWentWrong:`問題が発生しました`,quickPrompts:`クイックプロンプト`,workingOnRefinement:`リファインを作成中…`,history:`履歴`,viewCurrentContent:`現在の内容を表示`,conversation:`会話`,applied:`適用しました。`,you:`あなた`,autoTestResult:`自動テスト結果`,ai:`AI`,refinementReady:`リファインが完了しました — 右側の差分を確認してください。`,diffPreview:`差分プレビュー`,proposedChanges:`提案された変更`,wordLevelDiff:`単語レベルの差分`,forceApply:`強制適用`,conflict:{diskChanged:`編集中にディスク上のファイルが変更されたため、適用をブロックしました。`,nameChanged:`AI がエージェント名を変更しました。名前の変更は別の明示的な操作です — 下書きを調整するか、Studio で名前を変更してください。`},discardDialog:{ariaLabel:`変更を破棄しますか?`,title:`リファインを破棄しますか?`,body:`現在の下書きはキャンセルされ、適用されません。`,keepEditing:`編集を続ける`},composer:{sendAriaLabel:`送信 (⌘⏎)`,kbdSubmit:`送信`,kbdCancel:`キャンセル`}},t={title:`AI Edit`,placeholder:`希望する変更を記述してください…`,submit:`送信`,unsupportedFileType:`未対応のファイル形式: {{name}}`,uploadFailed:`{{name}} のアップロードに失敗しました: {{message}}`},n={inserted:`挿入`,removed:`削除`},r={serverError:`サーバーエラー ({{status}})`,connectionFailed:`接続に失敗しました: {{message}}`,applyFailed:`適用に失敗しました ({{status}})`,loadAgentFailed:`エージェントの読み込みに失敗しました ({{status}})`,loadSessionFailed:`セッションの読み込みに失敗しました ({{status}})`,rehydrateFailed:`セッションの復元に失敗しました: {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`Indietro (Esc)`,apply:`Applica`,somethingWentWrong:`Qualcosa è andato storto`,quickPrompts:`Prompt rapidi`,workingOnRefinement:`Sto lavorando alla tua rifinitura…`,history:`Cronologia`,viewCurrentContent:`Visualizza contenuto corrente`,conversation:`Conversazione`,applied:`Applicato.`,you:`Tu`,autoTestResult:`Risultato auto-test`,ai:`AI`,refinementReady:`Rifinitura pronta — rivedi il diff a destra.`,diffPreview:`Anteprima diff`,proposedChanges:`Modifiche proposte`,wordLevelDiff:`diff a livello di parola`,forceApply:`Forza applicazione`,conflict:{diskChanged:`Il file è cambiato su disco durante la modifica. L'applicazione è stata bloccata.`,nameChanged:`L'AI ha cambiato il nome dell'agente. La rinomina è un'azione esplicita separata — correggi la bozza o rinomina in Studio.`},discardDialog:{ariaLabel:`Scartare le modifiche?`,title:`Scartare la rifinitura?`,body:`La bozza corrente verrà annullata e non applicata.`,keepEditing:`Continua a modificare`},composer:{sendAriaLabel:`Invia (⌘⏎)`,kbdSubmit:`invia`,kbdCancel:`annulla`}},t={title:`AI Edit`,placeholder:`Descrivi le modifiche che vuoi…`,submit:`Invia`,unsupportedFileType:`Tipo di file non supportato: {{name}}`,uploadFailed:`Caricamento non riuscito per {{name}}: {{message}}`},n={inserted:`inserito`,removed:`rimosso`},r={serverError:`Errore del server ({{status}})`,connectionFailed:`Connessione non riuscita: {{message}}`,applyFailed:`Applicazione non riuscita ({{status}})`,loadAgentFailed:`Impossibile caricare l'agente ({{status}})`,loadSessionFailed:`Impossibile caricare la sessione ({{status}})`,rehydrateFailed:`Impossibile ripristinare la sessione: {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`Voltar (Esc)`,apply:`Aplicar`,somethingWentWrong:`Ocorreu um erro`,quickPrompts:`Prompts rápidos`,workingOnRefinement:`A trabalhar no seu refinamento…`,history:`Histórico`,viewCurrentContent:`Ver conteúdo atual`,conversation:`Conversa`,applied:`Aplicado.`,you:`Você`,autoTestResult:`Resultado do teste automático`,ai:`IA`,refinementReady:`Refinamento pronto — reveja o diff à direita.`,diffPreview:`Pré-visualização do diff`,proposedChanges:`Alterações propostas`,wordLevelDiff:`diff ao nível da palavra`,forceApply:`Forçar aplicação`,conflict:{diskChanged:`O ficheiro foi alterado no disco enquanto editava. A aplicação foi bloqueada.`,nameChanged:`A IA alterou o nome do agente. Renomear é uma ação explícita separada — ajuste o rascunho ou renomeie no Studio.`},discardDialog:{ariaLabel:`Descartar alterações?`,title:`Descartar refinamento?`,body:`O rascunho atual será cancelado e não será aplicado.`,keepEditing:`Continuar a editar`},composer:{sendAriaLabel:`Enviar (⌘⏎)`,kbdSubmit:`submeter`,kbdCancel:`cancelar`}},t={title:`Edição com IA`,placeholder:`Descreva as alterações que pretende…`,submit:`Submeter`,unsupportedFileType:`Tipo de ficheiro não suportado: {{name}}`,uploadFailed:`Falha no upload de {{name}}: {{message}}`},n={inserted:`inserido`,removed:`removido`},r={serverError:`Erro do servidor ({{status}})`,connectionFailed:`Falha na ligação: {{message}}`,applyFailed:`Falha ao aplicar ({{status}})`,loadAgentFailed:`Falha ao carregar o agente ({{status}})`,loadSessionFailed:`Falha ao carregar a sessão ({{status}})`,rehydrateFailed:`Falha ao restaurar a sessão: {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`Retour (Échap)`,apply:`Appliquer`,somethingWentWrong:`Une erreur est survenue`,quickPrompts:`Prompts rapides`,workingOnRefinement:`Préparation de votre amélioration…`,history:`Historique`,viewCurrentContent:`Voir le contenu actuel`,conversation:`Conversation`,applied:`Appliqué.`,you:`Vous`,autoTestResult:`Résultat du test automatique`,ai:`IA`,refinementReady:`Amélioration prête — vérifiez le diff à droite.`,diffPreview:`Aperçu du diff`,proposedChanges:`Modifications proposées`,wordLevelDiff:`diff au niveau des mots`,forceApply:`Forcer l'application`,conflict:{diskChanged:`Le fichier a changé sur le disque pendant votre édition. L'application a été bloquée.`,nameChanged:`L'IA a modifié le nom de l'agent. Le renommage est une action explicite distincte — ajustez le brouillon ou renommez dans le Studio.`},discardDialog:{ariaLabel:`Abandonner les modifications ?`,title:`Abandonner l'amélioration ?`,body:`Le brouillon actuel sera annulé et ne sera pas appliqué.`,keepEditing:`Continuer l'édition`},composer:{sendAriaLabel:`Envoyer (⌘⏎)`,kbdSubmit:`envoyer`,kbdCancel:`annuler`}},t={title:`AI Edit`,placeholder:`Décrivez les modifications souhaitées…`,submit:`Envoyer`,unsupportedFileType:`Type de fichier non pris en charge : {{name}}`,uploadFailed:`Échec de l'envoi de {{name}} : {{message}}`},n={inserted:`inséré`,removed:`supprimé`},r={serverError:`Erreur serveur ({{status}})`,connectionFailed:`Échec de la connexion : {{message}}`,applyFailed:`Échec de l'application ({{status}})`,loadAgentFailed:`Échec du chargement de l'agent ({{status}})`,loadSessionFailed:`Échec du chargement de la session ({{status}})`,rehydrateFailed:`Échec de la restauration de la session : {{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./chunk-CilyBKbf.js";var t=e({composer:()=>r,default:()=>o,diffView:()=>i,refine:()=>a,shell:()=>n}),n={backAriaLabel:`Back (Esc)`,apply:`Apply`,somethingWentWrong:`Something went wrong`,quickPrompts:`Quick prompts`,workingOnRefinement:`Working on your refinement…`,history:`History`,viewCurrentContent:`View current content`,conversation:`Conversation`,applied:`Applied.`,you:`You`,autoTestResult:`Auto-test result`,ai:`AI`,refinementReady:`Refinement ready — review the diff on the right.`,diffPreview:`Diff preview`,proposedChanges:`Proposed changes`,wordLevelDiff:`word-level diff`,forceApply:`Force apply`,conflict:{diskChanged:`The file changed on disk while you were editing. Apply was blocked.`,nameChanged:`The AI changed the agent name. Renaming is a separate explicit action — adjust the draft or rename in Studio.`},discardDialog:{ariaLabel:`Discard changes?`,title:`Discard refinement?`,body:`The current draft will be cancelled and not applied.`,keepEditing:`Keep editing`},composer:{sendAriaLabel:`Send (⌘⏎)`,kbdSubmit:`submit`,kbdCancel:`cancel`}},r={title:`AI Edit`,placeholder:`Describe the changes you want…`,submit:`Submit`,unsupportedFileType:`Unsupported file type: {{name}}`,uploadFailed:`Upload failed for {{name}}: {{message}}`},i={inserted:`inserted`,removed:`removed`},a={serverError:`Server error ({{status}})`,connectionFailed:`Connection failed: {{message}}`,applyFailed:`Apply failed ({{status}})`,loadAgentFailed:`Failed to load agent ({{status}})`,loadSessionFailed:`Failed to load session ({{status}})`,rehydrateFailed:`Failed to restore session: {{message}}`},o={shell:n,composer:r,diffView:i,refine:a};export{t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={backAriaLabel:`返回 (Esc)`,apply:`应用`,somethingWentWrong:`出错了`,quickPrompts:`快捷提示词`,workingOnRefinement:`正在处理你的改进…`,history:`历史`,viewCurrentContent:`查看当前内容`,conversation:`对话`,applied:`已应用。`,you:`你`,autoTestResult:`自动测试结果`,ai:`AI`,refinementReady:`改进已就绪 — 请在右侧查看 diff。`,diffPreview:`Diff 预览`,proposedChanges:`建议的更改`,wordLevelDiff:`词级 diff`,forceApply:`强制应用`,conflict:{diskChanged:`编辑期间文件在磁盘上发生了变化。应用已被阻止。`,nameChanged:`AI 修改了 Agent 名称。重命名是独立的显式操作 — 请调整草稿或在 Studio 中重命名。`},discardDialog:{ariaLabel:`丢弃更改?`,title:`丢弃改进?`,body:`当前草稿将被取消且不会应用。`,keepEditing:`继续编辑`},composer:{sendAriaLabel:`发送 (⌘⏎)`,kbdSubmit:`提交`,kbdCancel:`取消`}},t={title:`AI 编辑`,placeholder:`描述你想要的更改…`,submit:`提交`,unsupportedFileType:`不支持的文件类型:{{name}}`,uploadFailed:`{{name}} 上传失败:{{message}}`},n={inserted:`插入`,removed:`删除`},r={serverError:`服务器错误({{status}})`,connectionFailed:`连接失败:{{message}}`,applyFailed:`应用失败({{status}})`,loadAgentFailed:`加载 Agent 失败({{status}})`,loadSessionFailed:`加载会话失败({{status}})`,rehydrateFailed:`恢复会话失败:{{message}}`},i={shell:e,composer:t,diffView:n,refine:r};export{t as composer,i as default,n as diffView,r as refine,e as shell};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`Jobs`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Affinage`,smash:`SMASH`,fileSummary:`Résumés de fichiers`},t={d7:`7j`,d30:`30j`,d90:`90j`,all:`Tout`,custom:`Personnalisé`,startDate:`Date de début`,endDate:`Date de fin`,to:`au`},n=`{{count}} exécution`,r=`{{count}} exécutions`,i={title:`Analytics`,all:`Tout`,engine:`Moteur`,ticketChip:`ticket #{{id}} · ✕`,failedToLoad:`Échec du chargement : {{error}}`},a={spending:`Dépenses`,vsPrev:`{{pct}} % vs préc.`,invocations_one:`{{count}} invocation`,invocations_other:`{{count}} invocations`,tokens:`· {{tokens}} tokens`,tokensTooltip:`Total des tokens = entrée fraîche + sortie + lecture cache + création cache, sur toutes les invocations de cette période.`,includesEstimated:`· inclut ~{{amount}} estimés`,includesEstimatedTooltip:`Inclut {{amount}} de coût estimé pour les fournisseurs sans champ de coût natif (ex. codex via la table de tarifs locale).`,trackingStarted:`Suivi démarré le {{date}}`,trackingStartedFallback:`Le suivi démarre à la première invocation`,emptyState:`Aucune invocation pour cette période de filtrage.`,segmentTitle:`{{label}} : {{value}}`},o={title:`Par fournisseur`,description:`Répartition du coût entre les CLI IA de ce projet. Le préfixe <tilde>~</tilde> marque les lignes dont le coût est estimé à partir de la table de tarifs locale (le fournisseur ne le rapporte pas nativement).`,noCost:`Aucun coût enregistré sur cette période.`,segmentTitle:`{{label}} : {{value}} ({{count}})`},s={title:`Chronologie quotidienne`,subtitle:`empilée par surface`,empty:`Aucune dépense sur cette période.`},c={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Essayez Explore pour des specs plus riches`,runsSoFar_one:`{{count}} exécution pour l'instant`,runsSoFar_other:`{{count}} exécutions pour l'instant`,perSpec:`par spec`,createdRuns:`<strong>{{created}}</strong> créées · {{runs}} exécutions`,avgDuration:`{{duration}} en moyenne`,ratio:`{{ratio}}× de plus par spec`},l={title:`Modèles`,empty:`Aucun modèle enregistré.`},u={title:`Coût vs tours`,empty:`Aucune invocation à tracer.`,turnsLabel:`tours`,costLabel:`coût`},d={title:`Top tickets`,empty:`Aucune activité de ticket sur cette période.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Non attribué`,deletedTicket:`ticket supprimé #{{id}}`},f={title:`Toutes les invocations`,statusFilterAria:`Filtre de statut`,minCostFilterAria:`Filtre de coût minimum`,minCostPlaceholder:`≥ $0.00`,allStatus:`Tous les statuts`,success:`Succès`,failed:`Échec`,aborted:`Interrompu`,empty:`Aucune invocation ne correspond aux filtres actuels.`,colSurface:`Surface`,colTicket:`Ticket`,colCost:`Coût`,colTurns:`Tours`,colTokens:`Tokens`,colModel:`Modèle`,colStatus:`Statut`,colStarted:`Démarré`,contractLayer:`Contract Layer`,contractLayerRefinement:`Affinage Contract Layer`,deleted:`(supprimé)`,provisionalTitleTooltip:`Titre Explore provisoire — pas encore validé`,estimatedCostTooltip:`Estimé à partir de la table de tarifs locale — ce fournisseur ne rapporte pas le coût nativement.`,inferred:`inféré`,statusValue:{success:`succès`,failed:`échec`,aborted:`interrompu`},truncated:`Affichage des {{shown}} premières lignes sur {{total}} correspondantes.`},p={title:`Analytics de Desktop`,refreshAria:`Actualiser les analytics`,failedToLoad:`Échec du chargement des analytics : {{error}}`,totalCost:`Coût total`,costToday:`{{value}} aujourd'hui`,totalJobs:`Total des jobs`,jobsToday:`{{n}} aujourd'hui`,successRate:`Taux de réussite`,acrossAllProjects:`sur tous les projets`,avgCostPerJob:`Coût moyen / job`,periodAverage:`moyenne de la période`,costOverTime:`Coût inter-projets dans le temps`,noCostData:`Aucune donnée de coût pour cette période`,projectComparison:`Comparaison des projets`,noProjects:`Aucun projet enregistré.`,jobsCount_one:`{{count}} job`,jobsCount_other:`{{count}} jobs`,successPct:`{{pct}} % de réussite`,costByProject:`Coût par projet`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`CSV résumé`,rawCsv:`CSV brut`,summaryJson:`JSON résumé`,rawJson:`JSON brut`,downloading:`Téléchargement…`,noData:`Aucune donnée pour les filtres actuels`,failed:`Échec de l'export`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`任务`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`AI 编辑`,smash:`SMASH`,fileSummary:`文件摘要`},t={d7:`7天`,d30:`30天`,d90:`90天`,all:`全部`,custom:`自定义`,startDate:`开始日期`,endDate:`结束日期`,to:`至`},n=`{{count}} 次运行`,r=`{{count}} 次运行`,i={title:`分析`,all:`全部`,engine:`引擎`,ticketChip:`工单 #{{id}} · ✕`,failedToLoad:`加载失败:{{error}}`},a={spending:`支出`,vsPrev:`较上期 {{pct}}%`,invocations_one:`{{count}} 次调用`,invocations_other:`{{count}} 次调用`,tokens:`· {{tokens}} token`,tokensTooltip:`总 token 数 = 此时间窗口内所有调用的新输入 + 输出 + 缓存读取 + 缓存创建之和。`,includesEstimated:`· 含约 {{amount}} 估算值`,includesEstimatedTooltip:`包含 {{amount}} 的估算成本,来自不原生上报成本的提供方(例如 codex,按本地价格表估算)。`,trackingStarted:`追踪始于 {{date}}`,trackingStartedFallback:`首次调用后开始追踪`,emptyState:`当前筛选窗口内暂无调用。`,segmentTitle:`{{label}}:{{value}}`},o={title:`按提供方`,description:`此项目中各 AI CLI 的成本分布。<tilde>~</tilde> 前缀表示该行成本由本地价格表估算(提供方不原生上报)。`,noCost:`此时间窗口内暂无成本记录。`,segmentTitle:`{{label}}:{{value}}({{count}})`},s={title:`每日时间线`,subtitle:`按来源堆叠`,empty:`此期间没有支出。`},c={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`试试 Explore,获得更丰富的 spec`,runsSoFar_one:`目前 {{count}} 次运行`,runsSoFar_other:`目前 {{count}} 次运行`,perSpec:`每个 spec`,createdRuns:`已创建 <strong>{{created}}</strong> · {{runs}} 次运行`,avgDuration:`平均 {{duration}}`,ratio:`每个 spec 多 {{ratio}}×`},l={title:`模型`,empty:`暂无模型记录。`},u={title:`成本 vs 轮次`,empty:`暂无可绘制的调用。`,turnsLabel:`轮次`,costLabel:`成本`},d={title:`热门工单`,empty:`此期间没有工单活动。`,breakdownItem:`{{n}} {{label}}`,unattributed:`未归属`,deletedTicket:`已删除工单 #{{id}}`},f={title:`全部调用`,statusFilterAria:`状态筛选`,minCostFilterAria:`最低成本筛选`,minCostPlaceholder:`≥ $0.00`,allStatus:`全部状态`,success:`成功`,failed:`失败`,aborted:`已中止`,empty:`没有符合当前筛选条件的调用。`,colSurface:`来源`,colTicket:`工单`,colCost:`成本`,colTurns:`轮次`,colTokens:`Token`,colModel:`模型`,colStatus:`状态`,colStarted:`开始时间`,contractLayer:`Contract Layer`,contractLayerRefinement:`Contract Layer 增强`,deleted:`(已删除)`,provisionalTitleTooltip:`Explore 临时标题——尚未提交`,estimatedCostTooltip:`按本地价格表估算——此提供方不原生上报成本。`,inferred:`推断`,statusValue:{success:`成功`,failed:`失败`,aborted:`已中止`},truncated:`显示前 {{shown}} 条,共 {{total}} 条匹配记录。`},p={title:`Desktop 分析`,refreshAria:`刷新分析数据`,failedToLoad:`加载分析数据失败:{{error}}`,totalCost:`总成本`,costToday:`今日 {{value}}`,totalJobs:`任务总数`,jobsToday:`今日 {{n}} 个`,successRate:`成功率`,acrossAllProjects:`所有项目汇总`,avgCostPerJob:`平均成本 / 任务`,periodAverage:`期间平均`,costOverTime:`跨项目成本走势`,noCostData:`此期间无成本数据`,projectComparison:`项目对比`,noProjects:`尚未注册任何项目。`,jobsCount_one:`{{count}} 个任务`,jobsCount_other:`{{count}} 个任务`,successPct:`成功率 {{pct}}%`,costByProject:`按项目统计成本`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`摘要 CSV`,rawCsv:`原始 CSV`,summaryJson:`摘要 JSON`,rawJson:`原始 JSON`,downloading:`正在下载…`,noData:`当前筛选条件下无数据`,failed:`导出失败`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`Jobs`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Verfeinern`,smash:`SMASH`,fileSummary:`Dateizusammenfassungen`},t={d7:`7d`,d30:`30d`,d90:`90d`,all:`Alle`,custom:`Benutzerdefiniert`,startDate:`Startdatum`,endDate:`Enddatum`,to:`bis`},n=`{{count}} Lauf`,r=`{{count}} Läufe`,i={title:`Analytics`,all:`Alle`,engine:`Engine`,ticketChip:`Ticket #{{id}} · ✕`,failedToLoad:`Laden fehlgeschlagen: {{error}}`},a={spending:`Ausgaben`,vsPrev:`{{pct}} % ggü. Vorperiode`,invocations_one:`{{count}} Aufruf`,invocations_other:`{{count}} Aufrufe`,tokens:`· {{tokens}} Tokens`,tokensTooltip:`Tokens gesamt = neue Eingabe + Ausgabe + Cache-Read + Cache-Create über alle Aufrufe in diesem Zeitraum.`,includesEstimated:`· enthält ~{{amount}} geschätzt`,includesEstimatedTooltip:`Enthält {{amount}} geschätzte Kosten von Providern ohne natives Kostenfeld (z. B. codex über die lokale Preistabelle).`,trackingStarted:`Tracking gestartet am {{date}}`,trackingStartedFallback:`Tracking beginnt mit dem ersten Aufruf`,emptyState:`Noch keine Aufrufe für diesen Filterzeitraum.`,segmentTitle:`{{label}}: {{value}}`},o={title:`Nach Provider`,description:`So verteilen sich die Kosten auf die KI-CLIs in diesem Projekt. Das Präfix <tilde>~</tilde> markiert Zeilen, deren Kosten über die lokale Preistabelle geschätzt sind (der Provider meldet sie nicht nativ).`,noCost:`Noch keine Kosten in diesem Zeitraum erfasst.`,segmentTitle:`{{label}}: {{value}} ({{count}})`},s={title:`Täglicher Verlauf`,subtitle:`gestapelt nach Surface`,empty:`Keine Ausgaben in diesem Zeitraum.`},c={title:`Quick vs. Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Probiere Explore für reichhaltigere Specs`,runsSoFar_one:`bisher {{count}} Lauf`,runsSoFar_other:`bisher {{count}} Läufe`,perSpec:`pro Spec`,createdRuns:`<strong>{{created}}</strong> erstellt · {{runs}} Läufe`,avgDuration:`Ø {{duration}}`,ratio:`{{ratio}}× mehr pro Spec`},l={title:`Modelle`,empty:`Keine Modelle erfasst.`},u={title:`Kosten vs. Turns`,empty:`Keine Aufrufe zum Darstellen.`,turnsLabel:`Turns`,costLabel:`Kosten`},d={title:`Top-Tickets`,empty:`Keine Ticket-Aktivität in diesem Zeitraum.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Nicht zugeordnet`,deletedTicket:`gelöschtes Ticket #{{id}}`},f={title:`Alle Aufrufe`,statusFilterAria:`Statusfilter`,minCostFilterAria:`Mindestkosten-Filter`,minCostPlaceholder:`≥ $0.00`,allStatus:`Alle Status`,success:`Erfolgreich`,failed:`Fehlgeschlagen`,aborted:`Abgebrochen`,empty:`Keine Aufrufe entsprechen den aktuellen Filtern.`,colSurface:`Surface`,colTicket:`Ticket`,colCost:`Kosten`,colTurns:`Turns`,colTokens:`Tokens`,colModel:`Modell`,colStatus:`Status`,colStarted:`Gestartet`,contractLayer:`Contract Layer`,contractLayerRefinement:`Contract-Layer-Verfeinerung`,deleted:`(gelöscht)`,provisionalTitleTooltip:`Vorläufiger Explore-Titel – noch nicht committet`,estimatedCostTooltip:`Geschätzt anhand der lokalen Preistabelle – dieser Provider meldet Kosten nicht nativ.`,inferred:`abgeleitet`,statusValue:{success:`erfolgreich`,failed:`fehlgeschlagen`,aborted:`abgebrochen`},truncated:`Zeige die ersten {{shown}} von {{total}} passenden Zeilen.`},p={title:`Desktop-Analytics`,refreshAria:`Analytics aktualisieren`,failedToLoad:`Analytics konnten nicht geladen werden: {{error}}`,totalCost:`Gesamtkosten`,costToday:`{{value}} heute`,totalJobs:`Jobs gesamt`,jobsToday:`{{n}} heute`,successRate:`Erfolgsquote`,acrossAllProjects:`über alle Projekte`,avgCostPerJob:`Ø Kosten / Job`,periodAverage:`Durchschnitt im Zeitraum`,costOverTime:`Projektübergreifende Kosten im Zeitverlauf`,noCostData:`Keine Kostendaten für diesen Zeitraum`,projectComparison:`Projektvergleich`,noProjects:`Keine Projekte registriert.`,jobsCount_one:`{{count}} Job`,jobsCount_other:`{{count}} Jobs`,successPct:`{{pct}} % Erfolg`,costByProject:`Kosten nach Projekt`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`Zusammenfassung (CSV)`,rawCsv:`Rohdaten (CSV)`,summaryJson:`Zusammenfassung (JSON)`,rawJson:`Rohdaten (JSON)`,downloading:`Wird heruntergeladen…`,noData:`Keine Daten für aktuelle Filter`,failed:`Export fehlgeschlagen`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`Jobs`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Refinado`,smash:`SMASH`,fileSummary:`Resúmenes de archivo`},t={d7:`7d`,d30:`30d`,d90:`90d`,all:`Todo`,custom:`Personalizado`,startDate:`Fecha de inicio`,endDate:`Fecha de fin`,to:`a`},n=`{{count}} ejecución`,r=`{{count}} ejecuciones`,i={title:`Analíticas`,all:`Todo`,engine:`Motor`,ticketChip:`ticket #{{id}} · ✕`,failedToLoad:`Error al cargar: {{error}}`},a={spending:`Gasto`,vsPrev:`{{pct}}% vs anterior`,invocations_one:`{{count}} invocación`,invocations_other:`{{count}} invocaciones`,tokens:`· {{tokens}} tokens`,tokensTooltip:`Tokens totales = entrada nueva + salida + lectura de caché + creación de caché en todas las invocaciones de esta ventana.`,includesEstimated:`· incluye ~{{amount}} estimado`,includesEstimatedTooltip:`Incluye {{amount}} de coste estimado de proveedores sin campo de coste nativo (p. ej. codex mediante la tabla de precios local).`,trackingStarted:`Seguimiento iniciado el {{date}}`,trackingStartedFallback:`El seguimiento empieza con la primera invocación`,emptyState:`Aún no hay invocaciones para esta ventana de filtros.`,segmentTitle:`{{label}}: {{value}}`},o={title:`Por proveedor`,description:`Cómo se reparte el coste entre las CLI de IA de este proyecto. El prefijo <tilde>~</tilde> marca las filas cuyo coste se estima con la tabla de precios local (el proveedor no lo informa de forma nativa).`,noCost:`Aún no hay coste registrado en esta ventana.`,segmentTitle:`{{label}}: {{value}} ({{count}})`},s={title:`Cronología diaria`,subtitle:`apilada por superficie`,empty:`Sin gasto en este periodo.`},c={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Prueba Explore para conseguir specs más completas`,runsSoFar_one:`{{count}} ejecución hasta ahora`,runsSoFar_other:`{{count}} ejecuciones hasta ahora`,perSpec:`por spec`,createdRuns:`<strong>{{created}}</strong> creadas · {{runs}} ejecuciones`,avgDuration:`{{duration}} de media`,ratio:`{{ratio}}× más por spec`},l={title:`Modelos`,empty:`No hay modelos registrados.`},u={title:`Coste vs turnos`,empty:`No hay invocaciones que representar.`,turnsLabel:`turnos`,costLabel:`coste`},d={title:`Tickets principales`,empty:`Sin actividad de tickets en este periodo.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Sin atribuir`,deletedTicket:`ticket eliminado #{{id}}`},f={title:`Todas las invocaciones`,statusFilterAria:`Filtro de estado`,minCostFilterAria:`Filtro de coste mínimo`,minCostPlaceholder:`≥ $0.00`,allStatus:`Todos los estados`,success:`Éxito`,failed:`Fallido`,aborted:`Abortado`,empty:`Ninguna invocación coincide con los filtros actuales.`,colSurface:`Superficie`,colTicket:`Ticket`,colCost:`Coste`,colTurns:`Turnos`,colTokens:`Tokens`,colModel:`Modelo`,colStatus:`Estado`,colStarted:`Inicio`,contractLayer:`Contract Layer`,contractLayerRefinement:`Refinamiento de Contract Layer`,deleted:`(eliminado)`,provisionalTitleTooltip:`Título provisional de Explore — aún sin confirmar`,estimatedCostTooltip:`Estimado con la tabla de precios local — este proveedor no informa el coste de forma nativa.`,inferred:`inferido`,statusValue:{success:`éxito`,failed:`fallido`,aborted:`abortado`},truncated:`Mostrando las primeras {{shown}} de {{total}} filas coincidentes.`},p={title:`Analíticas de Desktop`,refreshAria:`Actualizar analíticas`,failedToLoad:`No se pudieron cargar las analíticas: {{error}}`,totalCost:`Coste total`,costToday:`{{value}} hoy`,totalJobs:`Jobs totales`,jobsToday:`{{n}} hoy`,successRate:`Tasa de éxito`,acrossAllProjects:`en todos los proyectos`,avgCostPerJob:`Coste medio / job`,periodAverage:`media del periodo`,costOverTime:`Coste entre proyectos a lo largo del tiempo`,noCostData:`Sin datos de coste para este periodo`,projectComparison:`Comparación de proyectos`,noProjects:`No hay proyectos registrados.`,jobsCount_one:`{{count}} job`,jobsCount_other:`{{count}} jobs`,successPct:`{{pct}}% de éxito`,costByProject:`Coste por proyecto`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`CSV resumen`,rawCsv:`CSV en bruto`,summaryJson:`JSON resumen`,rawJson:`JSON en bruto`,downloading:`Descargando…`,noData:`Sin datos para los filtros actuales`,failed:`Error al exportar`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`Job`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Raffinamento`,smash:`SMASH`,fileSummary:`Riepiloghi file`},t={d7:`7d`,d30:`30d`,d90:`90d`,all:`Tutto`,custom:`Personalizzato`,startDate:`Data di inizio`,endDate:`Data di fine`,to:`a`},n=`{{count}} esecuzione`,r=`{{count}} esecuzioni`,i={title:`Analytics`,all:`Tutti`,engine:`Engine`,ticketChip:`ticket #{{id}} · ✕`,failedToLoad:`Caricamento non riuscito: {{error}}`},a={spending:`Spesa`,vsPrev:`{{pct}}% vs prec.`,invocations_one:`{{count}} invocazione`,invocations_other:`{{count}} invocazioni`,tokens:`· {{tokens}} token`,tokensTooltip:`Token totali = input nuovo + output + lettura cache + creazione cache su tutte le invocazioni in questa finestra.`,includesEstimated:`· include ~{{amount}} stimati`,includesEstimatedTooltip:`Include {{amount}} di costo stimato da provider senza un campo di costo nativo (es. codex tramite la tabella prezzi locale).`,trackingStarted:`Tracciamento iniziato il {{date}}`,trackingStartedFallback:`Il tracciamento inizia alla prima invocazione`,emptyState:`Ancora nessuna invocazione per questa finestra di filtri.`,segmentTitle:`{{label}}: {{value}}`},o={title:`Per provider`,description:`Come si ripartisce il costo tra le CLI AI di questo progetto. Il prefisso <tilde>~</tilde> indica le righe in cui il costo è stimato dalla tabella prezzi locale (il provider non lo riporta nativamente).`,noCost:`Ancora nessun costo registrato in questa finestra.`,segmentTitle:`{{label}}: {{value}} ({{count}})`},s={title:`Timeline giornaliera`,subtitle:`impilata per origine`,empty:`Nessuna spesa in questo periodo.`},c={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Prova Explore per spec più ricche`,runsSoFar_one:`{{count}} esecuzione finora`,runsSoFar_other:`{{count}} esecuzioni finora`,perSpec:`per spec`,createdRuns:`<strong>{{created}}</strong> create · {{runs}} esecuzioni`,avgDuration:`{{duration}} in media`,ratio:`{{ratio}}× in più per spec`},l={title:`Modelli`,empty:`Nessun modello registrato.`},u={title:`Costo vs Turni`,empty:`Nessuna invocazione da rappresentare.`,turnsLabel:`turni`,costLabel:`costo`},d={title:`Top ticket`,empty:`Nessuna attività sui ticket in questo periodo.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Non attribuito`,deletedTicket:`ticket eliminato #{{id}}`},f={title:`Tutte le invocazioni`,statusFilterAria:`Filtro stato`,minCostFilterAria:`Filtro costo minimo`,minCostPlaceholder:`≥ $0.00`,allStatus:`Tutti gli stati`,success:`Riuscita`,failed:`Fallita`,aborted:`Interrotta`,empty:`Nessuna invocazione corrisponde ai filtri attuali.`,colSurface:`Origine`,colTicket:`Ticket`,colCost:`Costo`,colTurns:`Turni`,colTokens:`Token`,colModel:`Modello`,colStatus:`Stato`,colStarted:`Avvio`,contractLayer:`Contract Layer`,contractLayerRefinement:`Raffinamento Contract Layer`,deleted:`(eliminato)`,provisionalTitleTooltip:`Titolo Explore provvisorio — non ancora confermato`,estimatedCostTooltip:`Stimato dalla tabella prezzi locale — questo provider non riporta il costo nativamente.`,inferred:`dedotto`,statusValue:{success:`riuscita`,failed:`fallita`,aborted:`interrotta`},truncated:`Mostrate le prime {{shown}} di {{total}} righe corrispondenti.`},p={title:`Analytics di Desktop`,refreshAria:`Aggiorna le analytics`,failedToLoad:`Impossibile caricare le analytics: {{error}}`,totalCost:`Costo totale`,costToday:`{{value}} oggi`,totalJobs:`Job totali`,jobsToday:`{{n}} oggi`,successRate:`Tasso di successo`,acrossAllProjects:`su tutti i progetti`,avgCostPerJob:`Costo medio / job`,periodAverage:`media del periodo`,costOverTime:`Costo nel tempo tra i progetti`,noCostData:`Nessun dato di costo per questo periodo`,projectComparison:`Confronto progetti`,noProjects:`Nessun progetto registrato.`,jobsCount_one:`{{count}} job`,jobsCount_other:`{{count}} job`,successPct:`{{pct}}% di successo`,costByProject:`Costo per progetto`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`CSV riepilogo`,rawCsv:`CSV raw`,summaryJson:`JSON riepilogo`,rawJson:`JSON raw`,downloading:`Download in corso…`,noData:`Nessun dato per i filtri attuali`,failed:`Esportazione non riuscita`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`Jobs`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Refinamento`,smash:`SMASH`,fileSummary:`Resumos de ficheiros`},t={d7:`7d`,d30:`30d`,d90:`90d`,all:`Tudo`,custom:`Personalizado`,startDate:`Data de início`,endDate:`Data de fim`,to:`até`},n=`{{count}} execução`,r=`{{count}} execuções`,i={title:`Analytics`,all:`Tudo`,engine:`Motor`,ticketChip:`ticket #{{id}} · ✕`,failedToLoad:`Falha ao carregar: {{error}}`},a={spending:`Gastos`,vsPrev:`{{pct}}% vs anterior`,invocations_one:`{{count}} invocação`,invocations_other:`{{count}} invocações`,tokens:`· {{tokens}} tokens`,tokensTooltip:`Total de tokens = input novo + output + leitura de cache + criação de cache em todas as invocações desta janela.`,includesEstimated:`· inclui ~{{amount}} estimado`,includesEstimatedTooltip:`Inclui {{amount}} de custo estimado de fornecedores sem campo de custo nativo (p. ex. codex através da tabela de preços local).`,trackingStarted:`Registo iniciado em {{date}}`,trackingStartedFallback:`O registo começa na primeira invocação`,emptyState:`Ainda não há invocações para esta janela de filtros.`,segmentTitle:`{{label}}: {{value}}`},o={title:`Por fornecedor`,description:`Como o custo se divide entre as CLIs de IA deste projeto. O prefixo <tilde>~</tilde> assinala as linhas em que o custo é estimado a partir da tabela de preços local (o fornecedor não o reporta nativamente).`,noCost:`Ainda não há custo registado nesta janela.`,segmentTitle:`{{label}}: {{value}} ({{count}})`},s={title:`Cronologia diária`,subtitle:`empilhada por superfície`,empty:`Sem gastos neste período.`},c={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Experimente o Explore para specs mais ricas`,runsSoFar_one:`{{count}} execução até agora`,runsSoFar_other:`{{count}} execuções até agora`,perSpec:`por spec`,createdRuns:`<strong>{{created}}</strong> criadas · {{runs}} execuções`,avgDuration:`{{duration}} em média`,ratio:`{{ratio}}× mais por spec`},l={title:`Modelos`,empty:`Nenhum modelo registado.`},u={title:`Custo vs Turnos`,empty:`Sem invocações para representar.`,turnsLabel:`turnos`,costLabel:`custo`},d={title:`Top tickets`,empty:`Sem atividade de tickets neste período.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Sem atribuição`,deletedTicket:`ticket eliminado #{{id}}`},f={title:`Todas as invocações`,statusFilterAria:`Filtro de estado`,minCostFilterAria:`Filtro de custo mínimo`,minCostPlaceholder:`≥ $0.00`,allStatus:`Todos os estados`,success:`Sucesso`,failed:`Falhadas`,aborted:`Abortadas`,empty:`Nenhuma invocação corresponde aos filtros atuais.`,colSurface:`Superfície`,colTicket:`Ticket`,colCost:`Custo`,colTurns:`Turnos`,colTokens:`Tokens`,colModel:`Modelo`,colStatus:`Estado`,colStarted:`Início`,contractLayer:`Contract Layer`,contractLayerRefinement:`Refinamento do Contract Layer`,deleted:`(eliminado)`,provisionalTitleTooltip:`Título provisório do Explore — ainda não confirmado`,estimatedCostTooltip:`Estimado a partir da tabela de preços local — este fornecedor não reporta o custo nativamente.`,inferred:`inferido`,statusValue:{success:`sucesso`,failed:`falhada`,aborted:`abortada`},truncated:`A mostrar as primeiras {{shown}} de {{total}} linhas correspondentes.`},p={title:`Analytics do Desktop`,refreshAria:`Atualizar analytics`,failedToLoad:`Falha ao carregar as analytics: {{error}}`,totalCost:`Custo total`,costToday:`{{value}} hoje`,totalJobs:`Total de jobs`,jobsToday:`{{n}} hoje`,successRate:`Taxa de sucesso`,acrossAllProjects:`em todos os projetos`,avgCostPerJob:`Custo médio / job`,periodAverage:`média do período`,costOverTime:`Custo entre projetos ao longo do tempo`,noCostData:`Sem dados de custo para este período`,projectComparison:`Comparação de projetos`,noProjects:`Nenhum projeto registado.`,jobsCount_one:`{{count}} job`,jobsCount_other:`{{count}} jobs`,successPct:`{{pct}}% de sucesso`,costByProject:`Custo por projeto`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`CSV de resumo`,rawCsv:`CSV em bruto`,summaryJson:`JSON de resumo`,rawJson:`JSON em bruto`,downloading:`A transferir…`,noData:`Sem dados para os filtros atuais`,failed:`Falha na exportação`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={job:`ジョブ`,quickSpec:`クイック`,exploreSpec:`Explore`,aiEdit:`リファイン`,smash:`SMASH`,fileSummary:`ファイル要約`},t={d7:`7日`,d30:`30日`,d90:`90日`,all:`すべて`,custom:`カスタム`,startDate:`開始日`,endDate:`終了日`,to:`〜`},n=`{{count}} 回の実行`,r=`{{count}} 回の実行`,i={title:`アナリティクス`,all:`すべて`,engine:`エンジン`,ticketChip:`チケット #{{id}} · ✕`,failedToLoad:`読み込みに失敗しました: {{error}}`},a={spending:`支出`,vsPrev:`前期間比 {{pct}}%`,invocations_one:`{{count}} 回の呼び出し`,invocations_other:`{{count}} 回の呼び出し`,tokens:`· {{tokens}} トークン`,tokensTooltip:`合計トークン = この期間の全呼び出しにおける新規入力 + 出力 + キャッシュ読み取り + キャッシュ作成の合計。`,includesEstimated:`· 約 {{amount}} の推定値を含む`,includesEstimatedTooltip:`ネイティブのコストフィールドを持たないプロバイダーからの推定コスト {{amount}} を含みます(例: ローカル料金表で算出する codex)。`,trackingStarted:`トラッキング開始: {{date}}`,trackingStartedFallback:`最初の呼び出しからトラッキングを開始`,emptyState:`このフィルター期間の呼び出しはまだありません。`,segmentTitle:`{{label}}: {{value}}`},o={title:`プロバイダー別`,description:`このプロジェクトの AI CLI 間でのコストの内訳。<tilde>~</tilde> プレフィックスは、コストがローカル料金表からの推定値である行を示します(プロバイダーがネイティブに報告しない場合)。`,noCost:`この期間に記録されたコストはまだありません。`,segmentTitle:`{{label}}: {{value}} ({{count}})`},s={title:`日次タイムライン`,subtitle:`サーフェス別の積み上げ`,empty:`この期間の支出はありません。`},c={title:`クイック vs Explore`,quick:`クイック`,explore:`Explore`,sparseCta:`より充実したスペックには Explore をお試しください`,runsSoFar_one:`これまで {{count}} 回実行`,runsSoFar_other:`これまで {{count}} 回実行`,perSpec:`スペックあたり`,createdRuns:`<strong>{{created}}</strong> 件作成 · {{runs}} 回実行`,avgDuration:`平均 {{duration}}`,ratio:`スペックあたり {{ratio}}× 多い`},l={title:`モデル`,empty:`記録されたモデルはありません。`},u={title:`コスト vs ターン`,empty:`プロットする呼び出しがありません。`,turnsLabel:`ターン`,costLabel:`コスト`},d={title:`上位チケット`,empty:`この期間のチケットアクティビティはありません。`,breakdownItem:`{{n}} {{label}}`,unattributed:`未割り当て`,deletedTicket:`削除済みチケット #{{id}}`},f={title:`すべての呼び出し`,statusFilterAria:`ステータスフィルター`,minCostFilterAria:`最小コストフィルター`,minCostPlaceholder:`≥ $0.00`,allStatus:`すべてのステータス`,success:`成功`,failed:`失敗`,aborted:`中断`,empty:`現在のフィルターに一致する呼び出しはありません。`,colSurface:`サーフェス`,colTicket:`チケット`,colCost:`コスト`,colTurns:`ターン`,colTokens:`トークン`,colModel:`モデル`,colStatus:`ステータス`,colStarted:`開始`,contractLayer:`Contract Layer`,contractLayerRefinement:`Contract Layer の改良`,deleted:`(削除済み)`,provisionalTitleTooltip:`暫定の Explore タイトル — まだコミットされていません`,estimatedCostTooltip:`ローカル料金表からの推定値 — このプロバイダーはコストをネイティブに報告しません。`,inferred:`推定`,statusValue:{success:`成功`,failed:`失敗`,aborted:`中断`},truncated:`一致する {{total}} 行のうち最初の {{shown}} 行を表示しています。`},p={title:`Desktop アナリティクス`,refreshAria:`アナリティクスを更新`,failedToLoad:`アナリティクスの読み込みに失敗しました: {{error}}`,totalCost:`合計コスト`,costToday:`本日 {{value}}`,totalJobs:`合計ジョブ数`,jobsToday:`本日 {{n}} 件`,successRate:`成功率`,acrossAllProjects:`全プロジェクト`,avgCostPerJob:`ジョブあたり平均コスト`,periodAverage:`期間平均`,costOverTime:`プロジェクト横断のコスト推移`,noCostData:`この期間のコストデータはありません`,projectComparison:`プロジェクト比較`,noProjects:`登録されたプロジェクトはありません。`,jobsCount_one:`{{count}} 件のジョブ`,jobsCount_other:`{{count}} 件のジョブ`,successPct:`成功率 {{pct}}%`,costByProject:`プロジェクト別コスト`},m={surfaces:e,periods:t,runs_one:n,runs_other:r,page:i,hero:a,providerCard:o,timeline:s,quickVsExplore:c,models:l,scatter:u,topTickets:d,table:f,export:{summaryCsv:`サマリー CSV`,rawCsv:`生データ CSV`,summaryJson:`サマリー JSON`,rawJson:`生データ JSON`,downloading:`ダウンロード中…`,noData:`現在のフィルターにデータがありません`,failed:`エクスポートに失敗しました`},desktop:p};export{m as default,p as desktop,a as hero,l as models,i as page,t as periods,o as providerCard,c as quickVsExplore,n as runs_one,r as runs_other,u as scatter,e as surfaces,f as table,s as timeline,d as topTickets};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./chunk-CilyBKbf.js";var t=e({default:()=>g,desktop:()=>h,hero:()=>s,models:()=>d,page:()=>o,periods:()=>r,providerCard:()=>c,quickVsExplore:()=>u,runs_one:()=>i,runs_other:()=>a,scatter:()=>f,surfaces:()=>n,table:()=>m,timeline:()=>l,topTickets:()=>p}),n={job:`Jobs`,quickSpec:`Quick`,exploreSpec:`Explore`,aiEdit:`Refine`,smash:`SMASH`,fileSummary:`File summaries`},r={d7:`7d`,d30:`30d`,d90:`90d`,all:`All`,custom:`Custom`,startDate:`Start date`,endDate:`End date`,to:`to`},i=`{{count}} run`,a=`{{count}} runs`,o={title:`Analytics`,all:`All`,engine:`Engine`,ticketChip:`ticket #{{id}} · ✕`,failedToLoad:`Failed to load: {{error}}`},s={spending:`Spending`,vsPrev:`{{pct}}% vs prev`,invocations_one:`{{count}} invocation`,invocations_other:`{{count}} invocations`,tokens:`· {{tokens}} tokens`,tokensTooltip:`Total tokens = fresh input + output + cache-read + cache-create across all invocations in this window.`,includesEstimated:`· includes ~{{amount}} estimated`,includesEstimatedTooltip:`Includes {{amount}} of estimated cost from providers without a native cost field (e.g. codex via the local pricing table).`,trackingStarted:`Tracking started {{date}}`,trackingStartedFallback:`Tracking started on first invocation`,emptyState:`No invocations yet for this filter window.`,segmentTitle:`{{label}}: {{value}}`},c={title:`By provider`,description:`How cost splits across the AI CLIs in this project. The <tilde>~</tilde> prefix marks rows where cost is estimated from the local pricing table (the provider does not report it natively).`,noCost:`No cost recorded yet in this window.`,segmentTitle:`{{label}}: {{value}} ({{count}})`},l={title:`Daily timeline`,subtitle:`stacked by surface`,empty:`No spend in this period.`},u={title:`Quick vs Explore`,quick:`Quick`,explore:`Explore`,sparseCta:`Try Explore for richer specs`,runsSoFar_one:`{{count}} run so far`,runsSoFar_other:`{{count}} runs so far`,perSpec:`per spec`,createdRuns:`<strong>{{created}}</strong> created · {{runs}} runs`,avgDuration:`{{duration}} avg`,ratio:`{{ratio}}× more per spec`},d={title:`Models`,empty:`No models recorded.`},f={title:`Cost vs Turns`,empty:`No invocations to plot.`,turnsLabel:`turns`,costLabel:`cost`},p={title:`Top tickets`,empty:`No ticket activity in this period.`,breakdownItem:`{{n}} {{label}}`,unattributed:`Unattributed`,deletedTicket:`deleted ticket #{{id}}`},m={title:`All invocations`,statusFilterAria:`Status filter`,minCostFilterAria:`Minimum cost filter`,minCostPlaceholder:`≥ $0.00`,allStatus:`All status`,success:`Success`,failed:`Failed`,aborted:`Aborted`,empty:`No invocations match the current filters.`,colSurface:`Surface`,colTicket:`Ticket`,colCost:`Cost`,colTurns:`Turns`,colTokens:`Tokens`,colModel:`Model`,colStatus:`Status`,colStarted:`Started`,contractLayer:`Contract Layer`,contractLayerRefinement:`Contract Layer refinement`,deleted:`(deleted)`,provisionalTitleTooltip:`Provisional Explore title — not yet committed`,estimatedCostTooltip:`Estimated from local pricing table — this provider does not report cost natively.`,inferred:`inferred`,statusValue:{success:`success`,failed:`failed`,aborted:`aborted`},truncated:`Showing first {{shown}} of {{total}} matching rows.`},h={title:`Desktop Analytics`,refreshAria:`Refresh analytics`,failedToLoad:`Failed to load analytics: {{error}}`,totalCost:`Total Cost`,costToday:`{{value}} today`,totalJobs:`Total Jobs`,jobsToday:`{{n}} today`,successRate:`Success Rate`,acrossAllProjects:`across all projects`,avgCostPerJob:`Avg Cost / Job`,periodAverage:`period average`,costOverTime:`Cross-Project Cost Over Time`,noCostData:`No cost data for this period`,projectComparison:`Project Comparison`,noProjects:`No projects registered.`,jobsCount_one:`{{count}} job`,jobsCount_other:`{{count}} jobs`,successPct:`{{pct}}% success`,costByProject:`Cost by Project`},g={surfaces:n,periods:r,runs_one:i,runs_other:a,page:o,hero:s,providerCard:c,timeline:l,quickVsExplore:u,models:d,scatter:f,topTickets:p,table:m,export:{summaryCsv:`Summary CSV`,rawCsv:`Raw CSV`,summaryJson:`Summary JSON`,rawJson:`Raw JSON`,downloading:`Downloading…`,noData:`No data for current filters`,failed:`Export failed`},desktop:h};export{t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={wordPattern:/(-?\d*\.\d\w*)|([^\`\~\!\#\%\^\&\*\(\)\-\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,comments:{lineComment:`//`,blockComment:[`/*`,`*/`]},brackets:[[`{`,`}`],[`[`,`]`],[`(`,`)`]],autoClosingPairs:[{open:`{`,close:`}`},{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`"`,close:`"`},{open:`'`,close:`'`}],surroundingPairs:[{open:`{`,close:`}`},{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`"`,close:`"`},{open:`'`,close:`'`},{open:`<`,close:`>`}],folding:{markers:{start:RegExp(`^\\s*//\\s*(?:(?:#?region\\b)|(?:<editor-fold\\b))`),end:RegExp(`^\\s*//\\s*(?:(?:#?endregion\\b)|(?:</editor-fold>))`)}}},t=`abstract.activate.and.any.array.as.asc.assert.autonomous.begin.bigdecimal.blob.boolean.break.bulk.by.case.cast.catch.char.class.collect.commit.const.continue.convertcurrency.decimal.default.delete.desc.do.double.else.end.enum.exception.exit.export.extends.false.final.finally.float.for.from.future.get.global.goto.group.having.hint.if.implements.import.in.inner.insert.instanceof.int.interface.into.join.last_90_days.last_month.last_n_days.last_week.like.limit.list.long.loop.map.merge.native.new.next_90_days.next_month.next_n_days.next_week.not.null.nulls.number.object.of.on.or.outer.override.package.parallel.pragma.private.protected.public.retrieve.return.returning.rollback.savepoint.search.select.set.short.sort.stat.static.strictfp.super.switch.synchronized.system.testmethod.then.this.this_month.this_week.throw.throws.today.tolabel.tomorrow.transaction.transient.trigger.true.try.type.undelete.update.upsert.using.virtual.void.volatile.webservice.when.where.while.yesterday`.split(`.`),n=e=>e.charAt(0).toUpperCase()+e.substr(1),r=[];t.forEach(e=>{r.push(e),r.push(e.toUpperCase()),r.push(n(e))});var i={defaultToken:``,tokenPostfix:`.apex`,keywords:r,operators:`=.>.<.!.~.?.:.==.<=.>=.!=.&&.||.++.--.+.-.*./.&.|.^.%.<<.>>.>>>.+=.-=.*=./=.&=.|=.^=.%=.<<=.>>=.>>>=`.split(`.`),symbols:/[=><!~?:&|+\-*\/\^%]+/,escapes:/\\(?:[abfnrtv\\"']|x[0-9A-Fa-f]{1,4}|u[0-9A-Fa-f]{4}|U[0-9A-Fa-f]{8})/,digits:/\d+(_+\d+)*/,octaldigits:/[0-7]+(_+[0-7]+)*/,binarydigits:/[0-1]+(_+[0-1]+)*/,hexdigits:/[[0-9a-fA-F]+(_+[0-9a-fA-F]+)*/,tokenizer:{root:[[/[a-z_$][\w$]*/,{cases:{"@keywords":{token:`keyword.$0`},"@default":`identifier`}}],[/[A-Z][\w\$]*/,{cases:{"@keywords":{token:`keyword.$0`},"@default":`type.identifier`}}],{include:`@whitespace`},[/[{}()\[\]]/,`@brackets`],[/[<>](?!@symbols)/,`@brackets`],[/@symbols/,{cases:{"@operators":`delimiter`,"@default":``}}],[/@\s*[a-zA-Z_\$][\w\$]*/,`annotation`],[/(@digits)[eE]([\-+]?(@digits))?[fFdD]?/,`number.float`],[/(@digits)\.(@digits)([eE][\-+]?(@digits))?[fFdD]?/,`number.float`],[/(@digits)[fFdD]/,`number.float`],[/(@digits)[lL]?/,`number`],[/[;,.]/,`delimiter`],[/"([^"\\]|\\.)*$/,`string.invalid`],[/'([^'\\]|\\.)*$/,`string.invalid`],[/"/,`string`,`@string."`],[/'/,`string`,`@string.'`],[/'[^\\']'/,`string`],[/(')(@escapes)(')/,[`string`,`string.escape`,`string`]],[/'/,`string.invalid`]],whitespace:[[/[ \t\r\n]+/,``],[/\/\*\*(?!\/)/,`comment.doc`,`@apexdoc`],[/\/\*/,`comment`,`@comment`],[/\/\/.*$/,`comment`]],comment:[[/[^\/*]+/,`comment`],[/\*\//,`comment`,`@pop`],[/[\/*]/,`comment`]],apexdoc:[[/[^\/*]+/,`comment.doc`],[/\*\//,`comment.doc`,`@pop`],[/[\/*]/,`comment.doc`]],string:[[/[^\\"']+/,`string`],[/@escapes/,`string.escape`],[/\\./,`string.escape.invalid`],[/["']/,{cases:{"$#==$S2":{token:`string`,next:`@pop`},"@default":`string`}}]]}};export{e as conf,i as language};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#abb2bf;background:#282c34}.hljs-comment,.hljs-quote{color:#5c6370;font-style:italic}.hljs-doctag,.hljs-keyword,.hljs-formula{color:#c678dd}.hljs-section,.hljs-name,.hljs-selector-tag,.hljs-deletion,.hljs-subst{color:#e06c75}.hljs-literal{color:#56b6c2}.hljs-string,.hljs-regexp,.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string{color:#98c379}.hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-type,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-number{color:#d19a66}.hljs-symbol,.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-title{color:#61aeee}.hljs-built_in,.hljs-title.class_,.hljs-class .hljs-title{color:#e6c07b}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{n as e}from"./chunk-CilyBKbf.js";var t=e({chip:()=>i,default:()=>l,editor:()=>a,errors:()=>r,lightbox:()=>s,removeFile:()=>n,section:()=>o,sessionBar:()=>c}),n=`Remove {{name}}`,r={uploadFailed:`Upload failed ({{status}})`,uploadFailedFile:`Upload failed: {{name}}`,deleteFailed:`Delete failed ({{status}})`,bulkDeleteFailed:`Bulk delete failed ({{status}})`,listFailed:`List failed ({{status}})`,fetchFailed:`Fetch failed ({{status}})`,removeFailed:`Failed to remove attachment`,loadFailed:`Failed to load attachment`},i={uploading:`Uploading…`,genericFile:`file`},a={attachFiles:`Attach files`,uploadingFiles_one:`Uploading {{count}} file…`,uploadingFiles_other:`Uploading {{count}} files…`,dropToAddContext:`Drop to add context`},o={ariaLabel:`Attachments`,title:`Resources`,fileCount_one:`{{count}} file`,fileCount_other:`{{count}} files`},s={preview:`Preview {{name}}`,backToDesktop:`Back to Specrails`,download:`Download`,downloadFile:`Download {{name}}`,loading:`Loading attachment...`,loadError:`Could not load attachment: {{error}}`,previewUnavailable:`Preview not available for this file type.`},c={empty:`No pinned resources — drop files or click Add`},l={removeFile:n,errors:r,chip:i,editor:a,section:o,lightbox:s,sessionBar:c};export{t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`Rimuovi {{name}}`,t={uploadFailed:`Caricamento non riuscito ({{status}})`,uploadFailedFile:`Caricamento non riuscito: {{name}}`,deleteFailed:`Eliminazione non riuscita ({{status}})`,bulkDeleteFailed:`Eliminazione multipla non riuscita ({{status}})`,listFailed:`Recupero dell'elenco non riuscito ({{status}})`,fetchFailed:`Recupero non riuscito ({{status}})`,removeFailed:`Impossibile rimuovere l'allegato`,loadFailed:`Impossibile caricare l'allegato`},n={uploading:`Caricamento…`,genericFile:`file`},r={attachFiles:`Allega file`,uploadingFiles_one:`Caricamento di {{count}} file…`,uploadingFiles_other:`Caricamento di {{count}} file…`,dropToAddContext:`Rilascia per aggiungere contesto`},i={ariaLabel:`Allegati`,title:`Risorse`,fileCount_one:`{{count}} file`,fileCount_other:`{{count}} file`},a={preview:`Anteprima di {{name}}`,backToDesktop:`Torna a Specrails`,download:`Scarica`,downloadFile:`Scarica {{name}}`,loading:`Caricamento allegato...`,loadError:`Impossibile caricare l'allegato: {{error}}`,previewUnavailable:`Anteprima non disponibile per questo tipo di file.`},o={empty:`Nessuna risorsa fissata — trascina file o clicca Aggiungi`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`移除 {{name}}`,t={uploadFailed:`上传失败({{status}})`,uploadFailedFile:`上传失败:{{name}}`,deleteFailed:`删除失败({{status}})`,bulkDeleteFailed:`批量删除失败({{status}})`,listFailed:`列表加载失败({{status}})`,fetchFailed:`获取失败({{status}})`,removeFailed:`移除附件失败`,loadFailed:`加载附件失败`},n={uploading:`上传中…`,genericFile:`文件`},r={attachFiles:`附加文件`,uploadingFiles_one:`正在上传 {{count}} 个文件…`,uploadingFiles_other:`正在上传 {{count}} 个文件…`,dropToAddContext:`拖放以添加上下文`},i={ariaLabel:`附件`,title:`资源`,fileCount_one:`{{count}} 个文件`,fileCount_other:`{{count}} 个文件`},a={preview:`预览 {{name}}`,backToDesktop:`返回 Specrails`,download:`下载`,downloadFile:`下载 {{name}}`,loading:`正在加载附件...`,loadError:`无法加载附件:{{error}}`,previewUnavailable:`此文件类型不支持预览。`},o={empty:`暂无固定资源 — 拖入文件或点击“添加”`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`Quitar {{name}}`,t={uploadFailed:`Error al subir ({{status}})`,uploadFailedFile:`Error al subir: {{name}}`,deleteFailed:`Error al eliminar ({{status}})`,bulkDeleteFailed:`Error al eliminar en bloque ({{status}})`,listFailed:`Error al listar ({{status}})`,fetchFailed:`Error al obtener ({{status}})`,removeFailed:`No se pudo quitar el adjunto`,loadFailed:`No se pudo cargar el adjunto`},n={uploading:`Subiendo…`,genericFile:`archivo`},r={attachFiles:`Adjuntar archivos`,uploadingFiles_one:`Subiendo {{count}} archivo…`,uploadingFiles_other:`Subiendo {{count}} archivos…`,dropToAddContext:`Suelta para añadir contexto`},i={ariaLabel:`Adjuntos`,title:`Recursos`,fileCount_one:`{{count}} archivo`,fileCount_other:`{{count}} archivos`},a={preview:`Vista previa de {{name}}`,backToDesktop:`Volver a Specrails`,download:`Descargar`,downloadFile:`Descargar {{name}}`,loading:`Cargando adjunto...`,loadError:`No se pudo cargar el adjunto: {{error}}`,previewUnavailable:`Vista previa no disponible para este tipo de archivo.`},o={empty:`No hay recursos fijados — suelta archivos o haz clic en Añadir`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`{{name}} entfernen`,t={uploadFailed:`Upload fehlgeschlagen ({{status}})`,uploadFailedFile:`Upload fehlgeschlagen: {{name}}`,deleteFailed:`Löschen fehlgeschlagen ({{status}})`,bulkDeleteFailed:`Massenlöschen fehlgeschlagen ({{status}})`,listFailed:`Auflisten fehlgeschlagen ({{status}})`,fetchFailed:`Abruf fehlgeschlagen ({{status}})`,removeFailed:`Anhang konnte nicht entfernt werden`,loadFailed:`Anhang konnte nicht geladen werden`},n={uploading:`Wird hochgeladen…`,genericFile:`Datei`},r={attachFiles:`Dateien anhängen`,uploadingFiles_one:`{{count}} Datei wird hochgeladen…`,uploadingFiles_other:`{{count}} Dateien werden hochgeladen…`,dropToAddContext:`Loslassen, um Kontext hinzuzufügen`},i={ariaLabel:`Anhänge`,title:`Ressourcen`,fileCount_one:`{{count}} Datei`,fileCount_other:`{{count}} Dateien`},a={preview:`Vorschau von {{name}}`,backToDesktop:`Zurück zu Specrails`,download:`Herunterladen`,downloadFile:`{{name}} herunterladen`,loading:`Anhang wird geladen...`,loadError:`Anhang konnte nicht geladen werden: {{error}}`,previewUnavailable:`Für diesen Dateityp ist keine Vorschau verfügbar.`},o={empty:`Keine angepinnten Ressourcen – Dateien hierher ziehen oder auf „Hinzufügen“ klicken`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`Retirer {{name}}`,t={uploadFailed:`Échec de l'envoi ({{status}})`,uploadFailedFile:`Échec de l'envoi : {{name}}`,deleteFailed:`Échec de la suppression ({{status}})`,bulkDeleteFailed:`Échec de la suppression groupée ({{status}})`,listFailed:`Échec du listage ({{status}})`,fetchFailed:`Échec de la récupération ({{status}})`,removeFailed:`Échec du retrait de la pièce jointe`,loadFailed:`Échec du chargement de la pièce jointe`},n={uploading:`Envoi…`,genericFile:`fichier`},r={attachFiles:`Joindre des fichiers`,uploadingFiles_one:`Envoi de {{count}} fichier…`,uploadingFiles_other:`Envoi de {{count}} fichiers…`,dropToAddContext:`Déposez pour ajouter du contexte`},i={ariaLabel:`Pièces jointes`,title:`Ressources`,fileCount_one:`{{count}} fichier`,fileCount_other:`{{count}} fichiers`},a={preview:`Aperçu de {{name}}`,backToDesktop:`Retour à Specrails`,download:`Télécharger`,downloadFile:`Télécharger {{name}}`,loading:`Chargement de la pièce jointe...`,loadError:`Impossible de charger la pièce jointe : {{error}}`,previewUnavailable:`Aperçu non disponible pour ce type de fichier.`},o={empty:`Aucune ressource épinglée — déposez des fichiers ou cliquez sur Ajouter`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`Remover {{name}}`,t={uploadFailed:`Falha no upload ({{status}})`,uploadFailedFile:`Falha no upload: {{name}}`,deleteFailed:`Falha ao eliminar ({{status}})`,bulkDeleteFailed:`Falha na eliminação em massa ({{status}})`,listFailed:`Falha ao listar ({{status}})`,fetchFailed:`Falha ao obter ({{status}})`,removeFailed:`Falha ao remover o anexo`,loadFailed:`Falha ao carregar o anexo`},n={uploading:`A enviar…`,genericFile:`ficheiro`},r={attachFiles:`Anexar ficheiros`,uploadingFiles_one:`A enviar {{count}} ficheiro…`,uploadingFiles_other:`A enviar {{count}} ficheiros…`,dropToAddContext:`Largue para adicionar contexto`},i={ariaLabel:`Anexos`,title:`Recursos`,fileCount_one:`{{count}} ficheiro`,fileCount_other:`{{count}} ficheiros`},a={preview:`Pré-visualizar {{name}}`,backToDesktop:`Voltar ao Specrails`,download:`Transferir`,downloadFile:`Transferir {{name}}`,loading:`A carregar anexo...`,loadError:`Não foi possível carregar o anexo: {{error}}`,previewUnavailable:`Pré-visualização indisponível para este tipo de ficheiro.`},o={empty:`Sem recursos afixados — largue ficheiros ou clique em Adicionar`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e=`{{name}} を削除`,t={uploadFailed:`アップロードに失敗しました ({{status}})`,uploadFailedFile:`アップロード失敗: {{name}}`,deleteFailed:`削除に失敗しました ({{status}})`,bulkDeleteFailed:`一括削除に失敗しました ({{status}})`,listFailed:`一覧の取得に失敗しました ({{status}})`,fetchFailed:`取得に失敗しました ({{status}})`,removeFailed:`添付ファイルの削除に失敗しました`,loadFailed:`添付ファイルの読み込みに失敗しました`},n={uploading:`アップロード中…`,genericFile:`ファイル`},r={attachFiles:`ファイルを添付`,uploadingFiles_one:`{{count}} 件のファイルをアップロード中…`,uploadingFiles_other:`{{count}} 件のファイルをアップロード中…`,dropToAddContext:`ドロップしてコンテキストに追加`},i={ariaLabel:`添付ファイル`,title:`リソース`,fileCount_one:`{{count}} ファイル`,fileCount_other:`{{count}} ファイル`},a={preview:`{{name}} をプレビュー`,backToDesktop:`Specrails に戻る`,download:`ダウンロード`,downloadFile:`{{name}} をダウンロード`,loading:`添付ファイルを読み込み中...`,loadError:`添付ファイルを読み込めませんでした: {{error}}`,previewUnavailable:`このファイル形式のプレビューには対応していません。`},o={empty:`ピン留めされたリソースはありません — ファイルをドロップするか「追加」をクリック`},s={removeFile:e,errors:t,chip:n,editor:r,section:i,lightbox:a,sessionBar:o};export{n as chip,s as default,r as editor,t as errors,a as lightbox,e as removeFile,i as section,o as sessionBar};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={comments:{lineComment:`#`}},t={defaultToken:`keyword`,ignoreCase:!0,tokenPostfix:`.azcli`,str:/[^#\s]/,tokenizer:{root:[{include:`@comment`},[/\s-+@str*\s*/,{cases:{"@eos":{token:`key.identifier`,next:`@popall`},"@default":{token:`key.identifier`,next:`@type`}}}],[/^-+@str*\s*/,{cases:{"@eos":{token:`key.identifier`,next:`@popall`},"@default":{token:`key.identifier`,next:`@type`}}}]],type:[{include:`@comment`},[/-+@str*\s*/,{cases:{"@eos":{token:`key.identifier`,next:`@popall`},"@default":`key.identifier`}}],[/@str+\s*/,{cases:{"@eos":{token:`string`,next:`@popall`},"@default":`string`}}]],comment:[[/#.*$/,{cases:{"@eos":{token:`comment`,next:`@popall`}}}]]}};export{e as conf,t as language};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={comments:{lineComment:`REM`},brackets:[[`{`,`}`],[`[`,`]`],[`(`,`)`]],autoClosingPairs:[{open:`{`,close:`}`},{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`"`,close:`"`}],surroundingPairs:[{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`"`,close:`"`}],folding:{markers:{start:RegExp(`^\\s*(::\\s*|REM\\s+)#region`),end:RegExp(`^\\s*(::\\s*|REM\\s+)#endregion`)}}},t={defaultToken:``,ignoreCase:!0,tokenPostfix:`.bat`,brackets:[{token:`delimiter.bracket`,open:`{`,close:`}`},{token:`delimiter.parenthesis`,open:`(`,close:`)`},{token:`delimiter.square`,open:`[`,close:`]`}],keywords:/call|defined|echo|errorlevel|exist|for|goto|if|pause|set|shift|start|title|not|pushd|popd/,symbols:/[=><!~?&|+\-*\/\^;\.,]+/,escapes:/\\(?:[abfnrtv\\"']|x[0-9A-Fa-f]{1,4}|u[0-9A-Fa-f]{4}|U[0-9A-Fa-f]{8})/,tokenizer:{root:[[/^(\s*)(rem(?:\s.*|))$/,[``,`comment`]],[/(\@?)(@keywords)(?!\w)/,[{token:`keyword`},{token:`keyword.$2`}]],[/[ \t\r\n]+/,``],[/setlocal(?!\w)/,`keyword.tag-setlocal`],[/endlocal(?!\w)/,`keyword.tag-setlocal`],[/[a-zA-Z_]\w*/,``],[/:\w*/,`metatag`],[/%[^%]+%/,`variable`],[/%%[\w]+(?!\w)/,`variable`],[/[{}()\[\]]/,`@brackets`],[/@symbols/,`delimiter`],[/\d*\.\d+([eE][\-+]?\d+)?/,`number.float`],[/0[xX][0-9a-fA-F_]*[0-9a-fA-F]/,`number.hex`],[/\d+/,`number`],[/[;,.]/,`delimiter`],[/"/,`string`,`@string."`],[/'/,`string`,`@string.'`]],string:[[/[^\\"'%]+/,{cases:{"@eos":{token:`string`,next:`@popall`},"@default":`string`}}],[/@escapes/,`string.escape`],[/\\./,`string.escape.invalid`],[/%[\w ]+%/,`variable`],[/%%[\w]+(?!\w)/,`variable`],[/["']/,{cases:{"$#==$S2":{token:`string`,next:`@pop`},"@default":`string`}}],[/$/,`string`,`@popall`]]}};export{e as conf,t as language};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var e=(e=>`\\b${e}\\b`)(`[_a-zA-Z][_a-zA-Z0-9]*`),t=[`targetScope`,`resource`,`module`,`param`,`var`,`output`,`for`,`in`,`if`,`existing`],n=[`true`,`false`,`null`],r=`[ \\t\\r\\n]`,i=`[0-9]+`,a={comments:{lineComment:`//`,blockComment:[`/*`,`*/`]},brackets:[[`{`,`}`],[`[`,`]`],[`(`,`)`]],surroundingPairs:[{open:`{`,close:`}`},{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`'`,close:`'`},{open:`'''`,close:`'''`}],autoClosingPairs:[{open:`{`,close:`}`},{open:`[`,close:`]`},{open:`(`,close:`)`},{open:`'`,close:`'`,notIn:[`string`,`comment`]},{open:`'''`,close:`'''`,notIn:[`string`,`comment`]}],autoCloseBefore:`:.,=}])'
|
|
2
|
+
`,indentationRules:{increaseIndentPattern:RegExp(`^((?!\\/\\/).)*(\\{[^}"'\`]*|\\([^)"'\`]*|\\[[^\\]"'\`]*)$`),decreaseIndentPattern:RegExp(`^((?!.*?\\/\\*).*\\*/)?\\s*[\\}\\]].*$`)}},o={defaultToken:``,tokenPostfix:`.bicep`,brackets:[{open:`{`,close:`}`,token:`delimiter.curly`},{open:`[`,close:`]`,token:`delimiter.square`},{open:`(`,close:`)`,token:`delimiter.parenthesis`}],symbols:/[=><!~?:&|+\-*/^%]+/,keywords:t,namedLiterals:n,escapes:"\\\\(u{[0-9A-Fa-f]+}|n|r|t|\\\\|'|\\${)",tokenizer:{root:[{include:`@expression`},{include:`@whitespace`}],stringVerbatim:[{regex:`(|'|'')[^']`,action:{token:`string`}},{regex:`'''`,action:{token:`string.quote`,next:`@pop`}}],stringLiteral:[{regex:"\\${",action:{token:`delimiter.bracket`,next:`@bracketCounting`}},{regex:`[^\\\\'$]+`,action:{token:`string`}},{regex:`@escapes`,action:{token:`string.escape`}},{regex:`\\\\.`,action:{token:`string.escape.invalid`}},{regex:`'`,action:{token:`string`,next:`@pop`}}],bracketCounting:[{regex:`{`,action:{token:`delimiter.bracket`,next:`@bracketCounting`}},{regex:`}`,action:{token:`delimiter.bracket`,next:`@pop`}},{include:`expression`}],comment:[{regex:`[^\\*]+`,action:{token:`comment`}},{regex:`\\*\\/`,action:{token:`comment`,next:`@pop`}},{regex:`[\\/*]`,action:{token:`comment`}}],whitespace:[{regex:r},{regex:`\\/\\*`,action:{token:`comment`,next:`@comment`}},{regex:`\\/\\/.*$`,action:{token:`comment`}}],expression:[{regex:`'''`,action:{token:`string.quote`,next:`@stringVerbatim`}},{regex:`'`,action:{token:`string.quote`,next:`@stringLiteral`}},{regex:i,action:{token:`number`}},{regex:e,action:{cases:{"@keywords":{token:`keyword`},"@namedLiterals":{token:`keyword`},"@default":{token:`identifier`}}}}]}};export{a as conf,o as language};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={dialogLabel:`Browser-Aufnahme`,nav:{forward:`Vorwärts`,reload:`Neu laden`},address:{placeholder:`URL eingeben und „Los“ drücken…`,label:`Adressleiste`,go:`Los`},viewport:{groupLabel:`Viewport-Größe`,presetLabel:`Viewport {{preset}}`,presetTitle:`Viewport: {{preset}}`,fit:`Anpassen`,desktop:`Desktop`,tablet:`Tablet`,mobile:`Mobil`},network:{ariaLabel:`Netzwerk-Requests aufzeichnen`,titleOn:`Netzwerk-Requests der Seite werden aufgezeichnet (zum Deaktivieren klicken)`,titleOff:`Netzwerkaufzeichnung aus (zum Aktivieren klicken)`,button:`Netzwerk`},allSizes:{ariaLabel:`In allen Bildschirmgrößen aufnehmen`,titleOn:`Dieses Element wird in Desktop, Tablet und Mobil aufgenommen (zum Deaktivieren klicken)`,titleOff:`In allen Größen aufnehmen: Desktop, Tablet und Mobil`,button:`Alle Größen`},select:{active:`Element anklicken oder ziehen…`,start:`Auswählen, um Spec zu erstellen`,hint:`Klicke ein hervorgehobenes Element an, um es aufzunehmen, oder ziehe ein eigenes Rechteck. Nutze die Breadcrumb (oder ↑/↓) zum Verfeinern. Esc zum Abbrechen.`},closeBrowser:`Browser schließen`,status:{connecting:`Browser wird verbunden…`,unavailable:`Browser nicht verfügbar`,opening:`Browser wird geöffnet…`,capturing:`Aufnahme läuft…`},error:{unavailable:`Der Browser ist nicht verfügbar.`,devHint:`Führe in der Entwicklung einmal <cmd>npx playwright install chromium</cmd> aus. In der Desktop-App ist Chromium gebündelt.`},breadcrumb:{hint:`↑ Elternelement · ↓ Kindelement`},toast:{captured:`Seitenauswahl aufgenommen`,captureFailed:`Aufnahme fehlgeschlagen`}},t={tools:{arrow:`Pfeil (A)`,box:`Rechteck (R)`,text:`Text (T)`,blur:`Weichzeichnen / Schwärzen (B)`,step:`Schrittnummer (N)`},notePrompt:`Notiztext:`,colorLabel:`Farbe {{color}}`,undo:`Rückgängig`,undoTitle:`Rückgängig (⌘Z)`,redo:`Wiederholen`,redoTitle:`Wiederholen (⌘⇧Z)`,capturedAlt:`Aufgenommene Auswahl`,discardConfirm:`Anmerkungen verwerfen?`,reselect:`Neu auswählen`,createSpec:`Spec erstellen`,skipContinue:`Überspringen & weiter`},n={header:`Aufgenommene Seite · {{title}}`,badge:{elements_one:`{{count}} Element`,elements_other:`{{count}} Elemente`,tokens:`Tokens`,requests:`{{count}} Req.`,truncated:`gekürzt`},removeLabel:`Aufgenommenen Seitenkontext entfernen`,noMarkup:`(kein Markup aufgenommen)`,appliedCss:`Angewendetes CSS`,appliedCssTruncated:`Angewendetes CSS (gekürzt)`,designTokens:`Design-Tokens`,fonts:`Schriften:`,copyJson:`Als JSON kopieren`,copied:`Kopiert!`,network_one:`Netzwerk · {{count}} Request`,network_other:`Netzwerk · {{count}} Requests`},r={connectionError:`Verbindungsfehler`,lostConnection:`Verbindung zum Browser verloren. Schließe „Von einer Website“ und öffne es erneut.`,tooManySessions:`Zu viele offene Browser-Sessions. Schließe eine und versuche es erneut.`,launchFailed:`Der Browser konnte auf dem Server nicht gestartet werden.`,openFailed:`Browser konnte nicht geöffnet werden.`},i={modal:e,editor:t,domPanel:n,session:r};export{i as default,n as domPanel,t as editor,e as modal,r as session};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var e={dialogLabel:`Capture navigateur`,nav:{forward:`Avancer`,reload:`Recharger`},address:{placeholder:`Saisissez une URL puis appuyez sur Aller…`,label:`Barre d'adresse`,go:`Aller`},viewport:{groupLabel:`Taille du viewport`,presetLabel:`Viewport {{preset}}`,presetTitle:`Viewport : {{preset}}`,fit:`ajusté`,desktop:`bureau`,tablet:`tablette`,mobile:`mobile`},network:{ariaLabel:`Capturer les requêtes réseau`,titleOn:`Capture des requêtes réseau de la page activée (cliquez pour désactiver)`,titleOff:`Capture réseau désactivée (cliquez pour activer)`,button:`Réseau`},allSizes:{ariaLabel:`Capturer à toutes les tailles d'écran`,titleOn:`Capturera cet élément en bureau, tablette et mobile (cliquez pour désactiver)`,titleOff:`Capturer à toutes les tailles : bureau, tablette et mobile`,button:`Toutes tailles`},select:{active:`Cliquez sur un élément ou faites glisser…`,start:`Sélectionner pour créer une spec`,hint:`Cliquez sur un élément en surbrillance pour le capturer, ou tracez un rectangle personnalisé. Utilisez le fil d'Ariane (ou ↑/↓) pour affiner. Appuyez sur Échap pour annuler.`},closeBrowser:`Fermer le navigateur`,status:{connecting:`Connexion du navigateur…`,unavailable:`Navigateur indisponible`,opening:`Ouverture du navigateur…`,capturing:`Capture…`},error:{unavailable:`Le navigateur est indisponible.`,devHint:`En dev, exécutez <cmd>npx playwright install chromium</cmd> une fois. Dans l'app de bureau, Chromium est intégré.`},breadcrumb:{hint:`↑ parent · ↓ enfant`},toast:{captured:`Sélection de la page capturée`,captureFailed:`Échec de la capture`}},t={tools:{arrow:`Flèche (A)`,box:`Rectangle (R)`,text:`Texte (T)`,blur:`Flouter / caviarder (B)`,step:`Numéro d'étape (N)`},notePrompt:`Texte de la note :`,colorLabel:`Couleur {{color}}`,undo:`Annuler`,undoTitle:`Annuler (⌘Z)`,redo:`Rétablir`,redoTitle:`Rétablir (⌘⇧Z)`,capturedAlt:`Sélection capturée`,discardConfirm:`Abandonner les annotations ?`,reselect:`Resélectionner`,createSpec:`Créer une spec`,skipContinue:`Passer et continuer`},n={header:`Page capturée · {{title}}`,badge:{elements_one:`{{count}} élément`,elements_other:`{{count}} éléments`,tokens:`tokens`,requests:`{{count}} req`,truncated:`tronqué`},removeLabel:`Retirer le contexte de la page capturée`,noMarkup:`(aucun balisage capturé)`,appliedCss:`CSS appliqué`,appliedCssTruncated:`CSS appliqué (tronqué)`,designTokens:`Design tokens`,fonts:`Polices :`,copyJson:`Copier en JSON`,copied:`Copié !`,network_one:`Réseau · {{count}} requête`,network_other:`Réseau · {{count}} requêtes`},r={connectionError:`Erreur de connexion`,lostConnection:`Connexion au navigateur perdue. Fermez puis rouvrez « Depuis un site web ».`,tooManySessions:`Trop de sessions de navigateur ouvertes. Fermez-en une et réessayez.`,launchFailed:`Le navigateur n'a pas pu démarrer sur le serveur.`,openFailed:`Impossible d'ouvrir le navigateur.`},i={modal:e,editor:t,domPanel:n,session:r};export{i as default,n as domPanel,t as editor,e as modal,r as session};
|