roamjs-components 0.85.1 → 0.86.0-alpha.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.
- package/.eslintrc.json +19 -0
- package/.github/workflows/main.yaml +34 -0
- package/LICENSE +21 -21
- package/README.md +29 -29
- package/docs/components.md +32 -0
- package/docs/date.md +13 -0
- package/docs/dom.md +58 -0
- package/docs/events.md +16 -0
- package/docs/hooks.md +15 -0
- package/docs/marked.md +56 -0
- package/docs/queries.md +24 -0
- package/docs/scripts.md +20 -0
- package/docs/types.md +32 -0
- package/docs/util.md +38 -0
- package/docs/writes.md +23 -0
- package/package.json +125 -117
- package/patches/@blueprintjs+core+3.50.4.patch +48 -0
- package/patches/@blueprintjs+select+3.18.6.patch +12 -0
- package/patches/dotenv+16.3.1.patch +12 -0
- package/src/components/AutocompleteInput.tsx +248 -0
- package/src/components/BlockErrorBoundary.tsx +39 -0
- package/src/components/BlockInput.tsx +117 -0
- package/src/components/ComponentContainer.tsx +70 -0
- package/src/components/ConfigPage.tsx +320 -0
- package/src/components/ConfigPanels/BlockPanel.tsx +60 -0
- package/src/components/ConfigPanels/BlocksPanel.tsx +100 -0
- package/src/components/ConfigPanels/CustomPanel.tsx +41 -0
- package/src/components/ConfigPanels/FlagPanel.tsx +48 -0
- package/src/components/ConfigPanels/MultiChildPanel.tsx +99 -0
- package/src/components/ConfigPanels/MultiTextPanel.tsx +23 -0
- package/src/components/ConfigPanels/NumberPanel.tsx +36 -0
- package/src/components/ConfigPanels/OauthPanel.tsx +127 -0
- package/src/components/ConfigPanels/PagesPanel.tsx +19 -0
- package/src/components/ConfigPanels/SelectPanel.tsx +46 -0
- package/src/components/ConfigPanels/TextPanel.tsx +44 -0
- package/src/components/ConfigPanels/TimePanel.tsx +45 -0
- package/src/components/ConfigPanels/getBrandColors.tsx +31 -0
- package/src/components/ConfigPanels/types.ts +111 -0
- package/src/components/ConfigPanels/useSingleChildValue.tsx +63 -0
- package/src/components/CursorMenu.tsx +286 -0
- package/src/components/Description.tsx +31 -0
- package/src/components/ExtensionApiContext.tsx +24 -0
- package/src/components/ExternalLogin.tsx +190 -0
- package/src/components/Filter.tsx +313 -0
- package/src/components/FormDialog.tsx +503 -0
- package/src/components/Loading.tsx +33 -0
- package/src/components/MenuItemSelect.tsx +93 -0
- package/src/components/OauthPanel.tsx +62 -0
- package/src/components/OauthSelect.tsx +40 -0
- package/src/components/PageInput.tsx +17 -0
- package/src/components/PageLink.tsx +50 -0
- package/src/components/ProgressDialog.tsx +85 -0
- package/src/components/SimpleAlert.tsx +103 -0
- package/src/components/Toast.tsx +85 -0
- package/src/components/index.ts +5 -0
- package/src/components.tsx +285 -0
- package/src/date/constants.ts +19 -0
- package/{date/index.d.ts → src/date/index.ts} +3 -3
- package/src/date/parseNlpDate.ts +255 -0
- package/src/date/parseRoamDateUid.ts +6 -0
- package/src/dom/addBlockCommand.ts +59 -0
- package/src/dom/addKeyboardTriggers.ts +52 -0
- package/src/dom/addOldRoamJSDependency.ts +10 -0
- package/src/dom/addRoamJSDependency.ts +7 -0
- package/src/dom/addScriptAsDependency.ts +24 -0
- package/src/dom/addStyle.ts +11 -0
- package/src/dom/constants.ts +1 -0
- package/src/dom/createBlockObserver.ts +44 -0
- package/src/dom/createButtonObserver.ts +31 -0
- package/src/dom/createDivObserver.ts +15 -0
- package/src/dom/createHTMLObserver.ts +44 -0
- package/src/dom/createHashtagObserver.ts +22 -0
- package/src/dom/createIconButton.ts +13 -0
- package/src/dom/createObserver.ts +15 -0
- package/src/dom/createOverlayObserver.ts +7 -0
- package/src/dom/createPageObserver.ts +37 -0
- package/src/dom/createPageTitleObserver.ts +43 -0
- package/src/dom/elToTitle.ts +21 -0
- package/src/dom/genericError.ts +13 -0
- package/src/dom/getActiveUids.ts +6 -0
- package/src/dom/getBlockUidFromTarget.ts +39 -0
- package/src/dom/getCurrentPageUid.ts +5 -0
- package/src/dom/getDomRefs.ts +15 -0
- package/src/dom/getDropUidOffset.ts +36 -0
- package/src/dom/getMutatedNodes.ts +31 -0
- package/src/dom/getPageTitleByHtmlElement.ts +19 -0
- package/src/dom/getPageTitleValueByHtmlElement.ts +8 -0
- package/src/dom/getReferenceBlockUid.ts +22 -0
- package/src/dom/getRoamUrl.ts +6 -0
- package/src/dom/getRoamUrlByPage.ts +9 -0
- package/src/dom/getUids.ts +9 -0
- package/src/dom/getUidsFromButton.ts +9 -0
- package/src/dom/getUidsFromId.ts +13 -0
- package/{dom/index.d.ts → src/dom/index.ts} +30 -30
- package/src/dom/parseRoamBlocksToHtml.ts +118 -0
- package/src/dom/resolveRefs.ts +31 -0
- package/{events/index.d.ts → src/events/index.ts} +1 -1
- package/src/events/watchOnce.ts +17 -0
- package/{hooks/index.d.ts → src/hooks/index.ts} +2 -2
- package/src/hooks/useArrowKeyDown.ts +72 -0
- package/src/hooks/useSubTree.ts +16 -0
- package/src/marked/index.ts +619 -0
- package/src/queries/compileDatalog.ts +81 -0
- package/src/queries/getAllBlockUids.ts +6 -0
- package/src/queries/getAllBlockUidsAndTexts.ts +6 -0
- package/src/queries/getAllPageNames.ts +6 -0
- package/src/queries/getAttributeValueByBlockAndName.ts +23 -0
- package/src/queries/getBasicTreeByParentUid.ts +21 -0
- package/src/queries/getBlockUidAndTextIncludingText.ts +15 -0
- package/src/queries/getBlockUidByTextOnPage.ts +12 -0
- package/src/queries/getBlockUidsAndTextsReferencingPage.ts +18 -0
- package/src/queries/getBlockUidsByPageTitle.ts +12 -0
- package/src/queries/getBlockUidsReferencingBlock.ts +10 -0
- package/src/queries/getBlockUidsReferencingPage.ts +13 -0
- package/src/queries/getBlockUidsWithParentUid.ts +10 -0
- package/src/queries/getChildrenLengthByPageUid.ts +7 -0
- package/src/queries/getChildrenLengthByParentUid.ts +6 -0
- package/src/queries/getCreateTimeByBlockUid.ts +6 -0
- package/src/queries/getCurrentUser.ts +12 -0
- package/src/queries/getCurrentUserDisplayName.ts +9 -0
- package/src/queries/getCurrentUserEmail.ts +12 -0
- package/src/queries/getCurrentUserUid.ts +12 -0
- package/src/queries/getDisplayNameByEmail.ts +6 -0
- package/src/queries/getDisplayNameByUid.ts +6 -0
- package/src/queries/getEditTimeByBlockUid.ts +6 -0
- package/src/queries/getEditedUserEmailByBlockUid.ts +6 -0
- package/src/queries/getFirstChildTextByBlockUid.ts +8 -0
- package/src/queries/getFirstChildUidByBlockUid.ts +6 -0
- package/src/queries/getFullTreeByParentUid.ts +60 -0
- package/src/queries/getLinkedPageTitlesUnderUid.ts +8 -0
- package/src/queries/getNthChildUidByBlockUid.ts +16 -0
- package/src/queries/getOrderByBlockUid.ts +6 -0
- package/src/queries/getPageTitleByBlockUid.ts +8 -0
- package/src/queries/getPageTitleByPageUid.ts +11 -0
- package/src/queries/getPageTitleReferencesByPageTitle.ts +13 -0
- package/src/queries/getPageTitlesAndBlockUidsReferencingPage.ts +18 -0
- package/src/queries/getPageTitlesAndUidsDirectlyReferencingPage.ts +18 -0
- package/src/queries/getPageTitlesReferencingBlockUid.ts +10 -0
- package/src/queries/getPageTitlesStartingWithPrefix.ts +8 -0
- package/src/queries/getPageUidByBlockUid.ts +8 -0
- package/src/queries/getPageUidByPageTitle.ts +10 -0
- package/src/queries/getPageViewType.ts +11 -0
- package/src/queries/getParentTextByBlockUid.ts +6 -0
- package/src/queries/getParentTextByBlockUidAndTag.ts +12 -0
- package/src/queries/getParentUidByBlockUid.ts +10 -0
- package/src/queries/getParentUidsOfBlockUid.ts +10 -0
- package/src/queries/getSettingsByEmail.ts +8 -0
- package/src/queries/getShallowTreeByParentUid.ts +17 -0
- package/src/queries/getTextByBlockUid.ts +8 -0
- package/src/queries/index.ts +5 -0
- package/src/queries/isLiveBlock.ts +4 -0
- package/src/queries/isTagOnPage.ts +12 -0
- package/src/queries/normalizePageTitle.ts +4 -0
- package/src/scripts/index.ts +2 -0
- package/src/scripts/publishToRoamDepot.ts +163 -0
- package/src/testing/mockRoamEnvironment.ts +1489 -0
- package/src/types/index.ts +260 -0
- package/src/types/native.ts +495 -0
- package/src/types/query-builder.ts +10 -0
- package/src/types/smartblocks.ts +39 -0
- package/src/util/addInputSetting.ts +33 -0
- package/src/util/apiDelete.ts +5 -0
- package/src/util/apiGet.ts +5 -0
- package/src/util/apiPost.ts +5 -0
- package/src/util/apiPut.ts +5 -0
- package/src/util/createOverlayRender.ts +12 -0
- package/src/util/createTagRegex.ts +7 -0
- package/src/util/dispatchToRegistry.ts +11 -0
- package/src/util/env.ts +44 -0
- package/src/util/extensionApiContext.ts +17 -0
- package/src/util/extensionDeprecatedWarning.ts +57 -0
- package/src/util/extractRef.ts +8 -0
- package/src/util/extractTag.ts +15 -0
- package/src/util/focusMainWindowBlock.ts +13 -0
- package/src/util/getAuthorizationHeader.ts +11 -0
- package/src/util/getLocalStorageKey.ts +4 -0
- package/src/util/getOauth.ts +57 -0
- package/src/util/getOauthAccounts.ts +26 -0
- package/src/util/getRenderRoot.ts +17 -0
- package/src/util/getSettingIntFromTree.ts +18 -0
- package/src/util/getSettingValueFromTree.ts +23 -0
- package/src/util/getSettingValuesFromTree.ts +20 -0
- package/src/util/getSubTree.ts +31 -0
- package/src/util/getToken.ts +12 -0
- package/src/util/getTokenFromTree.ts +6 -0
- package/src/util/getWorkerClient.ts +55 -0
- package/src/util/handleBodyFetch.ts +38 -0
- package/src/util/handleFetch.ts +70 -0
- package/src/util/handleUrlFetch.ts +30 -0
- package/src/util/idToTitle.ts +8 -0
- package/{util/index.d.ts → src/util/index.ts} +24 -24
- package/src/util/isControl.ts +4 -0
- package/src/util/localStorageGet.ts +6 -0
- package/src/util/localStorageRemove.ts +6 -0
- package/src/util/localStorageSet.ts +6 -0
- package/src/util/registerExperimentalMode.ts +76 -0
- package/src/util/registerSmartBlocksCommand.ts +23 -0
- package/src/util/removeFromRegistry.ts +11 -0
- package/src/util/renderOverlay.ts +69 -0
- package/src/util/renderWithUnmount.ts +50 -0
- package/src/util/runExtension.ts +206 -0
- package/src/util/setInputSetting.ts +46 -0
- package/src/util/setInputSettings.ts +37 -0
- package/src/util/stripUid.ts +10 -0
- package/src/util/toConfigPageName.ts +3 -0
- package/src/util/toFlexRegex.ts +7 -0
- package/src/writes/clearBlockById.ts +17 -0
- package/src/writes/clearBlockByUid.ts +16 -0
- package/src/writes/createBlock.ts +50 -0
- package/src/writes/createPage.ts +30 -0
- package/src/writes/deleteBlock.ts +9 -0
- package/{writes/index.d.ts → src/writes/index.ts} +8 -8
- package/src/writes/openBlockInSidebar.ts +13 -0
- package/src/writes/submitActions.ts +54 -0
- package/src/writes/updateActiveBlock.ts +17 -0
- package/src/writes/updateBlock.ts +33 -0
- package/tests/backend.test.tsx +28 -0
- package/tests/date.test.ts +26 -0
- package/tests/dom.test.tsx +10 -0
- package/tests/index.test.tsx +25 -0
- package/tests/marked.test.ts +474 -0
- package/tests/util/createTagRegex.test.ts +63 -0
- package/tests/util/extractTag.test.ts +17 -0
- package/tests/util/toFlexRegex.test.ts +7 -0
- package/tsconfig.json +26 -0
- package/components/AutocompleteInput.d.ts +0 -28
- package/components/AutocompleteInput.js +0 -121
- package/components/AutocompleteInput.js.map +0 -1
- package/components/BlockErrorBoundary.d.ts +0 -15
- package/components/BlockErrorBoundary.js +0 -28
- package/components/BlockErrorBoundary.js.map +0 -1
- package/components/BlockInput.d.ts +0 -13
- package/components/BlockInput.js +0 -56
- package/components/BlockInput.js.map +0 -1
- package/components/ComponentContainer.d.ts +0 -10
- package/components/ComponentContainer.js +0 -38
- package/components/ComponentContainer.js.map +0 -1
- package/components/ConfigPage.d.ts +0 -35
- package/components/ConfigPage.js +0 -160
- package/components/ConfigPage.js.map +0 -1
- package/components/ConfigPanels/BlockPanel.d.ts +0 -3
- package/components/ConfigPanels/BlockPanel.js +0 -43
- package/components/ConfigPanels/BlockPanel.js.map +0 -1
- package/components/ConfigPanels/BlocksPanel.d.ts +0 -3
- package/components/ConfigPanels/BlocksPanel.js +0 -69
- package/components/ConfigPanels/BlocksPanel.js.map +0 -1
- package/components/ConfigPanels/CustomPanel.d.ts +0 -3
- package/components/ConfigPanels/CustomPanel.js +0 -25
- package/components/ConfigPanels/CustomPanel.js.map +0 -1
- package/components/ConfigPanels/FlagPanel.d.ts +0 -3
- package/components/ConfigPanels/FlagPanel.js +0 -32
- package/components/ConfigPanels/FlagPanel.js.map +0 -1
- package/components/ConfigPanels/MultiChildPanel.d.ts +0 -9
- package/components/ConfigPanels/MultiChildPanel.js +0 -59
- package/components/ConfigPanels/MultiChildPanel.js.map +0 -1
- package/components/ConfigPanels/MultiTextPanel.d.ts +0 -3
- package/components/ConfigPanels/MultiTextPanel.js +0 -15
- package/components/ConfigPanels/MultiTextPanel.js.map +0 -1
- package/components/ConfigPanels/NumberPanel.d.ts +0 -3
- package/components/ConfigPanels/NumberPanel.js +0 -26
- package/components/ConfigPanels/NumberPanel.js.map +0 -1
- package/components/ConfigPanels/OauthPanel.d.ts +0 -3
- package/components/ConfigPanels/OauthPanel.js +0 -82
- package/components/ConfigPanels/OauthPanel.js.map +0 -1
- package/components/ConfigPanels/PagesPanel.d.ts +0 -3
- package/components/ConfigPanels/PagesPanel.js +0 -12
- package/components/ConfigPanels/PagesPanel.js.map +0 -1
- package/components/ConfigPanels/SelectPanel.d.ts +0 -3
- package/components/ConfigPanels/SelectPanel.js +0 -28
- package/components/ConfigPanels/SelectPanel.js.map +0 -1
- package/components/ConfigPanels/TextPanel.d.ts +0 -3
- package/components/ConfigPanels/TextPanel.js +0 -29
- package/components/ConfigPanels/TextPanel.js.map +0 -1
- package/components/ConfigPanels/TimePanel.d.ts +0 -3
- package/components/ConfigPanels/TimePanel.js +0 -35
- package/components/ConfigPanels/TimePanel.js.map +0 -1
- package/components/ConfigPanels/getBrandColors.d.ts +0 -7
- package/components/ConfigPanels/getBrandColors.js +0 -29
- package/components/ConfigPanels/getBrandColors.js.map +0 -1
- package/components/ConfigPanels/types.d.ts +0 -84
- package/components/ConfigPanels/types.js +0 -3
- package/components/ConfigPanels/types.js.map +0 -1
- package/components/ConfigPanels/useSingleChildValue.d.ts +0 -13
- package/components/ConfigPanels/useSingleChildValue.js +0 -44
- package/components/ConfigPanels/useSingleChildValue.js.map +0 -1
- package/components/CursorMenu.d.ts +0 -21
- package/components/CursorMenu.js +0 -182
- package/components/CursorMenu.js.map +0 -1
- package/components/Description.d.ts +0 -5
- package/components/Description.js +0 -17
- package/components/Description.js.map +0 -1
- package/components/ExtensionApiContext.d.ts +0 -31
- package/components/ExtensionApiContext.js +0 -17
- package/components/ExtensionApiContext.js.map +0 -1
- package/components/ExternalLogin.d.ts +0 -18
- package/components/ExternalLogin.js +0 -142
- package/components/ExternalLogin.js.map +0 -1
- package/components/Filter.d.ts +0 -15
- package/components/Filter.js +0 -143
- package/components/Filter.js.map +0 -1
- package/components/FormDialog.d.ts +0 -55
- package/components/FormDialog.js +0 -224
- package/components/FormDialog.js.map +0 -1
- package/components/Loading.d.ts +0 -4
- package/components/Loading.js +0 -36
- package/components/Loading.js.map +0 -1
- package/components/MenuItemSelect.d.ts +0 -17
- package/components/MenuItemSelect.js +0 -24
- package/components/MenuItemSelect.js.map +0 -1
- package/components/OauthPanel.d.ts +0 -7
- package/components/OauthPanel.js +0 -31
- package/components/OauthPanel.js.map +0 -1
- package/components/OauthSelect.d.ts +0 -5
- package/components/OauthSelect.js +0 -26
- package/components/OauthSelect.js.map +0 -1
- package/components/PageInput.d.ts +0 -6
- package/components/PageInput.js +0 -14
- package/components/PageInput.js.map +0 -1
- package/components/PageLink.d.ts +0 -6
- package/components/PageLink.js +0 -32
- package/components/PageLink.js.map +0 -1
- package/components/ProgressDialog.d.ts +0 -11
- package/components/ProgressDialog.js +0 -61
- package/components/ProgressDialog.js.map +0 -1
- package/components/SimpleAlert.d.ts +0 -15
- package/components/SimpleAlert.js +0 -48
- package/components/SimpleAlert.js.map +0 -1
- package/components/Toast.d.ts +0 -15
- package/components/Toast.js +0 -51
- package/components/Toast.js.map +0 -1
- package/components/index.d.ts +0 -0
- package/components/index.js +0 -5
- package/components/index.js.map +0 -1
- package/components.d.ts +0 -5
- package/components.js +0 -171
- package/components.js.map +0 -1
- package/date/constants.d.ts +0 -3
- package/date/constants.js +0 -20
- package/date/constants.js.map +0 -1
- package/date/index.js +0 -10
- package/date/index.js.map +0 -1
- package/date/parseNlpDate.d.ts +0 -5
- package/date/parseNlpDate.js +0 -227
- package/date/parseNlpDate.js.map +0 -1
- package/date/parseRoamDateUid.d.ts +0 -2
- package/date/parseRoamDateUid.js +0 -8
- package/date/parseRoamDateUid.js.map +0 -1
- package/dom/addBlockCommand.d.ts +0 -5
- package/dom/addBlockCommand.js +0 -54
- package/dom/addBlockCommand.js.map +0 -1
- package/dom/addKeyboardTriggers.d.ts +0 -11
- package/dom/addKeyboardTriggers.js +0 -39
- package/dom/addKeyboardTriggers.js.map +0 -1
- package/dom/addOldRoamJSDependency.d.ts +0 -2
- package/dom/addOldRoamJSDependency.js +0 -11
- package/dom/addOldRoamJSDependency.js.map +0 -1
- package/dom/addRoamJSDependency.d.ts +0 -2
- package/dom/addRoamJSDependency.js +0 -9
- package/dom/addRoamJSDependency.js.map +0 -1
- package/dom/addScriptAsDependency.d.ts +0 -6
- package/dom/addScriptAsDependency.js +0 -17
- package/dom/addScriptAsDependency.js.map +0 -1
- package/dom/addStyle.d.ts +0 -2
- package/dom/addStyle.js +0 -15
- package/dom/addStyle.js.map +0 -1
- package/dom/constants.d.ts +0 -1
- package/dom/constants.js +0 -5
- package/dom/constants.js.map +0 -1
- package/dom/createBlockObserver.d.ts +0 -7
- package/dom/createBlockObserver.js +0 -44
- package/dom/createBlockObserver.js.map +0 -1
- package/dom/createButtonObserver.d.ts +0 -6
- package/dom/createButtonObserver.js +0 -22
- package/dom/createButtonObserver.js.map +0 -1
- package/dom/createDivObserver.d.ts +0 -2
- package/dom/createDivObserver.js +0 -14
- package/dom/createDivObserver.js.map +0 -1
- package/dom/createHTMLObserver.d.ts +0 -8
- package/dom/createHTMLObserver.js +0 -25
- package/dom/createHTMLObserver.js.map +0 -1
- package/dom/createHashtagObserver.d.ts +0 -5
- package/dom/createHashtagObserver.js +0 -17
- package/dom/createHashtagObserver.js.map +0 -1
- package/dom/createIconButton.d.ts +0 -2
- package/dom/createIconButton.js +0 -13
- package/dom/createIconButton.js.map +0 -1
- package/dom/createObserver.d.ts +0 -2
- package/dom/createObserver.js +0 -10
- package/dom/createObserver.js.map +0 -1
- package/dom/createOverlayObserver.d.ts +0 -2
- package/dom/createOverlayObserver.js +0 -7
- package/dom/createOverlayObserver.js.map +0 -1
- package/dom/createPageObserver.d.ts +0 -2
- package/dom/createPageObserver.js +0 -35
- package/dom/createPageObserver.js.map +0 -1
- package/dom/createPageTitleObserver.d.ts +0 -6
- package/dom/createPageTitleObserver.js +0 -32
- package/dom/createPageTitleObserver.js.map +0 -1
- package/dom/elToTitle.d.ts +0 -2
- package/dom/elToTitle.js +0 -23
- package/dom/elToTitle.js.map +0 -1
- package/dom/genericError.d.ts +0 -3
- package/dom/genericError.js +0 -12
- package/dom/genericError.js.map +0 -1
- package/dom/getActiveUids.d.ts +0 -3
- package/dom/getActiveUids.js +0 -7
- package/dom/getActiveUids.js.map +0 -1
- package/dom/getBlockUidFromTarget.d.ts +0 -2
- package/dom/getBlockUidFromTarget.js +0 -34
- package/dom/getBlockUidFromTarget.js.map +0 -1
- package/dom/getCurrentPageUid.d.ts +0 -2
- package/dom/getCurrentPageUid.js +0 -9
- package/dom/getCurrentPageUid.js.map +0 -1
- package/dom/getDomRefs.d.ts +0 -2
- package/dom/getDomRefs.js +0 -13
- package/dom/getDomRefs.js.map +0 -1
- package/dom/getDropUidOffset.d.ts +0 -5
- package/dom/getDropUidOffset.js +0 -28
- package/dom/getDropUidOffset.js.map +0 -1
- package/dom/getMutatedNodes.d.ts +0 -7
- package/dom/getMutatedNodes.js +0 -12
- package/dom/getMutatedNodes.js.map +0 -1
- package/dom/getPageTitleByHtmlElement.d.ts +0 -2
- package/dom/getPageTitleByHtmlElement.js +0 -13
- package/dom/getPageTitleByHtmlElement.js.map +0 -1
- package/dom/getPageTitleValueByHtmlElement.d.ts +0 -2
- package/dom/getPageTitleValueByHtmlElement.js +0 -10
- package/dom/getPageTitleValueByHtmlElement.js.map +0 -1
- package/dom/getReferenceBlockUid.d.ts +0 -2
- package/dom/getReferenceBlockUid.js +0 -19
- package/dom/getReferenceBlockUid.js.map +0 -1
- package/dom/getRoamUrl.d.ts +0 -2
- package/dom/getRoamUrl.js +0 -5
- package/dom/getRoamUrl.js.map +0 -1
- package/dom/getRoamUrlByPage.d.ts +0 -2
- package/dom/getRoamUrlByPage.js +0 -11
- package/dom/getRoamUrlByPage.js.map +0 -1
- package/dom/getUids.d.ts +0 -3
- package/dom/getUids.js +0 -9
- package/dom/getUids.js.map +0 -1
- package/dom/getUidsFromButton.d.ts +0 -3
- package/dom/getUidsFromButton.js +0 -9
- package/dom/getUidsFromButton.js.map +0 -1
- package/dom/getUidsFromId.d.ts +0 -5
- package/dom/getUidsFromId.js +0 -16
- package/dom/getUidsFromId.js.map +0 -1
- package/dom/index.js +0 -64
- package/dom/index.js.map +0 -1
- package/dom/parseRoamBlocksToHtml.d.ts +0 -11
- package/dom/parseRoamBlocksToHtml.js +0 -80
- package/dom/parseRoamBlocksToHtml.js.map +0 -1
- package/dom/resolveRefs.d.ts +0 -2
- package/dom/resolveRefs.js +0 -25
- package/dom/resolveRefs.js.map +0 -1
- package/events/index.js +0 -9
- package/events/index.js.map +0 -1
- package/events/watchOnce.d.ts +0 -3
- package/events/watchOnce.js +0 -13
- package/events/watchOnce.js.map +0 -1
- package/hooks/index.js +0 -11
- package/hooks/index.js.map +0 -1
- package/hooks/useArrowKeyDown.d.ts +0 -10
- package/hooks/useArrowKeyDown.js +0 -55
- package/hooks/useArrowKeyDown.js.map +0 -1
- package/hooks/useSubTree.d.ts +0 -3
- package/hooks/useSubTree.js +0 -12
- package/hooks/useSubTree.js.map +0 -1
- package/marked/index.d.ts +0 -25
- package/marked/index.js +0 -568
- package/marked/index.js.map +0 -1
- package/queries/compileDatalog.d.ts +0 -3
- package/queries/compileDatalog.js +0 -64
- package/queries/compileDatalog.js.map +0 -1
- package/queries/getAllBlockUids.d.ts +0 -2
- package/queries/getAllBlockUids.js +0 -7
- package/queries/getAllBlockUids.js.map +0 -1
- package/queries/getAllBlockUidsAndTexts.d.ts +0 -5
- package/queries/getAllBlockUidsAndTexts.js +0 -7
- package/queries/getAllBlockUidsAndTexts.js.map +0 -1
- package/queries/getAllPageNames.d.ts +0 -2
- package/queries/getAllPageNames.js +0 -7
- package/queries/getAllPageNames.js.map +0 -1
- package/queries/getAttributeValueByBlockAndName.d.ts +0 -5
- package/queries/getAttributeValueByBlockAndName.js +0 -12
- package/queries/getAttributeValueByBlockAndName.js.map +0 -1
- package/queries/getBasicTreeByParentUid.d.ts +0 -3
- package/queries/getBasicTreeByParentUid.js +0 -14
- package/queries/getBasicTreeByParentUid.js.map +0 -1
- package/queries/getBlockUidAndTextIncludingText.d.ts +0 -5
- package/queries/getBlockUidAndTextIncludingText.js +0 -8
- package/queries/getBlockUidAndTextIncludingText.js.map +0 -1
- package/queries/getBlockUidByTextOnPage.d.ts +0 -5
- package/queries/getBlockUidByTextOnPage.js +0 -8
- package/queries/getBlockUidByTextOnPage.js.map +0 -1
- package/queries/getBlockUidsAndTextsReferencingPage.d.ts +0 -5
- package/queries/getBlockUidsAndTextsReferencingPage.js +0 -10
- package/queries/getBlockUidsAndTextsReferencingPage.js.map +0 -1
- package/queries/getBlockUidsByPageTitle.d.ts +0 -2
- package/queries/getBlockUidsByPageTitle.js +0 -9
- package/queries/getBlockUidsByPageTitle.js.map +0 -1
- package/queries/getBlockUidsReferencingBlock.d.ts +0 -2
- package/queries/getBlockUidsReferencingBlock.js +0 -5
- package/queries/getBlockUidsReferencingBlock.js.map +0 -1
- package/queries/getBlockUidsReferencingPage.d.ts +0 -2
- package/queries/getBlockUidsReferencingPage.js +0 -7
- package/queries/getBlockUidsReferencingPage.js.map +0 -1
- package/queries/getBlockUidsWithParentUid.d.ts +0 -2
- package/queries/getBlockUidsWithParentUid.js +0 -7
- package/queries/getBlockUidsWithParentUid.js.map +0 -1
- package/queries/getChildrenLengthByPageUid.d.ts +0 -2
- package/queries/getChildrenLengthByPageUid.js +0 -9
- package/queries/getChildrenLengthByPageUid.js.map +0 -1
- package/queries/getChildrenLengthByParentUid.d.ts +0 -2
- package/queries/getChildrenLengthByParentUid.js +0 -8
- package/queries/getChildrenLengthByParentUid.js.map +0 -1
- package/queries/getCreateTimeByBlockUid.d.ts +0 -2
- package/queries/getCreateTimeByBlockUid.js +0 -8
- package/queries/getCreateTimeByBlockUid.js.map +0 -1
- package/queries/getCurrentUser.d.ts +0 -2
- package/queries/getCurrentUser.js +0 -12
- package/queries/getCurrentUser.js.map +0 -1
- package/queries/getCurrentUserDisplayName.d.ts +0 -2
- package/queries/getCurrentUserDisplayName.js +0 -11
- package/queries/getCurrentUserDisplayName.js.map +0 -1
- package/queries/getCurrentUserEmail.d.ts +0 -2
- package/queries/getCurrentUserEmail.js +0 -14
- package/queries/getCurrentUserEmail.js.map +0 -1
- package/queries/getCurrentUserUid.d.ts +0 -2
- package/queries/getCurrentUserUid.js +0 -14
- package/queries/getCurrentUserUid.js.map +0 -1
- package/queries/getDisplayNameByEmail.d.ts +0 -2
- package/queries/getDisplayNameByEmail.js +0 -8
- package/queries/getDisplayNameByEmail.js.map +0 -1
- package/queries/getDisplayNameByUid.d.ts +0 -2
- package/queries/getDisplayNameByUid.js +0 -8
- package/queries/getDisplayNameByUid.js.map +0 -1
- package/queries/getEditTimeByBlockUid.d.ts +0 -2
- package/queries/getEditTimeByBlockUid.js +0 -8
- package/queries/getEditTimeByBlockUid.js.map +0 -1
- package/queries/getEditedUserEmailByBlockUid.d.ts +0 -2
- package/queries/getEditedUserEmailByBlockUid.js +0 -8
- package/queries/getEditedUserEmailByBlockUid.js.map +0 -1
- package/queries/getFirstChildTextByBlockUid.d.ts +0 -2
- package/queries/getFirstChildTextByBlockUid.js +0 -8
- package/queries/getFirstChildTextByBlockUid.js.map +0 -1
- package/queries/getFirstChildUidByBlockUid.d.ts +0 -2
- package/queries/getFirstChildUidByBlockUid.js +0 -7
- package/queries/getFirstChildUidByBlockUid.js.map +0 -1
- package/queries/getFullTreeByParentUid.d.ts +0 -3
- package/queries/getFullTreeByParentUid.js +0 -52
- package/queries/getFullTreeByParentUid.js.map +0 -1
- package/queries/getLinkedPageTitlesUnderUid.d.ts +0 -2
- package/queries/getLinkedPageTitlesUnderUid.js +0 -7
- package/queries/getLinkedPageTitlesUnderUid.js.map +0 -1
- package/queries/getNthChildUidByBlockUid.d.ts +0 -5
- package/queries/getNthChildUidByBlockUid.js +0 -8
- package/queries/getNthChildUidByBlockUid.js.map +0 -1
- package/queries/getOrderByBlockUid.d.ts +0 -2
- package/queries/getOrderByBlockUid.js +0 -8
- package/queries/getOrderByBlockUid.js.map +0 -1
- package/queries/getPageTitleByBlockUid.d.ts +0 -2
- package/queries/getPageTitleByBlockUid.js +0 -8
- package/queries/getPageTitleByBlockUid.js.map +0 -1
- package/queries/getPageTitleByPageUid.d.ts +0 -2
- package/queries/getPageTitleByPageUid.js +0 -13
- package/queries/getPageTitleByPageUid.js.map +0 -1
- package/queries/getPageTitleReferencesByPageTitle.d.ts +0 -2
- package/queries/getPageTitleReferencesByPageTitle.js +0 -7
- package/queries/getPageTitleReferencesByPageTitle.js.map +0 -1
- package/queries/getPageTitlesAndBlockUidsReferencingPage.d.ts +0 -5
- package/queries/getPageTitlesAndBlockUidsReferencingPage.js +0 -10
- package/queries/getPageTitlesAndBlockUidsReferencingPage.js.map +0 -1
- package/queries/getPageTitlesAndUidsDirectlyReferencingPage.d.ts +0 -5
- package/queries/getPageTitlesAndUidsDirectlyReferencingPage.js +0 -10
- package/queries/getPageTitlesAndUidsDirectlyReferencingPage.js.map +0 -1
- package/queries/getPageTitlesReferencingBlockUid.d.ts +0 -2
- package/queries/getPageTitlesReferencingBlockUid.js +0 -5
- package/queries/getPageTitlesReferencingBlockUid.js.map +0 -1
- package/queries/getPageTitlesStartingWithPrefix.d.ts +0 -2
- package/queries/getPageTitlesStartingWithPrefix.js +0 -7
- package/queries/getPageTitlesStartingWithPrefix.js.map +0 -1
- package/queries/getPageUidByBlockUid.d.ts +0 -2
- package/queries/getPageUidByBlockUid.js +0 -8
- package/queries/getPageUidByBlockUid.js.map +0 -1
- package/queries/getPageUidByPageTitle.d.ts +0 -2
- package/queries/getPageUidByPageTitle.js +0 -10
- package/queries/getPageUidByPageTitle.js.map +0 -1
- package/queries/getPageViewType.d.ts +0 -3
- package/queries/getPageViewType.js +0 -10
- package/queries/getPageViewType.js.map +0 -1
- package/queries/getParentTextByBlockUid.d.ts +0 -2
- package/queries/getParentTextByBlockUid.js +0 -8
- package/queries/getParentTextByBlockUid.js.map +0 -1
- package/queries/getParentTextByBlockUidAndTag.d.ts +0 -5
- package/queries/getParentTextByBlockUidAndTag.js +0 -8
- package/queries/getParentTextByBlockUidAndTag.js.map +0 -1
- package/queries/getParentUidByBlockUid.d.ts +0 -2
- package/queries/getParentUidByBlockUid.js +0 -8
- package/queries/getParentUidByBlockUid.js.map +0 -1
- package/queries/getParentUidsOfBlockUid.d.ts +0 -2
- package/queries/getParentUidsOfBlockUid.js +0 -5
- package/queries/getParentUidsOfBlockUid.js.map +0 -1
- package/queries/getSettingsByEmail.d.ts +0 -3
- package/queries/getSettingsByEmail.js +0 -8
- package/queries/getSettingsByEmail.js.map +0 -1
- package/queries/getShallowTreeByParentUid.d.ts +0 -5
- package/queries/getShallowTreeByParentUid.js +0 -10
- package/queries/getShallowTreeByParentUid.js.map +0 -1
- package/queries/getTextByBlockUid.d.ts +0 -2
- package/queries/getTextByBlockUid.js +0 -10
- package/queries/getTextByBlockUid.js.map +0 -1
- package/queries/index.d.ts +0 -0
- package/queries/index.js +0 -5
- package/queries/index.js.map +0 -1
- package/queries/isLiveBlock.d.ts +0 -2
- package/queries/isLiveBlock.js +0 -5
- package/queries/isLiveBlock.js.map +0 -1
- package/queries/isTagOnPage.d.ts +0 -5
- package/queries/isTagOnPage.js +0 -10
- package/queries/isTagOnPage.js.map +0 -1
- package/queries/normalizePageTitle.d.ts +0 -2
- package/queries/normalizePageTitle.js +0 -5
- package/queries/normalizePageTitle.js.map +0 -1
- package/scripts/index.d.ts +0 -1
- package/scripts/index.js +0 -27
- package/scripts/index.js.map +0 -1
- package/scripts/publishToRoamDepot.d.ts +0 -7
- package/scripts/publishToRoamDepot.js +0 -114
- package/scripts/publishToRoamDepot.js.map +0 -1
- package/testing/mockRoamEnvironment.d.ts +0 -2
- package/testing/mockRoamEnvironment.js +0 -1254
- package/testing/mockRoamEnvironment.js.map +0 -1
- package/types/index.d.ts +0 -250
- package/types/index.js +0 -5
- package/types/index.js.map +0 -1
- package/types/native.d.ts +0 -402
- package/types/native.js +0 -5
- package/types/native.js.map +0 -1
- package/types/query-builder.d.ts +0 -10
- package/types/query-builder.js +0 -3
- package/types/query-builder.js.map +0 -1
- package/types/smartblocks.d.ts +0 -35
- package/types/smartblocks.js +0 -3
- package/types/smartblocks.js.map +0 -1
- package/util/addInputSetting.d.ts +0 -7
- package/util/addInputSetting.js +0 -26
- package/util/addInputSetting.js.map +0 -1
- package/util/apiDelete.d.ts +0 -2
- package/util/apiDelete.js +0 -7
- package/util/apiDelete.js.map +0 -1
- package/util/apiGet.d.ts +0 -2
- package/util/apiGet.js +0 -7
- package/util/apiGet.js.map +0 -1
- package/util/apiPost.d.ts +0 -2
- package/util/apiPost.js +0 -7
- package/util/apiPost.js.map +0 -1
- package/util/apiPut.d.ts +0 -2
- package/util/apiPut.js +0 -7
- package/util/apiPut.js.map +0 -1
- package/util/createOverlayRender.d.ts +0 -4
- package/util/createOverlayRender.js +0 -7
- package/util/createOverlayRender.js.map +0 -1
- package/util/createTagRegex.d.ts +0 -2
- package/util/createTagRegex.js +0 -8
- package/util/createTagRegex.js.map +0 -1
- package/util/dispatchToRegistry.d.ts +0 -3
- package/util/dispatchToRegistry.js +0 -8
- package/util/dispatchToRegistry.js.map +0 -1
- package/util/env.d.ts +0 -4
- package/util/env.js +0 -48
- package/util/env.js.map +0 -1
- package/util/extensionApiContext.d.ts +0 -29
- package/util/extensionApiContext.js +0 -18
- package/util/extensionApiContext.js.map +0 -1
- package/util/extensionDeprecatedWarning.d.ts +0 -5
- package/util/extensionDeprecatedWarning.js +0 -40
- package/util/extensionDeprecatedWarning.js.map +0 -1
- package/util/extractRef.d.ts +0 -2
- package/util/extractRef.js +0 -9
- package/util/extractRef.js.map +0 -1
- package/util/extractTag.d.ts +0 -2
- package/util/extractTag.js +0 -16
- package/util/extractTag.js.map +0 -1
- package/util/focusMainWindowBlock.d.ts +0 -2
- package/util/focusMainWindowBlock.js +0 -13
- package/util/focusMainWindowBlock.js.map +0 -1
- package/util/getAuthorizationHeader.d.ts +0 -2
- package/util/getAuthorizationHeader.js +0 -13
- package/util/getAuthorizationHeader.js.map +0 -1
- package/util/getLocalStorageKey.d.ts +0 -2
- package/util/getLocalStorageKey.js +0 -5
- package/util/getLocalStorageKey.js.map +0 -1
- package/util/getOauth.d.ts +0 -2
- package/util/getOauth.js +0 -53
- package/util/getOauth.js.map +0 -1
- package/util/getOauthAccounts.d.ts +0 -2
- package/util/getOauthAccounts.js +0 -23
- package/util/getOauthAccounts.js.map +0 -1
- package/util/getRenderRoot.d.ts +0 -2
- package/util/getRenderRoot.js +0 -19
- package/util/getRenderRoot.js.map +0 -1
- package/util/getSettingIntFromTree.d.ts +0 -7
- package/util/getSettingIntFromTree.js +0 -12
- package/util/getSettingIntFromTree.js.map +0 -1
- package/util/getSettingValueFromTree.d.ts +0 -8
- package/util/getSettingValueFromTree.js +0 -15
- package/util/getSettingValueFromTree.js.map +0 -1
- package/util/getSettingValuesFromTree.d.ts +0 -7
- package/util/getSettingValuesFromTree.js +0 -13
- package/util/getSettingValuesFromTree.js.map +0 -1
- package/util/getSubTree.d.ts +0 -8
- package/util/getSubTree.js +0 -20
- package/util/getSubTree.js.map +0 -1
- package/util/getToken.d.ts +0 -2
- package/util/getToken.js +0 -11
- package/util/getToken.js.map +0 -1
- package/util/getTokenFromTree.d.ts +0 -3
- package/util/getTokenFromTree.js +0 -5
- package/util/getTokenFromTree.js.map +0 -1
- package/util/getWorkerClient.d.ts +0 -12
- package/util/getWorkerClient.js +0 -42
- package/util/getWorkerClient.js.map +0 -1
- package/util/handleBodyFetch.d.ts +0 -3
- package/util/handleBodyFetch.js +0 -22
- package/util/handleBodyFetch.js.map +0 -1
- package/util/handleFetch.d.ts +0 -13
- package/util/handleFetch.js +0 -41
- package/util/handleFetch.js.map +0 -1
- package/util/handleUrlFetch.d.ts +0 -3
- package/util/handleUrlFetch.js +0 -20
- package/util/handleUrlFetch.js.map +0 -1
- package/util/idToTitle.d.ts +0 -2
- package/util/idToTitle.js +0 -9
- package/util/idToTitle.js.map +0 -1
- package/util/index.js +0 -55
- package/util/index.js.map +0 -1
- package/util/isControl.d.ts +0 -2
- package/util/isControl.js +0 -5
- package/util/isControl.js.map +0 -1
- package/util/localStorageGet.d.ts +0 -2
- package/util/localStorageGet.js +0 -9
- package/util/localStorageGet.js.map +0 -1
- package/util/localStorageRemove.d.ts +0 -2
- package/util/localStorageRemove.js +0 -7
- package/util/localStorageRemove.js.map +0 -1
- package/util/localStorageSet.d.ts +0 -2
- package/util/localStorageSet.js +0 -9
- package/util/localStorageSet.js.map +0 -1
- package/util/registerExperimentalMode.d.ts +0 -6
- package/util/registerExperimentalMode.js +0 -66
- package/util/registerExperimentalMode.js.map +0 -1
- package/util/registerSmartBlocksCommand.d.ts +0 -3
- package/util/registerSmartBlocksCommand.js +0 -24
- package/util/registerSmartBlocksCommand.js.map +0 -1
- package/util/removeFromRegistry.d.ts +0 -3
- package/util/removeFromRegistry.js +0 -8
- package/util/removeFromRegistry.js.map +0 -1
- package/util/renderOverlay.d.ts +0 -12
- package/util/renderOverlay.js +0 -49
- package/util/renderOverlay.js.map +0 -1
- package/util/renderWithUnmount.d.ts +0 -4
- package/util/renderWithUnmount.js +0 -45
- package/util/renderWithUnmount.js.map +0 -1
- package/util/runExtension.d.ts +0 -11
- package/util/runExtension.js +0 -175
- package/util/runExtension.js.map +0 -1
- package/util/setInputSetting.d.ts +0 -7
- package/util/setInputSetting.js +0 -38
- package/util/setInputSetting.js.map +0 -1
- package/util/setInputSettings.d.ts +0 -7
- package/util/setInputSettings.js +0 -29
- package/util/setInputSettings.js.map +0 -1
- package/util/stripUid.d.ts +0 -3
- package/util/stripUid.js +0 -11
- package/util/stripUid.js.map +0 -1
- package/util/toConfigPageName.d.ts +0 -2
- package/util/toConfigPageName.js +0 -5
- package/util/toConfigPageName.js.map +0 -1
- package/util/toFlexRegex.d.ts +0 -2
- package/util/toFlexRegex.js +0 -5
- package/util/toFlexRegex.js.map +0 -1
- package/writes/clearBlockById.d.ts +0 -2
- package/writes/clearBlockById.js +0 -18
- package/writes/clearBlockById.js.map +0 -1
- package/writes/clearBlockByUid.d.ts +0 -2
- package/writes/clearBlockByUid.js +0 -17
- package/writes/clearBlockByUid.js.map +0 -1
- package/writes/createBlock.d.ts +0 -8
- package/writes/createBlock.js +0 -29
- package/writes/createBlock.js.map +0 -1
- package/writes/createPage.d.ts +0 -7
- package/writes/createPage.js +0 -21
- package/writes/createPage.js.map +0 -1
- package/writes/deleteBlock.d.ts +0 -2
- package/writes/deleteBlock.js +0 -11
- package/writes/deleteBlock.js.map +0 -1
- package/writes/index.js +0 -23
- package/writes/index.js.map +0 -1
- package/writes/openBlockInSidebar.d.ts +0 -2
- package/writes/openBlockInSidebar.js +0 -14
- package/writes/openBlockInSidebar.js.map +0 -1
- package/writes/submitActions.d.ts +0 -8
- package/writes/submitActions.js +0 -37
- package/writes/submitActions.js.map +0 -1
- package/writes/updateActiveBlock.d.ts +0 -2
- package/writes/updateActiveBlock.js +0 -18
- package/writes/updateActiveBlock.js.map +0 -1
- package/writes/updateBlock.d.ts +0 -5
- package/writes/updateBlock.js +0 -24
- package/writes/updateBlock.js.map +0 -1
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import addWeeks from "date-fns/addWeeks";
|
|
2
|
+
import addDays from "date-fns/addDays";
|
|
3
|
+
import dateFnsStartOfWeek from "date-fns/startOfWeek";
|
|
4
|
+
import startOfMonth from "date-fns/startOfMonth";
|
|
5
|
+
import startOfYear from "date-fns/startOfYear";
|
|
6
|
+
import dateFnsEndOfWeek from "date-fns/endOfWeek";
|
|
7
|
+
import endOfMonth from "date-fns/endOfMonth";
|
|
8
|
+
import endOfYear from "date-fns/endOfYear";
|
|
9
|
+
import { Chrono, Parser } from "chrono-node";
|
|
10
|
+
import { ParsingComponents } from "chrono-node/dist/results";
|
|
11
|
+
import getCurrentUserUid from "../queries/getCurrentUserUid";
|
|
12
|
+
|
|
13
|
+
const startOfWeek = (date: Date) => {
|
|
14
|
+
const weekStartsOn = window.roamAlphaAPI.pull("[:user/settings]", [
|
|
15
|
+
":user/uid",
|
|
16
|
+
getCurrentUserUid(),
|
|
17
|
+
])?.[":user/settings"]?.[":first-day-of-week"];
|
|
18
|
+
return dateFnsStartOfWeek(date, weekStartsOn ? { weekStartsOn } : undefined);
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const endOfWeek = (date: Date) => {
|
|
22
|
+
const weekStartsOn = window.roamAlphaAPI.pull("[:user/settings]", [
|
|
23
|
+
":user/uid",
|
|
24
|
+
getCurrentUserUid(),
|
|
25
|
+
])?.[":user/settings"]?.[":first-day-of-week"];
|
|
26
|
+
return dateFnsEndOfWeek(date, weekStartsOn ? { weekStartsOn } : undefined);
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
const ORDINAL_WORD_DICTIONARY: { [word: string]: number } = {
|
|
30
|
+
first: 1,
|
|
31
|
+
second: 2,
|
|
32
|
+
third: 3,
|
|
33
|
+
fourth: 4,
|
|
34
|
+
fifth: 5,
|
|
35
|
+
sixth: 6,
|
|
36
|
+
seventh: 7,
|
|
37
|
+
eighth: 8,
|
|
38
|
+
ninth: 9,
|
|
39
|
+
tenth: 10,
|
|
40
|
+
eleventh: 11,
|
|
41
|
+
twelfth: 12,
|
|
42
|
+
thirteenth: 13,
|
|
43
|
+
fourteenth: 14,
|
|
44
|
+
fifteenth: 15,
|
|
45
|
+
sixteenth: 16,
|
|
46
|
+
seventeenth: 17,
|
|
47
|
+
eighteenth: 18,
|
|
48
|
+
nineteenth: 19,
|
|
49
|
+
twentieth: 20,
|
|
50
|
+
"twenty first": 21,
|
|
51
|
+
"twenty-first": 21,
|
|
52
|
+
"twenty second": 22,
|
|
53
|
+
"twenty-second": 22,
|
|
54
|
+
"twenty third": 23,
|
|
55
|
+
"twenty-third": 23,
|
|
56
|
+
"twenty fourth": 24,
|
|
57
|
+
"twenty-fourth": 24,
|
|
58
|
+
"twenty fifth": 25,
|
|
59
|
+
"twenty-fifth": 25,
|
|
60
|
+
"twenty sixth": 26,
|
|
61
|
+
"twenty-sixth": 26,
|
|
62
|
+
"twenty seventh": 27,
|
|
63
|
+
"twenty-seventh": 27,
|
|
64
|
+
"twenty eighth": 28,
|
|
65
|
+
"twenty-eighth": 28,
|
|
66
|
+
"twenty ninth": 29,
|
|
67
|
+
"twenty-ninth": 29,
|
|
68
|
+
thirtieth: 30,
|
|
69
|
+
"thirty first": 31,
|
|
70
|
+
"thirty-first": 31,
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
const ORDINAL_REGEX = new RegExp(
|
|
74
|
+
`\\b(?:${Object.keys(ORDINAL_WORD_DICTIONARY)
|
|
75
|
+
.sort((a, b) => b.length - a.length)
|
|
76
|
+
.join("|")}|(?:[1-9])?[0-9](?:st|nd|rd|th)?)\\b`,
|
|
77
|
+
"i"
|
|
78
|
+
);
|
|
79
|
+
|
|
80
|
+
const customDateNlp = new Chrono();
|
|
81
|
+
const DAYS_OFFSET = {
|
|
82
|
+
sunday: 0,
|
|
83
|
+
sun: 0,
|
|
84
|
+
monday: 1,
|
|
85
|
+
mon: 1,
|
|
86
|
+
tuesday: 2,
|
|
87
|
+
tues: 2,
|
|
88
|
+
tue: 2,
|
|
89
|
+
wednesday: 3,
|
|
90
|
+
wed: 3,
|
|
91
|
+
thursday: 4,
|
|
92
|
+
thurs: 4,
|
|
93
|
+
thur: 4,
|
|
94
|
+
thu: 4,
|
|
95
|
+
friday: 5,
|
|
96
|
+
fri: 5,
|
|
97
|
+
saturday: 6,
|
|
98
|
+
sat: 6,
|
|
99
|
+
};
|
|
100
|
+
const UPCOMING_PATTERN = new RegExp(
|
|
101
|
+
"(\\W|^)" +
|
|
102
|
+
"(?:(?:\\,|\\(|\\()\\s*)?" +
|
|
103
|
+
"(?:on\\s*?)?" +
|
|
104
|
+
"upcoming\\s*" +
|
|
105
|
+
"(" +
|
|
106
|
+
Object.keys(DAYS_OFFSET).join("|") +
|
|
107
|
+
")" +
|
|
108
|
+
"(?=\\W|$)",
|
|
109
|
+
"i"
|
|
110
|
+
);
|
|
111
|
+
// https://github.com/wanasit/chrono/blob/d8da3c840c50c959a62a0840c9a627f39bc765df/src/parsers/en/ENWeekdayParser.js
|
|
112
|
+
customDateNlp.parsers.unshift({
|
|
113
|
+
pattern: () => UPCOMING_PATTERN,
|
|
114
|
+
extract: (context, match) => {
|
|
115
|
+
const index = (match.index || 0) + match[1].length;
|
|
116
|
+
const text = match[0].substr(
|
|
117
|
+
match[1].length,
|
|
118
|
+
match[0].length - match[1].length
|
|
119
|
+
);
|
|
120
|
+
const result = context.createParsingResult(index, text);
|
|
121
|
+
|
|
122
|
+
const dayOfWeek = match[2].toLowerCase();
|
|
123
|
+
const offset = DAYS_OFFSET[dayOfWeek as keyof typeof DAYS_OFFSET];
|
|
124
|
+
if (offset === undefined) {
|
|
125
|
+
return null;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
const startMoment = context.refDate;
|
|
129
|
+
const refOffset = startMoment.getDay();
|
|
130
|
+
result.start.assign("weekday", offset);
|
|
131
|
+
if (offset <= refOffset) {
|
|
132
|
+
startMoment.setDate(offset + 7 + startMoment.getDate() - refOffset);
|
|
133
|
+
result.start.assign("day", startMoment.getDate());
|
|
134
|
+
result.start.assign("month", startMoment.getMonth() + 1);
|
|
135
|
+
result.start.assign("year", startMoment.getFullYear());
|
|
136
|
+
} else {
|
|
137
|
+
startMoment.setDate(offset + startMoment.getDate() - refOffset);
|
|
138
|
+
result.start.imply("day", startMoment.getDate());
|
|
139
|
+
result.start.imply("month", startMoment.getMonth() + 1);
|
|
140
|
+
result.start.imply("year", startMoment.getFullYear());
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
return result;
|
|
144
|
+
},
|
|
145
|
+
});
|
|
146
|
+
customDateNlp.parsers.push(
|
|
147
|
+
{
|
|
148
|
+
pattern: () => /\b((start|end) )?of\b/i,
|
|
149
|
+
extract: () => ({}),
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
pattern: () => ORDINAL_REGEX,
|
|
153
|
+
extract: () => ({}),
|
|
154
|
+
}
|
|
155
|
+
);
|
|
156
|
+
|
|
157
|
+
export const addNlpDateParser = (p: Parser) => customDateNlp.parsers.push(p);
|
|
158
|
+
|
|
159
|
+
const assignDay = (p: ParsingComponents, d: Date) => {
|
|
160
|
+
p.assign("year", d.getFullYear());
|
|
161
|
+
p.assign("month", d.getMonth() + 1);
|
|
162
|
+
p.assign("day", d.getDate());
|
|
163
|
+
};
|
|
164
|
+
customDateNlp.refiners.unshift({
|
|
165
|
+
refine: (_, results) => {
|
|
166
|
+
if (results.length >= 2) {
|
|
167
|
+
const [modifier, date, ...rest] = results;
|
|
168
|
+
if (/start of/i.test(modifier.text)) {
|
|
169
|
+
const dateObj = date.date();
|
|
170
|
+
if (/week/i.test(date.text)) {
|
|
171
|
+
const newDateObj = startOfWeek(dateObj);
|
|
172
|
+
assignDay(date.start, newDateObj);
|
|
173
|
+
}
|
|
174
|
+
if (/month/i.test(date.text)) {
|
|
175
|
+
const newDateObj = startOfMonth(dateObj);
|
|
176
|
+
assignDay(date.start, newDateObj);
|
|
177
|
+
}
|
|
178
|
+
if (/year/i.test(date.text)) {
|
|
179
|
+
const newDateObj = startOfYear(dateObj);
|
|
180
|
+
assignDay(date.start, newDateObj);
|
|
181
|
+
}
|
|
182
|
+
} else if (/end of/i.test(modifier.text)) {
|
|
183
|
+
const dateObj = date.date();
|
|
184
|
+
if (/week/i.test(date.text)) {
|
|
185
|
+
const newDateObj = endOfWeek(dateObj);
|
|
186
|
+
assignDay(date.start, newDateObj);
|
|
187
|
+
}
|
|
188
|
+
if (/month/i.test(date.text)) {
|
|
189
|
+
const newDateObj = endOfMonth(dateObj);
|
|
190
|
+
assignDay(date.start, newDateObj);
|
|
191
|
+
}
|
|
192
|
+
if (/year/i.test(date.text)) {
|
|
193
|
+
const newDateObj = endOfYear(dateObj);
|
|
194
|
+
assignDay(date.start, newDateObj);
|
|
195
|
+
}
|
|
196
|
+
} else if (rest.length >= 2) {
|
|
197
|
+
const [of, d, ...moreRest] = rest;
|
|
198
|
+
if (
|
|
199
|
+
ORDINAL_REGEX.test(modifier.text) &&
|
|
200
|
+
date.start.isOnlyWeekdayComponent() &&
|
|
201
|
+
/of/i.test(of.text)
|
|
202
|
+
) {
|
|
203
|
+
const match = (
|
|
204
|
+
ORDINAL_REGEX.exec(modifier.text)?.[0] || ""
|
|
205
|
+
).toLowerCase();
|
|
206
|
+
const num =
|
|
207
|
+
ORDINAL_WORD_DICTIONARY[match] ||
|
|
208
|
+
Number(match.replace(/(?:st|nd|rd|th)$/i, ""));
|
|
209
|
+
const dateObj = d.date();
|
|
210
|
+
if (/month/i.test(d.text)) {
|
|
211
|
+
const startOfMonthDate = startOfMonth(dateObj);
|
|
212
|
+
const originalMonth = startOfMonthDate.getMonth();
|
|
213
|
+
const startOfWeekDate = startOfWeek(startOfMonthDate);
|
|
214
|
+
const dayOfWeekDate = addDays(
|
|
215
|
+
startOfWeekDate,
|
|
216
|
+
date.start.get("weekday") || 0
|
|
217
|
+
);
|
|
218
|
+
const newDateObj = addWeeks(
|
|
219
|
+
dayOfWeekDate,
|
|
220
|
+
num - (originalMonth === dayOfWeekDate.getMonth() ? 1 : 0)
|
|
221
|
+
);
|
|
222
|
+
assignDay(d.start, newDateObj);
|
|
223
|
+
} else if (/year/i.test(d.text)) {
|
|
224
|
+
const startOfYearDate = startOfYear(dateObj);
|
|
225
|
+
const originalYear = startOfYearDate.getFullYear();
|
|
226
|
+
const startOfWeekDate = startOfWeek(startOfYearDate);
|
|
227
|
+
const dayOfWeekDate = addDays(
|
|
228
|
+
startOfWeekDate,
|
|
229
|
+
date.start.get("weekday") || 0
|
|
230
|
+
);
|
|
231
|
+
const newDateObj = addWeeks(
|
|
232
|
+
dayOfWeekDate,
|
|
233
|
+
num - (originalYear === dayOfWeekDate.getFullYear() ? 1 : 0)
|
|
234
|
+
);
|
|
235
|
+
assignDay(d.start, newDateObj);
|
|
236
|
+
} else {
|
|
237
|
+
return results;
|
|
238
|
+
}
|
|
239
|
+
return [d, ...moreRest];
|
|
240
|
+
}
|
|
241
|
+
} else {
|
|
242
|
+
return results;
|
|
243
|
+
}
|
|
244
|
+
return [date, ...rest];
|
|
245
|
+
}
|
|
246
|
+
return results;
|
|
247
|
+
},
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
const parseNlpDate = (s: string, ref?: Date): Date =>
|
|
251
|
+
customDateNlp.parseDate(s, ref) || new Date();
|
|
252
|
+
|
|
253
|
+
export const parse = (t: string, ref?: Date) => customDateNlp.parse(t, ref);
|
|
254
|
+
|
|
255
|
+
export default parseNlpDate;
|
|
@@ -0,0 +1,59 @@
|
|
|
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
|
+
|
|
11
|
+
const addBlockCommand = ({
|
|
12
|
+
label,
|
|
13
|
+
callback,
|
|
14
|
+
}: {
|
|
15
|
+
label: string;
|
|
16
|
+
callback: (uid: string) => void;
|
|
17
|
+
}): void => {
|
|
18
|
+
const textareaRef: { current: HTMLTextAreaElement | null } = {
|
|
19
|
+
current: null,
|
|
20
|
+
};
|
|
21
|
+
const loadBlockUid = (pageUid: string) => {
|
|
22
|
+
if (textareaRef.current) {
|
|
23
|
+
const uid = getUids(textareaRef.current).blockUid;
|
|
24
|
+
const parentUid = getParentUidByBlockUid(uid);
|
|
25
|
+
const text = getTextByBlockUid(uid);
|
|
26
|
+
if (text.length) {
|
|
27
|
+
return createBlock({
|
|
28
|
+
node: { text: "Loading..." },
|
|
29
|
+
parentUid,
|
|
30
|
+
order: getOrderByBlockUid(uid) + 1,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
return updateBlock({
|
|
34
|
+
uid,
|
|
35
|
+
text: "Loading...",
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
return createBlock({
|
|
39
|
+
node: { text: "Loading..." },
|
|
40
|
+
parentUid: pageUid,
|
|
41
|
+
order: getChildrenLengthByPageUid(pageUid),
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
createHTMLObserver({
|
|
45
|
+
tag: "TEXTAREA",
|
|
46
|
+
className: "rm-block-input",
|
|
47
|
+
callback: (t: HTMLElement) =>
|
|
48
|
+
(textareaRef.current = t as HTMLTextAreaElement),
|
|
49
|
+
});
|
|
50
|
+
window.roamAlphaAPI.ui.commandPalette.addCommand({
|
|
51
|
+
label,
|
|
52
|
+
callback: () => {
|
|
53
|
+
const parentUid = getCurrentPageUid();
|
|
54
|
+
loadBlockUid(parentUid).then(callback);
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
export default addBlockCommand;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { RoamBasicNode } from "../types/native";
|
|
2
|
+
import getSettingValueFromTree from "../util/getSettingValueFromTree";
|
|
3
|
+
|
|
4
|
+
const addKeybordTriggers = ({
|
|
5
|
+
triggers: inputTriggers,
|
|
6
|
+
}: {
|
|
7
|
+
triggers: {
|
|
8
|
+
trigger:
|
|
9
|
+
| RegExp
|
|
10
|
+
| (() => RegExp)
|
|
11
|
+
| { tree: RoamBasicNode[]; defaultValue?: string };
|
|
12
|
+
callback: () => void;
|
|
13
|
+
}[];
|
|
14
|
+
}) => {
|
|
15
|
+
const triggers = inputTriggers.map(({ trigger, callback }) => {
|
|
16
|
+
if (trigger instanceof RegExp) {
|
|
17
|
+
return { trigger, callback };
|
|
18
|
+
} else if (typeof trigger === "function") {
|
|
19
|
+
return { callback, trigger: trigger() };
|
|
20
|
+
} else {
|
|
21
|
+
const triggerValue = getSettingValueFromTree({
|
|
22
|
+
tree: trigger.tree,
|
|
23
|
+
key: "trigger",
|
|
24
|
+
defaultValue: trigger.defaultValue || "\\\\",
|
|
25
|
+
})
|
|
26
|
+
.replace(/"/g, "")
|
|
27
|
+
.replace(/\\/g, "\\\\")
|
|
28
|
+
.replace(/\+/g, "\\+")
|
|
29
|
+
.trim();
|
|
30
|
+
|
|
31
|
+
const triggerRegex = new RegExp(`${triggerValue}$`);
|
|
32
|
+
return { callback, trigger: triggerRegex };
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
document.addEventListener("input", (e) => {
|
|
37
|
+
const target = e.target as HTMLElement;
|
|
38
|
+
if (
|
|
39
|
+
target.tagName === "TEXTAREA" &&
|
|
40
|
+
target.classList.contains("rm-block-input")
|
|
41
|
+
) {
|
|
42
|
+
const textarea = target as HTMLTextAreaElement;
|
|
43
|
+
const valueToCursor = textarea.value.substring(
|
|
44
|
+
0,
|
|
45
|
+
textarea.selectionStart
|
|
46
|
+
);
|
|
47
|
+
triggers.find((args) => args.trigger.test(valueToCursor))?.callback?.();
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
export default addKeybordTriggers;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import addScriptAsDependency from "./addScriptAsDependency";
|
|
2
|
+
|
|
3
|
+
const addOldRoamJSDependency = (extension: string, source?: string): void =>
|
|
4
|
+
addScriptAsDependency({
|
|
5
|
+
id: `roamjs-${extension.replace(/\/main$/, "")}`,
|
|
6
|
+
src: `https://roamjs.com/${extension}.js`,
|
|
7
|
+
dataAttributes: source ? { source } : {},
|
|
8
|
+
});
|
|
9
|
+
|
|
10
|
+
export default addOldRoamJSDependency;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
const addScriptAsDependency = ({
|
|
2
|
+
id,
|
|
3
|
+
src,
|
|
4
|
+
dataAttributes,
|
|
5
|
+
}: {
|
|
6
|
+
id: string;
|
|
7
|
+
src: string;
|
|
8
|
+
dataAttributes: Record<string, string>;
|
|
9
|
+
}): void => {
|
|
10
|
+
const existing = document.getElementById(id);
|
|
11
|
+
if (!existing) {
|
|
12
|
+
const script = document.createElement("script");
|
|
13
|
+
script.src = src;
|
|
14
|
+
script.async = true;
|
|
15
|
+
script.type = "text/javascript";
|
|
16
|
+
script.id = id;
|
|
17
|
+
Object.entries(dataAttributes).forEach(([k, v]) =>
|
|
18
|
+
script.setAttribute(`data-${k}`, v)
|
|
19
|
+
);
|
|
20
|
+
document.querySelector("head")?.appendChild(script);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export default addScriptAsDependency;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
const addStyle = (content: string, id?: string): HTMLStyleElement => {
|
|
2
|
+
const existing = document.getElementById(id || "") as HTMLStyleElement;
|
|
3
|
+
if (existing) return existing;
|
|
4
|
+
const css = document.createElement("style");
|
|
5
|
+
css.textContent = content;
|
|
6
|
+
if (id) css.id = id;
|
|
7
|
+
document.getElementsByTagName("head")[0].appendChild(css);
|
|
8
|
+
return css;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export default addStyle;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const BLOCK_REF_REGEX = /\(\(([\w\d-]{9,10})\)\)/;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import createHTMLObserver from "./createHTMLObserver";
|
|
2
|
+
|
|
3
|
+
const createBlockObserver = (
|
|
4
|
+
blockCallbackOrConfig:
|
|
5
|
+
| ((b: HTMLDivElement) => void)
|
|
6
|
+
| {
|
|
7
|
+
onBlockLoad?: (b: HTMLDivElement) => void;
|
|
8
|
+
onBlockUnload?: (b: HTMLDivElement) => void;
|
|
9
|
+
onBlockRefLoad?: (b: HTMLSpanElement) => void;
|
|
10
|
+
onBlockRefUnload?: (b: HTMLSpanElement) => void;
|
|
11
|
+
},
|
|
12
|
+
blockRefCallback?: (b: HTMLSpanElement) => void
|
|
13
|
+
): MutationObserver[] => {
|
|
14
|
+
const blockObserver = createHTMLObserver({
|
|
15
|
+
callback: (e) =>
|
|
16
|
+
typeof blockCallbackOrConfig === "function"
|
|
17
|
+
? blockCallbackOrConfig(e as HTMLDivElement)
|
|
18
|
+
: blockCallbackOrConfig.onBlockLoad?.(e as HTMLDivElement),
|
|
19
|
+
removeCallback: (e) =>
|
|
20
|
+
typeof blockCallbackOrConfig === "object" &&
|
|
21
|
+
blockCallbackOrConfig.onBlockUnload?.(e as HTMLDivElement),
|
|
22
|
+
tag: "DIV",
|
|
23
|
+
className: "roam-block",
|
|
24
|
+
});
|
|
25
|
+
if (blockRefCallback) {
|
|
26
|
+
return [
|
|
27
|
+
blockObserver,
|
|
28
|
+
createHTMLObserver({
|
|
29
|
+
callback: (e) =>
|
|
30
|
+
typeof blockCallbackOrConfig === "object"
|
|
31
|
+
? blockCallbackOrConfig.onBlockRefLoad?.(e as HTMLSpanElement)
|
|
32
|
+
: blockRefCallback?.(e as HTMLSpanElement),
|
|
33
|
+
removeCallback: (e) =>
|
|
34
|
+
typeof blockCallbackOrConfig === "object" &&
|
|
35
|
+
blockCallbackOrConfig.onBlockRefUnload?.(e as HTMLSpanElement),
|
|
36
|
+
tag: "SPAN",
|
|
37
|
+
className: "rm-block-ref",
|
|
38
|
+
}),
|
|
39
|
+
];
|
|
40
|
+
}
|
|
41
|
+
return [blockObserver];
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
export default createBlockObserver;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import createHTMLObserver from "./createHTMLObserver";
|
|
2
|
+
|
|
3
|
+
const createButtonObserver = ({
|
|
4
|
+
attribute,
|
|
5
|
+
render,
|
|
6
|
+
shortcut = attribute,
|
|
7
|
+
}: {
|
|
8
|
+
shortcut?: string;
|
|
9
|
+
attribute: string;
|
|
10
|
+
render: (b: HTMLButtonElement) => void;
|
|
11
|
+
}): MutationObserver =>
|
|
12
|
+
createHTMLObserver({
|
|
13
|
+
callback: (b) => {
|
|
14
|
+
if (
|
|
15
|
+
b.innerText.toUpperCase() ===
|
|
16
|
+
attribute.toUpperCase().replace(/-/g, " ") ||
|
|
17
|
+
b.innerText.toUpperCase() === shortcut.toUpperCase()
|
|
18
|
+
) {
|
|
19
|
+
const dataAttribute = `data-roamjs-${attribute}`;
|
|
20
|
+
if (!b.getAttribute(dataAttribute)) {
|
|
21
|
+
b.setAttribute(dataAttribute, "true");
|
|
22
|
+
render(b as HTMLButtonElement);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
tag: "BUTTON",
|
|
27
|
+
className: "bp3-button",
|
|
28
|
+
useBody: true,
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
export default createButtonObserver;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import dispatchToRegistry from "../util/dispatchToRegistry";
|
|
2
|
+
|
|
3
|
+
const createDivObserver = (
|
|
4
|
+
mutationCallback: MutationCallback,
|
|
5
|
+
mutationTarget: Element
|
|
6
|
+
) => {
|
|
7
|
+
const observer = new MutationObserver(mutationCallback);
|
|
8
|
+
observer.observe(mutationTarget, { childList: true, subtree: true });
|
|
9
|
+
dispatchToRegistry({
|
|
10
|
+
observers: [observer],
|
|
11
|
+
});
|
|
12
|
+
return observer;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default createDivObserver;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import createObserver from "./createObserver";
|
|
2
|
+
import createOverlayObserver from "./createOverlayObserver";
|
|
3
|
+
|
|
4
|
+
const createHTMLObserver = ({
|
|
5
|
+
callback,
|
|
6
|
+
tag,
|
|
7
|
+
className,
|
|
8
|
+
removeCallback,
|
|
9
|
+
useBody,
|
|
10
|
+
}: {
|
|
11
|
+
callback: (b: HTMLElement) => void;
|
|
12
|
+
tag: string;
|
|
13
|
+
className: string;
|
|
14
|
+
removeCallback?: (b: HTMLElement) => void;
|
|
15
|
+
useBody?: boolean;
|
|
16
|
+
}): MutationObserver => {
|
|
17
|
+
const getChildren = (d: Node) =>
|
|
18
|
+
Array.from((d as HTMLElement).getElementsByClassName(className)).filter(
|
|
19
|
+
(d) => d.nodeName === tag
|
|
20
|
+
) as HTMLElement[];
|
|
21
|
+
getChildren(document).forEach(callback);
|
|
22
|
+
|
|
23
|
+
const isNode = (d: Node) =>
|
|
24
|
+
d.nodeName === tag &&
|
|
25
|
+
Array.from((d as HTMLElement).classList).includes(className);
|
|
26
|
+
const getNodes = (nodes: NodeList) =>
|
|
27
|
+
Array.from(nodes)
|
|
28
|
+
.filter((d: Node) => isNode(d) || d.hasChildNodes())
|
|
29
|
+
.flatMap((d) => (isNode(d) ? [d] : getChildren(d)));
|
|
30
|
+
|
|
31
|
+
return (useBody ? createOverlayObserver : createObserver)((ms) => {
|
|
32
|
+
const nodes = ms.flatMap((m) => [
|
|
33
|
+
...getNodes(m.addedNodes).map((node) => ({ node, added: true })),
|
|
34
|
+
...getNodes(m.removedNodes).map((node) => ({ node, added: false })),
|
|
35
|
+
]);
|
|
36
|
+
nodes.forEach((b) =>
|
|
37
|
+
b.added
|
|
38
|
+
? callback(b.node as HTMLElement)
|
|
39
|
+
: removeCallback?.(b.node as HTMLElement)
|
|
40
|
+
);
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
export default createHTMLObserver;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import createHTMLObserver from "./createHTMLObserver";
|
|
2
|
+
|
|
3
|
+
const createHashtagObserver = ({
|
|
4
|
+
callback,
|
|
5
|
+
attribute,
|
|
6
|
+
}: {
|
|
7
|
+
callback: (s: HTMLSpanElement) => void;
|
|
8
|
+
attribute: string;
|
|
9
|
+
}): MutationObserver =>
|
|
10
|
+
createHTMLObserver({
|
|
11
|
+
useBody: true,
|
|
12
|
+
tag: "SPAN",
|
|
13
|
+
className: "rm-page-ref--tag",
|
|
14
|
+
callback: (s: HTMLSpanElement) => {
|
|
15
|
+
if (!s.getAttribute(attribute)) {
|
|
16
|
+
s.setAttribute(attribute, "true");
|
|
17
|
+
callback(s);
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
export default createHashtagObserver;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const createIconButton = (icon: string): HTMLSpanElement => {
|
|
2
|
+
const popoverButton = document.createElement("span");
|
|
3
|
+
popoverButton.className = "bp3-button bp3-minimal bp3-small";
|
|
4
|
+
popoverButton.tabIndex = 0;
|
|
5
|
+
|
|
6
|
+
const popoverIcon = document.createElement("span");
|
|
7
|
+
popoverIcon.className = `bp3-icon bp3-icon-${icon}`;
|
|
8
|
+
popoverButton.appendChild(popoverIcon);
|
|
9
|
+
|
|
10
|
+
return popoverButton;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export default createIconButton;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import createDivObserver from "./createDivObserver";
|
|
2
|
+
|
|
3
|
+
const createObserver = (
|
|
4
|
+
mutationCallback: (
|
|
5
|
+
mutationList: MutationRecord[],
|
|
6
|
+
observer: MutationObserver
|
|
7
|
+
) => void
|
|
8
|
+
): MutationObserver => {
|
|
9
|
+
return createDivObserver(
|
|
10
|
+
mutationCallback,
|
|
11
|
+
document.getElementById("app") ?? document.body
|
|
12
|
+
);
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default createObserver;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import createDivObserver from "./createDivObserver";
|
|
2
|
+
|
|
3
|
+
const createOverlayObserver = (
|
|
4
|
+
mutationCallback: (mutationList: MutationRecord[]) => void
|
|
5
|
+
): MutationObserver => createDivObserver(mutationCallback, document.body);
|
|
6
|
+
|
|
7
|
+
export default createOverlayObserver;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import getBlockUidsByPageTitle from "../queries/getBlockUidsByPageTitle";
|
|
2
|
+
import createObserver from "./createObserver";
|
|
3
|
+
import getMutatedNodes from "./getMutatedNodes";
|
|
4
|
+
import getUids from "./getUids";
|
|
5
|
+
|
|
6
|
+
const createPageObserver = (
|
|
7
|
+
name: string,
|
|
8
|
+
callback: (blockUid: string, added: boolean) => void
|
|
9
|
+
): MutationObserver =>
|
|
10
|
+
createObserver((ms) => {
|
|
11
|
+
const addedNodes = getMutatedNodes({
|
|
12
|
+
ms,
|
|
13
|
+
nodeList: "addedNodes",
|
|
14
|
+
tag: "DIV",
|
|
15
|
+
className: "roam-block",
|
|
16
|
+
}).map((blockNode) => ({
|
|
17
|
+
blockUid: getUids(blockNode as HTMLDivElement).blockUid,
|
|
18
|
+
added: true,
|
|
19
|
+
}));
|
|
20
|
+
const removedNodes = getMutatedNodes({
|
|
21
|
+
ms,
|
|
22
|
+
nodeList: "removedNodes",
|
|
23
|
+
tag: "DIV",
|
|
24
|
+
className: "roam-block",
|
|
25
|
+
}).map((blockNode) => ({
|
|
26
|
+
blockUid: getUids(blockNode as HTMLDivElement).blockUid,
|
|
27
|
+
added: false,
|
|
28
|
+
}));
|
|
29
|
+
if (addedNodes.length || removedNodes.length) {
|
|
30
|
+
const blockUids = new Set(getBlockUidsByPageTitle(name));
|
|
31
|
+
[...removedNodes, ...addedNodes]
|
|
32
|
+
.filter(({ blockUid }) => blockUids.has(blockUid))
|
|
33
|
+
.forEach(({ blockUid, added }) => callback(blockUid, added));
|
|
34
|
+
}
|
|
35
|
+
})
|
|
36
|
+
|
|
37
|
+
export default createPageObserver;
|