@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,134 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.TypeaheadEditor = TypeaheadEditor;
40
+ const code_1 = require("@lexical/code");
41
+ const link_1 = require("@lexical/link");
42
+ const list_1 = require("@lexical/list");
43
+ const LexicalAutoFocusPlugin_1 = require("@lexical/react/LexicalAutoFocusPlugin");
44
+ const LexicalComposer_1 = require("@lexical/react/LexicalComposer");
45
+ const LexicalComposerContext_1 = require("@lexical/react/LexicalComposerContext");
46
+ const LexicalContentEditable_1 = require("@lexical/react/LexicalContentEditable");
47
+ const LexicalErrorBoundary_1 = require("@lexical/react/LexicalErrorBoundary");
48
+ const LexicalHistoryPlugin_1 = require("@lexical/react/LexicalHistoryPlugin");
49
+ const LexicalRichTextPlugin_1 = require("@lexical/react/LexicalRichTextPlugin");
50
+ const rich_text_1 = require("@lexical/rich-text");
51
+ const peers_sdk_1 = require("@peers-app/peers-sdk");
52
+ const lexical_1 = require("lexical");
53
+ const react_1 = __importStar(require("react"));
54
+ const markdown_plugin_1 = require("../markdown-editor/markdown-plugin");
55
+ const mention_node_1 = require("../markdown-editor/mention-node");
56
+ const theme_1 = __importDefault(require("../markdown-editor/theme"));
57
+ const mentions_plugin_1 = require("./mentions-plugin");
58
+ const mention_configs_1 = require("../../mention-configs");
59
+ const editorConfig = {
60
+ namespace: 'PeersEditor',
61
+ nodes: [
62
+ rich_text_1.HeadingNode,
63
+ rich_text_1.QuoteNode,
64
+ code_1.CodeNode,
65
+ list_1.ListNode,
66
+ list_1.ListItemNode,
67
+ mention_node_1.MentionNode,
68
+ link_1.AutoLinkNode,
69
+ link_1.LinkNode,
70
+ ],
71
+ // Handling of errors during update
72
+ onError(error) {
73
+ throw error;
74
+ },
75
+ // The editor theme
76
+ theme: theme_1.default,
77
+ };
78
+ function TypeaheadEditor(props) {
79
+ const { effects } = props;
80
+ const editorRef = react_1.default.useRef(null);
81
+ const [mentionsOpen] = (0, react_1.useState)(() => {
82
+ const obs = (0, peers_sdk_1.observable)(false);
83
+ return obs;
84
+ });
85
+ if (effects) {
86
+ effects.focus = () => {
87
+ if (editorRef.current?.children[0]) {
88
+ const div = editorRef.current.children[0];
89
+ setTimeout(() => {
90
+ div.focus();
91
+ // Set the selection to the end of the div content
92
+ const range = document.createRange();
93
+ range.selectNodeContents(div);
94
+ range.collapse(false);
95
+ const selection = window.getSelection();
96
+ if (selection) {
97
+ selection.removeAllRanges();
98
+ selection.addRange(range);
99
+ }
100
+ }, 10);
101
+ }
102
+ };
103
+ }
104
+ const _mentionConfigs = props.mentionConfigs ?? mention_configs_1.mentionConfigs;
105
+ return (react_1.default.createElement("div", { className: "border rounded border-dark-subtle" },
106
+ react_1.default.createElement(LexicalComposer_1.LexicalComposer, { initialConfig: { ...editorConfig } },
107
+ react_1.default.createElement("div", { className: "editor-container" },
108
+ react_1.default.createElement("div", { className: "editor-inner", ref: editorRef, style: { maxHeight: props.maxHeight ?? 30, overflowY: 'hidden' } },
109
+ react_1.default.createElement(LexicalRichTextPlugin_1.RichTextPlugin, { contentEditable: react_1.default.createElement(LexicalContentEditable_1.ContentEditable, { className: "editor-input p-1" }),
110
+ // placeholder={(isEditable) => !isEditable ? <div className="text-muted">Type here...</div> : null}
111
+ ErrorBoundary: LexicalErrorBoundary_1.LexicalErrorBoundary }),
112
+ react_1.default.createElement(LexicalHistoryPlugin_1.HistoryPlugin, null),
113
+ props.autoFocus && react_1.default.createElement(LexicalAutoFocusPlugin_1.AutoFocusPlugin, { defaultSelection: 'rootEnd' }),
114
+ _mentionConfigs.length > 0 && (react_1.default.createElement(mentions_plugin_1.MentionsPlugin, { mentionConfigs: _mentionConfigs, mentionsOpen: mentionsOpen })),
115
+ react_1.default.createElement(markdown_plugin_1.MarkdownPlugin, { markdownObs: props.value }),
116
+ react_1.default.createElement(OnKeyDownPlugin, { effects: props.effects, mentionsOpen: mentionsOpen }))))));
117
+ }
118
+ const OnKeyDownPlugin = (props) => {
119
+ const [editor] = (0, LexicalComposerContext_1.useLexicalComposerContext)();
120
+ (0, react_1.useEffect)(() => {
121
+ const removeListener = editor.registerCommand(lexical_1.KEY_DOWN_COMMAND, (event) => {
122
+ if (props.mentionsOpen()) {
123
+ return false;
124
+ }
125
+ if (props.effects?.onKeyDown) {
126
+ const result = props.effects.onKeyDown(event);
127
+ return !!result;
128
+ }
129
+ return false;
130
+ }, lexical_1.COMMAND_PRIORITY_LOW);
131
+ return removeListener;
132
+ }, [editor]);
133
+ return null;
134
+ };
@@ -0,0 +1,12 @@
1
+ import { Observable } from "@peers-app/peers-sdk";
2
+ import React from 'react';
3
+ import { IMentionConfig } from '../../mention-configs';
4
+ interface IProps<T> {
5
+ value: Observable<string> | Observable<string | undefined>;
6
+ textValue?: Observable<string>;
7
+ mentionConfigs: IMentionConfig[];
8
+ autoFocus?: boolean;
9
+ onSubmit?: (value: string, textValue: string) => void;
10
+ }
11
+ export declare function Typeahead<T>(props: IProps<T>): React.JSX.Element;
12
+ export {};
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.Typeahead = Typeahead;
37
+ const peers_sdk_1 = require("@peers-app/peers-sdk");
38
+ const react_1 = __importStar(require("react"));
39
+ const hooks_1 = require("../../hooks");
40
+ const typeahead_editor_1 = require("./typeahead-editor");
41
+ function Typeahead(props) {
42
+ const { value: sourceValue } = props;
43
+ // const typeaheadValue = useObservableState('', true);
44
+ const [typeaheadValue] = (0, react_1.useState)(() => {
45
+ if (props.textValue) {
46
+ return props.textValue;
47
+ }
48
+ else {
49
+ return (0, peers_sdk_1.observable)('');
50
+ }
51
+ });
52
+ (0, hooks_1.useObservable)(typeaheadValue);
53
+ const existingMention = (0, hooks_1.usePromise)(async () => {
54
+ const id = sourceValue();
55
+ if (!id)
56
+ return true;
57
+ for (const config of props.mentionConfigs) {
58
+ const refValue = await config.getById(id);
59
+ if (refValue) {
60
+ typeaheadValue((0, peers_sdk_1.formatMention)({ kind: config.kind, id, name: refValue.name }) + ' ');
61
+ return true;
62
+ }
63
+ }
64
+ return true;
65
+ });
66
+ (0, hooks_1.useSubscription)(typeaheadValue, () => {
67
+ const mentions = (0, peers_sdk_1.getAllMentions)(typeaheadValue());
68
+ const resolvedMention = mentions.find(m => m.id !== sourceValue()) || mentions[0];
69
+ const resolvedId = resolvedMention?.id;
70
+ if (resolvedId !== sourceValue() || mentions.length > 1) {
71
+ sourceValue(resolvedId);
72
+ if (resolvedId) {
73
+ const newTypeaheadValue = (0, peers_sdk_1.formatMention)(resolvedMention) + ' ';
74
+ typeaheadValue(newTypeaheadValue);
75
+ }
76
+ }
77
+ }, true);
78
+ if (!existingMention) {
79
+ return react_1.default.createElement("div", null, "...");
80
+ }
81
+ return (react_1.default.createElement(typeahead_editor_1.TypeaheadEditor, { value: typeaheadValue, mentionConfigs: props.mentionConfigs, autoFocus: props.autoFocus,
82
+ // these settings configure it for a single line input
83
+ effects: {
84
+ onKeyDown(e) {
85
+ if (e.key === 'Enter') {
86
+ e.preventDefault();
87
+ if (props.onSubmit) {
88
+ props.onSubmit(sourceValue() ?? '', typeaheadValue());
89
+ }
90
+ return true;
91
+ }
92
+ },
93
+ } }));
94
+ }
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ export interface TypeaheadItem {
3
+ id: string;
4
+ [key: string]: any;
5
+ }
6
+ interface TypeaheadProps<T extends TypeaheadItem> {
7
+ placeholder?: string;
8
+ searchFn: (query: string) => Promise<T[]>;
9
+ onSelectionChange: (selectedItems: T[]) => void;
10
+ renderItem: (item: T, isSelected: boolean) => React.ReactNode;
11
+ renderBadge?: (item: T) => React.ReactNode;
12
+ selectedItems?: T[];
13
+ multiSelect?: boolean;
14
+ maxSelections?: number;
15
+ className?: string;
16
+ disabled?: boolean;
17
+ minSearchLength?: number;
18
+ debounceMs?: number;
19
+ maxResults?: number;
20
+ }
21
+ export declare function Typeahead<T extends TypeaheadItem>(props: TypeaheadProps<T>): React.JSX.Element;
22
+ export {};
@@ -0,0 +1,270 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.Typeahead = Typeahead;
37
+ const react_1 = __importStar(require("react"));
38
+ // CSS for hover effects that work with both light and dark themes
39
+ const typeaheadStyles = `
40
+ .typeahead-item:not(.bg-primary):hover {
41
+ background-color: var(--bs-secondary-bg) !important;
42
+ }
43
+
44
+ [data-bs-theme="dark"] .typeahead-item:not(.bg-primary):hover {
45
+ background-color: var(--bs-dark) !important;
46
+ }
47
+
48
+ .typeahead-input-container {
49
+ position: relative;
50
+ display: flex;
51
+ flex-wrap: wrap;
52
+ align-items: center;
53
+ min-height: 38px;
54
+ border: 1px solid var(--bs-border-color);
55
+ border-radius: 0.375rem;
56
+ background-color: var(--bs-body-bg);
57
+ padding: 4px 8px;
58
+ gap: 4px;
59
+ }
60
+
61
+ .typeahead-input-container:focus-within {
62
+ border-color: #86b7fe;
63
+ box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
64
+ }
65
+
66
+ .typeahead-input {
67
+ border: none;
68
+ outline: none;
69
+ background: transparent;
70
+ flex: 1;
71
+ min-width: 120px;
72
+ height: 30px;
73
+ font-size: 1rem;
74
+ color: var(--bs-body-color);
75
+ }
76
+
77
+ .typeahead-input::placeholder {
78
+ color: var(--bs-secondary-color);
79
+ }
80
+
81
+ .typeahead-badge {
82
+ display: inline-flex;
83
+ align-items: center;
84
+ font-size: 0.8rem;
85
+ padding: 2px 8px;
86
+ margin: 1px;
87
+ white-space: nowrap;
88
+ }
89
+ `;
90
+ function Typeahead(props) {
91
+ const { placeholder = "Search...", searchFn, onSelectionChange, renderItem, renderBadge, selectedItems = [], multiSelect = false, maxSelections, className = "form-control", disabled = false, minSearchLength = 1, debounceMs = 300, maxResults = 10 } = props;
92
+ const [query, setQuery] = (0, react_1.useState)('');
93
+ const [results, setResults] = (0, react_1.useState)([]);
94
+ const [selectedIndex, setSelectedIndex] = (0, react_1.useState)(-1);
95
+ const [isOpen, setIsOpen] = (0, react_1.useState)(false);
96
+ const [isLoading, setIsLoading] = (0, react_1.useState)(false);
97
+ const inputRef = (0, react_1.useRef)(null);
98
+ const containerRef = (0, react_1.useRef)(null);
99
+ const resultsRef = (0, react_1.useRef)(null);
100
+ const debounceRef = (0, react_1.useRef)();
101
+ // Inject styles once
102
+ (0, react_1.useEffect)(() => {
103
+ const styleId = 'typeahead-styles';
104
+ if (!document.getElementById(styleId)) {
105
+ const style = document.createElement('style');
106
+ style.id = styleId;
107
+ style.textContent = typeaheadStyles;
108
+ document.head.appendChild(style);
109
+ }
110
+ }, []);
111
+ // Debounced search
112
+ (0, react_1.useEffect)(() => {
113
+ if (debounceRef.current) {
114
+ clearTimeout(debounceRef.current);
115
+ }
116
+ if (query.length >= minSearchLength) {
117
+ debounceRef.current = setTimeout(async () => {
118
+ setIsLoading(true);
119
+ try {
120
+ const searchResults = await searchFn(query);
121
+ // Filter out already selected items
122
+ const selectedIds = selectedItems.map(item => item.id);
123
+ const filteredResults = searchResults.filter(item => !selectedIds.includes(item.id));
124
+ setResults(filteredResults.slice(0, maxResults));
125
+ setIsOpen(filteredResults.length > 0);
126
+ setSelectedIndex(-1);
127
+ }
128
+ catch (error) {
129
+ console.error('Search error:', error);
130
+ setResults([]);
131
+ }
132
+ finally {
133
+ setIsLoading(false);
134
+ }
135
+ }, debounceMs);
136
+ }
137
+ else {
138
+ setResults([]);
139
+ setIsOpen(false);
140
+ setSelectedIndex(-1);
141
+ }
142
+ return () => {
143
+ if (debounceRef.current) {
144
+ clearTimeout(debounceRef.current);
145
+ }
146
+ };
147
+ }, [query, searchFn, minSearchLength, debounceMs, maxResults, selectedItems]);
148
+ // Click outside to close
149
+ (0, react_1.useEffect)(() => {
150
+ function handleClickOutside(event) {
151
+ if (containerRef.current && !containerRef.current.contains(event.target)) {
152
+ setIsOpen(false);
153
+ setSelectedIndex(-1);
154
+ }
155
+ }
156
+ document.addEventListener('mousedown', handleClickOutside);
157
+ return () => document.removeEventListener('mousedown', handleClickOutside);
158
+ }, []);
159
+ const handleKeyDown = (e) => {
160
+ // Handle backspace to remove last selected item when input is empty
161
+ if (e.key === 'Backspace' && query === '' && selectedItems.length > 0) {
162
+ e.preventDefault();
163
+ const lastItem = selectedItems[selectedItems.length - 1];
164
+ handleRemove(lastItem);
165
+ return;
166
+ }
167
+ // Handle tab to auto-select highlighted result (or first result if none highlighted)
168
+ if (e.key === 'Tab' && isOpen && results.length > 0) {
169
+ e.preventDefault();
170
+ const indexToSelect = selectedIndex >= 0 ? selectedIndex : 0;
171
+ handleSelect(results[indexToSelect]);
172
+ return;
173
+ }
174
+ if (!isOpen || results.length === 0)
175
+ return;
176
+ switch (e.key) {
177
+ case 'ArrowDown':
178
+ e.preventDefault();
179
+ setSelectedIndex(prev => prev < results.length - 1 ? prev + 1 : 0);
180
+ break;
181
+ case 'ArrowUp':
182
+ e.preventDefault();
183
+ setSelectedIndex(prev => prev > 0 ? prev - 1 : results.length - 1);
184
+ break;
185
+ case 'Enter':
186
+ e.preventDefault();
187
+ if (selectedIndex >= 0 && selectedIndex < results.length) {
188
+ handleSelect(results[selectedIndex]);
189
+ }
190
+ break;
191
+ case 'Escape':
192
+ e.preventDefault();
193
+ setIsOpen(false);
194
+ setSelectedIndex(-1);
195
+ inputRef.current?.blur();
196
+ break;
197
+ }
198
+ };
199
+ const handleSelect = (item) => {
200
+ if (maxSelections && selectedItems.length >= maxSelections) {
201
+ return; // Don't allow selection beyond max
202
+ }
203
+ let newSelectedItems;
204
+ if (multiSelect) {
205
+ // Add to existing selections
206
+ newSelectedItems = [...selectedItems, item];
207
+ }
208
+ else {
209
+ // Replace existing selection
210
+ newSelectedItems = [item];
211
+ }
212
+ onSelectionChange(newSelectedItems);
213
+ setQuery('');
214
+ setResults([]);
215
+ setIsOpen(false);
216
+ setSelectedIndex(-1);
217
+ inputRef.current?.focus();
218
+ };
219
+ const handleRemove = (itemToRemove) => {
220
+ const newSelectedItems = selectedItems.filter(item => item.id !== itemToRemove.id);
221
+ onSelectionChange(newSelectedItems);
222
+ inputRef.current?.focus();
223
+ };
224
+ const defaultRenderBadge = (item) => {
225
+ // Extract display text - try common properties
226
+ const displayText = item.name || item.title || item.label || item.id;
227
+ return displayText;
228
+ };
229
+ const handleInputChange = (e) => {
230
+ setQuery(e.target.value);
231
+ };
232
+ const handleInputFocus = () => {
233
+ if (results.length > 0) {
234
+ setIsOpen(true);
235
+ }
236
+ };
237
+ return (react_1.default.createElement("div", { ref: containerRef, className: "position-relative" },
238
+ react_1.default.createElement("div", { className: "typeahead-input-container", onClick: () => inputRef.current?.focus() },
239
+ selectedItems.map((item) => (react_1.default.createElement("div", { key: item.id, className: "badge bg-primary typeahead-badge d-flex align-items-center position-relative pe-4" },
240
+ react_1.default.createElement("span", null, renderBadge ? renderBadge(item) : defaultRenderBadge(item)),
241
+ react_1.default.createElement("button", { type: "button", className: "btn-close btn-close-white position-absolute", style: {
242
+ right: '2px',
243
+ top: '50%',
244
+ transform: 'translateY(-50%)',
245
+ fontSize: '0.5rem',
246
+ width: '10px',
247
+ height: '10px'
248
+ }, onClick: (e) => {
249
+ e.stopPropagation();
250
+ handleRemove(item);
251
+ }, disabled: disabled, "aria-label": "Remove" })))),
252
+ react_1.default.createElement("input", { ref: inputRef, type: "text", className: "typeahead-input", placeholder: selectedItems.length > 0 && !multiSelect ? "Selection made" : placeholder, value: query, onChange: handleInputChange, onKeyDown: handleKeyDown, onFocus: handleInputFocus, disabled: disabled || (!multiSelect && selectedItems.length > 0) }),
253
+ isLoading && (react_1.default.createElement("div", { className: "position-absolute", style: {
254
+ right: '8px',
255
+ top: '50%',
256
+ transform: 'translateY(-50%)'
257
+ } },
258
+ react_1.default.createElement("div", { className: "spinner-border spinner-border-sm text-secondary", role: "status" },
259
+ react_1.default.createElement("span", { className: "visually-hidden" }, "Loading..."))))),
260
+ isOpen && results.length > 0 && (react_1.default.createElement("div", { ref: resultsRef, className: "position-absolute w-100 bg-body border border-top-0 rounded-bottom shadow-lg", style: {
261
+ zIndex: 1000,
262
+ maxHeight: '300px',
263
+ overflowY: 'auto'
264
+ } }, results.map((item, index) => (react_1.default.createElement("div", { key: item.id, className: `px-3 py-2 border-bottom typeahead-item ${index === selectedIndex
265
+ ? 'bg-primary text-white'
266
+ : 'bg-body text-body'}`, style: {
267
+ cursor: 'pointer'
268
+ }, onClick: () => handleSelect(item), onMouseEnter: () => setSelectedIndex(index) }, renderItem(item, index === selectedIndex)))))),
269
+ isOpen && query.length >= minSearchLength && results.length === 0 && !isLoading && (react_1.default.createElement("div", { className: "position-absolute w-100 bg-body border border-top-0 rounded-bottom shadow-lg px-3 py-2 text-muted", style: { zIndex: 1000 } }, "No results found"))));
270
+ }
@@ -0,0 +1,29 @@
1
+ import { IMessage, IUser, groupUserVar } from "@peers-app/peers-sdk";
2
+ export declare const packageReloaded: import("@peers-app/peers-sdk").Observable<number>;
3
+ export declare const _mainContentPath: import("@peers-app/peers-sdk").PersistentVar<string>;
4
+ export declare const mainContentPath: import("@peers-app/peers-sdk").Observable<string>;
5
+ export declare const queryParams: import("@peers-app/peers-sdk").Observable<{
6
+ [key: string]: string;
7
+ }>;
8
+ export declare function queryParam(name: string, value?: string): string;
9
+ export declare const openThreads: ReturnType<typeof groupUserVar<(string | IMessage)[]>>;
10
+ export declare const threadViewOpen: import("@peers-app/peers-sdk").PersistentVar<boolean>;
11
+ export declare function openThread(thread: string | IMessage): Promise<void>;
12
+ export declare function openThreadInTab(thread: string | IMessage): Promise<void>;
13
+ export declare let me: IUser;
14
+ export declare const windowWidth: import("@peers-app/peers-sdk").Observable<number>;
15
+ export declare const windowHeight: import("@peers-app/peers-sdk").Observable<number>;
16
+ export declare const isDesktop: import("@peers-app/peers-sdk").Observable<boolean>;
17
+ export declare const groups: import("@peers-app/peers-sdk").Observable<{
18
+ name: string;
19
+ description: string;
20
+ signature: string;
21
+ publicKey: string;
22
+ groupId: string;
23
+ founderUserId: string;
24
+ publicBoxKey: string;
25
+ disabled?: boolean | undefined;
26
+ iconClassName?: string | undefined;
27
+ publicRole?: import("@peers-app/peers-sdk").GroupMemberRole | undefined;
28
+ }[]>;
29
+ export declare function loadGlobals(): Promise<boolean>;