roamjs-components 0.32.1 → 0.32.2

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 (296) hide show
  1. package/README.md +25 -11
  2. package/date/constants.d.ts +2 -0
  3. package/date/constants.js +3 -0
  4. package/date/constants.js.map +1 -0
  5. package/date/index.d.ts +5 -0
  6. package/date/index.js +6 -0
  7. package/date/index.js.map +1 -0
  8. package/date/parseRoamDate.d.ts +2 -0
  9. package/date/parseRoamDate.js +4 -0
  10. package/date/parseRoamDate.js.map +1 -0
  11. package/date/parseRoamDateUid.d.ts +2 -0
  12. package/date/parseRoamDateUid.js +4 -0
  13. package/date/parseRoamDateUid.js.map +1 -0
  14. package/date/toRoamDate.d.ts +2 -0
  15. package/date/toRoamDate.js +4 -0
  16. package/date/toRoamDate.js.map +1 -0
  17. package/date/toRoamDateUid.d.ts +2 -0
  18. package/date/toRoamDateUid.js +4 -0
  19. package/date/toRoamDateUid.js.map +1 -0
  20. package/dom/addBlockCommand.d.ts +5 -0
  21. package/dom/addBlockCommand.js +52 -0
  22. package/dom/addBlockCommand.js.map +1 -0
  23. package/dom/addOldRoamJSDependency.d.ts +2 -0
  24. package/dom/addOldRoamJSDependency.js +15 -0
  25. package/dom/addOldRoamJSDependency.js.map +1 -0
  26. package/dom/addRoamJSDependency.d.ts +2 -0
  27. package/dom/addRoamJSDependency.js +6 -0
  28. package/dom/addRoamJSDependency.js.map +1 -0
  29. package/dom/addStyle.d.ts +2 -0
  30. package/dom/addStyle.js +13 -0
  31. package/dom/addStyle.js.map +1 -0
  32. package/dom/constants.d.ts +1 -0
  33. package/dom/constants.js +2 -0
  34. package/dom/constants.js.map +1 -0
  35. package/dom/createBlockObserver.d.ts +2 -0
  36. package/dom/createBlockObserver.js +17 -0
  37. package/dom/createBlockObserver.js.map +1 -0
  38. package/dom/createButtonObserver.d.ts +6 -0
  39. package/dom/createButtonObserver.js +19 -0
  40. package/dom/createButtonObserver.js.map +1 -0
  41. package/dom/createDivObserver.d.ts +2 -0
  42. package/dom/createDivObserver.js +6 -0
  43. package/dom/createDivObserver.js.map +1 -0
  44. package/dom/createHTMLObserver.d.ts +8 -0
  45. package/dom/createHTMLObserver.js +27 -0
  46. package/dom/createHTMLObserver.js.map +1 -0
  47. package/dom/createHashtagObserver.d.ts +5 -0
  48. package/dom/createHashtagObserver.js +14 -0
  49. package/dom/createHashtagObserver.js.map +1 -0
  50. package/dom/createIconButton.d.ts +2 -0
  51. package/dom/createIconButton.js +11 -0
  52. package/dom/createIconButton.js.map +1 -0
  53. package/dom/createObserver.d.ts +2 -0
  54. package/dom/createObserver.js +4 -0
  55. package/dom/createObserver.js.map +1 -0
  56. package/dom/createOverlayObserver.d.ts +2 -0
  57. package/dom/createOverlayObserver.js +4 -0
  58. package/dom/createOverlayObserver.js.map +1 -0
  59. package/dom/createPageObserver.d.ts +2 -0
  60. package/dom/createPageObserver.js +32 -0
  61. package/dom/createPageObserver.js.map +1 -0
  62. package/dom/createPageTitleObserver.d.ts +6 -0
  63. package/dom/createPageTitleObserver.js +27 -0
  64. package/dom/createPageTitleObserver.js.map +1 -0
  65. package/dom/genericError.d.ts +4 -0
  66. package/dom/genericError.js +15 -0
  67. package/dom/genericError.js.map +1 -0
  68. package/dom/getActiveUids.d.ts +3 -0
  69. package/dom/getActiveUids.js +4 -0
  70. package/dom/getActiveUids.js.map +1 -0
  71. package/dom/getBlockUidFromTarget.d.ts +2 -0
  72. package/dom/getBlockUidFromTarget.js +31 -0
  73. package/dom/getBlockUidFromTarget.js.map +1 -0
  74. package/dom/getCurrentPageUid.d.ts +2 -0
  75. package/dom/getCurrentPageUid.js +4 -0
  76. package/dom/getCurrentPageUid.js.map +1 -0
  77. package/dom/getDomRefs.d.ts +2 -0
  78. package/dom/getDomRefs.js +10 -0
  79. package/dom/getDomRefs.js.map +1 -0
  80. package/dom/getDropUidOffset.d.ts +5 -0
  81. package/dom/getDropUidOffset.js +25 -0
  82. package/dom/getDropUidOffset.js.map +1 -0
  83. package/dom/getMutatedNodes.d.ts +7 -0
  84. package/dom/getMutatedNodes.js +10 -0
  85. package/dom/getMutatedNodes.js.map +1 -0
  86. package/dom/getPageTitleByHtmlElement.d.ts +2 -0
  87. package/dom/getPageTitleByHtmlElement.js +11 -0
  88. package/dom/getPageTitleByHtmlElement.js.map +1 -0
  89. package/dom/getPageTitleValueByHtmlElement.d.ts +2 -0
  90. package/dom/getPageTitleValueByHtmlElement.js +25 -0
  91. package/dom/getPageTitleValueByHtmlElement.js.map +1 -0
  92. package/dom/getReferenceBlockUid.d.ts +2 -0
  93. package/dom/getReferenceBlockUid.js +16 -0
  94. package/dom/getReferenceBlockUid.js.map +1 -0
  95. package/dom/getRoamUrl.d.ts +2 -0
  96. package/dom/getRoamUrl.js +3 -0
  97. package/dom/getRoamUrl.js.map +1 -0
  98. package/dom/getRoamUrlByPage.d.ts +2 -0
  99. package/dom/getRoamUrlByPage.js +8 -0
  100. package/dom/getRoamUrlByPage.js.map +1 -0
  101. package/dom/getUids.d.ts +3 -0
  102. package/dom/getUids.js +6 -0
  103. package/dom/getUids.js.map +1 -0
  104. package/dom/getUidsFromButton.d.ts +3 -0
  105. package/dom/getUidsFromButton.js +7 -0
  106. package/dom/getUidsFromButton.js.map +1 -0
  107. package/dom/getUidsFromId.d.ts +5 -0
  108. package/dom/getUidsFromId.js +14 -0
  109. package/dom/getUidsFromId.js.map +1 -0
  110. package/dom/index.d.ts +30 -0
  111. package/dom/index.js +31 -0
  112. package/dom/index.js.map +1 -0
  113. package/dom/openBlock.d.ts +2 -0
  114. package/dom/openBlock.js +4 -0
  115. package/dom/openBlock.js.map +1 -0
  116. package/dom/openBlockElement.d.ts +2 -0
  117. package/dom/openBlockElement.js +15 -0
  118. package/dom/openBlockElement.js.map +1 -0
  119. package/dom/parseRoamBlocksToHtml.d.ts +9 -0
  120. package/dom/parseRoamBlocksToHtml.js +74 -0
  121. package/dom/parseRoamBlocksToHtml.js.map +1 -0
  122. package/dom/resolveRefs.d.ts +2 -0
  123. package/dom/resolveRefs.js +22 -0
  124. package/dom/resolveRefs.js.map +1 -0
  125. package/events/watchOnce.d.ts +3 -0
  126. package/events/watchOnce.js +10 -0
  127. package/events/watchOnce.js.map +1 -0
  128. package/marked/index.d.ts +14 -0
  129. package/marked/index.js +540 -0
  130. package/marked/index.js.map +1 -0
  131. package/package.json +9 -2
  132. package/queries/getAllBlockUids.d.ts +2 -0
  133. package/queries/getAllBlockUids.js +5 -0
  134. package/queries/getAllBlockUids.js.map +1 -0
  135. package/queries/getAllBlockUidsAndTexts.d.ts +5 -0
  136. package/queries/getAllBlockUidsAndTexts.js +5 -0
  137. package/queries/getAllBlockUidsAndTexts.js.map +1 -0
  138. package/queries/getAllPageNames.d.ts +2 -0
  139. package/queries/getAllPageNames.js +5 -0
  140. package/queries/getAllPageNames.js.map +1 -0
  141. package/queries/getBasicTreeByParentUid.d.ts +3 -0
  142. package/queries/getBasicTreeByParentUid.js +12 -0
  143. package/queries/getBasicTreeByParentUid.js.map +1 -0
  144. package/queries/getBlockUidAndTextIncludingText.d.ts +5 -0
  145. package/queries/getBlockUidAndTextIncludingText.js +5 -0
  146. package/queries/getBlockUidAndTextIncludingText.js.map +1 -0
  147. package/queries/getBlockUidByTextOnPage.d.ts +5 -0
  148. package/queries/getBlockUidByTextOnPage.js +6 -0
  149. package/queries/getBlockUidByTextOnPage.js.map +1 -0
  150. package/queries/getBlockUidsAndTextsReferencingPage.d.ts +5 -0
  151. package/queries/getBlockUidsAndTextsReferencingPage.js +6 -0
  152. package/queries/getBlockUidsAndTextsReferencingPage.js.map +1 -0
  153. package/queries/getBlockUidsByPageTitle.d.ts +2 -0
  154. package/queries/getBlockUidsByPageTitle.js +6 -0
  155. package/queries/getBlockUidsByPageTitle.js.map +1 -0
  156. package/queries/getBlockUidsReferencingBlock.d.ts +2 -0
  157. package/queries/getBlockUidsReferencingBlock.js +5 -0
  158. package/queries/getBlockUidsReferencingBlock.js.map +1 -0
  159. package/queries/getBlockUidsReferencingPage.d.ts +2 -0
  160. package/queries/getBlockUidsReferencingPage.js +6 -0
  161. package/queries/getBlockUidsReferencingPage.js.map +1 -0
  162. package/queries/getBlockUidsWithParentUid.d.ts +2 -0
  163. package/queries/getBlockUidsWithParentUid.js +5 -0
  164. package/queries/getBlockUidsWithParentUid.js.map +1 -0
  165. package/queries/getChildrenLengthByPageUid.d.ts +2 -0
  166. package/queries/getChildrenLengthByPageUid.js +3 -0
  167. package/queries/getChildrenLengthByPageUid.js.map +1 -0
  168. package/queries/getCreateTimeByBlockUid.d.ts +2 -0
  169. package/queries/getCreateTimeByBlockUid.js +6 -0
  170. package/queries/getCreateTimeByBlockUid.js.map +1 -0
  171. package/queries/getCurrentUser.d.ts +2 -0
  172. package/queries/getCurrentUser.js +10 -0
  173. package/queries/getCurrentUser.js.map +1 -0
  174. package/queries/getCurrentUserDisplayName.d.ts +2 -0
  175. package/queries/getCurrentUserDisplayName.js +11 -0
  176. package/queries/getCurrentUserDisplayName.js.map +1 -0
  177. package/queries/getCurrentUserEmail.d.ts +2 -0
  178. package/queries/getCurrentUserEmail.js +11 -0
  179. package/queries/getCurrentUserEmail.js.map +1 -0
  180. package/queries/getCurrentUserUid.d.ts +2 -0
  181. package/queries/getCurrentUserUid.js +11 -0
  182. package/queries/getCurrentUserUid.js.map +1 -0
  183. package/queries/getDisplayNameByEmail.d.ts +2 -0
  184. package/queries/getDisplayNameByEmail.js +6 -0
  185. package/queries/getDisplayNameByEmail.js.map +1 -0
  186. package/queries/getDisplayNameByUid.d.ts +2 -0
  187. package/queries/getDisplayNameByUid.js +6 -0
  188. package/queries/getDisplayNameByUid.js.map +1 -0
  189. package/queries/getEditTimeByBlockUid.d.ts +2 -0
  190. package/queries/getEditTimeByBlockUid.js +6 -0
  191. package/queries/getEditTimeByBlockUid.js.map +1 -0
  192. package/queries/getEditedUserEmailByBlockUid.d.ts +2 -0
  193. package/queries/getEditedUserEmailByBlockUid.js +6 -0
  194. package/queries/getEditedUserEmailByBlockUid.js.map +1 -0
  195. package/queries/getFirstChildTextByBlockUid.d.ts +2 -0
  196. package/queries/getFirstChildTextByBlockUid.js +6 -0
  197. package/queries/getFirstChildTextByBlockUid.js.map +1 -0
  198. package/queries/getFirstChildUidByBlockUid.d.ts +2 -0
  199. package/queries/getFirstChildUidByBlockUid.js +4 -0
  200. package/queries/getFirstChildUidByBlockUid.js.map +1 -0
  201. package/queries/getFullTreeByParentUid.d.ts +3 -0
  202. package/queries/getFullTreeByParentUid.js +39 -0
  203. package/queries/getFullTreeByParentUid.js.map +1 -0
  204. package/queries/getLinkedPageTitlesUnderUid.d.ts +2 -0
  205. package/queries/getLinkedPageTitlesUnderUid.js +5 -0
  206. package/queries/getLinkedPageTitlesUnderUid.js.map +1 -0
  207. package/queries/getNthChildUidByBlockUid.d.ts +5 -0
  208. package/queries/getNthChildUidByBlockUid.js +6 -0
  209. package/queries/getNthChildUidByBlockUid.js.map +1 -0
  210. package/queries/getOrderByBlockUid.d.ts +2 -0
  211. package/queries/getOrderByBlockUid.js +6 -0
  212. package/queries/getOrderByBlockUid.js.map +1 -0
  213. package/queries/getPageTitleByBlockUid.d.ts +2 -0
  214. package/queries/getPageTitleByBlockUid.js +6 -0
  215. package/queries/getPageTitleByBlockUid.js.map +1 -0
  216. package/queries/getPageTitleReferencesByPageTitle.d.ts +2 -0
  217. package/queries/getPageTitleReferencesByPageTitle.js +6 -0
  218. package/queries/getPageTitleReferencesByPageTitle.js.map +1 -0
  219. package/queries/getPageTitlesAndBlockUidsReferencingPage.d.ts +5 -0
  220. package/queries/getPageTitlesAndBlockUidsReferencingPage.js +6 -0
  221. package/queries/getPageTitlesAndBlockUidsReferencingPage.js.map +1 -0
  222. package/queries/getPageTitlesAndUidsDirectlyReferencingPage.d.ts +5 -0
  223. package/queries/getPageTitlesAndUidsDirectlyReferencingPage.js +6 -0
  224. package/queries/getPageTitlesAndUidsDirectlyReferencingPage.js.map +1 -0
  225. package/queries/getPageTitlesReferencingBlockUid.d.ts +2 -0
  226. package/queries/getPageTitlesReferencingBlockUid.js +5 -0
  227. package/queries/getPageTitlesReferencingBlockUid.js.map +1 -0
  228. package/queries/getPageTitlesStartingWithPrefix.d.ts +2 -0
  229. package/queries/getPageTitlesStartingWithPrefix.js +5 -0
  230. package/queries/getPageTitlesStartingWithPrefix.js.map +1 -0
  231. package/queries/getPageUidByPageTitle.d.ts +2 -0
  232. package/queries/getPageUidByPageTitle.js +7 -0
  233. package/queries/getPageUidByPageTitle.js.map +1 -0
  234. package/queries/getPageViewType.d.ts +3 -0
  235. package/queries/getPageViewType.js +7 -0
  236. package/queries/getPageViewType.js.map +1 -0
  237. package/queries/getParentTextByBlockUid.d.ts +2 -0
  238. package/queries/getParentTextByBlockUid.js +6 -0
  239. package/queries/getParentTextByBlockUid.js.map +1 -0
  240. package/queries/getParentTextByBlockUidAndTag.d.ts +5 -0
  241. package/queries/getParentTextByBlockUidAndTag.js +6 -0
  242. package/queries/getParentTextByBlockUidAndTag.js.map +1 -0
  243. package/queries/getParentUidByBlockUid.d.ts +2 -0
  244. package/queries/getParentUidByBlockUid.js +6 -0
  245. package/queries/getParentUidByBlockUid.js.map +1 -0
  246. package/queries/getParentUidsOfBlockUid.d.ts +2 -0
  247. package/queries/getParentUidsOfBlockUid.js +5 -0
  248. package/queries/getParentUidsOfBlockUid.js.map +1 -0
  249. package/queries/getSettingsByEmail.d.ts +3 -0
  250. package/queries/getSettingsByEmail.js +6 -0
  251. package/queries/getSettingsByEmail.js.map +1 -0
  252. package/queries/getShallowTreeByParentUid.d.ts +5 -0
  253. package/queries/getShallowTreeByParentUid.js +9 -0
  254. package/queries/getShallowTreeByParentUid.js.map +1 -0
  255. package/queries/getTextByBlockUid.d.ts +2 -0
  256. package/queries/getTextByBlockUid.js +6 -0
  257. package/queries/getTextByBlockUid.js.map +1 -0
  258. package/queries/index.d.ts +43 -0
  259. package/queries/index.js +44 -0
  260. package/queries/index.js.map +1 -0
  261. package/queries/isTagOnPage.d.ts +5 -0
  262. package/queries/isTagOnPage.js +7 -0
  263. package/queries/isTagOnPage.js.map +1 -0
  264. package/queries/normalizePageTitle.d.ts +2 -0
  265. package/queries/normalizePageTitle.js +3 -0
  266. package/queries/normalizePageTitle.js.map +1 -0
  267. package/types/index.d.ts +330 -0
  268. package/types/index.js +2 -0
  269. package/types/index.js.map +1 -0
  270. package/writes/clearBlockById.d.ts +2 -0
  271. package/writes/clearBlockById.js +9 -0
  272. package/writes/clearBlockById.js.map +1 -0
  273. package/writes/clearBlockByUid.d.ts +2 -0
  274. package/writes/clearBlockByUid.js +8 -0
  275. package/writes/clearBlockByUid.js.map +1 -0
  276. package/writes/createBlock.d.ts +7 -0
  277. package/writes/createBlock.js +19 -0
  278. package/writes/createBlock.js.map +1 -0
  279. package/writes/createPage.d.ts +6 -0
  280. package/writes/createPage.js +14 -0
  281. package/writes/createPage.js.map +1 -0
  282. package/writes/deleteBlock.d.ts +2 -0
  283. package/writes/deleteBlock.js +6 -0
  284. package/writes/deleteBlock.js.map +1 -0
  285. package/writes/index.d.ts +8 -0
  286. package/writes/index.js +9 -0
  287. package/writes/index.js.map +1 -0
  288. package/writes/openBlockInSidebar.d.ts +2 -0
  289. package/writes/openBlockInSidebar.js +12 -0
  290. package/writes/openBlockInSidebar.js.map +1 -0
  291. package/writes/updateActiveBlock.d.ts +2 -0
  292. package/writes/updateActiveBlock.js +9 -0
  293. package/writes/updateActiveBlock.js.map +1 -0
  294. package/writes/updateBlock.d.ts +5 -0
  295. package/writes/updateBlock.js +15 -0
  296. package/writes/updateBlock.js.map +1 -0
