@peers-app/peers-ui 0.0.14

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 (404) hide show
  1. package/.github/README.md +52 -0
  2. package/.github/workflows/publish.yml +45 -0
  3. package/babel.config.js +7 -0
  4. package/dist/app.d.ts +9 -0
  5. package/dist/app.js +54 -0
  6. package/dist/command-palette/command-palette-ui.d.ts +2 -0
  7. package/dist/command-palette/command-palette-ui.js +192 -0
  8. package/dist/command-palette/command-palette.d.ts +23 -0
  9. package/dist/command-palette/command-palette.js +371 -0
  10. package/dist/components/checkbox.d.ts +7 -0
  11. package/dist/components/checkbox.js +20 -0
  12. package/dist/components/group-switcher.d.ts +6 -0
  13. package/dist/components/group-switcher.js +301 -0
  14. package/dist/components/input-date.d.ts +7 -0
  15. package/dist/components/input-date.js +19 -0
  16. package/dist/components/input-datetime.d.ts +7 -0
  17. package/dist/components/input-datetime.js +35 -0
  18. package/dist/components/input-number.d.ts +9 -0
  19. package/dist/components/input-number.js +87 -0
  20. package/dist/components/input.d.ts +7 -0
  21. package/dist/components/input.js +20 -0
  22. package/dist/components/io-schema-values.d.ts +15 -0
  23. package/dist/components/io-schema-values.js +105 -0
  24. package/dist/components/io-schema.d.ts +13 -0
  25. package/dist/components/io-schema.js +163 -0
  26. package/dist/components/lazy-list.d.ts +13 -0
  27. package/dist/components/lazy-list.js +91 -0
  28. package/dist/components/lazy-sortable-list.d.ts +29 -0
  29. package/dist/components/lazy-sortable-list.js +12 -0
  30. package/dist/components/left-bar.d.ts +3 -0
  31. package/dist/components/left-bar.js +130 -0
  32. package/dist/components/list-screen.d.ts +16 -0
  33. package/dist/components/list-screen.js +100 -0
  34. package/dist/components/loading-indicator.d.ts +2 -0
  35. package/dist/components/loading-indicator.js +12 -0
  36. package/dist/components/main-content-container.d.ts +2 -0
  37. package/dist/components/main-content-container.js +90 -0
  38. package/dist/components/markdown-editor/autolink-plugin.d.ts +2 -0
  39. package/dist/components/markdown-editor/autolink-plugin.js +29 -0
  40. package/dist/components/markdown-editor/editor-inline.d.ts +3 -0
  41. package/dist/components/markdown-editor/editor-inline.js +13 -0
  42. package/dist/components/markdown-editor/editor.d.ts +18 -0
  43. package/dist/components/markdown-editor/editor.js +143 -0
  44. package/dist/components/markdown-editor/markdown-plugin.d.ts +9 -0
  45. package/dist/components/markdown-editor/markdown-plugin.js +194 -0
  46. package/dist/components/markdown-editor/mention-node.d.ts +21 -0
  47. package/dist/components/markdown-editor/mention-node.js +160 -0
  48. package/dist/components/markdown-editor/mentions-plugin.d.ts +7 -0
  49. package/dist/components/markdown-editor/mentions-plugin.js +268 -0
  50. package/dist/components/markdown-editor/theme.d.ts +46 -0
  51. package/dist/components/markdown-editor/theme.js +48 -0
  52. package/dist/components/markdown-editor/toolbar.d.ts +10 -0
  53. package/dist/components/markdown-editor/toolbar.js +112 -0
  54. package/dist/components/markdown-with-mentions.d.ts +4 -0
  55. package/dist/components/markdown-with-mentions.js +140 -0
  56. package/dist/components/message-logs/message-logs.d.ts +6 -0
  57. package/dist/components/message-logs/message-logs.js +307 -0
  58. package/dist/components/messages/avatar.d.ts +10 -0
  59. package/dist/components/messages/avatar.js +65 -0
  60. package/dist/components/messages/channel-message-list.d.ts +14 -0
  61. package/dist/components/messages/channel-message-list.js +158 -0
  62. package/dist/components/messages/channel-view.d.ts +6 -0
  63. package/dist/components/messages/channel-view.js +82 -0
  64. package/dist/components/messages/message-compose.d.ts +11 -0
  65. package/dist/components/messages/message-compose.js +152 -0
  66. package/dist/components/messages/message-display.d.ts +10 -0
  67. package/dist/components/messages/message-display.js +152 -0
  68. package/dist/components/messages/thread-message-list.d.ts +11 -0
  69. package/dist/components/messages/thread-message-list.js +122 -0
  70. package/dist/components/messages/thread-view.d.ts +6 -0
  71. package/dist/components/messages/thread-view.js +174 -0
  72. package/dist/components/off-canvas.d.ts +13 -0
  73. package/dist/components/off-canvas.js +89 -0
  74. package/dist/components/router.d.ts +6 -0
  75. package/dist/components/router.js +240 -0
  76. package/dist/components/save-button.d.ts +13 -0
  77. package/dist/components/save-button.js +75 -0
  78. package/dist/components/sortable-list.d.ts +36 -0
  79. package/dist/components/sortable-list.js +77 -0
  80. package/dist/components/tabs.d.ts +11 -0
  81. package/dist/components/tabs.js +69 -0
  82. package/dist/components/text-list-editor.tsx/text-list-editor.d.ts +6 -0
  83. package/dist/components/text-list-editor.tsx/text-list-editor.js +13 -0
  84. package/dist/components/tooltip.d.ts +11 -0
  85. package/dist/components/tooltip.js +20 -0
  86. package/dist/components/top-bar.d.ts +2 -0
  87. package/dist/components/top-bar.js +51 -0
  88. package/dist/components/typeahead/mentions-plugin.d.ts +7 -0
  89. package/dist/components/typeahead/mentions-plugin.js +203 -0
  90. package/dist/components/typeahead/typeahead-editor.d.ts +15 -0
  91. package/dist/components/typeahead/typeahead-editor.js +134 -0
  92. package/dist/components/typeahead/typeahead.d.ts +12 -0
  93. package/dist/components/typeahead/typeahead.js +94 -0
  94. package/dist/components/typeahead.d.ts +22 -0
  95. package/dist/components/typeahead.js +270 -0
  96. package/dist/globals.d.ts +29 -0
  97. package/dist/globals.js +148 -0
  98. package/dist/hooks.d.ts +34 -0
  99. package/dist/hooks.js +137 -0
  100. package/dist/index.d.ts +4 -0
  101. package/dist/index.js +20 -0
  102. package/dist/layout-vars.d.ts +6 -0
  103. package/dist/layout-vars.js +10 -0
  104. package/dist/mention-configs.d.ts +18 -0
  105. package/dist/mention-configs.js +149 -0
  106. package/dist/screens/assistants/assistant-config.d.ts +5 -0
  107. package/dist/screens/assistants/assistant-config.js +52 -0
  108. package/dist/screens/assistants/assistant-details.d.ts +4 -0
  109. package/dist/screens/assistants/assistant-details.js +85 -0
  110. package/dist/screens/assistants/assistant-info.d.ts +6 -0
  111. package/dist/screens/assistants/assistant-info.js +28 -0
  112. package/dist/screens/assistants/assistant-list.d.ts +2 -0
  113. package/dist/screens/assistants/assistant-list.js +114 -0
  114. package/dist/screens/assistants/assistant-tools.d.ts +5 -0
  115. package/dist/screens/assistants/assistant-tools.js +38 -0
  116. package/dist/screens/contacts/contact-details.d.ts +6 -0
  117. package/dist/screens/contacts/contact-details.js +100 -0
  118. package/dist/screens/contacts/contact-list.d.ts +2 -0
  119. package/dist/screens/contacts/contact-list.js +213 -0
  120. package/dist/screens/contacts/index.d.ts +4 -0
  121. package/dist/screens/contacts/index.js +21 -0
  122. package/dist/screens/events/cron.d.ts +3 -0
  123. package/dist/screens/events/cron.js +77 -0
  124. package/dist/screens/events/event-details.d.ts +6 -0
  125. package/dist/screens/events/event-details.js +112 -0
  126. package/dist/screens/events/event-handlers.d.ts +7 -0
  127. package/dist/screens/events/event-handlers.js +84 -0
  128. package/dist/screens/events/event-info.d.ts +5 -0
  129. package/dist/screens/events/event-info.js +19 -0
  130. package/dist/screens/events/event-list.d.ts +2 -0
  131. package/dist/screens/events/event-list.js +107 -0
  132. package/dist/screens/events/event-schedule.d.ts +5 -0
  133. package/dist/screens/events/event-schedule.js +124 -0
  134. package/dist/screens/groups/group-details.d.ts +6 -0
  135. package/dist/screens/groups/group-details.js +218 -0
  136. package/dist/screens/groups/group-list.d.ts +2 -0
  137. package/dist/screens/groups/group-list.js +275 -0
  138. package/dist/screens/groups/group-members.d.ts +8 -0
  139. package/dist/screens/groups/group-members.js +315 -0
  140. package/dist/screens/groups/index.d.ts +6 -0
  141. package/dist/screens/groups/index.js +23 -0
  142. package/dist/screens/knowledge/knowledge-frame-details.bk.d.ts +6 -0
  143. package/dist/screens/knowledge/knowledge-frame-details.bk.js +84 -0
  144. package/dist/screens/knowledge/knowledge-frame-details.d.ts +8 -0
  145. package/dist/screens/knowledge/knowledge-frame-details.js +143 -0
  146. package/dist/screens/knowledge/knowledge-frame-list.d.ts +2 -0
  147. package/dist/screens/knowledge/knowledge-frame-list.js +45 -0
  148. package/dist/screens/knowledge/knowledge-value-details.d.ts +6 -0
  149. package/dist/screens/knowledge/knowledge-value-details.js +150 -0
  150. package/dist/screens/knowledge/knowledge-value-list-item.d.ts +5 -0
  151. package/dist/screens/knowledge/knowledge-value-list-item.js +39 -0
  152. package/dist/screens/knowledge/knowledge-value-list.d.ts +3 -0
  153. package/dist/screens/knowledge/knowledge-value-list.js +123 -0
  154. package/dist/screens/packages/package-details.d.ts +6 -0
  155. package/dist/screens/packages/package-details.js +82 -0
  156. package/dist/screens/packages/package-info.d.ts +5 -0
  157. package/dist/screens/packages/package-info.js +42 -0
  158. package/dist/screens/packages/package-list.d.ts +2 -0
  159. package/dist/screens/packages/package-list.js +182 -0
  160. package/dist/screens/packages/package-new-local.d.ts +2 -0
  161. package/dist/screens/packages/package-new-local.js +82 -0
  162. package/dist/screens/peer-types/peer-type-details.d.ts +10 -0
  163. package/dist/screens/peer-types/peer-type-details.js +126 -0
  164. package/dist/screens/peer-types/peer-type-list.d.ts +2 -0
  165. package/dist/screens/peer-types/peer-type-list.js +57 -0
  166. package/dist/screens/predicates/predicate-details.d.ts +6 -0
  167. package/dist/screens/predicates/predicate-details.js +103 -0
  168. package/dist/screens/predicates/predicate-list.d.ts +2 -0
  169. package/dist/screens/predicates/predicate-list.js +46 -0
  170. package/dist/screens/profile.d.ts +2 -0
  171. package/dist/screens/profile.js +66 -0
  172. package/dist/screens/search/global-search.d.ts +2 -0
  173. package/dist/screens/search/global-search.js +186 -0
  174. package/dist/screens/settings/color-mode-dropdown.d.ts +6 -0
  175. package/dist/screens/settings/color-mode-dropdown.js +63 -0
  176. package/dist/screens/settings/settings-page.d.ts +2 -0
  177. package/dist/screens/settings/settings-page.js +49 -0
  178. package/dist/screens/setup-user.d.ts +2 -0
  179. package/dist/screens/setup-user.js +270 -0
  180. package/dist/screens/tools/tool-code.d.ts +5 -0
  181. package/dist/screens/tools/tool-code.js +32 -0
  182. package/dist/screens/tools/tool-details.d.ts +6 -0
  183. package/dist/screens/tools/tool-details.js +68 -0
  184. package/dist/screens/tools/tool-info.d.ts +5 -0
  185. package/dist/screens/tools/tool-info.js +74 -0
  186. package/dist/screens/tools/tool-list.d.ts +2 -0
  187. package/dist/screens/tools/tool-list.js +123 -0
  188. package/dist/screens/tools/tool-schema.d.ts +5 -0
  189. package/dist/screens/tools/tool-schema.js +30 -0
  190. package/dist/screens/tools/tool-test-details.d.ts +4 -0
  191. package/dist/screens/tools/tool-test-details.js +54 -0
  192. package/dist/screens/tools/tool-test-list.d.ts +4 -0
  193. package/dist/screens/tools/tool-test-list.js +82 -0
  194. package/dist/screens/variables/variable-details.d.ts +6 -0
  195. package/dist/screens/variables/variable-details.js +140 -0
  196. package/dist/screens/variables/variable-list.d.ts +2 -0
  197. package/dist/screens/variables/variable-list.js +58 -0
  198. package/dist/screens/workflows/workflow-details.d.ts +6 -0
  199. package/dist/screens/workflows/workflow-details.js +122 -0
  200. package/dist/screens/workflows/workflow-info.d.ts +5 -0
  201. package/dist/screens/workflows/workflow-info.js +18 -0
  202. package/dist/screens/workflows/workflow-instructions.d.ts +5 -0
  203. package/dist/screens/workflows/workflow-instructions.js +118 -0
  204. package/dist/screens/workflows/workflow-list.d.ts +2 -0
  205. package/dist/screens/workflows/workflow-list.js +109 -0
  206. package/dist/screens/workflows/workflow-subscriptions.d.ts +6 -0
  207. package/dist/screens/workflows/workflow-subscriptions.js +81 -0
  208. package/dist/setupTests.d.ts +1 -0
  209. package/dist/setupTests.js +31 -0
  210. package/dist/system-apps/assistants.app.d.ts +2 -0
  211. package/dist/system-apps/assistants.app.js +8 -0
  212. package/dist/system-apps/contacts.app.d.ts +2 -0
  213. package/dist/system-apps/contacts.app.js +9 -0
  214. package/dist/system-apps/events.app.d.ts +2 -0
  215. package/dist/system-apps/events.app.js +8 -0
  216. package/dist/system-apps/groups.app.d.ts +2 -0
  217. package/dist/system-apps/groups.app.js +9 -0
  218. package/dist/system-apps/index.d.ts +19 -0
  219. package/dist/system-apps/index.js +90 -0
  220. package/dist/system-apps/knowledge-frames.app.d.ts +2 -0
  221. package/dist/system-apps/knowledge-frames.app.js +9 -0
  222. package/dist/system-apps/knowledge-values.app.d.ts +2 -0
  223. package/dist/system-apps/knowledge-values.app.js +9 -0
  224. package/dist/system-apps/packages.app.d.ts +2 -0
  225. package/dist/system-apps/packages.app.js +8 -0
  226. package/dist/system-apps/predicates.app.d.ts +2 -0
  227. package/dist/system-apps/predicates.app.js +8 -0
  228. package/dist/system-apps/profile.app.d.ts +2 -0
  229. package/dist/system-apps/profile.app.js +8 -0
  230. package/dist/system-apps/search.app.d.ts +2 -0
  231. package/dist/system-apps/search.app.js +9 -0
  232. package/dist/system-apps/settings.app.d.ts +2 -0
  233. package/dist/system-apps/settings.app.js +8 -0
  234. package/dist/system-apps/threads.app.d.ts +2 -0
  235. package/dist/system-apps/threads.app.js +8 -0
  236. package/dist/system-apps/tools.app.d.ts +2 -0
  237. package/dist/system-apps/tools.app.js +8 -0
  238. package/dist/system-apps/types.app.d.ts +2 -0
  239. package/dist/system-apps/types.app.js +8 -0
  240. package/dist/system-apps/variables.app.d.ts +2 -0
  241. package/dist/system-apps/variables.app.js +8 -0
  242. package/dist/system-apps/workflows.app.d.ts +2 -0
  243. package/dist/system-apps/workflows.app.js +8 -0
  244. package/dist/tabs-layout/tabs-layout.d.ts +5 -0
  245. package/dist/tabs-layout/tabs-layout.js +374 -0
  246. package/dist/tabs-layout/tabs-state.d.ts +26 -0
  247. package/dist/tabs-layout/tabs-state.js +239 -0
  248. package/dist/three-bar-layout/left-bar-content.d.ts +7 -0
  249. package/dist/three-bar-layout/left-bar-content.js +151 -0
  250. package/dist/three-bar-layout/right-bar-content.d.ts +2 -0
  251. package/dist/three-bar-layout/right-bar-content.js +64 -0
  252. package/dist/three-bar-layout/three-bar-layout.d.ts +5 -0
  253. package/dist/three-bar-layout/three-bar-layout.js +218 -0
  254. package/dist/ui-defaults/index.d.ts +2 -0
  255. package/dist/ui-defaults/index.js +4 -0
  256. package/dist/ui-defaults/list-screen.d.ts +6 -0
  257. package/dist/ui-defaults/list-screen.js +74 -0
  258. package/dist/ui-defaults/notes-editor.d.ts +7 -0
  259. package/dist/ui-defaults/notes-editor.js +41 -0
  260. package/dist/ui-router/routes-loader.d.ts +25 -0
  261. package/dist/ui-router/routes-loader.js +97 -0
  262. package/dist/ui-router/ui-loader.d.ts +18 -0
  263. package/dist/ui-router/ui-loader.js +481 -0
  264. package/dist/utils.d.ts +9 -0
  265. package/dist/utils.js +250 -0
  266. package/docs/conversation-tab.md +201 -0
  267. package/docs/getting-started.md +284 -0
  268. package/docs/knowledge.md +187 -0
  269. package/docs/tabs-ui.md +696 -0
  270. package/docs/user-contacts-ui.md +384 -0
  271. package/jest.config.js +25 -0
  272. package/package.json +109 -0
  273. package/src/app.tsx +59 -0
  274. package/src/command-palette/command-palette-ui.tsx +264 -0
  275. package/src/command-palette/command-palette.ts +364 -0
  276. package/src/components/checkbox.tsx +22 -0
  277. package/src/components/group-switcher.tsx +469 -0
  278. package/src/components/input-date.tsx +28 -0
  279. package/src/components/input-datetime.tsx +41 -0
  280. package/src/components/input-number.tsx +67 -0
  281. package/src/components/input.tsx +22 -0
  282. package/src/components/io-schema-values.tsx +122 -0
  283. package/src/components/io-schema.tsx +234 -0
  284. package/src/components/lazy-list.tsx +98 -0
  285. package/src/components/lazy-sortable-list.tsx +51 -0
  286. package/src/components/left-bar.tsx +264 -0
  287. package/src/components/list-screen.tsx +105 -0
  288. package/src/components/loading-indicator.tsx +9 -0
  289. package/src/components/main-content-container.tsx +76 -0
  290. package/src/components/markdown-editor/autolink-plugin.tsx +36 -0
  291. package/src/components/markdown-editor/editor-inline.tsx +10 -0
  292. package/src/components/markdown-editor/editor.tsx +152 -0
  293. package/src/components/markdown-editor/markdown-plugin.tsx +224 -0
  294. package/src/components/markdown-editor/mention-node.ts +199 -0
  295. package/src/components/markdown-editor/mentions-plugin.tsx +356 -0
  296. package/src/components/markdown-editor/theme.ts +47 -0
  297. package/src/components/markdown-editor/toolbar.tsx +263 -0
  298. package/src/components/markdown-with-mentions.tsx +183 -0
  299. package/src/components/message-logs/message-logs.tsx +406 -0
  300. package/src/components/messages/avatar.tsx +95 -0
  301. package/src/components/messages/channel-message-list.tsx +177 -0
  302. package/src/components/messages/channel-view.tsx +74 -0
  303. package/src/components/messages/message-compose.tsx +162 -0
  304. package/src/components/messages/message-display.tsx +217 -0
  305. package/src/components/messages/thread-message-list.tsx +126 -0
  306. package/src/components/messages/thread-view.tsx +214 -0
  307. package/src/components/off-canvas.tsx +83 -0
  308. package/src/components/router.tsx +224 -0
  309. package/src/components/save-button.tsx +109 -0
  310. package/src/components/sortable-list.tsx +102 -0
  311. package/src/components/tabs.tsx +70 -0
  312. package/src/components/text-list-editor.tsx/text-list-editor.tsx +13 -0
  313. package/src/components/tooltip.tsx +50 -0
  314. package/src/components/top-bar.tsx +119 -0
  315. package/src/components/typeahead/mentions-plugin.tsx +265 -0
  316. package/src/components/typeahead/typeahead-editor.tsx +140 -0
  317. package/src/components/typeahead/typeahead.tsx +77 -0
  318. package/src/components/typeahead.tsx +359 -0
  319. package/src/globals.tsx +162 -0
  320. package/src/hooks.ts +144 -0
  321. package/src/index.tsx +8 -0
  322. package/src/layout-vars.ts +8 -0
  323. package/src/mention-configs.ts +166 -0
  324. package/src/screens/assistants/assistant-config.tsx +80 -0
  325. package/src/screens/assistants/assistant-details.tsx +77 -0
  326. package/src/screens/assistants/assistant-info.tsx +45 -0
  327. package/src/screens/assistants/assistant-list.tsx +115 -0
  328. package/src/screens/assistants/assistant-tools.tsx +61 -0
  329. package/src/screens/contacts/contact-details.tsx +175 -0
  330. package/src/screens/contacts/contact-list.tsx +251 -0
  331. package/src/screens/contacts/index.ts +6 -0
  332. package/src/screens/events/cron.ts +74 -0
  333. package/src/screens/events/event-details.tsx +117 -0
  334. package/src/screens/events/event-handlers.tsx +61 -0
  335. package/src/screens/events/event-info.tsx +29 -0
  336. package/src/screens/events/event-list.tsx +104 -0
  337. package/src/screens/events/event-schedule.tsx +130 -0
  338. package/src/screens/groups/group-details.tsx +306 -0
  339. package/src/screens/groups/group-list.tsx +366 -0
  340. package/src/screens/groups/group-members.tsx +455 -0
  341. package/src/screens/groups/index.ts +9 -0
  342. package/src/screens/knowledge/knowledge-frame-details.bk.tsx +160 -0
  343. package/src/screens/knowledge/knowledge-frame-details.tsx +176 -0
  344. package/src/screens/knowledge/knowledge-frame-list.tsx +49 -0
  345. package/src/screens/knowledge/knowledge-value-details.tsx +181 -0
  346. package/src/screens/knowledge/knowledge-value-list-item.tsx +48 -0
  347. package/src/screens/knowledge/knowledge-value-list.tsx +131 -0
  348. package/src/screens/packages/package-details.tsx +117 -0
  349. package/src/screens/packages/package-info.tsx +83 -0
  350. package/src/screens/packages/package-list.tsx +191 -0
  351. package/src/screens/packages/package-new-local.tsx +93 -0
  352. package/src/screens/peer-types/peer-type-details.tsx +162 -0
  353. package/src/screens/peer-types/peer-type-list.tsx +74 -0
  354. package/src/screens/predicates/predicate-details.tsx +125 -0
  355. package/src/screens/predicates/predicate-list.tsx +50 -0
  356. package/src/screens/profile.tsx +68 -0
  357. package/src/screens/search/global-search.tsx +274 -0
  358. package/src/screens/settings/color-mode-dropdown.tsx +57 -0
  359. package/src/screens/settings/settings-page.tsx +76 -0
  360. package/src/screens/setup-user.tsx +367 -0
  361. package/src/screens/tools/tool-code.tsx +35 -0
  362. package/src/screens/tools/tool-details.tsx +101 -0
  363. package/src/screens/tools/tool-info.tsx +60 -0
  364. package/src/screens/tools/tool-list.tsx +121 -0
  365. package/src/screens/tools/tool-schema.tsx +42 -0
  366. package/src/screens/tools/tool-test-details.tsx +100 -0
  367. package/src/screens/tools/tool-test-list.tsx +74 -0
  368. package/src/screens/variables/variable-details.tsx +183 -0
  369. package/src/screens/variables/variable-list.tsx +74 -0
  370. package/src/screens/workflows/workflow-details.tsx +130 -0
  371. package/src/screens/workflows/workflow-info.tsx +29 -0
  372. package/src/screens/workflows/workflow-instructions.tsx +127 -0
  373. package/src/screens/workflows/workflow-list.tsx +107 -0
  374. package/src/screens/workflows/workflow-subscriptions.tsx +58 -0
  375. package/src/setupTests.ts +32 -0
  376. package/src/system-apps/assistants.app.ts +7 -0
  377. package/src/system-apps/contacts.app.ts +8 -0
  378. package/src/system-apps/events.app.ts +7 -0
  379. package/src/system-apps/groups.app.ts +8 -0
  380. package/src/system-apps/index.ts +79 -0
  381. package/src/system-apps/knowledge-frames.app.ts +8 -0
  382. package/src/system-apps/knowledge-values.app.ts +8 -0
  383. package/src/system-apps/packages.app.ts +7 -0
  384. package/src/system-apps/predicates.app.ts +7 -0
  385. package/src/system-apps/profile.app.ts +7 -0
  386. package/src/system-apps/search.app.ts +8 -0
  387. package/src/system-apps/settings.app.ts +7 -0
  388. package/src/system-apps/threads.app.ts +7 -0
  389. package/src/system-apps/tools.app.ts +7 -0
  390. package/src/system-apps/types.app.ts +7 -0
  391. package/src/system-apps/variables.app.ts +7 -0
  392. package/src/system-apps/workflows.app.ts +7 -0
  393. package/src/tabs-layout/tabs-layout.tsx +672 -0
  394. package/src/tabs-layout/tabs-state.ts +269 -0
  395. package/src/three-bar-layout/left-bar-content.tsx +202 -0
  396. package/src/three-bar-layout/right-bar-content.tsx +67 -0
  397. package/src/three-bar-layout/three-bar-layout.tsx +297 -0
  398. package/src/ui-defaults/index.ts +3 -0
  399. package/src/ui-defaults/list-screen.tsx +92 -0
  400. package/src/ui-defaults/notes-editor.tsx +51 -0
  401. package/src/ui-router/routes-loader.ts +98 -0
  402. package/src/ui-router/ui-loader.tsx +497 -0
  403. package/src/utils.ts +266 -0
  404. package/tsconfig.json +24 -0
