@researai/deepscientist 1.5.14 → 1.5.16

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.
Files changed (225) hide show
  1. package/README.md +336 -90
  2. package/assets/branding/logo-raster.png +0 -0
  3. package/bin/ds.js +816 -131
  4. package/docs/en/00_QUICK_START.md +36 -15
  5. package/docs/en/01_SETTINGS_REFERENCE.md +53 -4
  6. package/docs/en/02_START_RESEARCH_GUIDE.md +7 -0
  7. package/docs/en/03_QQ_CONNECTOR_GUIDE.md +19 -0
  8. package/docs/en/05_TUI_GUIDE.md +6 -0
  9. package/docs/en/06_RUNTIME_AND_CANVAS.md +4 -3
  10. package/docs/en/09_DOCTOR.md +11 -5
  11. package/docs/en/10_WEIXIN_CONNECTOR_GUIDE.md +20 -0
  12. package/docs/en/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +65 -13
  13. package/docs/en/15_CODEX_PROVIDER_SETUP.md +25 -8
  14. package/docs/en/16_TELEGRAM_CONNECTOR_GUIDE.md +134 -0
  15. package/docs/en/17_WHATSAPP_CONNECTOR_GUIDE.md +126 -0
  16. package/docs/en/18_FEISHU_CONNECTOR_GUIDE.md +136 -0
  17. package/docs/en/19_EXTERNAL_CONTROLLER_GUIDE.md +226 -0
  18. package/docs/en/19_LOCAL_BROWSER_AUTH.md +70 -0
  19. package/docs/en/20_WORKSPACE_MODES_GUIDE.md +250 -0
  20. package/docs/en/README.md +24 -0
  21. package/docs/zh/00_QUICK_START.md +36 -15
  22. package/docs/zh/01_SETTINGS_REFERENCE.md +53 -4
  23. package/docs/zh/02_START_RESEARCH_GUIDE.md +7 -0
  24. package/docs/zh/03_QQ_CONNECTOR_GUIDE.md +19 -0
  25. package/docs/zh/05_TUI_GUIDE.md +6 -0
  26. package/docs/zh/09_DOCTOR.md +11 -5
  27. package/docs/zh/10_WEIXIN_CONNECTOR_GUIDE.md +20 -0
  28. package/docs/zh/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +65 -13
  29. package/docs/zh/15_CODEX_PROVIDER_SETUP.md +25 -8
  30. package/docs/zh/16_TELEGRAM_CONNECTOR_GUIDE.md +134 -0
  31. package/docs/zh/17_WHATSAPP_CONNECTOR_GUIDE.md +126 -0
  32. package/docs/zh/18_FEISHU_CONNECTOR_GUIDE.md +136 -0
  33. package/docs/zh/19_EXTERNAL_CONTROLLER_GUIDE.md +226 -0
  34. package/docs/zh/19_LOCAL_BROWSER_AUTH.md +68 -0
  35. package/docs/zh/20_WORKSPACE_MODES_GUIDE.md +251 -0
  36. package/docs/zh/README.md +24 -0
  37. package/install.sh +2 -0
  38. package/package.json +1 -1
  39. package/pyproject.toml +1 -1
  40. package/src/deepscientist/__init__.py +1 -1
  41. package/src/deepscientist/acp/envelope.py +6 -0
  42. package/src/deepscientist/artifact/charts.py +567 -0
  43. package/src/deepscientist/artifact/guidance.py +50 -10
  44. package/src/deepscientist/artifact/metrics.py +228 -5
  45. package/src/deepscientist/artifact/schemas.py +3 -0
  46. package/src/deepscientist/artifact/service.py +4276 -308
  47. package/src/deepscientist/bash_exec/models.py +23 -0
  48. package/src/deepscientist/bash_exec/monitor.py +147 -67
  49. package/src/deepscientist/bash_exec/runtime.py +218 -156
  50. package/src/deepscientist/bash_exec/service.py +309 -69
  51. package/src/deepscientist/bash_exec/shells.py +87 -0
  52. package/src/deepscientist/bridges/connectors.py +51 -2
  53. package/src/deepscientist/cli.py +115 -19
  54. package/src/deepscientist/codex_cli_compat.py +232 -0
  55. package/src/deepscientist/config/models.py +8 -4
  56. package/src/deepscientist/config/service.py +38 -11
  57. package/src/deepscientist/connector/weixin_support.py +122 -1
  58. package/src/deepscientist/daemon/api/handlers.py +199 -9
  59. package/src/deepscientist/daemon/api/router.py +5 -0
  60. package/src/deepscientist/daemon/app.py +1458 -289
  61. package/src/deepscientist/doctor.py +51 -0
  62. package/src/deepscientist/file_lock.py +48 -0
  63. package/src/deepscientist/gitops/__init__.py +10 -1
  64. package/src/deepscientist/gitops/diff.py +296 -1
  65. package/src/deepscientist/gitops/service.py +4 -1
  66. package/src/deepscientist/mcp/server.py +212 -5
  67. package/src/deepscientist/process_control.py +161 -0
  68. package/src/deepscientist/prompts/builder.py +501 -453
  69. package/src/deepscientist/quest/layout.py +15 -2
  70. package/src/deepscientist/quest/service.py +2539 -195
  71. package/src/deepscientist/quest/stage_views.py +177 -1
  72. package/src/deepscientist/runners/base.py +2 -0
  73. package/src/deepscientist/runners/codex.py +169 -31
  74. package/src/deepscientist/runners/runtime_overrides.py +17 -1
  75. package/src/deepscientist/skills/__init__.py +2 -2
  76. package/src/deepscientist/skills/installer.py +196 -5
  77. package/src/deepscientist/skills/registry.py +66 -0
  78. package/src/prompts/connectors/qq.md +18 -8
  79. package/src/prompts/connectors/weixin.md +16 -6
  80. package/src/prompts/contracts/shared_interaction.md +24 -4
  81. package/src/prompts/system.md +921 -72
  82. package/src/prompts/system_copilot.md +43 -0
  83. package/src/skills/analysis-campaign/SKILL.md +32 -2
  84. package/src/skills/analysis-campaign/references/artifact-orchestration.md +1 -1
  85. package/src/skills/analysis-campaign/references/writing-facing-slice-examples.md +65 -0
  86. package/src/skills/baseline/SKILL.md +10 -0
  87. package/src/skills/decision/SKILL.md +27 -2
  88. package/src/skills/experiment/SKILL.md +16 -2
  89. package/src/skills/figure-polish/SKILL.md +1 -0
  90. package/src/skills/finalize/SKILL.md +19 -0
  91. package/src/skills/idea/SKILL.md +79 -0
  92. package/src/skills/idea/references/idea-generation-playbook.md +100 -0
  93. package/src/skills/idea/references/outline-seeding-example.md +60 -0
  94. package/src/skills/intake-audit/SKILL.md +9 -1
  95. package/src/skills/mentor/SKILL.md +217 -0
  96. package/src/skills/mentor/references/correction-rules.md +210 -0
  97. package/src/skills/mentor/references/knowledge-profile.md +91 -0
  98. package/src/skills/mentor/references/persona-profile.md +138 -0
  99. package/src/skills/mentor/references/taste-profile.md +128 -0
  100. package/src/skills/mentor/references/thought-style-profile.md +138 -0
  101. package/src/skills/mentor/references/work-profile.md +289 -0
  102. package/src/skills/mentor/references/workflow-profile.md +240 -0
  103. package/src/skills/optimize/SKILL.md +1645 -0
  104. package/src/skills/rebuttal/SKILL.md +3 -1
  105. package/src/skills/review/SKILL.md +3 -1
  106. package/src/skills/scout/SKILL.md +8 -0
  107. package/src/skills/write/SKILL.md +81 -12
  108. package/src/skills/write/references/outline-evidence-contract-example.md +107 -0
  109. package/src/tui/dist/app/AppContainer.js +22 -11
  110. package/src/tui/dist/index.js +4 -1
  111. package/src/tui/dist/lib/api.js +33 -3
  112. package/src/tui/package.json +1 -1
  113. package/src/ui/dist/assets/AiManusChatView-COFACy7V.js +204 -0
  114. package/src/ui/dist/assets/AnalysisPlugin-DnSm0GZn.js +1 -0
  115. package/src/ui/dist/assets/CliPlugin-CvwCmDQ5.js +109 -0
  116. package/src/ui/dist/assets/CodeEditorPlugin-cOqSa0xq.js +2 -0
  117. package/src/ui/dist/assets/CodeViewerPlugin-itb0tltR.js +270 -0
  118. package/src/ui/dist/assets/DocViewerPlugin-DqKkiCI6.js +7 -0
  119. package/src/ui/dist/assets/GitCommitViewerPlugin-DVgNHBCS.js +1 -0
  120. package/src/ui/dist/assets/GitDiffViewerPlugin-DxL2ezFG.js +6 -0
  121. package/src/ui/dist/assets/GitSnapshotViewer-B_RQm1YZ.js +30 -0
  122. package/src/ui/dist/assets/ImageViewerPlugin-tHqlXY3n.js +26 -0
  123. package/src/ui/dist/assets/LabCopilotPanel-ClMbq5Yu.js +14 -0
  124. package/src/ui/dist/assets/LabPlugin-L_SuE8ow.js +22 -0
  125. package/src/ui/dist/assets/LatexPlugin-B495DTXC.js +25 -0
  126. package/src/ui/dist/assets/MarkdownViewerPlugin-DG28-61B.js +128 -0
  127. package/src/ui/dist/assets/MarketplacePlugin-BiOGT-Kj.js +13 -0
  128. package/src/ui/dist/assets/{NotebookEditor-CccQYZjX.css → NotebookEditor-BHH8rdGj.css} +1 -1
  129. package/src/ui/dist/assets/NotebookEditor-BOr3x3Ej.css +1 -0
  130. package/src/ui/dist/assets/NotebookEditor-C-4Kt1p9.js +81 -0
  131. package/src/ui/dist/assets/NotebookEditor-CVsj8h_T.js +361 -0
  132. package/src/ui/dist/assets/PdfLoader-CASDQmxJ.js +16 -0
  133. package/src/ui/dist/assets/PdfLoader-Cy5jtWrr.css +1 -0
  134. package/src/ui/dist/assets/PdfMarkdownPlugin-BFhwoKsY.js +1 -0
  135. package/src/ui/dist/assets/PdfViewerPlugin-DcOzU9vd.js +17 -0
  136. package/src/ui/dist/assets/PdfViewerPlugin-nwwE-fjJ.css +1 -0
  137. package/src/ui/dist/assets/SearchPlugin-CHj7M58O.js +16 -0
  138. package/src/ui/dist/assets/SearchPlugin-DA4en4hK.css +1 -0
  139. package/src/ui/dist/assets/TextViewerPlugin-CB4DYfWO.js +54 -0
  140. package/src/ui/dist/assets/VNCViewer-CjlbyCB3.js +11 -0
  141. package/src/ui/dist/assets/bot-CFkZY-JP.js +6 -0
  142. package/src/ui/dist/assets/browser-CTB2jwNe.js +8 -0
  143. package/src/ui/dist/assets/chevron-up-Dq5ofbht.js +6 -0
  144. package/src/ui/dist/assets/code-DLC6G24T.js +6 -0
  145. package/src/ui/dist/assets/file-content-Dv4LoZec.js +1 -0
  146. package/src/ui/dist/assets/file-diff-panel-Denq-lC3.js +1 -0
  147. package/src/ui/dist/assets/file-jump-queue-DA-SdG__.js +1 -0
  148. package/src/ui/dist/assets/file-socket-Cu4Qln7Y.js +1 -0
  149. package/src/ui/dist/assets/git-commit-horizontal-BUh6G52n.js +6 -0
  150. package/src/ui/dist/assets/image-B9HUUddG.js +6 -0
  151. package/src/ui/dist/assets/index-B2B1sg-M.js +1 -0
  152. package/src/ui/dist/assets/index-Cgla8biy.css +33 -0
  153. package/src/ui/dist/assets/index-DRyx7vAc.js +1 -0
  154. package/src/ui/dist/assets/index-Gbl53BNp.js +2496 -0
  155. package/src/ui/dist/assets/index-wQ7RIIRd.js +11 -0
  156. package/src/ui/dist/assets/monaco-CiHMMNH_.js +1 -0
  157. package/src/ui/dist/assets/pdf-effect-queue-ZtnHFCAi.js +6 -0
  158. package/src/ui/dist/assets/plugin-monaco-C8UgLomw.js +19 -0
  159. package/src/ui/dist/assets/plugin-notebook-HbW2K-1c.js +169 -0
  160. package/src/ui/dist/assets/plugin-pdf-CR8hgQBV.js +357 -0
  161. package/src/ui/dist/assets/plugin-terminal-MXFIPun8.js +227 -0
  162. package/src/ui/dist/assets/popover-DL6h35vr.js +1 -0
  163. package/src/ui/dist/assets/project-sync-CsX08Qno.js +1 -0
  164. package/src/ui/dist/assets/select-DvmXt1yY.js +11 -0
  165. package/src/ui/dist/assets/sigma-7jpXazui.js +6 -0
  166. package/src/ui/dist/assets/trash-xA7kFt8i.js +11 -0
  167. package/src/ui/dist/assets/useCliAccess-DsMwDjOp.js +1 -0
  168. package/src/ui/dist/assets/useFileDiffOverlay-FuhcnKiw.js +1 -0
  169. package/src/ui/dist/assets/wrap-text-CwMn-iqb.js +11 -0
  170. package/src/ui/dist/assets/zoom-out-R-GWEhzS.js +11 -0
  171. package/src/ui/dist/index.html +5 -2
  172. package/src/ui/dist/assets/AiManusChatView-DaF9Nge_.js +0 -26597
  173. package/src/ui/dist/assets/AnalysisPlugin-BSVx6dXE.js +0 -123
  174. package/src/ui/dist/assets/CliPlugin-C9gzJX41.js +0 -5905
  175. package/src/ui/dist/assets/CodeEditorPlugin-DU9G0Tox.js +0 -427
  176. package/src/ui/dist/assets/CodeViewerPlugin-DoX_fI9l.js +0 -905
  177. package/src/ui/dist/assets/DocViewerPlugin-C4FWIXuU.js +0 -278
  178. package/src/ui/dist/assets/GitDiffViewerPlugin-BgfFMgtf.js +0 -2661
  179. package/src/ui/dist/assets/ImageViewerPlugin-tcPkfY_x.js +0 -500
  180. package/src/ui/dist/assets/LabCopilotPanel-_dKV60Bf.js +0 -4104
  181. package/src/ui/dist/assets/LabPlugin-Bje0ayoC.js +0 -2677
  182. package/src/ui/dist/assets/LatexPlugin-CVsBzAln.js +0 -1792
  183. package/src/ui/dist/assets/MarkdownViewerPlugin-xjmrqv_8.js +0 -308
  184. package/src/ui/dist/assets/MarketplacePlugin-mMM2A8wP.js +0 -413
  185. package/src/ui/dist/assets/NotebookEditor-3kVDSOBo.js +0 -4214
  186. package/src/ui/dist/assets/NotebookEditor-C3VQ7ylN.css +0 -1405
  187. package/src/ui/dist/assets/NotebookEditor-SoJ8X-MO.js +0 -84873
  188. package/src/ui/dist/assets/PdfLoader-C-Y707R3.css +0 -49
  189. package/src/ui/dist/assets/PdfLoader-DElVuHl9.js +0 -25468
  190. package/src/ui/dist/assets/PdfMarkdownPlugin-Bq88XT4G.js +0 -409
  191. package/src/ui/dist/assets/PdfViewerPlugin-CsCXMo9S.js +0 -3095
  192. package/src/ui/dist/assets/PdfViewerPlugin-DQ11QcSf.css +0 -3627
  193. package/src/ui/dist/assets/SearchPlugin-DDMrGDkh.css +0 -379
  194. package/src/ui/dist/assets/SearchPlugin-oUPvy19k.js +0 -741
  195. package/src/ui/dist/assets/TextViewerPlugin-CRkT9yNy.js +0 -472
  196. package/src/ui/dist/assets/VNCViewer-BgbuvWhR.js +0 -18821
  197. package/src/ui/dist/assets/awareness-C0NPR2Dj.js +0 -292
  198. package/src/ui/dist/assets/bot-v_RASACv.js +0 -21
  199. package/src/ui/dist/assets/browser-BAcuE0Xj.js +0 -2895
  200. package/src/ui/dist/assets/code-5hC9d0VH.js +0 -17
  201. package/src/ui/dist/assets/file-content-D1PxfOrp.js +0 -377
  202. package/src/ui/dist/assets/file-diff-panel-DG1oT_Hj.js +0 -92
  203. package/src/ui/dist/assets/file-jump-queue-r5XKgJEV.js +0 -16
  204. package/src/ui/dist/assets/file-socket-BmdFYQlk.js +0 -58
  205. package/src/ui/dist/assets/function-B5QZkkHC.js +0 -1895
  206. package/src/ui/dist/assets/image-Dqe2X2tW.js +0 -18
  207. package/src/ui/dist/assets/index-BQG-1s2o.css +0 -12553
  208. package/src/ui/dist/assets/index-DVsMKK_y.js +0 -25
  209. package/src/ui/dist/assets/index-Duvz8Ip0.js +0 -159
  210. package/src/ui/dist/assets/index-Nt9hS4ck.js +0 -244829
  211. package/src/ui/dist/assets/index-RDlNXXx1.js +0 -120
  212. package/src/ui/dist/assets/monaco-DIXge1CP.js +0 -623
  213. package/src/ui/dist/assets/pdf-effect-queue-BBTTQaO-.js +0 -47
  214. package/src/ui/dist/assets/pdf_viewer-e0g1is2C.js +0 -8206
  215. package/src/ui/dist/assets/popover-BWlolyxo.js +0 -476
  216. package/src/ui/dist/assets/project-sync-BM5PkFH4.js +0 -297
  217. package/src/ui/dist/assets/select-D4dAtrA8.js +0 -1690
  218. package/src/ui/dist/assets/sigma-CKbE5jJT.js +0 -22
  219. package/src/ui/dist/assets/square-check-big-CZNGMgiB.js +0 -17
  220. package/src/ui/dist/assets/trash-DaB37xAz.js +0 -32
  221. package/src/ui/dist/assets/useCliAccess-C2OmAcWe.js +0 -957
  222. package/src/ui/dist/assets/useFileDiffOverlay-Dowd1Ij4.js +0 -53
  223. package/src/ui/dist/assets/wrap-text-BGjAhAUq.js +0 -35
  224. package/src/ui/dist/assets/yjs-DncrqiZ8.js +0 -11243
  225. package/src/ui/dist/assets/zoom-out-dMZQMXzc.js +0 -34