package/README.md CHANGED
@@ -2,23 +2,37 @@
2
2
 
3
3
  This is a collection of common UI components used by RoamJS extensions and services made available to make development easier for other Roam developers.
4
4
 
5
- ## Pre-Requisites
6
-
7
- This library is built on [blueprint](https://blueprintjs.com/docs/#core), a component library developed by Palantir and the primary front end framework used by Roam. It was chosen to build most of the components in this library for consistency with Roam's frontend.
5
+ ## Organization
6
+
7
+ This package takes a modular approach - each function exposed in its own file in an effort to limit the bundle sizes of consumers. It has the following directories:
8
+ - `components` - React components used in Roam
9
+ - `date` - Utilities made to make interacting with Roam dates easier
10
+ - `dom` - Utilities that interact with Roam's DOM structure
11
+ - `events` - Utilities that interact with Roam's event system
12
+ - `hooks` - React hooks commonly used in Roam extensions
13
+ - `marked` - RoamJS' official Roam-flavored markdown to HTML processor
14
+ - `queries` - Helpers that abstract datalog into common, easy-to-invoke, typed queries
15
+ - `types` - Common typescript types used when interacting with these methods
16
+ - `util` - All other utilities not found in the other directories
17
+ - `writes` - Helpers that abstract Roam's write API into common, easy-to-invoke, typed actions
18
+
19
+ We recommend using modular imports for using any methods found in these libraries. For example,
20
+
21
+ ```typescript
22
+ import getTextByBlockUid from "roam-client/queries/getTextByBlockUid";
23
+ ```
8
24
 
9
- You will therefore need to install the following peer dependencies when using this library:
25
+ instead of
10
26
 
11
- ```bash
12
- npm install react react-dom @blueprintjs/core @blueprintjs/select roamjs-components
27
+ ```typescript
28
+ import { getTextByBlockUid } from "roam-client/queries";
13
29
  ```
14
30
 
15
- If you're using TypeScript, you will additionally need to install:
31
+ though, the latter is still available for convenience.
16
32
 
17
- ```bash
18
- npm install @types/react @types/react-dom
19
- ```
33
+ The rest of this README is not exhaustive, and will soon live in https://roamjs.com/extensions/developer.
20
34
 
21
- ## Utilities
35
+ ## Util
22
36
 
23
37
  The following are a list of methods used to help interface with the RoamJS Components found in this library.
24
38
 
@@ -0,0 +1,2 @@
1
+ export declare const DAILY_NOTE_PAGE_REGEX: RegExp;
2
+ export declare const DAILY_NOTE_PAGE_TITLE_REGEX: RegExp;
@@ -0,0 +1,3 @@
1
+ export const DAILY_NOTE_PAGE_REGEX = /(January|February|March|April|May|June|July|August|September|October|November|December) [0-3]?[0-9](st|nd|rd|th), [0-9][0-9][0-9][0-9]/;
2
+ export const DAILY_NOTE_PAGE_TITLE_REGEX = new RegExp(`^${DAILY_NOTE_PAGE_REGEX.source}$`);
3
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/date/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,qBAAqB,GAChC,wIAAwI,CAAC;AAC3I,MAAM,CAAC,MAAM,2BAA2B,GAAG,IAAI,MAAM,CACnD,IAAI,qBAAqB,CAAC,MAAM,GAAG,CACpC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { default as parseRoamDate } from "./parseRoamDate";
2
+ export { default as parseRoamDateUid } from "./parseRoamDateUid";
3
+ export { default as toRoamDate } from "./toRoamDate";
4
+ export { default as toRoamDateUid } from "./toRoamDateUid";
5
+ export * from "./constants";
package/date/index.js ADDED
@@ -0,0 +1,6 @@
1
+ export { default as parseRoamDate } from "./parseRoamDate";
2
+ export { default as parseRoamDateUid } from "./parseRoamDateUid";
3
+ export { default as toRoamDate } from "./toRoamDate";
4
+ export { default as toRoamDateUid } from "./toRoamDateUid";
5
+ export * from "./constants";
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/date/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,cAAc,aAAa,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const parseRoamDate: (s: string) => Date;
2
+ export default parseRoamDate;
@@ -0,0 +1,4 @@
1
+ import parse from "date-fns/parse";
2
+ const parseRoamDate = (s) => parse(s, "MMMM do, yyyy", new Date());
3
+ export default parseRoamDate;
4
+ //# sourceMappingURL=parseRoamDate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseRoamDate.js","sourceRoot":"","sources":["../src/date/parseRoamDate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,gBAAgB,CAAC;AAEnC,MAAM,aAAa,GAAG,CAAC,CAAS,EAAQ,EAAE,CACxC,KAAK,CAAC,CAAC,EAAE,eAAe,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;AAExC,eAAe,aAAa,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const parseRoamDateUid: (s: string) => Date;
2
+ export default parseRoamDateUid;
@@ -0,0 +1,4 @@
1
+ import parse from "date-fns/parse";
2
+ const parseRoamDateUid = (s) => parse(s, "MM-dd-yyyy", new Date());
3
+ export default parseRoamDateUid;
4
+ //# sourceMappingURL=parseRoamDateUid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseRoamDateUid.js","sourceRoot":"","sources":["../src/date/parseRoamDateUid.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,gBAAgB,CAAC;AAEnC,MAAM,gBAAgB,GAAG,CAAC,CAAS,EAAQ,EAAE,CAC3C,KAAK,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;AAErC,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const toRoamDate: (d?: Date) => string;
2
+ export default toRoamDate;
@@ -0,0 +1,4 @@
1
+ import format from "date-fns/format";
2
+ const toRoamDate = (d = new Date()) => isNaN(d.valueOf()) ? "" : format(d, "MMMM do, yyyy");
3
+ export default toRoamDate;
4
+ //# sourceMappingURL=toRoamDate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toRoamDate.js","sourceRoot":"","sources":["../src/date/toRoamDate.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAErC,MAAM,UAAU,GAAG,CAAC,CAAC,GAAG,IAAI,IAAI,EAAE,EAAU,EAAE,CAC5C,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;AAEvD,eAAe,UAAU,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const toRoamDateUid: (d?: Date) => string;
2
+ export default toRoamDateUid;
@@ -0,0 +1,4 @@
1
+ import format from "date-fns/format";
2
+ const toRoamDateUid = (d = new Date()) => isNaN(d.valueOf()) ? "" : format(d, "MM-dd-yyyy");
3
+ export default toRoamDateUid;
4
+ //# sourceMappingURL=toRoamDateUid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toRoamDateUid.js","sourceRoot":"","sources":["../src/date/toRoamDateUid.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAErC,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,IAAI,IAAI,EAAE,EAAU,EAAE,CAC/C,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;AAEpD,eAAe,aAAa,CAAC"}
@@ -0,0 +1,5 @@
1
+ declare const addBlockCommand: ({ label, callback, }: {
2
+ label: string;
3
+ callback: (uid: string) => void;
4
+ }) => void;
5
+ export default addBlockCommand;
@@ -0,0 +1,52 @@
1
+ import getChildrenLengthByPageUid from "../queries/getChildrenLengthByPageUid";
2
+ import getOrderByBlockUid from "../queries/getOrderByBlockUid";
3
+ import getParentUidByBlockUid from "../queries/getParentUidByBlockUid";
4
+ import getTextByBlockUid from "../queries/getTextByBlockUid";
5
+ import createBlock from "../writes/createBlock";
6
+ import updateBlock from "../writes/updateBlock";
7
+ import createHTMLObserver from "./createHTMLObserver";
8
+ import getCurrentPageUid from "./getCurrentPageUid";
9
+ import getUids from "./getUids";
10
+ const addBlockCommand = ({ label, callback, }) => {
11
+ const textareaRef = {
12
+ current: null,
13
+ };
14
+ const loadBlockUid = (pageUid) => {
15
+ if (textareaRef.current) {
16
+ const uid = getUids(textareaRef.current).blockUid;
17
+ const parentUid = getParentUidByBlockUid(uid);
18
+ const text = getTextByBlockUid(uid);
19
+ if (text.length) {
20
+ return createBlock({
21
+ node: { text: "Loading..." },
22
+ parentUid,
23
+ order: getOrderByBlockUid(uid) + 1,
24
+ });
25
+ }
26
+ return updateBlock({
27
+ uid,
28
+ text: "Loading...",
29
+ });
30
+ }
31
+ return createBlock({
32
+ node: { text: "Loading..." },
33
+ parentUid: pageUid,
34
+ order: getChildrenLengthByPageUid(pageUid),
35
+ });
36
+ };
37
+ createHTMLObserver({
38
+ tag: "TEXTAREA",
39
+ className: "rm-block-input",
40
+ callback: (t) => (textareaRef.current = t),
41
+ });
42
+ window.roamAlphaAPI.ui.commandPalette.addCommand({
43
+ label,
44
+ callback: () => {
45
+ const parentUid = getCurrentPageUid();
46
+ const blockUid = loadBlockUid(parentUid);
47
+ return callback(blockUid);
48
+ },
49
+ });
50
+ };
51
+ export default addBlockCommand;
52
+ //# sourceMappingURL=addBlockCommand.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addBlockCommand.js","sourceRoot":"","sources":["../src/dom/addBlockCommand.ts"],"names":[],"mappings":"AAAA,OAAO,0BAA0B,MAAM,uCAAuC,CAAC;AAC/E,OAAO,kBAAkB,MAAM,+BAA+B,CAAC;AAC/D,OAAO,sBAAsB,MAAM,mCAAmC,CAAC;AACvE,OAAO,iBAAiB,MAAM,8BAA8B,CAAC;AAC7D,OAAO,WAAW,MAAM,uBAAuB,CAAC;AAChD,OAAO,WAAW,MAAM,uBAAuB,CAAC;AAChD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,OAAO,MAAM,WAAW,CAAC;AAEhC,MAAM,eAAe,GAAG,CAAC,EACvB,KAAK,EACL,QAAQ,GAIT,EAAQ,EAAE;IACT,MAAM,WAAW,GAA4C;QAC3D,OAAO,EAAE,IAAI;KACd,CAAC;IACF,MAAM,YAAY,GAAG,CAAC,OAAe,EAAE,EAAE;QACvC,IAAI,WAAW,CAAC,OAAO,EAAE;YACvB,MAAM,GAAG,GAAG,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC;YAClD,MAAM,SAAS,GAAG,sBAAsB,CAAC,GAAG,CAAC,CAAC;YAC9C,MAAM,IAAI,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC;YACpC,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,OAAO,WAAW,CAAC;oBACjB,IAAI,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE;oBAC5B,SAAS;oBACT,KAAK,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC;iBACnC,CAAC,CAAC;aACJ;YACD,OAAO,WAAW,CAAC;gBACjB,GAAG;gBACH,IAAI,EAAE,YAAY;aACnB,CAAC,CAAC;SACJ;QACD,OAAO,WAAW,CAAC;YACjB,IAAI,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE;YAC5B,SAAS,EAAE,OAAO;YAClB,KAAK,EAAE,0BAA0B,CAAC,OAAO,CAAC;SAC3C,CAAC,CAAC;IACL,CAAC,CAAC;IACF,kBAAkB,CAAC;QACjB,GAAG,EAAE,UAAU;QACf,SAAS,EAAE,gBAAgB;QAC3B,QAAQ,EAAE,CAAC,CAAc,EAAE,EAAE,CAC3B,CAAC,WAAW,CAAC,OAAO,GAAG,CAAwB,CAAC;KACnD,CAAC,CAAC;IACH,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC;QAC/C,KAAK;QACL,QAAQ,EAAE,GAAG,EAAE;YACb,MAAM,SAAS,GAAG,iBAAiB,EAAE,CAAC;YACtC,MAAM,QAAQ,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;YACzC,OAAO,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC;KACF,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const addOldRoamJSDependency: (extension: string) => void;
2
+ export default addOldRoamJSDependency;
@@ -0,0 +1,15 @@
1
+ const addOldRoamJSDependency = (extension) => {
2
+ var _a;
3
+ const id = `roamjs-${extension.replace(/\/main$/, "")}`;
4
+ const existing = document.getElementById(id);
5
+ if (!existing) {
6
+ const script = document.createElement("script");
7
+ script.src = `https://roamjs.com/${extension}.js`;
8
+ script.async = true;
9
+ script.type = "text/javascript";
10
+ script.id = id;
11
+ (_a = document.querySelector("head")) === null || _a === void 0 ? void 0 : _a.appendChild(script);
12
+ }
13
+ };
14
+ export default addOldRoamJSDependency;
15
+ //# sourceMappingURL=addOldRoamJSDependency.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addOldRoamJSDependency.js","sourceRoot":"","sources":["../src/dom/addOldRoamJSDependency.ts"],"names":[],"mappings":"AAAA,MAAM,sBAAsB,GAAG,CAAC,SAAiB,EAAQ,EAAE;;IACzD,MAAM,EAAE,GAAG,UAAU,SAAS,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,EAAE,CAAC;IACxD,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;IAC7C,IAAI,CAAC,QAAQ,EAAE;QACb,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,CAAC,GAAG,GAAG,sBAAsB,SAAS,KAAK,CAAC;QAClD,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,MAAM,CAAC,IAAI,GAAG,iBAAiB,CAAC;QAChC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC;QACf,MAAA,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,0CAAE,WAAW,CAAC,MAAM,CAAC,CAAC;KACrD;AACH,CAAC,CAAC;AAEF,eAAe,sBAAsB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const addRoamJSDependency: (extension: string) => void;
2
+ export default addRoamJSDependency;
@@ -0,0 +1,6 @@
1
+ import addOldRoamJSDependency from "./addOldRoamJSDependency";
2
+ const addRoamJSDependency = (extension) => {
3
+ addOldRoamJSDependency(`${extension}/main`);
4
+ };
5
+ export default addRoamJSDependency;
6
+ //# sourceMappingURL=addRoamJSDependency.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addRoamJSDependency.js","sourceRoot":"","sources":["../src/dom/addRoamJSDependency.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAE9D,MAAM,mBAAmB,GAAG,CAAC,SAAiB,EAAQ,EAAE;IACtD,sBAAsB,CAAC,GAAG,SAAS,OAAO,CAAC,CAAC;AAC9C,CAAC,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const addStyle: (content: string, id?: string | undefined) => HTMLStyleElement;
2
+ export default addStyle;
@@ -0,0 +1,13 @@
1
+ const addStyle = (content, id) => {
2
+ const existing = document.getElementById(id || "");
3
+ if (existing)
4
+ return existing;
5
+ const css = document.createElement("style");
6
+ css.textContent = content;
7
+ if (id)
8
+ css.id = id;
9
+ document.getElementsByTagName("head")[0].appendChild(css);
10
+ return css;
11
+ };
12
+ export default addStyle;
13
+ //# sourceMappingURL=addStyle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addStyle.js","sourceRoot":"","sources":["../src/dom/addStyle.ts"],"names":[],"mappings":"AAAA,MAAM,QAAQ,GAAG,CAAC,OAAe,EAAE,EAAW,EAAoB,EAAE;IAClE,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,EAAE,IAAI,EAAE,CAAqB,CAAC;IACvE,IAAI,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAC9B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC5C,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;IAC1B,IAAI,EAAE;QAAE,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;IACpB,QAAQ,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC1D,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const BLOCK_REF_REGEX: RegExp;
@@ -0,0 +1,2 @@
1
+ export const BLOCK_REF_REGEX = /\(\(([\w\d-]{9,10})\)\)/;
2
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/dom/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,eAAe,GAAG,yBAAyB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createBlockObserver: (blockCallback: (b: HTMLDivElement) => void, blockRefCallback?: ((b: HTMLSpanElement) => void) | undefined) => void;
2
+ export default createBlockObserver;
@@ -0,0 +1,17 @@
1
+ import createHTMLObserver from "./createHTMLObserver";
2
+ const createBlockObserver = (blockCallback, blockRefCallback) => {
3
+ createHTMLObserver({
4
+ callback: (e) => blockCallback(e),
5
+ tag: "DIV",
6
+ className: "roam-block",
7
+ });
8
+ if (blockRefCallback) {
9
+ createHTMLObserver({
10
+ callback: blockRefCallback,
11
+ tag: "SPAN",
12
+ className: "rm-block-ref",
13
+ });
14
+ }
15
+ };
16
+ export default createBlockObserver;
17
+ //# sourceMappingURL=createBlockObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createBlockObserver.js","sourceRoot":"","sources":["../src/dom/createBlockObserver.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAEtD,MAAM,mBAAmB,GAAG,CAC1B,aAA0C,EAC1C,gBAA+C,EACzC,EAAE;IACR,kBAAkB,CAAC;QACjB,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAmB,CAAC;QACnD,GAAG,EAAE,KAAK;QACV,SAAS,EAAE,YAAY;KACxB,CAAC,CAAC;IACH,IAAI,gBAAgB,EAAE;QACpB,kBAAkB,CAAC;YACjB,QAAQ,EAAE,gBAAgB;YAC1B,GAAG,EAAE,MAAM;YACX,SAAS,EAAE,cAAc;SAC1B,CAAC,CAAC;KACJ;AACH,CAAC,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
@@ -0,0 +1,6 @@
1
+ declare const createButtonObserver: ({ attribute, render, shortcut, }: {
2
+ shortcut?: string | undefined;
3
+ attribute: string;
4
+ render: (b: HTMLButtonElement) => void;
5
+ }) => void;
6
+ export default createButtonObserver;
@@ -0,0 +1,19 @@
1
+ import createHTMLObserver from "./createHTMLObserver";
2
+ const createButtonObserver = ({ attribute, render, shortcut = attribute, }) => createHTMLObserver({
3
+ callback: (b) => {
4
+ if (b.innerText.toUpperCase() ===
5
+ attribute.toUpperCase().replace(/-/g, " ") ||
6
+ b.innerText.toUpperCase() === shortcut.toUpperCase()) {
7
+ const dataAttribute = `data-roamjs-${attribute}`;
8
+ if (!b.getAttribute(dataAttribute)) {
9
+ b.setAttribute(dataAttribute, "true");
10
+ render(b);
11
+ }
12
+ }
13
+ },
14
+ tag: "BUTTON",
15
+ className: "bp3-button",
16
+ useBody: true,
17
+ });
18
+ export default createButtonObserver;
19
+ //# sourceMappingURL=createButtonObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createButtonObserver.js","sourceRoot":"","sources":["../src/dom/createButtonObserver.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAEtD,MAAM,oBAAoB,GAAG,CAAC,EAC5B,SAAS,EACT,MAAM,EACN,QAAQ,GAAG,SAAS,GAKrB,EAAQ,EAAE,CACT,kBAAkB,CAAC;IACjB,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;QACd,IACE,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE;YACvB,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;YAC5C,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,WAAW,EAAE,EACpD;YACA,MAAM,aAAa,GAAG,eAAe,SAAS,EAAE,CAAC;YACjD,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE;gBAClC,CAAC,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;gBACtC,MAAM,CAAC,CAAsB,CAAC,CAAC;aAChC;SACF;IACH,CAAC;IACD,GAAG,EAAE,QAAQ;IACb,SAAS,EAAE,YAAY;IACvB,OAAO,EAAE,IAAI;CACd,CAAC,CAAC;AAEL,eAAe,oBAAoB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createDivObserver: (mutationCallback: MutationCallback, mutationTarget: Element) => void;
2
+ export default createDivObserver;
@@ -0,0 +1,6 @@
1
+ const createDivObserver = (mutationCallback, mutationTarget) => {
2
+ const observer = new MutationObserver(mutationCallback);
3
+ observer.observe(mutationTarget, { childList: true, subtree: true });
4
+ };
5
+ export default createDivObserver;
6
+ //# sourceMappingURL=createDivObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createDivObserver.js","sourceRoot":"","sources":["../src/dom/createDivObserver.ts"],"names":[],"mappings":"AAEA,MAAM,iBAAiB,GAAG,CACxB,gBAAkC,EAClC,cAAuB,EACvB,EAAE;IACF,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;IACxD,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;AACvE,CAAC,CAAA;AAED,eAAe,iBAAiB,CAAC"}
@@ -0,0 +1,8 @@
1
+ declare const createHTMLObserver: ({ callback, tag, className, removeCallback, useBody, }: {
2
+ callback: (b: HTMLElement) => void;
3
+ tag: string;
4
+ className: string;
5
+ removeCallback?: ((b: HTMLElement) => void) | undefined;
6
+ useBody?: boolean | undefined;
7
+ }) => void;
8
+ export default createHTMLObserver;
@@ -0,0 +1,27 @@
1
+ import createObserver from "./createObserver";
2
+ import createOverlayObserver from "./createOverlayObserver";
3
+ import getMutatedNodes from "./getMutatedNodes";
4
+ const createHTMLObserver = ({ callback, tag, className, removeCallback, useBody, }) => {
5
+ const blocks = document.getElementsByClassName(className);
6
+ Array.from(blocks).forEach(callback);
7
+ (useBody ? createOverlayObserver : createObserver)((ms) => {
8
+ const addedNodes = getMutatedNodes({
9
+ ms,
10
+ nodeList: "addedNodes",
11
+ tag,
12
+ className,
13
+ });
14
+ addedNodes.map((n) => n).forEach(callback);
15
+ if (removeCallback) {
16
+ const removedNodes = getMutatedNodes({
17
+ ms,
18
+ nodeList: "removedNodes",
19
+ tag,
20
+ className,
21
+ });
22
+ removedNodes.map((n) => n).forEach(removeCallback);
23
+ }
24
+ });
25
+ };
26
+ export default createHTMLObserver;
27
+ //# sourceMappingURL=createHTMLObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createHTMLObserver.js","sourceRoot":"","sources":["../src/dom/createHTMLObserver.ts"],"names":[],"mappings":"AAAA,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAEhD,MAAM,kBAAkB,GAAG,CAAC,EAC1B,QAAQ,EACR,GAAG,EACH,SAAS,EACT,cAAc,EACd,OAAO,GAOR,EAAQ,EAAE;IACT,MAAM,MAAM,GAAG,QAAQ,CAAC,sBAAsB,CAC5C,SAAS,CACuB,CAAC;IACnC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC,OAAO,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE;QACxD,MAAM,UAAU,GAAG,eAAe,CAAC;YACjC,EAAE;YACF,QAAQ,EAAE,YAAY;YACtB,GAAG;YACH,SAAS;SACV,CAAC,CAAC;QACH,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAgB,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAC1D,IAAI,cAAc,EAAE;YAClB,MAAM,YAAY,GAAG,eAAe,CAAC;gBACnC,EAAE;gBACF,QAAQ,EAAE,cAAc;gBACxB,GAAG;gBACH,SAAS;aACV,CAAC,CAAC;YACH,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAgB,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;SACnE;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,5 @@
1
+ declare const createHashtagObserver: ({ callback, attribute, }: {
2
+ callback: (s: HTMLSpanElement) => void;
3
+ attribute: string;
4
+ }) => void;
5
+ export default createHashtagObserver;
@@ -0,0 +1,14 @@
1
+ import createHTMLObserver from "./createHTMLObserver";
2
+ const createHashtagObserver = ({ callback, attribute, }) => createHTMLObserver({
3
+ useBody: true,
4
+ tag: "SPAN",
5
+ className: "rm-page-ref--tag",
6
+ callback: (s) => {
7
+ if (!s.getAttribute(attribute)) {
8
+ s.setAttribute(attribute, "true");
9
+ callback(s);
10
+ }
11
+ },
12
+ });
13
+ export default createHashtagObserver;
14
+ //# sourceMappingURL=createHashtagObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createHashtagObserver.js","sourceRoot":"","sources":["../src/dom/createHashtagObserver.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAEtD,MAAM,qBAAqB,GAAG,CAAC,EAC7B,QAAQ,EACR,SAAS,GAIV,EAAQ,EAAE,CACT,kBAAkB,CAAC;IACjB,OAAO,EAAE,IAAI;IACb,GAAG,EAAE,MAAM;IACX,SAAS,EAAE,kBAAkB;IAC7B,QAAQ,EAAE,CAAC,CAAkB,EAAE,EAAE;QAC/B,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;YAC9B,CAAC,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;YAClC,QAAQ,CAAC,CAAC,CAAC,CAAC;SACb;IACH,CAAC;CACF,CAAC,CAAC;AAEL,eAAe,qBAAqB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createIconButton: (icon: string) => HTMLSpanElement;
2
+ export default createIconButton;
@@ -0,0 +1,11 @@
1
+ const createIconButton = (icon) => {
2
+ const popoverButton = document.createElement("span");
3
+ popoverButton.className = "bp3-button bp3-minimal bp3-small";
4
+ popoverButton.tabIndex = 0;
5
+ const popoverIcon = document.createElement("span");
6
+ popoverIcon.className = `bp3-icon bp3-icon-${icon}`;
7
+ popoverButton.appendChild(popoverIcon);
8
+ return popoverButton;
9
+ };
10
+ export default createIconButton;
11
+ //# sourceMappingURL=createIconButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createIconButton.js","sourceRoot":"","sources":["../src/dom/createIconButton.ts"],"names":[],"mappings":"AAAA,MAAM,gBAAgB,GAAG,CAAC,IAAY,EAAmB,EAAE;IACzD,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACrD,aAAa,CAAC,SAAS,GAAG,kCAAkC,CAAC;IAC7D,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC;IAE3B,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACnD,WAAW,CAAC,SAAS,GAAG,qBAAqB,IAAI,EAAE,CAAC;IACpD,aAAa,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IAEvC,OAAO,aAAa,CAAC;AACvB,CAAC,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createObserver: (mutationCallback: (mutationList: MutationRecord[], observer: MutationObserver) => void) => void;
2
+ export default createObserver;
@@ -0,0 +1,4 @@
1
+ import createDivObserver from "./createDivObserver";
2
+ const createObserver = (mutationCallback) => createDivObserver(mutationCallback, document.getElementsByClassName("roam-body")[0]);
3
+ export default createObserver;
4
+ //# sourceMappingURL=createObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createObserver.js","sourceRoot":"","sources":["../src/dom/createObserver.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AAEpD,MAAM,cAAc,GAAG,CACrB,gBAGS,EACH,EAAE,CACR,iBAAiB,CACf,gBAAgB,EAChB,QAAQ,CAAC,sBAAsB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAChD,CAAC;AAEJ,eAAe,cAAc,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createOverlayObserver: (mutationCallback: (mutationList: MutationRecord[]) => void) => void;
2
+ export default createOverlayObserver;
@@ -0,0 +1,4 @@
1
+ import createDivObserver from "./createDivObserver";
2
+ const createOverlayObserver = (mutationCallback) => createDivObserver(mutationCallback, document.body);
3
+ export default createOverlayObserver;
4
+ //# sourceMappingURL=createOverlayObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createOverlayObserver.js","sourceRoot":"","sources":["../src/dom/createOverlayObserver.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AAEpD,MAAM,qBAAqB,GAAG,CAC5B,gBAA0D,EACpD,EAAE,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;AAE9D,eAAe,qBAAqB,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const createPageObserver: (name: string, callback: (blockUid: string, added: boolean) => void) => void;
2
+ export default createPageObserver;
@@ -0,0 +1,32 @@
1
+ import getBlockUidsByPageTitle from "../queries/getBlockUidsByPageTitle";
2
+ import createObserver from "./createObserver";
3
+ import getMutatedNodes from "./getMutatedNodes";
4
+ import getUids from "./getUids";
5
+ const createPageObserver = (name, callback) => createObserver((ms) => {
6
+ const addedNodes = getMutatedNodes({
7
+ ms,
8
+ nodeList: "addedNodes",
9
+ tag: "DIV",
10
+ className: "roam-block",
11
+ }).map((blockNode) => ({
12
+ blockUid: getUids(blockNode).blockUid,
13
+ added: true,
14
+ }));
15
+ const removedNodes = getMutatedNodes({
16
+ ms,
17
+ nodeList: "removedNodes",
18
+ tag: "DIV",
19
+ className: "roam-block",
20
+ }).map((blockNode) => ({
21
+ blockUid: getUids(blockNode).blockUid,
22
+ added: false,
23
+ }));
24
+ if (addedNodes.length || removedNodes.length) {
25
+ const blockUids = new Set(getBlockUidsByPageTitle(name));
26
+ [...removedNodes, ...addedNodes]
27
+ .filter(({ blockUid }) => blockUids.has(blockUid))
28
+ .forEach(({ blockUid, added }) => callback(blockUid, added));
29
+ }
30
+ });
31
+ export default createPageObserver;
32
+ //# sourceMappingURL=createPageObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createPageObserver.js","sourceRoot":"","sources":["../src/dom/createPageObserver.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,MAAM,oCAAoC,CAAC;AACzE,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,OAAO,MAAM,WAAW,CAAC;AAEhC,MAAM,kBAAkB,GAAG,CACzB,IAAY,EACZ,QAAoD,EAC9C,EAAE,CACR,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE;IACpB,MAAM,UAAU,GAAG,eAAe,CAAC;QACjC,EAAE;QACF,QAAQ,EAAE,YAAY;QACtB,GAAG,EAAE,KAAK;QACV,SAAS,EAAE,YAAY;KACxB,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACrB,QAAQ,EAAE,OAAO,CAAC,SAA2B,CAAC,CAAC,QAAQ;QACvD,KAAK,EAAE,IAAI;KACZ,CAAC,CAAC,CAAC;IACJ,MAAM,YAAY,GAAG,eAAe,CAAC;QACnC,EAAE;QACF,QAAQ,EAAE,cAAc;QACxB,GAAG,EAAE,KAAK;QACV,SAAS,EAAE,YAAY;KACxB,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACrB,QAAQ,EAAE,OAAO,CAAC,SAA2B,CAAC,CAAC,QAAQ;QACvD,KAAK,EAAE,KAAK;KACb,CAAC,CAAC,CAAC;IACJ,IAAI,UAAU,CAAC,MAAM,IAAI,YAAY,CAAC,MAAM,EAAE;QAC5C,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,CAAC,GAAG,YAAY,EAAE,GAAG,UAAU,CAAC;aAC7B,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;aACjD,OAAO,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;KAChE;AACH,CAAC,CAAC,CAAA;AAEJ,eAAe,kBAAkB,CAAC"}
@@ -0,0 +1,6 @@
1
+ declare const createPageTitleObserver: ({ title, callback, log, }: {
2
+ title: string;
3
+ callback: (d: HTMLDivElement) => void;
4
+ log?: boolean | undefined;
5
+ }) => void;
6
+ export default createPageTitleObserver;
@@ -0,0 +1,27 @@
1
+ import getPageUidByPageTitle from "../queries/getPageUidByPageTitle";
2
+ import getRoamUrl from "./getRoamUrl";
3
+ const createPageTitleObserver = ({ title, callback, log = false, }) => {
4
+ const listener = (url) => {
5
+ const d = document.getElementsByClassName("roam-article")[0];
6
+ if (d) {
7
+ const uid = getPageUidByPageTitle(title);
8
+ const attribute = `data-roamjs-${uid}`;
9
+ if ((uid && url === getRoamUrl(uid)) || (log && url === getRoamUrl())) {
10
+ // React's rerender crushes the old article/heading
11
+ setTimeout(() => {
12
+ if (!d.hasAttribute(attribute)) {
13
+ d.setAttribute(attribute, "true");
14
+ callback(document.getElementsByClassName("roam-article")[0]);
15
+ }
16
+ }, 1);
17
+ }
18
+ else {
19
+ d.removeAttribute(attribute);
20
+ }
21
+ }
22
+ };
23
+ window.addEventListener("hashchange", (e) => listener(e.newURL));
24
+ listener(window.location.href);
25
+ };
26
+ export default createPageTitleObserver;
27
+ //# sourceMappingURL=createPageTitleObserver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createPageTitleObserver.js","sourceRoot":"","sources":["../src/dom/createPageTitleObserver.ts"],"names":[],"mappings":"AAAA,OAAO,qBAAqB,MAAM,kCAAkC,CAAC;AACrE,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,MAAM,uBAAuB,GAAG,CAAC,EAC/B,KAAK,EACL,QAAQ,EACR,GAAG,GAAG,KAAK,GAKZ,EAAQ,EAAE;IACT,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAE,EAAE;QAC/B,MAAM,CAAC,GAAG,QAAQ,CAAC,sBAAsB,CACvC,cAAc,CACf,CAAC,CAAC,CAAmB,CAAC;QACvB,IAAI,CAAC,EAAE;YACL,MAAM,GAAG,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;YACzC,MAAM,SAAS,GAAG,eAAe,GAAG,EAAE,CAAC;YACvC,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,UAAU,EAAE,CAAC,EAAE;gBACrE,mDAAmD;gBACnD,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;wBAC9B,CAAC,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;wBAClC,QAAQ,CACN,QAAQ,CAAC,sBAAsB,CAC7B,cAAc,CACf,CAAC,CAAC,CAAmB,CACvB,CAAC;qBACH;gBACH,CAAC,EAAE,CAAC,CAAC,CAAC;aACP;iBAAM;gBACL,CAAC,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;aAC9B;SACF;IACH,CAAC,CAAC;IACF,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACjE,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AACjC,CAAC,CAAC;AAEF,eAAe,uBAAuB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { AxiosError } from "axios";
2
+ import type { RoamError } from "../types";
3
+ declare const genericError: (e: Partial<AxiosError & RoamError>) => string;
4
+ export default genericError;
@@ -0,0 +1,15 @@
1
+ import { updateActiveBlock } from "../writes";
2
+ const genericError = (e) => {
3
+ const message = (e.response
4
+ ? typeof e.response.data === "string"
5
+ ? e.response.data
6
+ : JSON.stringify(e.response.data)
7
+ : e.message) ||
8
+ e.raw ||
9
+ "Unknown Error Occurred";
10
+ const errMsg = `Error: ${message.length > 50 ? `${message.substring(0, 50)}...` : message}`;
11
+ updateActiveBlock(errMsg);
12
+ return errMsg;
13
+ };
14
+ export default genericError;
15
+ //# sourceMappingURL=genericError.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"genericError.js","sourceRoot":"","sources":["../src/dom/genericError.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAA;AAE7C,MAAM,YAAY,GAAG,CAAC,CAAkC,EAAU,EAAE;IAClE,MAAM,OAAO,GACX,CAAC,CAAC,CAAC,QAAQ;QACT,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAQ;YACnC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI;YACjB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;QACnC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACd,CAAC,CAAC,GAAG;QACL,wBAAwB,CAAC;IAC3B,MAAM,MAAM,GAAG,UACb,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,OAC3D,EAAE,CAAC;IACH,iBAAiB,CAAC,MAAM,CAAC,CAAC;IAC1B,OAAO,MAAM,CAAC;AAChB,CAAC,CAAA;AAED,eAAe,YAAY,CAAC"}
@@ -0,0 +1,3 @@
1
+ import getUids from "./getUids";
2
+ declare const getActiveUids: () => ReturnType<typeof getUids>;
3
+ export default getActiveUids;
@@ -0,0 +1,4 @@
1
+ import getUids from "./getUids";
2
+ const getActiveUids = () => getUids(document.activeElement);
3
+ export default getActiveUids;
4
+ //# sourceMappingURL=getActiveUids.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getActiveUids.js","sourceRoot":"","sources":["../src/dom/getActiveUids.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,WAAW,CAAC;AAEhC,MAAM,aAAa,GAAG,GAA+B,EAAE,CACrD,OAAO,CAAC,QAAQ,CAAC,aAAoC,CAAC,CAAA;AAExD,eAAe,aAAa,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare const getBlockUidFromTarget: (target: HTMLElement) => string;
2
+ export default getBlockUidFromTarget;