@@ -0,0 +1,166 @@
1
+ import { Assistants, IMentionData, PeerEventTypes, PeerTypes, Predicates, rpcClientCalls, Tools, Users, Workflows } from "@peers-app/peers-sdk";
2
+ // import { MENTIONS_MAX_RESULTS } from "../client/components/markdown-editor/mentions-plugin";
3
+
4
+ const MENTIONS_MAX_RESULTS = 10;
5
+
6
+ export interface IMentionConfig {
7
+ iconClass: string;
8
+ styleClass?: string;
9
+ kind: string;
10
+ query: (text: string) => Promise<IMentionData[]>;
11
+ getById: (id: string) => Promise<IMentionData | undefined>;
12
+ picture?: (data: IMentionData) => JSX.Element;
13
+ onClick?: ((data: IMentionData) => void);
14
+ }
15
+
16
+ export const toolMentionConfig: IMentionConfig = {
17
+ kind: 'tool',
18
+ iconClass: 'bi bi-tools',
19
+ styleClass: 'mention-tool',
20
+ query: async (search: string) => {
21
+ const results = await Tools().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS });
22
+ return results.map(p => ({
23
+ kind: 'tool',
24
+ id: p.toolId,
25
+ name: p.name
26
+ }));
27
+ },
28
+ getById: id => Tools().get(id).then(item => item && {
29
+ kind: 'tool',
30
+ id: item.toolId,
31
+ name: item.name
32
+ })
33
+ };
34
+
35
+ export const userMentionConfig: IMentionConfig = {
36
+ kind: 'user',
37
+ iconClass: 'bi-person-fill',
38
+ styleClass: 'mention-user',
39
+ query: async (search: string) => {
40
+ return Users().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS })
41
+ .then((users) => users.map((user) => ({
42
+ kind: 'user',
43
+ id: user.userId,
44
+ name: user.name,
45
+ })));
46
+ },
47
+ getById: id => Users().get(id).then(item => item && {
48
+ kind: 'user',
49
+ id: item.userId,
50
+ name: item.name
51
+ }),
52
+ };
53
+
54
+ export const assistantMentionConfig: IMentionConfig = {
55
+ kind: 'assistant',
56
+ iconClass: 'bi bi-person-fill-gear',
57
+ styleClass: 'mention-assistant',
58
+ query: async (search: string) => {
59
+ return Assistants().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS })
60
+ .then((assistants) => assistants.map((assistant) => ({
61
+ kind: 'assistant' as const,
62
+ id: assistant.assistantId,
63
+ name: assistant.name,
64
+ })));
65
+ },
66
+ getById: id => Assistants().get(id).then(item => item && {
67
+ kind: 'assistant',
68
+ id: item.assistantId,
69
+ name: item.name
70
+ }),
71
+ };
72
+
73
+ export const workflowMentionConfig: IMentionConfig = {
74
+ kind: 'workflow',
75
+ iconClass: 'bi bi-database-fill-gear',
76
+ styleClass: 'mention-workflow',
77
+ query: async (search: string) => {
78
+ return Workflows().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS })
79
+ .then((workflows) => workflows.map((workflow) => ({
80
+ kind: 'workflow' as const,
81
+ id: workflow.workflowId,
82
+ name: workflow.name,
83
+ })));
84
+ },
85
+ getById: id => Workflows().get(id).then(item => item && {
86
+ kind: 'workflow',
87
+ id: item.workflowId,
88
+ name: item.name
89
+ }),
90
+ };
91
+
92
+ export const peerEventTypeMentionConfig: IMentionConfig = {
93
+ kind: 'event',
94
+ iconClass: 'bi bi-lightning-charge-fill',
95
+ styleClass: 'mention-event',
96
+ query: async (search: string) => {
97
+ return PeerEventTypes().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS })
98
+ .then((events) => events.map((event) => ({
99
+ kind: 'event' as const,
100
+ id: event.peerEventTypeId,
101
+ name: event.name,
102
+ })));
103
+ },
104
+ getById: id => PeerEventTypes().get(id).then(item => item && {
105
+ kind: 'event',
106
+ id: item.peerEventTypeId,
107
+ name: item.name
108
+ }),
109
+ };
110
+
111
+ export const predicateMentionConfig: IMentionConfig = {
112
+ kind: 'predicate',
113
+ iconClass: 'bi bi-node-plus-fill',
114
+ query: async (search: string) => {
115
+ const results = await Predicates().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS });
116
+ return results.map(p => ({
117
+ kind: 'predicate',
118
+ id: p.predicateId,
119
+ name: p.name
120
+ }));
121
+ },
122
+ getById: id => Predicates().get(id).then(item => item && {
123
+ kind: 'predicate',
124
+ id: item.predicateId,
125
+ name: item.name
126
+ }),
127
+ };
128
+
129
+ export const valueTypeMentionConfig: IMentionConfig = {
130
+ kind: 'type',
131
+ iconClass: 'bi bi-code-square',
132
+ query: async (search: string) => {
133
+ const results = await PeerTypes().list({ name: { $matchWords: search } }, { pageSize: MENTIONS_MAX_RESULTS });
134
+ return results.map(item => ({
135
+ kind: 'type',
136
+ id: item.peerTypeId,
137
+ name: item.name
138
+ }));
139
+ },
140
+ getById: id => PeerTypes().get(id).then(item => item && {
141
+ kind: 'type',
142
+ id: item.peerTypeId,
143
+ name: item.name
144
+ }),
145
+ onClick(data) {
146
+ rpcClientCalls.setClientPath(`value-types/${data.id}`);
147
+ },
148
+ };
149
+
150
+ // Tasks().list({ title: { $matchWords: mentionString }, completeDT: { $exists: searchCompletedTasks } }, { pageSize: MAX_RESULTS })
151
+ // .then((tasks) => tasks.map((task) => ({
152
+ // kind: 'task' as const,
153
+ // id: task.taskId,
154
+ // name: task.title,
155
+ // }))),
156
+ // picture = <i className="bi bi-list-task pe-1" />;
157
+
158
+ export const mentionConfigs = [
159
+ toolMentionConfig,
160
+ userMentionConfig,
161
+ assistantMentionConfig,
162
+ workflowMentionConfig,
163
+ peerEventTypeMentionConfig,
164
+ predicateMentionConfig,
165
+ valueTypeMentionConfig,
166
+ ];
@@ -0,0 +1,80 @@
1
+ import { IAssistant, IDoc, IOSchemaType, Observable, Tools } from "@peers-app/peers-sdk";
2
+ import React from "react";
3
+ import { IOSchemaValues } from "../../components/io-schema-values";
4
+ import { LoadingIndicator } from "../../components/loading-indicator";
5
+ import { useObservable, usePromise } from "../../hooks";
6
+
7
+ export const AssistantConfig = (props: { assistant: IDoc<IAssistant> }) => {
8
+ const { assistant } = props;
9
+
10
+ const assistantRunnerTool = usePromise(async () => {
11
+ return await Tools().get(assistant.assistantRunnerToolId);
12
+ });
13
+
14
+ if (assistantRunnerTool === undefined) {
15
+ return <LoadingIndicator />;
16
+ }
17
+
18
+ if (assistantRunnerTool === null) {
19
+ return (
20
+ <div>
21
+ <div className='mt-2'>
22
+ <small>Assistant Runner Tool:</small>
23
+ <AssistantRunnersDropdown selectedToolId={assistant.qs.assistantRunnerToolId} />
24
+ </div>
25
+ </div>
26
+ );
27
+ }
28
+
29
+ assistantRunnerTool.configSchema = assistantRunnerTool.configSchema ?? {
30
+ type: IOSchemaType.complex,
31
+ fields: []
32
+ };
33
+
34
+ return (
35
+ <div>
36
+
37
+ <div className='mt-2'>
38
+ <small>Assistant Runner Tool:</small>
39
+ <AssistantRunnersDropdown selectedToolId={assistant.qs.assistantRunnerToolId} />
40
+ </div>
41
+
42
+ <IOSchemaValues ioSchema={assistantRunnerTool.configSchema} values={assistant.assistantRunnerConfig} q={assistant.q} />
43
+
44
+ </div>
45
+ );
46
+ };
47
+
48
+
49
+ const AssistantRunnersDropdown = (props: { selectedToolId: Observable<string> }) => {
50
+
51
+ const [selectedToolId] = useObservable(props.selectedToolId);
52
+
53
+ const modelTools = usePromise(async () => {
54
+ const modelTools = await Tools().list({ isAssistantRunner: true });
55
+ return modelTools;
56
+ });
57
+
58
+ if (!modelTools) {
59
+ return <LoadingIndicator />;
60
+ }
61
+
62
+ return (
63
+ <div className="dropdown">
64
+ <button className="btn btn-secondary dropdown-toggle" type="button" data-bs-toggle="dropdown" aria-expanded="false">
65
+ {modelTools.find(tool => tool.toolId === selectedToolId)?.name ?? 'Select Tool'}
66
+ </button>
67
+ <ul className="dropdown-menu">
68
+ {modelTools.map(tool => {
69
+ return (
70
+ <li key={tool.toolId} onClick={() => props.selectedToolId(tool.toolId)}>
71
+ {/* <button className="dropdown-item" type="button">Action</button> */}
72
+ {/* <MarkdownWithMentions content={tool.name} /> */}
73
+ <span className="dropdown-item">{tool.name}</span>
74
+ </li>
75
+ )
76
+ })}
77
+ </ul>
78
+ </div>
79
+ );
80
+ }
@@ -0,0 +1,77 @@
1
+ import { Assistants, defaultAssistantId, getPrimaryAssistant, observable } from "@peers-app/peers-sdk";
2
+ import React, { useState } from 'react';
3
+ import { Input } from '../../components/input';
4
+ import { LoadingIndicator } from '../../components/loading-indicator';
5
+ import { SaveButton } from '../../components/save-button';
6
+ import { Tabs } from '../../components/tabs';
7
+ import { usePromise } from '../../hooks';
8
+ import { updateActiveTabTitle } from '../../tabs-layout/tabs-state';
9
+ import { AssistantConfig } from './assistant-config';
10
+ import { AssistantInfo } from './assistant-info';
11
+ import { AssistantTools } from './assistant-tools';
12
+
13
+
14
+ export const AssistantDetails = (props: { assistantId: string }) => {
15
+
16
+ const [isPrimaryAssistant] = useState(() => observable(false));
17
+
18
+ const assistant = usePromise((async () => {
19
+ const assistant = await Assistants().get(props.assistantId);
20
+ if (!assistant) {
21
+ return null;
22
+ }
23
+ const primaryAssistantId = (await getPrimaryAssistant()).assistantId
24
+ || defaultAssistantId;
25
+ isPrimaryAssistant(assistant.assistantId === primaryAssistantId);
26
+ updateActiveTabTitle(assistant.name || "Assistant");
27
+ return Assistants().initDoc(assistant);
28
+ }), undefined, [props.assistantId]);
29
+
30
+ if (assistant === null) {
31
+ return <div>Assistant not found with id of {props.assistantId}</div>;
32
+ }
33
+
34
+ if (!assistant) {
35
+ return <LoadingIndicator />;
36
+ }
37
+
38
+ return (
39
+ <div className='container-fluid p-3'>
40
+
41
+ <div className="d-flex">
42
+ <div>
43
+ <h4>
44
+ <i className="bi bi-person-fill-gear me-2"></i>
45
+ </h4>
46
+ </div>
47
+ <div className="flex-grow-1">
48
+ <h4>
49
+ <Input
50
+ key={assistant.assistantId}
51
+ className='border border-0'
52
+ style={{ width: '100%', outline: 'none', backgroundColor: 'transparent' }}
53
+ value={assistant.qs.name}
54
+ />
55
+ </h4>
56
+ </div>
57
+ <div className="">
58
+
59
+ <SaveButton
60
+ key={assistant.assistantId}
61
+ doc={assistant}
62
+ />
63
+ </div>
64
+ </div>
65
+
66
+ <Tabs
67
+ key={assistant.assistantId}
68
+ tabs={[
69
+ { name: 'Info', content: <AssistantInfo assistant={assistant} isPrimaryAssistant={isPrimaryAssistant} /> },
70
+ { name: 'Config', content: <AssistantConfig assistant={assistant} /> },
71
+ { name: 'Tools', content: <AssistantTools assistant={assistant} />, },
72
+ ]}
73
+ />
74
+
75
+ </div>
76
+ );
77
+ }
@@ -0,0 +1,45 @@
1
+ import { IAssistant, IDoc, Observable } from "@peers-app/peers-sdk";
2
+ import React from "react";
3
+ import { Input } from "../../components/input";
4
+ import { MarkdownEditorInline } from "../../components/markdown-editor/editor-inline";
5
+ import { useObservable } from "../../hooks";
6
+
7
+ export const AssistantInfo = (props: { assistant: IDoc<IAssistant>, isPrimaryAssistant: Observable<boolean> }) => {
8
+ const { assistant, isPrimaryAssistant } = props;
9
+
10
+ useObservable(isPrimaryAssistant);
11
+
12
+ return (
13
+ <div>
14
+
15
+ <small>Name:</small>
16
+ <Input
17
+ value={assistant.qs.name}
18
+ className="form-control mb-3 p-0 ps-2"
19
+ placeholder="Tool name"
20
+ title="Tool name"
21
+ />
22
+
23
+ <div>
24
+ <label htmlFor="isPrimary" className="form-label small mt-2 me-2">Primary Assistant:</label>
25
+ <input
26
+ type="checkbox"
27
+ checked={isPrimaryAssistant()}
28
+ onChange={(e) => {
29
+ const checked = (e.target as HTMLInputElement).checked;
30
+ isPrimaryAssistant(checked);
31
+ assistant.q(assistant.q() + 1);
32
+ }}
33
+ />
34
+ </div>
35
+
36
+ <div className='mt-2'>
37
+ <small>Description:</small>
38
+ <MarkdownEditorInline
39
+ value={assistant.qs.description as any}
40
+ />
41
+ </div>
42
+
43
+ </div>
44
+ );
45
+ };
@@ -0,0 +1,115 @@
1
+ import { Assistants, IAssistant, ICursorIterable, newid, observable } from "@peers-app/peers-sdk";
2
+ import React, { useEffect, useState } from 'react';
3
+ import { Input } from "../../components/input";
4
+ import { LazyList } from "../../components/lazy-list";
5
+ import { LoadingIndicator } from '../../components/loading-indicator';
6
+ import { MarkdownWithMentions } from '../../components/markdown-with-mentions';
7
+ import { isDesktop, mainContentPath } from '../../globals';
8
+ import { useObservable } from "../../hooks";
9
+
10
+
11
+ export const AssistantList = () => {
12
+ const [searchTextObs] = useState(() => observable(''));
13
+ const [searchText] = useObservable(searchTextObs);
14
+
15
+ const [cursorObs] = useState(() => observable<ICursorIterable<IAssistant>>());
16
+ const [cursorId] = useState(() => observable(newid()));
17
+
18
+ async function newCursor() {
19
+ let cursor: ICursorIterable<IAssistant>;
20
+ const _searchText = searchText.trim();
21
+ if (_searchText) {
22
+ cursor = await Assistants().cursor({ name: { $matchWords: _searchText } }, { sortBy: ['-updatedAt'] });
23
+ } else {
24
+ cursor = await Assistants().cursor(undefined, { sortBy: ['-updatedAt'] });
25
+ }
26
+
27
+ cursorObs(cursor);
28
+ cursorId(newid());
29
+ return cursor;
30
+ }
31
+
32
+ useEffect(() => {
33
+ const sub = searchTextObs.subscribe(() => {
34
+ cursorObs(undefined);
35
+ cursorId(newid());
36
+ });
37
+ return () => sub.dispose();
38
+ }, [searchText]);
39
+
40
+ async function searchSubmit(evt: React.KeyboardEvent<HTMLInputElement>) {
41
+ if (evt.key !== "Enter") return;
42
+ if (!searchText.trim()) return;
43
+ let assistantName = searchText.trim();
44
+ const assistant = await Assistants().initRecord({
45
+ name: assistantName,
46
+ });
47
+ await Assistants().insert(assistant);
48
+ mainContentPath(`assistants/${assistant.assistantId}`);
49
+ }
50
+
51
+ async function loadMore(loadedRecords: IAssistant[]): Promise<IAssistant[]> {
52
+ let moreMatches: IAssistant[] = [];
53
+ let cursor = cursorObs() || await newCursor();
54
+ for await (const assistant of cursor) {
55
+ if (loadedRecords.find(a => a.assistantId === assistant.assistantId)) continue;
56
+ moreMatches.push(assistant);
57
+ if (searchText.length && moreMatches.length > 5) break;
58
+ if (moreMatches.length >= 50) break;
59
+ }
60
+ if (moreMatches.length === 0) {
61
+ cursorObs(undefined);
62
+ }
63
+ return moreMatches;
64
+ }
65
+
66
+ return (
67
+ <div className='container-fluid'>
68
+ <Input
69
+ value={searchTextObs}
70
+ className="form-control"
71
+ style={{ marginBottom: "10px" }}
72
+ placeholder="Search or create new assistant"
73
+ autoFocus={isDesktop() ? true : false}
74
+ onKeyUp={evt => searchSubmit(evt)}
75
+ />
76
+
77
+ <div className="peers-list-container">
78
+ <LazyList
79
+ key={cursorId()}
80
+ loadMore={loadMore}
81
+ scrollThreshold={0.6}
82
+ renderItems={(assistants) => {
83
+ return assistants.map(assistant => {
84
+ return (
85
+ <div
86
+ key={assistant.assistantId}
87
+ className='container-fluid pb-4'
88
+ >
89
+ <i className="bi bi-person-fill-gear"></i>&nbsp;
90
+ <a href={`#assistants/${assistant.assistantId}`}>
91
+ {assistant.name}
92
+ </a>
93
+ <div style={{ paddingLeft: '20px' }}>
94
+ <MarkdownWithMentions content={assistant.description ?? ''} />
95
+ </div>
96
+
97
+ </div>
98
+ )
99
+ })
100
+ }}
101
+ loadingIndicator={
102
+ <div className="d-flex justify-content-center" style={{ height: 200 }}>
103
+ <LoadingIndicator />
104
+ </div>
105
+ }
106
+ endOfList={
107
+ <div className="d-flex justify-content-center" style={{ height: 200 }}>
108
+ {/* <span className="h3">End of List</span> */}
109
+ </div>
110
+ }
111
+ />
112
+ </div>
113
+ </div>
114
+ );
115
+ };
@@ -0,0 +1,61 @@
1
+ import React from "react";
2
+ import { Assistants, IAssistant, ToolInclusionStrategy, IDoc, camelCaseToSpaces } from "@peers-app/peers-sdk";
3
+ import { Tooltip } from "../../components/tooltip";
4
+ import { MarkdownEditorInline } from "../../components/markdown-editor/editor-inline";
5
+ import { useObservable } from "../../hooks";
6
+
7
+ export const AssistantTools = (props: { assistant: IDoc<IAssistant> }) => {
8
+ const { assistant } = props;
9
+
10
+ return (
11
+ <div>
12
+
13
+ <div className='mt-2'>
14
+ <small>
15
+ Tool Inclusion Strategy:
16
+ <small>
17
+ <Tooltip markdownContent={Assistants().metaData.fields.find(f => f.name === 'toolInclusionStrategy')?.description ?? ''} />
18
+ </small>
19
+ </small>
20
+ <ToolInclusionStrategyDropDown assistant={assistant} />
21
+ </div>
22
+
23
+ <div className='mt-2'>
24
+ <small>
25
+ Tools to Include:
26
+ <small>
27
+ <Tooltip markdownContent={Assistants().metaData.fields.find(f => f.name === 'toolsToInclude')?.description ?? ''} />
28
+ </small>
29
+ </small>
30
+ <MarkdownEditorInline
31
+ value={assistant.qs.toolsToInclude as any}
32
+ />
33
+ </div>
34
+
35
+ </div>
36
+ );
37
+ };
38
+
39
+
40
+ const ToolInclusionStrategyDropDown = (props: { assistant: IDoc<IAssistant> }) => {
41
+ const { assistant } = props;
42
+
43
+ useObservable(assistant.qs.toolInclusionStrategy);
44
+
45
+ return (
46
+ <div className="dropdown">
47
+ <button className="btn btn-secondary dropdown-toggle" type="button" data-bs-toggle="dropdown" aria-expanded="false">
48
+ {camelCaseToSpaces(assistant.toolInclusionStrategy)}
49
+ </button>
50
+ <ul className="dropdown-menu">
51
+ {Object.values(ToolInclusionStrategy).map(strategy => {
52
+ return (
53
+ <li key={strategy} onClick={() => assistant.toolInclusionStrategy = strategy}>
54
+ <span className="dropdown-item">{camelCaseToSpaces(strategy)}</span>
55
+ </li>
56
+ )
57
+ })}
58
+ </ul>
59
+ </div>
60
+ );
61
+ }