@@ -1,476 +0,0 @@
1
- import { r as reactExports, j as jsxRuntimeExports, aj as composeRefs, ak as useControllableState, al as Root2$1, am as useId, an as useComposedRefs, ao as composeEventHandlers, ap as Anchor, aq as createPopperScope, ar as Presence, as as Portal$1, at as hideOthers, au as ReactRemoveScroll, av as useFocusGuards, aw as FocusScope, ax as DismissableLayer, ay as Content, az as Arrow, b as cn } from './index-Nt9hS4ck.js';
2
-
3
- // packages/react/context/src/create-context.tsx
4
- function createContextScope(scopeName, createContextScopeDeps = []) {
5
- let defaultContexts = [];
6
- function createContext3(rootComponentName, defaultContext) {
7
- const BaseContext = reactExports.createContext(defaultContext);
8
- const index = defaultContexts.length;
9
- defaultContexts = [...defaultContexts, defaultContext];
10
- const Provider = (props) => {
11
- const { scope, children, ...context } = props;
12
- const Context = scope?.[scopeName]?.[index] || BaseContext;
13
- const value = reactExports.useMemo(() => context, Object.values(context));
14
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Context.Provider, { value, children });
15
- };
16
- Provider.displayName = rootComponentName + "Provider";
17
- function useContext2(consumerName, scope) {
18
- const Context = scope?.[scopeName]?.[index] || BaseContext;
19
- const context = reactExports.useContext(Context);
20
- if (context) return context;
21
- if (defaultContext !== void 0) return defaultContext;
22
- throw new Error(`\`${consumerName}\` must be used within \`${rootComponentName}\``);
23
- }
24
- return [Provider, useContext2];
25
- }
26
- const createScope = () => {
27
- const scopeContexts = defaultContexts.map((defaultContext) => {
28
- return reactExports.createContext(defaultContext);
29
- });
30
- return function useScope(scope) {
31
- const contexts = scope?.[scopeName] || scopeContexts;
32
- return reactExports.useMemo(
33
- () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),
34
- [scope, contexts]
35
- );
36
- };
37
- };
38
- createScope.scopeName = scopeName;
39
- return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];
40
- }
41
- function composeContextScopes(...scopes) {
42
- const baseScope = scopes[0];
43
- if (scopes.length === 1) return baseScope;
44
- const createScope = () => {
45
- const scopeHooks = scopes.map((createScope2) => ({
46
- useScope: createScope2(),
47
- scopeName: createScope2.scopeName
48
- }));
49
- return function useComposedScopes(overrideScopes) {
50
- const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {
51
- const scopeProps = useScope(overrideScopes);
52
- const currentScope = scopeProps[`__scope${scopeName}`];
53
- return { ...nextScopes2, ...currentScope };
54
- }, {});
55
- return reactExports.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);
56
- };
57
- };
58
- createScope.scopeName = baseScope.scopeName;
59
- return createScope;
60
- }
61
-
62
- // src/slot.tsx
63
- // @__NO_SIDE_EFFECTS__
64
- function createSlot(ownerName) {
65
- const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);
66
- const Slot2 = reactExports.forwardRef((props, forwardedRef) => {
67
- const { children, ...slotProps } = props;
68
- const childrenArray = reactExports.Children.toArray(children);
69
- const slottable = childrenArray.find(isSlottable);
70
- if (slottable) {
71
- const newElement = slottable.props.children;
72
- const newChildren = childrenArray.map((child) => {
73
- if (child === slottable) {
74
- if (reactExports.Children.count(newElement) > 1) return reactExports.Children.only(null);
75
- return reactExports.isValidElement(newElement) ? newElement.props.children : null;
76
- } else {
77
- return child;
78
- }
79
- });
80
- return /* @__PURE__ */ jsxRuntimeExports.jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: reactExports.isValidElement(newElement) ? reactExports.cloneElement(newElement, void 0, newChildren) : null });
81
- }
82
- return /* @__PURE__ */ jsxRuntimeExports.jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });
83
- });
84
- Slot2.displayName = `${ownerName}.Slot`;
85
- return Slot2;
86
- }
87
- // @__NO_SIDE_EFFECTS__
88
- function createSlotClone(ownerName) {
89
- const SlotClone = reactExports.forwardRef((props, forwardedRef) => {
90
- const { children, ...slotProps } = props;
91
- if (reactExports.isValidElement(children)) {
92
- const childrenRef = getElementRef(children);
93
- const props2 = mergeProps(slotProps, children.props);
94
- if (children.type !== reactExports.Fragment) {
95
- props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;
96
- }
97
- return reactExports.cloneElement(children, props2);
98
- }
99
- return reactExports.Children.count(children) > 1 ? reactExports.Children.only(null) : null;
100
- });
101
- SlotClone.displayName = `${ownerName}.SlotClone`;
102
- return SlotClone;
103
- }
104
- var SLOTTABLE_IDENTIFIER = Symbol("radix.slottable");
105
- function isSlottable(child) {
106
- return reactExports.isValidElement(child) && typeof child.type === "function" && "__radixId" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;
107
- }
108
- function mergeProps(slotProps, childProps) {
109
- const overrideProps = { ...childProps };
110
- for (const propName in childProps) {
111
- const slotPropValue = slotProps[propName];
112
- const childPropValue = childProps[propName];
113
- const isHandler = /^on[A-Z]/.test(propName);
114
- if (isHandler) {
115
- if (slotPropValue && childPropValue) {
116
- overrideProps[propName] = (...args) => {
117
- const result = childPropValue(...args);
118
- slotPropValue(...args);
119
- return result;
120
- };
121
- } else if (slotPropValue) {
122
- overrideProps[propName] = slotPropValue;
123
- }
124
- } else if (propName === "style") {
125
- overrideProps[propName] = { ...slotPropValue, ...childPropValue };
126
- } else if (propName === "className") {
127
- overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(" ");
128
- }
129
- }
130
- return { ...slotProps, ...overrideProps };
131
- }
132
- function getElementRef(element) {
133
- let getter = Object.getOwnPropertyDescriptor(element.props, "ref")?.get;
134
- let mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
135
- if (mayWarn) {
136
- return element.ref;
137
- }
138
- getter = Object.getOwnPropertyDescriptor(element, "ref")?.get;
139
- mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
140
- if (mayWarn) {
141
- return element.props.ref;
142
- }
143
- return element.props.ref || element.ref;
144
- }
145
-
146
- // src/primitive.tsx
147
- var NODES = [
148
- "a",
149
- "button",
150
- "div",
151
- "form",
152
- "h2",
153
- "h3",
154
- "img",
155
- "input",
156
- "label",
157
- "li",
158
- "nav",
159
- "ol",
160
- "p",
161
- "select",
162
- "span",
163
- "svg",
164
- "ul"
165
- ];
166
- var Primitive = NODES.reduce((primitive, node) => {
167
- const Slot = createSlot(`Primitive.${node}`);
168
- const Node = reactExports.forwardRef((props, forwardedRef) => {
169
- const { asChild, ...primitiveProps } = props;
170
- const Comp = asChild ? Slot : node;
171
- if (typeof window !== "undefined") {
172
- window[Symbol.for("radix-ui")] = true;
173
- }
174
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Comp, { ...primitiveProps, ref: forwardedRef });
175
- });
176
- Node.displayName = `Primitive.${node}`;
177
- return { ...primitive, [node]: Node };
178
- }, {});
179
-
180
- var POPOVER_NAME = "Popover";
181
- var [createPopoverContext] = createContextScope(POPOVER_NAME, [
182
- createPopperScope
183
- ]);
184
- var usePopperScope = createPopperScope();
185
- var [PopoverProvider, usePopoverContext] = createPopoverContext(POPOVER_NAME);
186
- var Popover$1 = (props) => {
187
- const {
188
- __scopePopover,
189
- children,
190
- open: openProp,
191
- defaultOpen,
192
- onOpenChange,
193
- modal = false
194
- } = props;
195
- const popperScope = usePopperScope(__scopePopover);
196
- const triggerRef = reactExports.useRef(null);
197
- const [hasCustomAnchor, setHasCustomAnchor] = reactExports.useState(false);
198
- const [open, setOpen] = useControllableState({
199
- prop: openProp,
200
- defaultProp: defaultOpen ?? false,
201
- onChange: onOpenChange,
202
- caller: POPOVER_NAME
203
- });
204
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Root2$1, { ...popperScope, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
205
- PopoverProvider,
206
- {
207
- scope: __scopePopover,
208
- contentId: useId(),
209
- triggerRef,
210
- open,
211
- onOpenChange: setOpen,
212
- onOpenToggle: reactExports.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),
213
- hasCustomAnchor,
214
- onCustomAnchorAdd: reactExports.useCallback(() => setHasCustomAnchor(true), []),
215
- onCustomAnchorRemove: reactExports.useCallback(() => setHasCustomAnchor(false), []),
216
- modal,
217
- children
218
- }
219
- ) });
220
- };
221
- Popover$1.displayName = POPOVER_NAME;
222
- var ANCHOR_NAME = "PopoverAnchor";
223
- var PopoverAnchor = reactExports.forwardRef(
224
- (props, forwardedRef) => {
225
- const { __scopePopover, ...anchorProps } = props;
226
- const context = usePopoverContext(ANCHOR_NAME, __scopePopover);
227
- const popperScope = usePopperScope(__scopePopover);
228
- const { onCustomAnchorAdd, onCustomAnchorRemove } = context;
229
- reactExports.useEffect(() => {
230
- onCustomAnchorAdd();
231
- return () => onCustomAnchorRemove();
232
- }, [onCustomAnchorAdd, onCustomAnchorRemove]);
233
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Anchor, { ...popperScope, ...anchorProps, ref: forwardedRef });
234
- }
235
- );
236
- PopoverAnchor.displayName = ANCHOR_NAME;
237
- var TRIGGER_NAME = "PopoverTrigger";
238
- var PopoverTrigger$1 = reactExports.forwardRef(
239
- (props, forwardedRef) => {
240
- const { __scopePopover, ...triggerProps } = props;
241
- const context = usePopoverContext(TRIGGER_NAME, __scopePopover);
242
- const popperScope = usePopperScope(__scopePopover);
243
- const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);
244
- const trigger = /* @__PURE__ */ jsxRuntimeExports.jsx(
245
- Primitive.button,
246
- {
247
- type: "button",
248
- "aria-haspopup": "dialog",
249
- "aria-expanded": context.open,
250
- "aria-controls": context.contentId,
251
- "data-state": getState(context.open),
252
- ...triggerProps,
253
- ref: composedTriggerRef,
254
- onClick: composeEventHandlers(props.onClick, context.onOpenToggle)
255
- }
256
- );
257
- return context.hasCustomAnchor ? trigger : /* @__PURE__ */ jsxRuntimeExports.jsx(Anchor, { asChild: true, ...popperScope, children: trigger });
258
- }
259
- );
260
- PopoverTrigger$1.displayName = TRIGGER_NAME;
261
- var PORTAL_NAME = "PopoverPortal";
262
- var [PortalProvider, usePortalContext] = createPopoverContext(PORTAL_NAME, {
263
- forceMount: void 0
264
- });
265
- var PopoverPortal = (props) => {
266
- const { __scopePopover, forceMount, children, container } = props;
267
- const context = usePopoverContext(PORTAL_NAME, __scopePopover);
268
- return /* @__PURE__ */ jsxRuntimeExports.jsx(PortalProvider, { scope: __scopePopover, forceMount, children: /* @__PURE__ */ jsxRuntimeExports.jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsxRuntimeExports.jsx(Portal$1, { asChild: true, container, children }) }) });
269
- };
270
- PopoverPortal.displayName = PORTAL_NAME;
271
- var CONTENT_NAME = "PopoverContent";
272
- var PopoverContent$1 = reactExports.forwardRef(
273
- (props, forwardedRef) => {
274
- const portalContext = usePortalContext(CONTENT_NAME, props.__scopePopover);
275
- const { forceMount = portalContext.forceMount, ...contentProps } = props;
276
- const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);
277
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Presence, { present: forceMount || context.open, children: context.modal ? /* @__PURE__ */ jsxRuntimeExports.jsx(PopoverContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsxRuntimeExports.jsx(PopoverContentNonModal, { ...contentProps, ref: forwardedRef }) });
278
- }
279
- );
280
- PopoverContent$1.displayName = CONTENT_NAME;
281
- var Slot = createSlot("PopoverContent.RemoveScroll");
282
- var PopoverContentModal = reactExports.forwardRef(
283
- (props, forwardedRef) => {
284
- const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);
285
- const contentRef = reactExports.useRef(null);
286
- const composedRefs = useComposedRefs(forwardedRef, contentRef);
287
- const isRightClickOutsideRef = reactExports.useRef(false);
288
- reactExports.useEffect(() => {
289
- const content = contentRef.current;
290
- if (content) return hideOthers(content);
291
- }, []);
292
- return /* @__PURE__ */ jsxRuntimeExports.jsx(ReactRemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
293
- PopoverContentImpl,
294
- {
295
- ...props,
296
- ref: composedRefs,
297
- trapFocus: context.open,
298
- disableOutsidePointerEvents: true,
299
- onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {
300
- event.preventDefault();
301
- if (!isRightClickOutsideRef.current) context.triggerRef.current?.focus();
302
- }),
303
- onPointerDownOutside: composeEventHandlers(
304
- props.onPointerDownOutside,
305
- (event) => {
306
- const originalEvent = event.detail.originalEvent;
307
- const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;
308
- const isRightClick = originalEvent.button === 2 || ctrlLeftClick;
309
- isRightClickOutsideRef.current = isRightClick;
310
- },
311
- { checkForDefaultPrevented: false }
312
- ),
313
- onFocusOutside: composeEventHandlers(
314
- props.onFocusOutside,
315
- (event) => event.preventDefault(),
316
- { checkForDefaultPrevented: false }
317
- )
318
- }
319
- ) });
320
- }
321
- );
322
- var PopoverContentNonModal = reactExports.forwardRef(
323
- (props, forwardedRef) => {
324
- const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);
325
- const hasInteractedOutsideRef = reactExports.useRef(false);
326
- const hasPointerDownOutsideRef = reactExports.useRef(false);
327
- return /* @__PURE__ */ jsxRuntimeExports.jsx(
328
- PopoverContentImpl,
329
- {
330
- ...props,
331
- ref: forwardedRef,
332
- trapFocus: false,
333
- disableOutsidePointerEvents: false,
334
- onCloseAutoFocus: (event) => {
335
- props.onCloseAutoFocus?.(event);
336
- if (!event.defaultPrevented) {
337
- if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();
338
- event.preventDefault();
339
- }
340
- hasInteractedOutsideRef.current = false;
341
- hasPointerDownOutsideRef.current = false;
342
- },
343
- onInteractOutside: (event) => {
344
- props.onInteractOutside?.(event);
345
- if (!event.defaultPrevented) {
346
- hasInteractedOutsideRef.current = true;
347
- if (event.detail.originalEvent.type === "pointerdown") {
348
- hasPointerDownOutsideRef.current = true;
349
- }
350
- }
351
- const target = event.target;
352
- const targetIsTrigger = context.triggerRef.current?.contains(target);
353
- if (targetIsTrigger) event.preventDefault();
354
- if (event.detail.originalEvent.type === "focusin" && hasPointerDownOutsideRef.current) {
355
- event.preventDefault();
356
- }
357
- }
358
- }
359
- );
360
- }
361
- );
362
- var PopoverContentImpl = reactExports.forwardRef(
363
- (props, forwardedRef) => {
364
- const {
365
- __scopePopover,
366
- trapFocus,
367
- onOpenAutoFocus,
368
- onCloseAutoFocus,
369
- disableOutsidePointerEvents,
370
- onEscapeKeyDown,
371
- onPointerDownOutside,
372
- onFocusOutside,
373
- onInteractOutside,
374
- ...contentProps
375
- } = props;
376
- const context = usePopoverContext(CONTENT_NAME, __scopePopover);
377
- const popperScope = usePopperScope(__scopePopover);
378
- useFocusGuards();
379
- return /* @__PURE__ */ jsxRuntimeExports.jsx(
380
- FocusScope,
381
- {
382
- asChild: true,
383
- loop: true,
384
- trapped: trapFocus,
385
- onMountAutoFocus: onOpenAutoFocus,
386
- onUnmountAutoFocus: onCloseAutoFocus,
387
- children: /* @__PURE__ */ jsxRuntimeExports.jsx(
388
- DismissableLayer,
389
- {
390
- asChild: true,
391
- disableOutsidePointerEvents,
392
- onInteractOutside,
393
- onEscapeKeyDown,
394
- onPointerDownOutside,
395
- onFocusOutside,
396
- onDismiss: () => context.onOpenChange(false),
397
- children: /* @__PURE__ */ jsxRuntimeExports.jsx(
398
- Content,
399
- {
400
- "data-state": getState(context.open),
401
- role: "dialog",
402
- id: context.contentId,
403
- ...popperScope,
404
- ...contentProps,
405
- ref: forwardedRef,
406
- style: {
407
- ...contentProps.style,
408
- // re-namespace exposed content custom properties
409
- ...{
410
- "--radix-popover-content-transform-origin": "var(--radix-popper-transform-origin)",
411
- "--radix-popover-content-available-width": "var(--radix-popper-available-width)",
412
- "--radix-popover-content-available-height": "var(--radix-popper-available-height)",
413
- "--radix-popover-trigger-width": "var(--radix-popper-anchor-width)",
414
- "--radix-popover-trigger-height": "var(--radix-popper-anchor-height)"
415
- }
416
- }
417
- }
418
- )
419
- }
420
- )
421
- }
422
- );
423
- }
424
- );
425
- var CLOSE_NAME = "PopoverClose";
426
- var PopoverClose = reactExports.forwardRef(
427
- (props, forwardedRef) => {
428
- const { __scopePopover, ...closeProps } = props;
429
- const context = usePopoverContext(CLOSE_NAME, __scopePopover);
430
- return /* @__PURE__ */ jsxRuntimeExports.jsx(
431
- Primitive.button,
432
- {
433
- type: "button",
434
- ...closeProps,
435
- ref: forwardedRef,
436
- onClick: composeEventHandlers(props.onClick, () => context.onOpenChange(false))
437
- }
438
- );
439
- }
440
- );
441
- PopoverClose.displayName = CLOSE_NAME;
442
- var ARROW_NAME = "PopoverArrow";
443
- var PopoverArrow = reactExports.forwardRef(
444
- (props, forwardedRef) => {
445
- const { __scopePopover, ...arrowProps } = props;
446
- const popperScope = usePopperScope(__scopePopover);
447
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });
448
- }
449
- );
450
- PopoverArrow.displayName = ARROW_NAME;
451
- function getState(open) {
452
- return open ? "open" : "closed";
453
- }
454
- var Root2 = Popover$1;
455
- var Trigger = PopoverTrigger$1;
456
- var Portal = PopoverPortal;
457
- var Content2 = PopoverContent$1;
458
-
459
- const Popover = Root2;
460
- const PopoverTrigger = Trigger;
461
- const PopoverContent = reactExports.forwardRef(({ className, align = "center", sideOffset = 4, ...props }, ref) => /* @__PURE__ */ jsxRuntimeExports.jsx(Portal, { children: /* @__PURE__ */ jsxRuntimeExports.jsx(
462
- Content2,
463
- {
464
- ref,
465
- align,
466
- sideOffset,
467
- className: cn(
468
- "z-[10002] w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
469
- className
470
- ),
471
- ...props
472
- }
473
- ) }));
474
- PopoverContent.displayName = Content2.displayName;
475
-
476
- export { Popover as P, PopoverTrigger as a, PopoverContent as b };