roamjs-components 0.53.2 → 0.53.5
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/LICENSE +21 -21
- package/README.md +154 -154
- package/backend/emailCatch.d.ts +4 -4
- package/backend/emailCatch.js +11 -11
- package/backend/emailError.d.ts +4 -4
- package/backend/emailError.js +56 -56
- package/backend/getRoamJSUser.d.ts +11 -11
- package/backend/getRoamJSUser.js +30 -30
- package/backend/headers.d.ts +5 -5
- package/backend/headers.js +7 -7
- package/backend/index.d.ts +6 -6
- package/backend/index.js +20 -20
- package/backend/meterRoamJSUser.d.ts +4 -4
- package/backend/meterRoamJSUser.js +14 -14
- package/backend/putRoamJSUser.d.ts +10 -10
- package/backend/putRoamJSUser.js +25 -25
- package/components/BlockErrorBoundary.d.ts +15 -15
- package/components/BlockErrorBoundary.js +27 -27
- package/components/BlockInput.d.ts +12 -12
- package/components/BlockInput.js +53 -53
- package/components/ComponentContainer.d.ts +9 -9
- package/components/ComponentContainer.js +46 -46
- package/components/ConfigPage.d.ts +99 -99
- package/components/ConfigPage.js +751 -751
- package/components/CursorMenu.d.ts +21 -21
- package/components/CursorMenu.js +181 -181
- package/components/Description.d.ts +5 -5
- package/components/Description.js +16 -16
- package/components/ExternalLogin.d.ts +18 -18
- package/components/ExternalLogin.js +131 -131
- package/components/Filter.d.ts +14 -14
- package/components/Filter.js +147 -147
- package/components/Loading.d.ts +4 -4
- package/components/Loading.js +33 -33
- package/components/MenuItemSelect.d.ts +10 -10
- package/components/MenuItemSelect.js +13 -13
- package/components/OauthSelect.d.ts +5 -5
- package/components/OauthSelect.js +25 -25
- package/components/PageInput.d.ts +10 -10
- package/components/PageInput.js +69 -69
- package/components/ServiceComponents.d.ts +49 -49
- package/components/ServiceComponents.js +277 -277
- package/components/SimpleAlert.d.ts +12 -12
- package/components/SimpleAlert.js +38 -38
- package/components/Toast.d.ts +10 -10
- package/components/Toast.js +41 -41
- package/components/TokenDialog.d.ts +11 -11
- package/components/TokenDialog.js +100 -100
- package/components/index.d.ts +15 -15
- package/components/index.js +60 -60
- package/date/constants.d.ts +2 -2
- package/date/constants.js +5 -5
- package/date/index.d.ts +5 -5
- package/date/index.js +13 -13
- package/date/parseRoamDate.d.ts +2 -2
- package/date/parseRoamDate.js +6 -6
- package/date/parseRoamDateUid.d.ts +2 -2
- package/date/parseRoamDateUid.js +6 -6
- package/date/toRoamDate.d.ts +2 -2
- package/date/toRoamDate.js +6 -6
- package/date/toRoamDateUid.d.ts +2 -2
- package/date/toRoamDateUid.js +6 -6
- package/dom/addBlockCommand.d.ts +5 -5
- package/dom/addBlockCommand.js +53 -53
- package/dom/addOldRoamJSDependency.d.ts +2 -2
- package/dom/addOldRoamJSDependency.js +10 -10
- package/dom/addRoamJSDependency.d.ts +2 -2
- package/dom/addRoamJSDependency.js +8 -8
- package/dom/addScriptAsDependency.d.ts +6 -6
- package/dom/addScriptAsDependency.js +16 -16
- package/dom/addStyle.d.ts +2 -2
- package/dom/addStyle.js +14 -14
- package/dom/constants.d.ts +1 -1
- package/dom/constants.js +4 -4
- package/dom/createBlockObserver.d.ts +7 -7
- package/dom/createBlockObserver.js +43 -43
- package/dom/createButtonObserver.d.ts +6 -6
- package/dom/createButtonObserver.js +21 -21
- package/dom/createDivObserver.d.ts +2 -2
- package/dom/createDivObserver.js +8 -8
- package/dom/createHTMLObserver.d.ts +8 -8
- package/dom/createHTMLObserver.js +24 -24
- package/dom/createHashtagObserver.d.ts +5 -5
- package/dom/createHashtagObserver.js +16 -16
- package/dom/createIconButton.d.ts +2 -2
- package/dom/createIconButton.js +12 -12
- package/dom/createObserver.d.ts +2 -2
- package/dom/createObserver.js +6 -6
- package/dom/createOverlayObserver.d.ts +2 -2
- package/dom/createOverlayObserver.js +6 -6
- package/dom/createPageObserver.d.ts +2 -2
- package/dom/createPageObserver.js +34 -34
- package/dom/createPageTitleObserver.d.ts +6 -6
- package/dom/createPageTitleObserver.js +29 -29
- package/dom/genericError.d.ts +4 -4
- package/dom/genericError.js +16 -16
- package/dom/getActiveUids.d.ts +3 -3
- package/dom/getActiveUids.js +6 -6
- package/dom/getBlockUidFromTarget.d.ts +2 -2
- package/dom/getBlockUidFromTarget.js +33 -33
- package/dom/getCurrentPageUid.d.ts +2 -2
- package/dom/getCurrentPageUid.js +6 -6
- package/dom/getDomRefs.d.ts +2 -2
- package/dom/getDomRefs.js +12 -12
- package/dom/getDropUidOffset.d.ts +5 -5
- package/dom/getDropUidOffset.js +27 -27
- package/dom/getMutatedNodes.d.ts +7 -7
- package/dom/getMutatedNodes.js +11 -11
- package/dom/getPageTitleByHtmlElement.d.ts +2 -2
- package/dom/getPageTitleByHtmlElement.js +12 -12
- package/dom/getPageTitleValueByHtmlElement.d.ts +2 -2
- package/dom/getPageTitleValueByHtmlElement.js +27 -27
- package/dom/getReferenceBlockUid.d.ts +2 -2
- package/dom/getReferenceBlockUid.js +18 -18
- package/dom/getRoamUrl.d.ts +2 -2
- package/dom/getRoamUrl.js +4 -4
- package/dom/getRoamUrlByPage.d.ts +2 -2
- package/dom/getRoamUrlByPage.js +10 -10
- package/dom/getUids.d.ts +3 -3
- package/dom/getUids.js +8 -8
- package/dom/getUidsFromButton.d.ts +3 -3
- package/dom/getUidsFromButton.js +9 -9
- package/dom/getUidsFromId.d.ts +5 -5
- package/dom/getUidsFromId.js +15 -15
- package/dom/index.d.ts +31 -31
- package/dom/index.js +65 -65
- package/dom/openBlock.d.ts +2 -2
- package/dom/openBlock.js +6 -6
- package/dom/openBlockElement.d.ts +2 -2
- package/dom/openBlockElement.js +16 -16
- package/dom/parseRoamBlocksToHtml.d.ts +9 -9
- package/dom/parseRoamBlocksToHtml.js +75 -75
- package/dom/resolveRefs.d.ts +2 -2
- package/dom/resolveRefs.js +24 -24
- package/events/index.d.ts +1 -1
- package/events/index.js +8 -8
- package/events/watchOnce.d.ts +3 -3
- package/events/watchOnce.js +11 -11
- package/hooks/index.d.ts +3 -3
- package/hooks/index.js +12 -12
- package/hooks/useArrowKeyDown.d.ts +8 -8
- package/hooks/useArrowKeyDown.js +31 -31
- package/hooks/useRoamJSTokenWarning.d.ts +2 -2
- package/hooks/useRoamJSTokenWarning.js +11 -11
- package/hooks/useSubTree.d.ts +3 -3
- package/hooks/useSubTree.js +11 -11
- package/index.d.ts +11 -11
- package/index.js +14 -14
- package/marked/index.d.ts +14 -14
- package/marked/index.js +518 -518
- package/package.json +86 -86
- package/queries/getAllBlockUids.d.ts +2 -2
- package/queries/getAllBlockUids.js +6 -6
- package/queries/getAllBlockUidsAndTexts.d.ts +5 -5
- package/queries/getAllBlockUidsAndTexts.js +6 -6
- package/queries/getAllPageNames.d.ts +2 -2
- package/queries/getAllPageNames.js +6 -6
- package/queries/getAttributeValueByBlockAndName.d.ts +5 -5
- package/queries/getAttributeValueByBlockAndName.js +11 -11
- package/queries/getBasicTreeByParentUid.d.ts +3 -3
- package/queries/getBasicTreeByParentUid.js +13 -13
- package/queries/getBlockUidAndTextIncludingText.d.ts +5 -5
- package/queries/getBlockUidAndTextIncludingText.js +6 -6
- package/queries/getBlockUidByTextOnPage.d.ts +5 -5
- package/queries/getBlockUidByTextOnPage.js +7 -7
- package/queries/getBlockUidsAndTextsReferencingPage.d.ts +5 -5
- package/queries/getBlockUidsAndTextsReferencingPage.js +11 -11
- package/queries/getBlockUidsByPageTitle.d.ts +2 -2
- package/queries/getBlockUidsByPageTitle.js +8 -8
- package/queries/getBlockUidsReferencingBlock.d.ts +2 -2
- package/queries/getBlockUidsReferencingBlock.js +6 -6
- package/queries/getBlockUidsReferencingPage.d.ts +2 -2
- package/queries/getBlockUidsReferencingPage.js +8 -8
- package/queries/getBlockUidsWithParentUid.d.ts +2 -2
- package/queries/getBlockUidsWithParentUid.js +6 -6
- package/queries/getChildrenLengthByPageUid.d.ts +2 -2
- package/queries/getChildrenLengthByPageUid.js +4 -4
- package/queries/getCreateTimeByBlockUid.d.ts +2 -2
- package/queries/getCreateTimeByBlockUid.js +7 -7
- package/queries/getCurrentUser.d.ts +2 -2
- package/queries/getCurrentUser.js +11 -11
- package/queries/getCurrentUserDisplayName.d.ts +2 -2
- package/queries/getCurrentUserDisplayName.js +13 -13
- package/queries/getCurrentUserEmail.d.ts +2 -2
- package/queries/getCurrentUserEmail.js +13 -13
- package/queries/getCurrentUserUid.d.ts +2 -2
- package/queries/getCurrentUserUid.js +13 -13
- package/queries/getDisplayNameByEmail.d.ts +2 -2
- package/queries/getDisplayNameByEmail.js +7 -7
- package/queries/getDisplayNameByUid.d.ts +2 -2
- package/queries/getDisplayNameByUid.js +7 -7
- package/queries/getEditTimeByBlockUid.d.ts +2 -2
- package/queries/getEditTimeByBlockUid.js +7 -7
- package/queries/getEditedUserEmailByBlockUid.d.ts +2 -2
- package/queries/getEditedUserEmailByBlockUid.js +7 -7
- package/queries/getFirstChildTextByBlockUid.d.ts +2 -2
- package/queries/getFirstChildTextByBlockUid.js +7 -7
- package/queries/getFirstChildUidByBlockUid.d.ts +2 -2
- package/queries/getFirstChildUidByBlockUid.js +5 -5
- package/queries/getFullTreeByParentUid.d.ts +3 -3
- package/queries/getFullTreeByParentUid.js +26 -26
- package/queries/getLinkedPageTitlesUnderUid.d.ts +2 -2
- package/queries/getLinkedPageTitlesUnderUid.js +6 -6
- package/queries/getNthChildUidByBlockUid.d.ts +5 -5
- package/queries/getNthChildUidByBlockUid.js +7 -7
- package/queries/getOrderByBlockUid.d.ts +2 -2
- package/queries/getOrderByBlockUid.js +7 -7
- package/queries/getPageTitleByBlockUid.d.ts +2 -2
- package/queries/getPageTitleByBlockUid.js +7 -7
- package/queries/getPageTitleByPageUid.d.ts +2 -2
- package/queries/getPageTitleByPageUid.js +9 -9
- package/queries/getPageTitleReferencesByPageTitle.d.ts +2 -2
- package/queries/getPageTitleReferencesByPageTitle.js +8 -8
- package/queries/getPageTitlesAndBlockUidsReferencingPage.d.ts +5 -5
- package/queries/getPageTitlesAndBlockUidsReferencingPage.js +8 -8
- package/queries/getPageTitlesAndUidsDirectlyReferencingPage.d.ts +5 -5
- package/queries/getPageTitlesAndUidsDirectlyReferencingPage.js +8 -8
- package/queries/getPageTitlesReferencingBlockUid.d.ts +2 -2
- package/queries/getPageTitlesReferencingBlockUid.js +6 -6
- package/queries/getPageTitlesStartingWithPrefix.d.ts +2 -2
- package/queries/getPageTitlesStartingWithPrefix.js +6 -6
- package/queries/getPageUidByPageTitle.d.ts +2 -2
- package/queries/getPageUidByPageTitle.js +9 -9
- package/queries/getPageViewType.d.ts +3 -3
- package/queries/getPageViewType.js +9 -9
- package/queries/getParentTextByBlockUid.d.ts +2 -2
- package/queries/getParentTextByBlockUid.js +7 -7
- package/queries/getParentTextByBlockUidAndTag.d.ts +5 -5
- package/queries/getParentTextByBlockUidAndTag.js +7 -7
- package/queries/getParentUidByBlockUid.d.ts +2 -2
- package/queries/getParentUidByBlockUid.js +7 -7
- package/queries/getParentUidsOfBlockUid.d.ts +2 -2
- package/queries/getParentUidsOfBlockUid.js +6 -6
- package/queries/getSettingsByEmail.d.ts +3 -3
- package/queries/getSettingsByEmail.js +7 -7
- package/queries/getShallowTreeByParentUid.d.ts +5 -5
- package/queries/getShallowTreeByParentUid.js +10 -10
- package/queries/getTextByBlockUid.d.ts +2 -2
- package/queries/getTextByBlockUid.js +7 -7
- package/queries/index.d.ts +45 -45
- package/queries/index.js +96 -96
- package/queries/isTagOnPage.d.ts +5 -5
- package/queries/isTagOnPage.js +9 -9
- package/queries/normalizePageTitle.d.ts +2 -2
- package/queries/normalizePageTitle.js +4 -4
- package/types/index.d.ts +461 -459
- package/types/index.js +2 -2
- package/types/query-builder.d.ts +16 -16
- package/types/query-builder.js +2 -2
- package/util/addInputSetting.d.ts +7 -7
- package/util/addInputSetting.js +25 -25
- package/util/apiDelete.d.ts +2 -2
- package/util/apiDelete.js +9 -9
- package/util/apiGet.d.ts +2 -2
- package/util/apiGet.js +9 -9
- package/util/apiPost.d.ts +2 -2
- package/util/apiPost.js +9 -9
- package/util/apiPut.d.ts +2 -2
- package/util/apiPut.js +9 -9
- package/util/createOverlayRender.d.ts +6 -6
- package/util/createOverlayRender.js +18 -18
- package/util/createTagRegex.d.ts +2 -2
- package/util/createTagRegex.js +4 -4
- package/util/extractRef.d.ts +2 -2
- package/util/extractRef.js +8 -8
- package/util/extractTag.d.ts +2 -2
- package/util/extractTag.js +12 -12
- package/util/getAuthorizationHeader.d.ts +2 -2
- package/util/getAuthorizationHeader.js +12 -12
- package/util/getGraph.d.ts +2 -2
- package/util/getGraph.js +8 -8
- package/util/getLocalStorageKey.d.ts +2 -2
- package/util/getLocalStorageKey.js +6 -6
- package/util/getOauth.d.ts +2 -2
- package/util/getOauth.js +50 -50
- package/util/getOauthAccounts.d.ts +2 -2
- package/util/getOauthAccounts.js +21 -21
- package/util/getRenderRoot.d.ts +2 -2
- package/util/getRenderRoot.js +11 -11
- package/util/getSettingIntFromTree.d.ts +7 -7
- package/util/getSettingIntFromTree.js +11 -11
- package/util/getSettingValueFromTree.d.ts +7 -7
- package/util/getSettingValueFromTree.js +13 -13
- package/util/getSettingValuesFromTree.d.ts +7 -7
- package/util/getSettingValuesFromTree.js +12 -12
- package/util/getSubTree.d.ts +8 -8
- package/util/getSubTree.js +19 -19
- package/util/getToken.d.ts +2 -2
- package/util/getToken.js +9 -9
- package/util/getTokenFromTree.d.ts +2 -2
- package/util/getTokenFromTree.js +5 -5
- package/util/idToTitle.d.ts +2 -2
- package/util/idToTitle.js +8 -8
- package/util/index.d.ts +23 -23
- package/util/index.js +52 -52
- package/util/isControl.d.ts +2 -2
- package/util/isControl.js +6 -6
- package/util/localStorageGet.d.ts +2 -2
- package/util/localStorageGet.js +8 -8
- package/util/localStorageRemove.d.ts +2 -2
- package/util/localStorageRemove.js +6 -6
- package/util/localStorageSet.d.ts +2 -2
- package/util/localStorageSet.js +8 -8
- package/util/registerSmartBlocksCommand.d.ts +8 -8
- package/util/registerSmartBlocksCommand.js +24 -24
- package/util/runExtension.d.ts +4 -4
- package/util/runExtension.js +40 -40
- package/util/setInputSetting.d.ts +7 -7
- package/util/setInputSetting.js +33 -33
- package/util/setInputSettings.d.ts +7 -7
- package/util/setInputSettings.js +28 -28
- package/util/toConfigPageName.d.ts +2 -2
- package/util/toConfigPageName.js +4 -4
- package/util/toFlexRegex.d.ts +2 -2
- package/util/toFlexRegex.js +4 -4
- package/writes/clearBlockById.d.ts +2 -2
- package/writes/clearBlockById.js +11 -11
- package/writes/clearBlockByUid.d.ts +2 -2
- package/writes/clearBlockByUid.js +9 -9
- package/writes/createBlock.d.ts +9 -9
- package/writes/createBlock.js +61 -61
- package/writes/createPage.d.ts +7 -7
- package/writes/createPage.js +18 -18
- package/writes/deleteBlock.d.ts +2 -2
- package/writes/deleteBlock.js +6 -6
- package/writes/index.d.ts +8 -8
- package/writes/index.js +22 -22
- package/writes/openBlockInSidebar.d.ts +2 -2
- package/writes/openBlockInSidebar.js +13 -13
- package/writes/updateActiveBlock.d.ts +2 -2
- package/writes/updateActiveBlock.js +11 -11
- package/writes/updateBlock.d.ts +5 -5
- package/writes/updateBlock.js +17 -17
|
@@ -1,132 +1,132 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const tslib_1 = require("tslib");
|
|
4
|
-
const core_1 = require("@blueprintjs/core");
|
|
5
|
-
const react_1 = (0, tslib_1.__importStar)(require("react"));
|
|
6
|
-
const createBlock_1 = (0, tslib_1.__importDefault)(require("../writes/createBlock"));
|
|
7
|
-
const getBasicTreeByParentUid_1 = (0, tslib_1.__importDefault)(require("../queries/getBasicTreeByParentUid"));
|
|
8
|
-
const idToTitle_1 = (0, tslib_1.__importDefault)(require("../util/idToTitle"));
|
|
9
|
-
const randomstring_1 = (0, tslib_1.__importDefault)(require("randomstring"));
|
|
10
|
-
const axios_1 = (0, tslib_1.__importDefault)(require("axios"));
|
|
11
|
-
const aes_1 = (0, tslib_1.__importDefault)(require("crypto-js/aes"));
|
|
12
|
-
const enc_utf8_1 = (0, tslib_1.__importDefault)(require("crypto-js/enc-utf8"));
|
|
13
|
-
const localStorageGet_1 = (0, tslib_1.__importDefault)(require("../util/localStorageGet"));
|
|
14
|
-
const localStorageSet_1 = (0, tslib_1.__importDefault)(require("../util/localStorageSet"));
|
|
15
|
-
const targetOrigin = process.env.CUSTOM_ROAMJS_ORIGIN || "https://roamjs.com";
|
|
16
|
-
const ExternalLogin = ({ onSuccess, useLocal, parentUid, service, getPopoutUrl, getAuthData, ServiceIcon, loggedIn = false, }) => {
|
|
17
|
-
const [loading, setLoading] = (0, react_1.useState)(false);
|
|
18
|
-
const [error, setError] = (0, react_1.useState)("");
|
|
19
|
-
const onClick = (0, react_1.useCallback)(() => {
|
|
20
|
-
const otp = randomstring_1.default.generate(8);
|
|
21
|
-
const key = randomstring_1.default.generate(16);
|
|
22
|
-
const state = `${service}_${otp}_${key}`;
|
|
23
|
-
setLoading(true);
|
|
24
|
-
getPopoutUrl(state)
|
|
25
|
-
.then((url) => {
|
|
26
|
-
const width = 600;
|
|
27
|
-
const height = 525;
|
|
28
|
-
const left = window.screenX + (window.innerWidth - width) / 2;
|
|
29
|
-
const top = window.screenY + (window.innerHeight - height) / 2;
|
|
30
|
-
const loginWindow = window.open(`${url}&state=${state}`, `roamjs:${service}:login`, `left=${left},top=${top},width=${width},height=${height},status=1`);
|
|
31
|
-
let intervalListener = 0;
|
|
32
|
-
const processAuthData = (data) => {
|
|
33
|
-
var _a;
|
|
34
|
-
(_a = loginWindow === null || loginWindow === void 0 ? void 0 : loginWindow.close) === null || _a === void 0 ? void 0 : _a.call(loginWindow);
|
|
35
|
-
getAuthData(data)
|
|
36
|
-
.then((rr) => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
37
|
-
var _b;
|
|
38
|
-
const labelUid = window.roamAlphaAPI.util.generateUID();
|
|
39
|
-
const { label = "Default Account" } = rr, rawData = (0, tslib_1.__rest)(rr, ["label"]);
|
|
40
|
-
const oauthData = JSON.stringify(rawData);
|
|
41
|
-
const account = {
|
|
42
|
-
text: label,
|
|
43
|
-
uid: labelUid,
|
|
44
|
-
data: oauthData,
|
|
45
|
-
time: new Date().valueOf(),
|
|
46
|
-
};
|
|
47
|
-
const existingTree = (0, getBasicTreeByParentUid_1.default)(parentUid).find((t) => /oauth/i.test(t.text));
|
|
48
|
-
const blockUid = (existingTree === null || existingTree === void 0 ? void 0 : existingTree.uid) ||
|
|
49
|
-
(yield (0, createBlock_1.default)({ node: { text: "oauth" }, parentUid }));
|
|
50
|
-
if (useLocal) {
|
|
51
|
-
const key = `oauth-${service}`;
|
|
52
|
-
const accounts = JSON.parse((0, localStorageGet_1.default)(key));
|
|
53
|
-
(0, localStorageSet_1.default)(key, JSON.stringify([...accounts, account]));
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
window.roamAlphaAPI.createBlock({
|
|
57
|
-
block: { string: label, uid: labelUid },
|
|
58
|
-
location: {
|
|
59
|
-
"parent-uid": blockUid,
|
|
60
|
-
order: ((_b = existingTree === null || existingTree === void 0 ? void 0 : existingTree.children) === null || _b === void 0 ? void 0 : _b.length) || 0,
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
const valueUid = window.roamAlphaAPI.util.generateUID();
|
|
64
|
-
const block = {
|
|
65
|
-
string: oauthData,
|
|
66
|
-
uid: valueUid,
|
|
67
|
-
};
|
|
68
|
-
window.roamAlphaAPI.createBlock({
|
|
69
|
-
location: { "parent-uid": labelUid, order: 0 },
|
|
70
|
-
block,
|
|
71
|
-
});
|
|
72
|
-
window.roamAlphaAPI.updateBlock({
|
|
73
|
-
block: { open: false, string: "oauth", uid: blockUid },
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
onSuccess(account);
|
|
77
|
-
}))
|
|
78
|
-
.finally(() => {
|
|
79
|
-
window.removeEventListener("message", messageEventListener);
|
|
80
|
-
window.clearTimeout(intervalListener);
|
|
81
|
-
setLoading(false);
|
|
82
|
-
});
|
|
83
|
-
};
|
|
84
|
-
const messageEventListener = (e) => {
|
|
85
|
-
if (e.origin === targetOrigin && loginWindow) {
|
|
86
|
-
processAuthData(e.data);
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
const authInterval = () => {
|
|
90
|
-
axios_1.default
|
|
91
|
-
.post(`https://lambda.roamjs.com/auth`, {
|
|
92
|
-
service,
|
|
93
|
-
otp,
|
|
94
|
-
})
|
|
95
|
-
.then((r) => {
|
|
96
|
-
if (r.data.auth) {
|
|
97
|
-
const auth = aes_1.default.decrypt(r.data.auth, key).toString(enc_utf8_1.default);
|
|
98
|
-
processAuthData(auth);
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
intervalListener = window.setTimeout(authInterval, 1000);
|
|
102
|
-
}
|
|
103
|
-
})
|
|
104
|
-
.catch((e) => {
|
|
105
|
-
var _a;
|
|
106
|
-
if (((_a = e.response) === null || _a === void 0 ? void 0 : _a.status) !== 400) {
|
|
107
|
-
intervalListener = window.setTimeout(authInterval, 1000);
|
|
108
|
-
}
|
|
109
|
-
});
|
|
110
|
-
};
|
|
111
|
-
authInterval();
|
|
112
|
-
window.addEventListener("message", messageEventListener);
|
|
113
|
-
})
|
|
114
|
-
.catch((e) => {
|
|
115
|
-
setError(e.message);
|
|
116
|
-
setLoading(false);
|
|
117
|
-
});
|
|
118
|
-
}, [onSuccess, parentUid, setLoading, setError]);
|
|
119
|
-
return (react_1.default.createElement("div", { style: { display: "flex" } },
|
|
120
|
-
react_1.default.createElement(core_1.Button, { icon: react_1.default.createElement(core_1.Icon, { icon: react_1.default.createElement(ServiceIcon, { style: {
|
|
121
|
-
width: 15,
|
|
122
|
-
height: 15,
|
|
123
|
-
marginLeft: 4,
|
|
124
|
-
cursor: "pointer",
|
|
125
|
-
} }) }), onClick: onClick, disabled: loading, className: "roamjs-external-login" }, loggedIn
|
|
126
|
-
? `Add Another ${(0, idToTitle_1.default)(service)} Account`
|
|
127
|
-
: `Login With ${(0, idToTitle_1.default)(service)}`),
|
|
128
|
-
loading && react_1.default.createElement(core_1.Spinner, { size: core_1.Spinner.SIZE_SMALL }),
|
|
129
|
-
error && (react_1.default.createElement("div", { style: { color: "red", whiteSpace: "pre-line" } }, error))));
|
|
130
|
-
};
|
|
131
|
-
exports.default = ExternalLogin;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const core_1 = require("@blueprintjs/core");
|
|
5
|
+
const react_1 = (0, tslib_1.__importStar)(require("react"));
|
|
6
|
+
const createBlock_1 = (0, tslib_1.__importDefault)(require("../writes/createBlock"));
|
|
7
|
+
const getBasicTreeByParentUid_1 = (0, tslib_1.__importDefault)(require("../queries/getBasicTreeByParentUid"));
|
|
8
|
+
const idToTitle_1 = (0, tslib_1.__importDefault)(require("../util/idToTitle"));
|
|
9
|
+
const randomstring_1 = (0, tslib_1.__importDefault)(require("randomstring"));
|
|
10
|
+
const axios_1 = (0, tslib_1.__importDefault)(require("axios"));
|
|
11
|
+
const aes_1 = (0, tslib_1.__importDefault)(require("crypto-js/aes"));
|
|
12
|
+
const enc_utf8_1 = (0, tslib_1.__importDefault)(require("crypto-js/enc-utf8"));
|
|
13
|
+
const localStorageGet_1 = (0, tslib_1.__importDefault)(require("../util/localStorageGet"));
|
|
14
|
+
const localStorageSet_1 = (0, tslib_1.__importDefault)(require("../util/localStorageSet"));
|
|
15
|
+
const targetOrigin = process.env.CUSTOM_ROAMJS_ORIGIN || "https://roamjs.com";
|
|
16
|
+
const ExternalLogin = ({ onSuccess, useLocal, parentUid, service, getPopoutUrl, getAuthData, ServiceIcon, loggedIn = false, }) => {
|
|
17
|
+
const [loading, setLoading] = (0, react_1.useState)(false);
|
|
18
|
+
const [error, setError] = (0, react_1.useState)("");
|
|
19
|
+
const onClick = (0, react_1.useCallback)(() => {
|
|
20
|
+
const otp = randomstring_1.default.generate(8);
|
|
21
|
+
const key = randomstring_1.default.generate(16);
|
|
22
|
+
const state = `${service}_${otp}_${key}`;
|
|
23
|
+
setLoading(true);
|
|
24
|
+
getPopoutUrl(state)
|
|
25
|
+
.then((url) => {
|
|
26
|
+
const width = 600;
|
|
27
|
+
const height = 525;
|
|
28
|
+
const left = window.screenX + (window.innerWidth - width) / 2;
|
|
29
|
+
const top = window.screenY + (window.innerHeight - height) / 2;
|
|
30
|
+
const loginWindow = window.open(`${url}&state=${state}`, `roamjs:${service}:login`, `left=${left},top=${top},width=${width},height=${height},status=1`);
|
|
31
|
+
let intervalListener = 0;
|
|
32
|
+
const processAuthData = (data) => {
|
|
33
|
+
var _a;
|
|
34
|
+
(_a = loginWindow === null || loginWindow === void 0 ? void 0 : loginWindow.close) === null || _a === void 0 ? void 0 : _a.call(loginWindow);
|
|
35
|
+
getAuthData(data)
|
|
36
|
+
.then((rr) => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
|
|
37
|
+
var _b;
|
|
38
|
+
const labelUid = window.roamAlphaAPI.util.generateUID();
|
|
39
|
+
const { label = "Default Account" } = rr, rawData = (0, tslib_1.__rest)(rr, ["label"]);
|
|
40
|
+
const oauthData = JSON.stringify(rawData);
|
|
41
|
+
const account = {
|
|
42
|
+
text: label,
|
|
43
|
+
uid: labelUid,
|
|
44
|
+
data: oauthData,
|
|
45
|
+
time: new Date().valueOf(),
|
|
46
|
+
};
|
|
47
|
+
const existingTree = (0, getBasicTreeByParentUid_1.default)(parentUid).find((t) => /oauth/i.test(t.text));
|
|
48
|
+
const blockUid = (existingTree === null || existingTree === void 0 ? void 0 : existingTree.uid) ||
|
|
49
|
+
(yield (0, createBlock_1.default)({ node: { text: "oauth" }, parentUid }));
|
|
50
|
+
if (useLocal) {
|
|
51
|
+
const key = `oauth-${service}`;
|
|
52
|
+
const accounts = JSON.parse((0, localStorageGet_1.default)(key));
|
|
53
|
+
(0, localStorageSet_1.default)(key, JSON.stringify([...accounts, account]));
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
window.roamAlphaAPI.createBlock({
|
|
57
|
+
block: { string: label, uid: labelUid },
|
|
58
|
+
location: {
|
|
59
|
+
"parent-uid": blockUid,
|
|
60
|
+
order: ((_b = existingTree === null || existingTree === void 0 ? void 0 : existingTree.children) === null || _b === void 0 ? void 0 : _b.length) || 0,
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
const valueUid = window.roamAlphaAPI.util.generateUID();
|
|
64
|
+
const block = {
|
|
65
|
+
string: oauthData,
|
|
66
|
+
uid: valueUid,
|
|
67
|
+
};
|
|
68
|
+
window.roamAlphaAPI.createBlock({
|
|
69
|
+
location: { "parent-uid": labelUid, order: 0 },
|
|
70
|
+
block,
|
|
71
|
+
});
|
|
72
|
+
window.roamAlphaAPI.updateBlock({
|
|
73
|
+
block: { open: false, string: "oauth", uid: blockUid },
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
onSuccess(account);
|
|
77
|
+
}))
|
|
78
|
+
.finally(() => {
|
|
79
|
+
window.removeEventListener("message", messageEventListener);
|
|
80
|
+
window.clearTimeout(intervalListener);
|
|
81
|
+
setLoading(false);
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
const messageEventListener = (e) => {
|
|
85
|
+
if (e.origin === targetOrigin && loginWindow) {
|
|
86
|
+
processAuthData(e.data);
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
const authInterval = () => {
|
|
90
|
+
axios_1.default
|
|
91
|
+
.post(`https://lambda.roamjs.com/auth`, {
|
|
92
|
+
service,
|
|
93
|
+
otp,
|
|
94
|
+
})
|
|
95
|
+
.then((r) => {
|
|
96
|
+
if (r.data.auth) {
|
|
97
|
+
const auth = aes_1.default.decrypt(r.data.auth, key).toString(enc_utf8_1.default);
|
|
98
|
+
processAuthData(auth);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
intervalListener = window.setTimeout(authInterval, 1000);
|
|
102
|
+
}
|
|
103
|
+
})
|
|
104
|
+
.catch((e) => {
|
|
105
|
+
var _a;
|
|
106
|
+
if (((_a = e.response) === null || _a === void 0 ? void 0 : _a.status) !== 400) {
|
|
107
|
+
intervalListener = window.setTimeout(authInterval, 1000);
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
authInterval();
|
|
112
|
+
window.addEventListener("message", messageEventListener);
|
|
113
|
+
})
|
|
114
|
+
.catch((e) => {
|
|
115
|
+
setError(e.message);
|
|
116
|
+
setLoading(false);
|
|
117
|
+
});
|
|
118
|
+
}, [onSuccess, parentUid, setLoading, setError]);
|
|
119
|
+
return (react_1.default.createElement("div", { style: { display: "flex" } },
|
|
120
|
+
react_1.default.createElement(core_1.Button, { icon: react_1.default.createElement(core_1.Icon, { icon: react_1.default.createElement(ServiceIcon, { style: {
|
|
121
|
+
width: 15,
|
|
122
|
+
height: 15,
|
|
123
|
+
marginLeft: 4,
|
|
124
|
+
cursor: "pointer",
|
|
125
|
+
} }) }), onClick: onClick, disabled: loading, className: "roamjs-external-login" }, loggedIn
|
|
126
|
+
? `Add Another ${(0, idToTitle_1.default)(service)} Account`
|
|
127
|
+
: `Login With ${(0, idToTitle_1.default)(service)}`),
|
|
128
|
+
loading && react_1.default.createElement(core_1.Spinner, { size: core_1.Spinner.SIZE_SMALL }),
|
|
129
|
+
error && (react_1.default.createElement("div", { style: { color: "red", whiteSpace: "pre-line" } }, error))));
|
|
130
|
+
};
|
|
131
|
+
exports.default = ExternalLogin;
|
|
132
132
|
//# sourceMappingURL=ExternalLogin.js.map
|
package/components/Filter.d.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
declare type Filters = {
|
|
3
|
-
includes: Record<string, Set<string>>;
|
|
4
|
-
excludes: Record<string, Set<string>>;
|
|
5
|
-
};
|
|
6
|
-
declare const Filter: ({ data, initialValue, onChange, renderButtonText, includeHelpMessage, excludeHelpMessage, }: {
|
|
7
|
-
initialValue?: Filters | undefined;
|
|
8
|
-
data: Record<string, string[]>;
|
|
9
|
-
onChange: (filters: Filters) => void;
|
|
10
|
-
renderButtonText?: ((s: string, key: string) => React.ReactNode) | undefined;
|
|
11
|
-
includeHelpMessage?: string | undefined;
|
|
12
|
-
excludeHelpMessage?: string | undefined;
|
|
13
|
-
}) => JSX.Element;
|
|
14
|
-
export default Filter;
|
|
1
|
+
import React from "react";
|
|
2
|
+
declare type Filters = {
|
|
3
|
+
includes: Record<string, Set<string>>;
|
|
4
|
+
excludes: Record<string, Set<string>>;
|
|
5
|
+
};
|
|
6
|
+
declare const Filter: ({ data, initialValue, onChange, renderButtonText, includeHelpMessage, excludeHelpMessage, }: {
|
|
7
|
+
initialValue?: Filters | undefined;
|
|
8
|
+
data: Record<string, string[]>;
|
|
9
|
+
onChange: (filters: Filters) => void;
|
|
10
|
+
renderButtonText?: ((s: string, key: string) => React.ReactNode) | undefined;
|
|
11
|
+
includeHelpMessage?: string | undefined;
|
|
12
|
+
excludeHelpMessage?: string | undefined;
|
|
13
|
+
}) => JSX.Element;
|
|
14
|
+
export default Filter;
|
package/components/Filter.js
CHANGED
|
@@ -1,148 +1,148 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const tslib_1 = require("tslib");
|
|
4
|
-
const core_1 = require("@blueprintjs/core");
|
|
5
|
-
const react_1 = (0, tslib_1.__importStar)(require("react"));
|
|
6
|
-
const fuzzy_1 = (0, tslib_1.__importDefault)(require("fuzzy"));
|
|
7
|
-
const Filter = ({ data, initialValue, onChange, renderButtonText = (s) => s ? s.toString() : react_1.default.createElement("i", { style: { opacity: 0.5 } }, "(Empty)"), includeHelpMessage = "Only include these values", excludeHelpMessage = "Exclude these values", }) => {
|
|
8
|
-
const [isFilterOpen, setIsFilterOpen] = (0, react_1.useState)(false);
|
|
9
|
-
const openFilter = (0, react_1.useCallback)((e) => {
|
|
10
|
-
e.stopPropagation();
|
|
11
|
-
setIsFilterOpen(true);
|
|
12
|
-
}, [setIsFilterOpen]);
|
|
13
|
-
const closeFilter = (0, react_1.useCallback)(() => {
|
|
14
|
-
setIsFilterOpen(false);
|
|
15
|
-
}, [setIsFilterOpen]);
|
|
16
|
-
const filtersRef = (0, react_1.useRef)({
|
|
17
|
-
includes: Object.fromEntries(Object.keys(data).map((k) => [
|
|
18
|
-
k,
|
|
19
|
-
new Set(data[k].filter((d) => initialValue && initialValue.includes[k].has(d))),
|
|
20
|
-
])),
|
|
21
|
-
excludes: Object.fromEntries(Object.keys(data).map((k) => [
|
|
22
|
-
k,
|
|
23
|
-
new Set(data[k].filter((d) => initialValue && initialValue.excludes[k].has(d))),
|
|
24
|
-
])),
|
|
25
|
-
});
|
|
26
|
-
const [filters, setFilters] = (0, react_1.useState)(filtersRef.current);
|
|
27
|
-
const [filterSearch, setFilterSearch] = (0, react_1.useState)("");
|
|
28
|
-
return (react_1.default.createElement(core_1.Tooltip, { content: "Filters", position: core_1.Position.BOTTOM },
|
|
29
|
-
react_1.default.createElement(core_1.Popover, { target: react_1.default.createElement(core_1.Button, { icon: "filter", onClick: openFilter, className: "roamjs-filter", minimal: true, style: Object.keys(filters.includes).some((k) => filters.includes[k].size === 0) ||
|
|
30
|
-
Object.keys(filters.excludes).some((k) => filters.includes[k].size === 0)
|
|
31
|
-
? { color: "#a82a2a" }
|
|
32
|
-
: {} }), content: react_1.default.createElement("div", { style: { maxWidth: 600, maxHeight: 245, overflowY: "scroll" }, onClick: (e) => e.stopPropagation() },
|
|
33
|
-
react_1.default.createElement("div", { style: {
|
|
34
|
-
display: "flex",
|
|
35
|
-
flexDirection: "column",
|
|
36
|
-
width: 500,
|
|
37
|
-
maxWidth: "90vw",
|
|
38
|
-
transition: "all 300ms ease-in 0s",
|
|
39
|
-
padding: 8,
|
|
40
|
-
} },
|
|
41
|
-
react_1.default.createElement("div", { className: "flex-h-box" },
|
|
42
|
-
react_1.default.createElement("div", { style: {
|
|
43
|
-
flex: "1 1 100%",
|
|
44
|
-
paddingTop: 4,
|
|
45
|
-
paddingBottom: 4,
|
|
46
|
-
paddingLeft: 4,
|
|
47
|
-
} },
|
|
48
|
-
react_1.default.createElement("div", null,
|
|
49
|
-
react_1.default.createElement("strong", null, "Includes"),
|
|
50
|
-
react_1.default.createElement("span", { style: { marginLeft: 4, fontSize: 12 } }, "Click to Add"),
|
|
51
|
-
react_1.default.createElement("div", { style: {
|
|
52
|
-
padding: "8px 0px",
|
|
53
|
-
fontSize: "0.8em",
|
|
54
|
-
color: "rgb(167, 182, 194)",
|
|
55
|
-
} }, Object.keys(filters.includes).every((k) => filters.includes[k].size === 0)
|
|
56
|
-
? includeHelpMessage
|
|
57
|
-
: Object.keys(data).flatMap((key) => data[key]
|
|
58
|
-
.filter((n) => filters.includes[key].has(n))
|
|
59
|
-
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
60
|
-
position: "relative",
|
|
61
|
-
display: "inline-block",
|
|
62
|
-
}, key: `${n.toString()}-${i}` },
|
|
63
|
-
react_1.default.createElement("div", null,
|
|
64
|
-
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
65
|
-
margin: 4,
|
|
66
|
-
paddingRight: 4,
|
|
67
|
-
cursor: "pointer",
|
|
68
|
-
borderBottomColor: "rgb(92, 112, 128)",
|
|
69
|
-
}, onClick: () => {
|
|
70
|
-
filtersRef.current.includes[key].delete(n);
|
|
71
|
-
const filters = Object.assign({}, filtersRef.current);
|
|
72
|
-
setFilters(filters);
|
|
73
|
-
onChange(filters);
|
|
74
|
-
} }, renderButtonText(n, key))))))))),
|
|
75
|
-
react_1.default.createElement("div", { style: { paddingTop: 8 } })),
|
|
76
|
-
react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 8, marginBottom: 8 } }),
|
|
77
|
-
react_1.default.createElement("div", { style: {
|
|
78
|
-
flex: "1 1 100%",
|
|
79
|
-
paddingTop: 4,
|
|
80
|
-
paddingBottom: 4,
|
|
81
|
-
paddingLeft: 8,
|
|
82
|
-
} },
|
|
83
|
-
react_1.default.createElement("div", null,
|
|
84
|
-
react_1.default.createElement("strong", null, "Removes"),
|
|
85
|
-
react_1.default.createElement("span", { style: { marginLeft: 4, fontSize: 12 } }, "Shift-Click to Add"),
|
|
86
|
-
react_1.default.createElement("div", { style: {
|
|
87
|
-
padding: "8px 0px",
|
|
88
|
-
fontSize: "0.8em",
|
|
89
|
-
color: "rgb(167, 182, 194)",
|
|
90
|
-
} }, Object.keys(filters.excludes).every((k) => filters.excludes[k].size === 0)
|
|
91
|
-
? excludeHelpMessage
|
|
92
|
-
: Object.keys(data).flatMap((key) => data[key]
|
|
93
|
-
.filter((n) => filters.excludes[key].has(n))
|
|
94
|
-
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
95
|
-
position: "relative",
|
|
96
|
-
display: "inline-block",
|
|
97
|
-
}, key: `${n.toString()}-${i}` },
|
|
98
|
-
react_1.default.createElement("div", null,
|
|
99
|
-
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
100
|
-
margin: 4,
|
|
101
|
-
paddingRight: 4,
|
|
102
|
-
cursor: "pointer",
|
|
103
|
-
borderBottomColor: "rgb(92, 112, 128)",
|
|
104
|
-
}, onClick: () => {
|
|
105
|
-
filtersRef.current.excludes[key].delete(n);
|
|
106
|
-
const filters = Object.assign({}, filtersRef.current);
|
|
107
|
-
setFilters(filters);
|
|
108
|
-
onChange(filters);
|
|
109
|
-
} }, renderButtonText(n, key))))))))),
|
|
110
|
-
react_1.default.createElement("div", { style: { paddingTop: 8 } }))),
|
|
111
|
-
react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 4, borderColor: "rgb(41, 55, 66)" } }),
|
|
112
|
-
react_1.default.createElement("input", { placeholder: "Search References", className: "bp3-input bp3-minimal search-input", style: { margin: 8 }, value: filterSearch, onChange: (e) => setFilterSearch(e.target.value) }),
|
|
113
|
-
react_1.default.createElement("div", { className: "flex-h-box" }, Object.keys(data).map((k, i, all) => (react_1.default.createElement(react_1.default.Fragment, { key: k },
|
|
114
|
-
react_1.default.createElement("div", { style: {
|
|
115
|
-
flex: "1 1 100%",
|
|
116
|
-
paddingTop: 4,
|
|
117
|
-
paddingBottom: 4,
|
|
118
|
-
paddingLeft: 4,
|
|
119
|
-
} }, (filterSearch
|
|
120
|
-
? fuzzy_1.default
|
|
121
|
-
.filter(filterSearch, data[k])
|
|
122
|
-
.map((s) => s.string)
|
|
123
|
-
: data[k])
|
|
124
|
-
.filter((n) => !filters.includes[k].has(n) &&
|
|
125
|
-
!filters.excludes[k].has(n))
|
|
126
|
-
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
127
|
-
position: "relative",
|
|
128
|
-
display: "inline-block",
|
|
129
|
-
}, key: `${n.toString()}-${i}` },
|
|
130
|
-
react_1.default.createElement("div", null,
|
|
131
|
-
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
132
|
-
margin: 4,
|
|
133
|
-
paddingRight: 4,
|
|
134
|
-
cursor: "pointer",
|
|
135
|
-
borderBottomColor: "rgb(92, 112, 128)",
|
|
136
|
-
}, onClick: (e) => {
|
|
137
|
-
if (e.shiftKey)
|
|
138
|
-
filtersRef.current.excludes[k].add(n);
|
|
139
|
-
else
|
|
140
|
-
filtersRef.current.includes[k].add(n);
|
|
141
|
-
const filters = Object.assign({}, filtersRef.current);
|
|
142
|
-
setFilters(filters);
|
|
143
|
-
onChange(filters);
|
|
144
|
-
} }, renderButtonText(n, k))))))),
|
|
145
|
-
i < all.length - 1 && (react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 8, marginBottom: 8 } })))))))), onClose: closeFilter, isOpen: isFilterOpen })));
|
|
146
|
-
};
|
|
147
|
-
exports.default = Filter;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const core_1 = require("@blueprintjs/core");
|
|
5
|
+
const react_1 = (0, tslib_1.__importStar)(require("react"));
|
|
6
|
+
const fuzzy_1 = (0, tslib_1.__importDefault)(require("fuzzy"));
|
|
7
|
+
const Filter = ({ data, initialValue, onChange, renderButtonText = (s) => s ? s.toString() : react_1.default.createElement("i", { style: { opacity: 0.5 } }, "(Empty)"), includeHelpMessage = "Only include these values", excludeHelpMessage = "Exclude these values", }) => {
|
|
8
|
+
const [isFilterOpen, setIsFilterOpen] = (0, react_1.useState)(false);
|
|
9
|
+
const openFilter = (0, react_1.useCallback)((e) => {
|
|
10
|
+
e.stopPropagation();
|
|
11
|
+
setIsFilterOpen(true);
|
|
12
|
+
}, [setIsFilterOpen]);
|
|
13
|
+
const closeFilter = (0, react_1.useCallback)(() => {
|
|
14
|
+
setIsFilterOpen(false);
|
|
15
|
+
}, [setIsFilterOpen]);
|
|
16
|
+
const filtersRef = (0, react_1.useRef)({
|
|
17
|
+
includes: Object.fromEntries(Object.keys(data).map((k) => [
|
|
18
|
+
k,
|
|
19
|
+
new Set(data[k].filter((d) => initialValue && initialValue.includes[k].has(d))),
|
|
20
|
+
])),
|
|
21
|
+
excludes: Object.fromEntries(Object.keys(data).map((k) => [
|
|
22
|
+
k,
|
|
23
|
+
new Set(data[k].filter((d) => initialValue && initialValue.excludes[k].has(d))),
|
|
24
|
+
])),
|
|
25
|
+
});
|
|
26
|
+
const [filters, setFilters] = (0, react_1.useState)(filtersRef.current);
|
|
27
|
+
const [filterSearch, setFilterSearch] = (0, react_1.useState)("");
|
|
28
|
+
return (react_1.default.createElement(core_1.Tooltip, { content: "Filters", position: core_1.Position.BOTTOM },
|
|
29
|
+
react_1.default.createElement(core_1.Popover, { target: react_1.default.createElement(core_1.Button, { icon: "filter", onClick: openFilter, className: "roamjs-filter", minimal: true, style: Object.keys(filters.includes).some((k) => filters.includes[k].size === 0) ||
|
|
30
|
+
Object.keys(filters.excludes).some((k) => filters.includes[k].size === 0)
|
|
31
|
+
? { color: "#a82a2a" }
|
|
32
|
+
: {} }), content: react_1.default.createElement("div", { style: { maxWidth: 600, maxHeight: 245, overflowY: "scroll" }, onClick: (e) => e.stopPropagation() },
|
|
33
|
+
react_1.default.createElement("div", { style: {
|
|
34
|
+
display: "flex",
|
|
35
|
+
flexDirection: "column",
|
|
36
|
+
width: 500,
|
|
37
|
+
maxWidth: "90vw",
|
|
38
|
+
transition: "all 300ms ease-in 0s",
|
|
39
|
+
padding: 8,
|
|
40
|
+
} },
|
|
41
|
+
react_1.default.createElement("div", { className: "flex-h-box" },
|
|
42
|
+
react_1.default.createElement("div", { style: {
|
|
43
|
+
flex: "1 1 100%",
|
|
44
|
+
paddingTop: 4,
|
|
45
|
+
paddingBottom: 4,
|
|
46
|
+
paddingLeft: 4,
|
|
47
|
+
} },
|
|
48
|
+
react_1.default.createElement("div", null,
|
|
49
|
+
react_1.default.createElement("strong", null, "Includes"),
|
|
50
|
+
react_1.default.createElement("span", { style: { marginLeft: 4, fontSize: 12 } }, "Click to Add"),
|
|
51
|
+
react_1.default.createElement("div", { style: {
|
|
52
|
+
padding: "8px 0px",
|
|
53
|
+
fontSize: "0.8em",
|
|
54
|
+
color: "rgb(167, 182, 194)",
|
|
55
|
+
} }, Object.keys(filters.includes).every((k) => filters.includes[k].size === 0)
|
|
56
|
+
? includeHelpMessage
|
|
57
|
+
: Object.keys(data).flatMap((key) => data[key]
|
|
58
|
+
.filter((n) => filters.includes[key].has(n))
|
|
59
|
+
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
60
|
+
position: "relative",
|
|
61
|
+
display: "inline-block",
|
|
62
|
+
}, key: `${n.toString()}-${i}` },
|
|
63
|
+
react_1.default.createElement("div", null,
|
|
64
|
+
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
65
|
+
margin: 4,
|
|
66
|
+
paddingRight: 4,
|
|
67
|
+
cursor: "pointer",
|
|
68
|
+
borderBottomColor: "rgb(92, 112, 128)",
|
|
69
|
+
}, onClick: () => {
|
|
70
|
+
filtersRef.current.includes[key].delete(n);
|
|
71
|
+
const filters = Object.assign({}, filtersRef.current);
|
|
72
|
+
setFilters(filters);
|
|
73
|
+
onChange(filters);
|
|
74
|
+
} }, renderButtonText(n, key))))))))),
|
|
75
|
+
react_1.default.createElement("div", { style: { paddingTop: 8 } })),
|
|
76
|
+
react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 8, marginBottom: 8 } }),
|
|
77
|
+
react_1.default.createElement("div", { style: {
|
|
78
|
+
flex: "1 1 100%",
|
|
79
|
+
paddingTop: 4,
|
|
80
|
+
paddingBottom: 4,
|
|
81
|
+
paddingLeft: 8,
|
|
82
|
+
} },
|
|
83
|
+
react_1.default.createElement("div", null,
|
|
84
|
+
react_1.default.createElement("strong", null, "Removes"),
|
|
85
|
+
react_1.default.createElement("span", { style: { marginLeft: 4, fontSize: 12 } }, "Shift-Click to Add"),
|
|
86
|
+
react_1.default.createElement("div", { style: {
|
|
87
|
+
padding: "8px 0px",
|
|
88
|
+
fontSize: "0.8em",
|
|
89
|
+
color: "rgb(167, 182, 194)",
|
|
90
|
+
} }, Object.keys(filters.excludes).every((k) => filters.excludes[k].size === 0)
|
|
91
|
+
? excludeHelpMessage
|
|
92
|
+
: Object.keys(data).flatMap((key) => data[key]
|
|
93
|
+
.filter((n) => filters.excludes[key].has(n))
|
|
94
|
+
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
95
|
+
position: "relative",
|
|
96
|
+
display: "inline-block",
|
|
97
|
+
}, key: `${n.toString()}-${i}` },
|
|
98
|
+
react_1.default.createElement("div", null,
|
|
99
|
+
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
100
|
+
margin: 4,
|
|
101
|
+
paddingRight: 4,
|
|
102
|
+
cursor: "pointer",
|
|
103
|
+
borderBottomColor: "rgb(92, 112, 128)",
|
|
104
|
+
}, onClick: () => {
|
|
105
|
+
filtersRef.current.excludes[key].delete(n);
|
|
106
|
+
const filters = Object.assign({}, filtersRef.current);
|
|
107
|
+
setFilters(filters);
|
|
108
|
+
onChange(filters);
|
|
109
|
+
} }, renderButtonText(n, key))))))))),
|
|
110
|
+
react_1.default.createElement("div", { style: { paddingTop: 8 } }))),
|
|
111
|
+
react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 4, borderColor: "rgb(41, 55, 66)" } }),
|
|
112
|
+
react_1.default.createElement("input", { placeholder: "Search References", className: "bp3-input bp3-minimal search-input", style: { margin: 8 }, value: filterSearch, onChange: (e) => setFilterSearch(e.target.value) }),
|
|
113
|
+
react_1.default.createElement("div", { className: "flex-h-box" }, Object.keys(data).map((k, i, all) => (react_1.default.createElement(react_1.default.Fragment, { key: k },
|
|
114
|
+
react_1.default.createElement("div", { style: {
|
|
115
|
+
flex: "1 1 100%",
|
|
116
|
+
paddingTop: 4,
|
|
117
|
+
paddingBottom: 4,
|
|
118
|
+
paddingLeft: 4,
|
|
119
|
+
} }, (filterSearch
|
|
120
|
+
? fuzzy_1.default
|
|
121
|
+
.filter(filterSearch, data[k])
|
|
122
|
+
.map((s) => s.string)
|
|
123
|
+
: data[k])
|
|
124
|
+
.filter((n) => !filters.includes[k].has(n) &&
|
|
125
|
+
!filters.excludes[k].has(n))
|
|
126
|
+
.map((n, i) => (react_1.default.createElement("div", { style: {
|
|
127
|
+
position: "relative",
|
|
128
|
+
display: "inline-block",
|
|
129
|
+
}, key: `${n.toString()}-${i}` },
|
|
130
|
+
react_1.default.createElement("div", null,
|
|
131
|
+
react_1.default.createElement("button", { className: "bp3-button", style: {
|
|
132
|
+
margin: 4,
|
|
133
|
+
paddingRight: 4,
|
|
134
|
+
cursor: "pointer",
|
|
135
|
+
borderBottomColor: "rgb(92, 112, 128)",
|
|
136
|
+
}, onClick: (e) => {
|
|
137
|
+
if (e.shiftKey)
|
|
138
|
+
filtersRef.current.excludes[k].add(n);
|
|
139
|
+
else
|
|
140
|
+
filtersRef.current.includes[k].add(n);
|
|
141
|
+
const filters = Object.assign({}, filtersRef.current);
|
|
142
|
+
setFilters(filters);
|
|
143
|
+
onChange(filters);
|
|
144
|
+
} }, renderButtonText(n, k))))))),
|
|
145
|
+
i < all.length - 1 && (react_1.default.createElement("div", { className: "rm-line", style: { marginTop: 8, marginBottom: 8 } })))))))), onClose: closeFilter, isOpen: isFilterOpen })));
|
|
146
|
+
};
|
|
147
|
+
exports.default = Filter;
|
|
148
148
|
//# sourceMappingURL=Filter.js.map
|
package/components/Loading.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
declare const Loading: () => JSX.Element;
|
|
3
|
-
export declare const renderLoading: (targetUid: string) => () => void;
|
|
4
|
-
export default Loading;
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
declare const Loading: () => JSX.Element;
|
|
3
|
+
export declare const renderLoading: (targetUid: string) => () => void;
|
|
4
|
+
export default Loading;
|