@onepercentio/one-ui 0.1.5 → 0.2.0
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/cypress/support/commands.js +25 -0
- package/cypress/support/index.js +47 -0
- package/dist/__test__/analytics.d.ts +3 -0
- package/dist/__test__/analytics.js +20 -0
- package/dist/__test__/analytics.js.map +1 -0
- package/dist/__test__/firestore.d.ts +2 -0
- package/dist/__test__/firestore.js +26 -0
- package/dist/__test__/firestore.js.map +1 -0
- package/dist/__test__/utils.d.ts +16 -0
- package/dist/__test__/utils.js +184 -2
- package/dist/__test__/utils.js.map +1 -1
- package/dist/assets/styles/variables.scss +2 -0
- package/dist/components/AdaptiveButton/AdaptiveButton.js.map +1 -1
- package/dist/components/AdaptiveDialog/AdaptiveDialog.js +6 -36
- package/dist/components/AdaptiveDialog/AdaptiveDialog.js.map +1 -1
- package/dist/components/AdaptiveDialog/AdaptiveDialog.module.scss +3 -1
- package/dist/components/AdaptiveSidebar/AdaptiveSidebar.d.ts +4 -1
- package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js +10 -3
- package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js.map +1 -1
- package/dist/components/AdaptiveSidebar/AdaptiveSidebar.module.scss +4 -2
- package/dist/components/AdaptiveSidebar/AdaptiveSidebar.stories.d.ts +3 -0
- package/dist/components/AnchoredTooltip/AnchoredTooltip.d.ts +1 -0
- package/dist/components/AnchoredTooltip/AnchoredTooltip.js +45 -37
- package/dist/components/AnchoredTooltip/AnchoredTooltip.js.map +1 -1
- package/dist/components/Button/Button.d.ts +6 -6
- package/dist/components/Button/Button.js +27 -4
- package/dist/components/Button/Button.js.map +1 -1
- package/dist/components/Button/Button.module.scss +2 -2
- package/dist/components/Button/Button.stories.d.ts +5 -1
- package/dist/components/Collapsable/Collapsable.d.ts +1 -1
- package/dist/components/Collapsable/Collapsable.js +5 -0
- package/dist/components/Collapsable/Collapsable.js.map +1 -1
- package/dist/components/Collapsable/Collapsable.module.scss +2 -1
- package/dist/components/EmailInput/EmailInput.d.ts +5 -2
- package/dist/components/EmailInput/EmailInput.js +2 -0
- package/dist/components/EmailInput/EmailInput.js.map +1 -1
- package/dist/components/EmailInput/EmailInput.stories.d.ts +4 -2
- package/dist/components/EmailInput/index.d.ts +1 -1
- package/dist/components/EmailInput/index.js +2 -1
- package/dist/components/EmailInput/index.js.map +1 -1
- package/dist/components/Form/Form.d.ts +3 -2
- package/dist/components/Form/Form.js +1 -1
- package/dist/components/Form/Form.js.map +1 -1
- package/dist/components/Header/Header.d.ts +1 -0
- package/dist/components/Header/Header.js +1 -1
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/Header/Header.module.scss +15 -5
- package/dist/components/Header/Header.stories.d.ts +1 -0
- package/dist/components/HeaderCloseBtn/HeaderCloseBtn.stories.d.ts +1 -1
- package/dist/components/Input/Input.d.ts +6 -2
- package/dist/components/Input/Input.js +12 -4
- package/dist/components/Input/Input.js.map +1 -1
- package/dist/components/Input/Input.module.scss +1 -1
- package/dist/components/Input/Input.stories.d.ts +3 -1
- package/dist/components/MainGrid/MainGrid.d.ts +3 -2
- package/dist/components/MainGrid/MainGrid.js.map +1 -1
- package/dist/components/MainGrid/MainGrid.stories.d.ts +3 -2
- package/dist/components/MutableHamburgerButton/MutableHamburgerButton.d.ts +4 -3
- package/dist/components/MutableHamburgerButton/MutableHamburgerButton.js +14 -2
- package/dist/components/MutableHamburgerButton/MutableHamburgerButton.js.map +1 -1
- package/dist/components/MutableHamburgerButton/MutableHamburgerButton.module.scss +23 -0
- package/dist/components/MutableHamburgerButton/MutableHamburgerButton.stories.d.ts +3 -2
- package/dist/components/PasswordInput/PasswordInput.d.ts +3 -1
- package/dist/components/Select/Select.module.scss +0 -1
- package/dist/components/Select/Select.stories.d.ts +6 -2
- package/dist/components/Table/Table.js.map +1 -1
- package/dist/components/Text/Text.d.ts +7 -7
- package/dist/components/Text/Text.js +29 -4
- package/dist/components/Text/Text.js.map +1 -1
- package/dist/components/Text/Text.stories.d.ts +7 -2
- package/dist/components/Transition/Transition.d.ts +2 -5
- package/dist/components/Transition/Transition.js +3 -3
- package/dist/components/Transition/Transition.js.map +1 -1
- package/dist/components/Transition/Transition.stories.d.ts +3 -3
- package/dist/components/UncontrolledTransition/UncontrolledTransition.d.ts +1 -0
- package/dist/components/UncontrolledTransition/UncontrolledTransition.js +6 -2
- package/dist/components/UncontrolledTransition/UncontrolledTransition.js.map +1 -1
- package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.d.ts +2 -0
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.d.ts +16 -5
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js +36 -12
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js.map +1 -1
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.d.ts +26 -3
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js +13 -4
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js.map +1 -1
- package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.d.ts +7 -0
- package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js +71 -0
- package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js.map +1 -0
- package/dist/components/utilitary/ScrollAndFocusLock/index.d.ts +1 -0
- package/dist/components/utilitary/ScrollAndFocusLock/index.js +9 -0
- package/dist/components/utilitary/ScrollAndFocusLock/index.js.map +1 -0
- package/dist/context/OneUIProvider.d.ts +13 -0
- package/dist/context/OneUIProvider.js +14 -3
- package/dist/context/OneUIProvider.js.map +1 -1
- package/dist/context/OneUIProvider.test.js +0 -1
- package/dist/context/OneUIProvider.test.js.map +1 -1
- package/dist/context/__mocks__/OneUIProvider.d.ts +22 -0
- package/dist/hooks/shims/ObjectWatchShim.d.ts +0 -0
- package/dist/hooks/shims/ObjectWatchShim.js +48 -0
- package/dist/hooks/shims/ObjectWatchShim.js.map +1 -0
- package/dist/hooks/useObserve.d.ts +2 -0
- package/dist/hooks/useObserve.js +14 -0
- package/dist/hooks/useObserve.js.map +1 -0
- package/package.json +18 -10
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UncontrolledTransition.js","sourceRoot":"","sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+
|
|
1
|
+
{"version":3,"file":"UncontrolledTransition.js","sourceRoot":"","sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,7 @@ declare const _default: {
|
|
|
9
9
|
lockTransitionWidth?: boolean | undefined;
|
|
10
10
|
} & Pick<import("../Transition/Transition").TransitionProps, "contentStyle"> & import("../Transition/Transition").TransitionTypeDefinitions) & React.RefAttributes<{
|
|
11
11
|
setOrientation: (orientation: "forward" | "backward") => void;
|
|
12
|
+
sectionRef: React.RefObject<HTMLDivElement>;
|
|
12
13
|
}>>;
|
|
13
14
|
};
|
|
14
15
|
export default _default;
|
|
@@ -21,6 +22,7 @@ export declare const ClickBasedTransition: {
|
|
|
21
22
|
lockTransitionWidth?: boolean | undefined;
|
|
22
23
|
} & Pick<import("../Transition/Transition").TransitionProps, "contentStyle"> & import("../Transition/Transition").TransitionTypeDefinitions) & React.RefAttributes<{
|
|
23
24
|
setOrientation: (orientation: "forward" | "backward") => void;
|
|
25
|
+
sectionRef: React.RefObject<HTMLDivElement>;
|
|
24
26
|
}>;
|
|
25
27
|
};
|
|
26
28
|
export declare const AnchorBasedTransition: (args: ComponentProps<typeof UncontrolledTransition>) => JSX.Element;
|
|
@@ -1,18 +1,27 @@
|
|
|
1
|
-
import React from "react";
|
|
1
|
+
import React, { PropsWithChildren } from "react";
|
|
2
2
|
import useAsyncControl from "../../hooks/useAsyncControl";
|
|
3
|
-
export declare type WalletConnectionProps = Omit<ReturnType<typeof useAsyncControl>, "process"> & {
|
|
3
|
+
export declare type WalletConnectionProps = PropsWithChildren<Omit<ReturnType<typeof useAsyncControl>, "process"> & {
|
|
4
|
+
chainId?: number;
|
|
4
5
|
isChainIdValid: boolean;
|
|
5
6
|
isProviderAvailable: boolean;
|
|
6
7
|
isConnectedAndValidChain: boolean;
|
|
8
|
+
isConnected: boolean;
|
|
9
|
+
wallet?: string;
|
|
7
10
|
connect: () => void;
|
|
8
11
|
disconnect: () => void;
|
|
9
12
|
changeChainId: () => void;
|
|
10
|
-
}
|
|
13
|
+
}>;
|
|
11
14
|
declare type Props = {
|
|
12
15
|
/**
|
|
13
16
|
* The chain id that the user is expected to connect to
|
|
14
17
|
*/
|
|
15
|
-
|
|
18
|
+
chain: {
|
|
19
|
+
id: number;
|
|
20
|
+
rpcUrl: string;
|
|
21
|
+
explorerUrl: string;
|
|
22
|
+
name: string;
|
|
23
|
+
currency: string;
|
|
24
|
+
};
|
|
16
25
|
/**
|
|
17
26
|
* When the user doesn't have a provider like metamask available
|
|
18
27
|
*/
|
|
@@ -28,7 +37,9 @@ declare type Props = {
|
|
|
28
37
|
*/
|
|
29
38
|
Content: React.FunctionComponent<WalletConnectionProps>;
|
|
30
39
|
};
|
|
31
|
-
declare const _default: React.ForwardRefExoticComponent<Props &
|
|
40
|
+
declare const _default: React.ForwardRefExoticComponent<Props & {
|
|
41
|
+
children?: React.ReactNode;
|
|
42
|
+
} & React.RefAttributes<{
|
|
32
43
|
connect: () => Promise<void>;
|
|
33
44
|
disconnect: () => void;
|
|
34
45
|
}>>;
|
|
@@ -45,7 +45,7 @@ function WalletConnectionWrapper(props, ref) {
|
|
|
45
45
|
return (react_1.default.createElement(use_wallet_1.UseWalletProvider, null,
|
|
46
46
|
react_1.default.createElement(Content, Object.assign({ compRef: ref || (0, react_1.createRef)() }, props))));
|
|
47
47
|
}
|
|
48
|
-
function Content({ ProviderUnavailable, ChainIdInvalid,
|
|
48
|
+
function Content({ ProviderUnavailable, ChainIdInvalid, chain, Content, compRef, children, }) {
|
|
49
49
|
const wallet = (0, use_wallet_1.useWallet)();
|
|
50
50
|
const connectionAsyncWrapper = (0, useAsyncControl_1.default)();
|
|
51
51
|
const connect = () => __awaiter(this, void 0, void 0, function* () {
|
|
@@ -68,23 +68,47 @@ function Content({ ProviderUnavailable, ChainIdInvalid, allowedChainId, Content,
|
|
|
68
68
|
disconnect,
|
|
69
69
|
}), [wallet]);
|
|
70
70
|
const [isProviderAvailable] = (0, react_1.useState)(() => !!window.ethereum);
|
|
71
|
-
const isChainIdValid = (0, react_1.useMemo)(() => (wallet.isConnected() ? wallet.chainId ===
|
|
71
|
+
const isChainIdValid = (0, react_1.useMemo)(() => (wallet.isConnected() ? wallet.chainId === chain.id : true), [wallet, chain.id]);
|
|
72
72
|
function changeChainId() {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
73
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
74
|
+
wallet.reset();
|
|
75
|
+
try {
|
|
76
|
+
yield window.ethereum.request({
|
|
77
|
+
method: "wallet_switchEthereumChain",
|
|
78
|
+
params: [
|
|
79
|
+
{
|
|
80
|
+
chainId: `0x${chain.id.toString(16).padStart(2, "0")}`,
|
|
81
|
+
},
|
|
82
|
+
],
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
catch (e) {
|
|
86
|
+
switch (e.code) {
|
|
87
|
+
case 4902:
|
|
88
|
+
window.ethereum.request({
|
|
89
|
+
method: "wallet_addEthereumChain",
|
|
90
|
+
params: [
|
|
91
|
+
{
|
|
92
|
+
chainId: `0x${chain.id.toString(16).padStart(2, "0")}`,
|
|
93
|
+
chainName: chain.name,
|
|
94
|
+
rpcUrls: [chain.rpcUrl],
|
|
95
|
+
blockExplorerUrls: [chain.explorerUrl],
|
|
96
|
+
nativeCurrency: {
|
|
97
|
+
symbol: chain.currency,
|
|
98
|
+
decimals: 18,
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
],
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
wallet.connect("injected");
|
|
81
106
|
});
|
|
82
|
-
wallet.connect("injected");
|
|
83
107
|
}
|
|
84
108
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
85
109
|
ProviderUnavailable && !isProviderAvailable && react_1.default.createElement(ProviderUnavailable, null),
|
|
86
110
|
ChainIdInvalid && !isChainIdValid && (react_1.default.createElement(ChainIdInvalid, { changeChainId: changeChainId })),
|
|
87
|
-
react_1.default.createElement(Content, Object.assign({}, connectionAsyncWrapper, { isChainIdValid: isChainIdValid, isProviderAvailable: isProviderAvailable, isConnectedAndValidChain: isChainIdValid && wallet.isConnected(), connect: connect, disconnect: disconnect, changeChainId: changeChainId }))));
|
|
111
|
+
react_1.default.createElement(Content, Object.assign({}, connectionAsyncWrapper, { isChainIdValid: isChainIdValid, isProviderAvailable: isProviderAvailable, isConnectedAndValidChain: isChainIdValid && wallet.isConnected(), connect: connect, disconnect: disconnect, changeChainId: changeChainId, chainId: wallet.chainId, isConnected: wallet.isConnected(), wallet: wallet.account }), children)));
|
|
88
112
|
}
|
|
89
113
|
exports.default = (0, react_1.forwardRef)(WalletConnectionWrapper);
|
|
90
114
|
//# sourceMappingURL=WalletConnectionWrapper.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WalletConnectionWrapper.js","sourceRoot":"","sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+
|
|
1
|
+
{"version":3,"file":"WalletConnectionWrapper.js","sourceRoot":"","sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,12 +3,20 @@ import WalletConnectionWrapper from "./WalletConnectionWrapper";
|
|
|
3
3
|
declare const _default: {
|
|
4
4
|
title: string;
|
|
5
5
|
component: React.ForwardRefExoticComponent<{
|
|
6
|
-
|
|
6
|
+
chain: {
|
|
7
|
+
id: number;
|
|
8
|
+
rpcUrl: string;
|
|
9
|
+
explorerUrl: string;
|
|
10
|
+
name: string;
|
|
11
|
+
currency: string;
|
|
12
|
+
};
|
|
7
13
|
ProviderUnavailable?: React.FunctionComponent<{}> | undefined;
|
|
8
14
|
ChainIdInvalid?: React.FunctionComponent<{
|
|
9
15
|
changeChainId: () => void;
|
|
10
16
|
}> | undefined;
|
|
11
17
|
Content: React.FunctionComponent<import("./WalletConnectionWrapper").WalletConnectionProps>;
|
|
18
|
+
} & {
|
|
19
|
+
children?: React.ReactNode;
|
|
12
20
|
} & React.RefAttributes<{
|
|
13
21
|
connect: () => Promise<void>;
|
|
14
22
|
disconnect: () => void;
|
|
@@ -18,12 +26,20 @@ export default _default;
|
|
|
18
26
|
export declare const BasicUsage: {
|
|
19
27
|
(args: ComponentProps<typeof WalletConnectionWrapper>): JSX.Element;
|
|
20
28
|
args: {
|
|
21
|
-
|
|
29
|
+
chain: {
|
|
30
|
+
id: number;
|
|
31
|
+
rpcUrl: string;
|
|
32
|
+
explorerUrl: string;
|
|
33
|
+
name: string;
|
|
34
|
+
currency: string;
|
|
35
|
+
};
|
|
22
36
|
ProviderUnavailable?: React.FunctionComponent<{}> | undefined;
|
|
23
37
|
ChainIdInvalid?: React.FunctionComponent<{
|
|
24
38
|
changeChainId: () => void;
|
|
25
39
|
}> | undefined;
|
|
26
40
|
Content: React.FunctionComponent<import("./WalletConnectionWrapper").WalletConnectionProps>;
|
|
41
|
+
} & {
|
|
42
|
+
children?: React.ReactNode;
|
|
27
43
|
} & React.RefAttributes<{
|
|
28
44
|
connect: () => Promise<void>;
|
|
29
45
|
disconnect: () => void;
|
|
@@ -32,12 +48,19 @@ export declare const BasicUsage: {
|
|
|
32
48
|
export declare const UsageWithActionProps: {
|
|
33
49
|
(args: ComponentProps<typeof WalletConnectionWrapper>): JSX.Element;
|
|
34
50
|
args: {
|
|
35
|
-
|
|
51
|
+
chain: {
|
|
52
|
+
id: number;
|
|
53
|
+
rpcUrl: string;
|
|
54
|
+
explorerUrl: string;
|
|
55
|
+
name: string;
|
|
56
|
+
currency: string;
|
|
57
|
+
};
|
|
36
58
|
ProviderUnavailable?: React.FunctionComponent<{}> | undefined;
|
|
37
59
|
ChainIdInvalid?: React.FunctionComponent<{
|
|
38
60
|
changeChainId: () => void;
|
|
39
61
|
}> | undefined;
|
|
40
62
|
Content: React.FunctionComponent<import("./WalletConnectionWrapper").WalletConnectionProps>;
|
|
63
|
+
children?: React.ReactNode;
|
|
41
64
|
ref?: React.Ref<{
|
|
42
65
|
connect: () => Promise<void>;
|
|
43
66
|
disconnect: () => void;
|
|
@@ -13,7 +13,7 @@ exports.default = {
|
|
|
13
13
|
component: WalletConnectionWrapper_1.default,
|
|
14
14
|
};
|
|
15
15
|
const BasicUsage = (args) => {
|
|
16
|
-
return (react_1.default.createElement(WalletConnectionWrapper_1.default, Object.assign({}, args, { Content: ({ error, loading, isChainIdValid, isProviderAvailable, isConnectedAndValidChain, connect, disconnect, changeChainId, }) => (react_1.default.createElement(react_1.default.Fragment, null,
|
|
16
|
+
return (react_1.default.createElement(WalletConnectionWrapper_1.default, Object.assign({}, args, { Content: ({ chainId, error, loading, isChainIdValid, isProviderAvailable, isConnectedAndValidChain, connect, disconnect, changeChainId, }) => (react_1.default.createElement(react_1.default.Fragment, null,
|
|
17
17
|
react_1.default.createElement("h1", null, "The content prop will receive the props of control for handling wallet connection"),
|
|
18
18
|
react_1.default.createElement("h3", null, "You can test this component by using metamask"),
|
|
19
19
|
react_1.default.createElement("p", null,
|
|
@@ -28,9 +28,12 @@ const BasicUsage = (args) => {
|
|
|
28
28
|
String(loading)),
|
|
29
29
|
react_1.default.createElement("p", null,
|
|
30
30
|
"Valid chain (",
|
|
31
|
-
args.
|
|
31
|
+
args.chain.id,
|
|
32
32
|
"): ",
|
|
33
|
-
String(isChainIdValid)
|
|
33
|
+
String(isChainIdValid),
|
|
34
|
+
" (",
|
|
35
|
+
chainId,
|
|
36
|
+
")"),
|
|
34
37
|
react_1.default.createElement("p", null,
|
|
35
38
|
"Provider available (",
|
|
36
39
|
String(isProviderAvailable),
|
|
@@ -50,7 +53,13 @@ const UsageWithActionProps = (args) => {
|
|
|
50
53
|
};
|
|
51
54
|
exports.UsageWithActionProps = UsageWithActionProps;
|
|
52
55
|
exports.BasicUsage.args = {
|
|
53
|
-
|
|
56
|
+
chain: {
|
|
57
|
+
id: 80001,
|
|
58
|
+
name: "Polygon Testnet",
|
|
59
|
+
rpcUrl: "https://rpc-mumbai.matic.today/",
|
|
60
|
+
explorerUrl: "https://mumbai.polygonscan.com/",
|
|
61
|
+
currency: "MATIC",
|
|
62
|
+
},
|
|
54
63
|
};
|
|
55
64
|
exports.UsageWithActionProps.args = Object.assign({}, exports.BasicUsage.args);
|
|
56
65
|
//# sourceMappingURL=WalletConnectionWrapper.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WalletConnectionWrapper.stories.js","sourceRoot":"","sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.tsx"],"names":[],"mappings":";;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"WalletConnectionWrapper.stories.js","sourceRoot":"","sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.tsx"],"names":[],"mappings":";;;;;;AAAA,kDAA8C;AAC9C,wFAAgE;AAChE,uEAA+C;AAC/C,uDAA+B;AAE/B,kBAAe;IACb,KAAK,EAAE,2BAA2B;IAClC,SAAS,EAAE,iCAAuB;CACnC,CAAC;AAEK,MAAM,UAAU,GAAG,CACxB,IAAoD,EACpD,EAAE;IACF,OAAO,CACL,8BAAC,iCAAuB,oBAClB,IAAI,IACR,OAAO,EAAE,CAAC,EACR,OAAO,EACP,KAAK,EACL,OAAO,EACP,cAAc,EACd,mBAAmB,EACnB,wBAAwB,EACxB,OAAO,EACP,UAAU,EACV,aAAa,GACd,EAAE,EAAE,CAAC,CACJ;YACE,8HAGK;YACL,0FAAsD;YACtD;gBACE,0EAAqC;gBAAC,GAAG;gBACxC,MAAM,CAAC,wBAAwB,CAAC,CAC/B;YACJ;;gBAAW,MAAM,CAAC,KAAK,CAAC,CAAK;YAC7B;;gBAAa,MAAM,CAAC,OAAO,CAAC,CAAK;YACjC;;gBACgB,IAAI,CAAC,KAAK,CAAC,EAAE;;gBAAK,MAAM,CAAC,cAAc,CAAC;;gBAAI,OAAO;oBAC/D;YACJ;;gBAAwB,MAAM,CAAC,mBAAmB,CAAC;oBAAM;YACzD,oDAAgB;YAChB,0CAAQ,OAAO,EAAE,OAAO,cAAkB;YAC1C,0CAAQ,OAAO,EAAE,UAAU,iBAAqB;YAChD,0CAAQ,OAAO,EAAE,aAAa,wDAErB,CACR,CACJ,IACD,CACH,CAAC;AACJ,CAAC,CAAC;AA3CW,QAAA,UAAU,cA2CrB;AAEK,MAAM,oBAAoB,GAAG,CAClC,IAAoD,EACpD,EAAE;IACF,OAAO,CACL,8BAAC,iCAAuB,oBAClB,IAAI,IACR,mBAAmB,EAAE,GAAG,EAAE,CAAC,CACzB,8BAAC,wBAAc,IAAC,IAAI,4DAEH,CAClB,EACD,cAAc,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CACrC,8BAAC,wBAAc,IAAC,IAAI;;YAElB,8BAAC,gBAAM,IAAC,OAAO,EAAC,QAAQ,EAAC,OAAO,EAAE,aAAa,+BAEtC,CACM,CAClB,EACD,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CACxB;YACE,8HAGK;YACL,0CAAQ,OAAO,EAAE,OAAO,cAAkB,CACzC,CACJ,IACD,CACH,CAAC;AACJ,CAAC,CAAC;AA9BW,QAAA,oBAAoB,wBA8B/B;AAEF,kBAAU,CAAC,IAAI,GAAG;IAChB,KAAK,EAAE;QACL,EAAE,EAAE,KAAK;QACT,IAAI,EAAE,iBAAiB;QACvB,MAAM,EAAE,iCAAiC;QACzC,WAAW,EAAE,iCAAiC;QAC9C,QAAQ,EAAE,OAAO;KAClB;CACgD,CAAC;AAEpD,4BAAoB,CAAC,IAAI,qBACpB,kBAAU,CAAC,IAAI,CACnB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { PropsWithChildren } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* This utilitary component shall be used to lock the focus and disable scroll over the wrapped component
|
|
4
|
+
**/
|
|
5
|
+
export default function ScrollAndFocusLock({ open, children, }: PropsWithChildren<{
|
|
6
|
+
open: boolean;
|
|
7
|
+
}>): JSX.Element;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
const react_1 = __importStar(require("react"));
|
|
27
|
+
/**
|
|
28
|
+
* This utilitary component shall be used to lock the focus and disable scroll over the wrapped component
|
|
29
|
+
**/
|
|
30
|
+
function ScrollAndFocusLock({ open, children, }) {
|
|
31
|
+
const firstAnchor = (0, react_1.useRef)(null);
|
|
32
|
+
const lastAnchor = (0, react_1.useRef)(null);
|
|
33
|
+
const startOfModal = (0, react_1.useRef)(null);
|
|
34
|
+
(0, react_1.useEffect)(() => {
|
|
35
|
+
if (open)
|
|
36
|
+
startOfModal.current.focus();
|
|
37
|
+
}, []);
|
|
38
|
+
(0, react_1.useEffect)(() => {
|
|
39
|
+
if (open) {
|
|
40
|
+
startOfModal.current.focus();
|
|
41
|
+
document.body.style.overflow = "hidden";
|
|
42
|
+
return () => {
|
|
43
|
+
document.body.style.overflow = "";
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
}, [open]);
|
|
47
|
+
function onFocusAnchors(e) {
|
|
48
|
+
const focusOnStartOfModal = () => {
|
|
49
|
+
const nextSibling = firstAnchor.current.nextElementSibling;
|
|
50
|
+
if (nextSibling instanceof HTMLDivElement)
|
|
51
|
+
nextSibling.focus();
|
|
52
|
+
};
|
|
53
|
+
if (e.target === firstAnchor.current) {
|
|
54
|
+
if (e.relatedTarget === startOfModal.current)
|
|
55
|
+
lastAnchor.current.focus();
|
|
56
|
+
else
|
|
57
|
+
focusOnStartOfModal();
|
|
58
|
+
}
|
|
59
|
+
else if (e.target === lastAnchor.current &&
|
|
60
|
+
e.relatedTarget !== firstAnchor.current) {
|
|
61
|
+
focusOnStartOfModal();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
65
|
+
react_1.default.createElement("div", { ref: firstAnchor, tabIndex: 0, onFocus: onFocusAnchors }),
|
|
66
|
+
react_1.default.createElement("div", { ref: startOfModal, tabIndex: 0 }),
|
|
67
|
+
children,
|
|
68
|
+
react_1.default.createElement("div", { ref: lastAnchor, tabIndex: 0, onFocus: onFocusAnchors })));
|
|
69
|
+
}
|
|
70
|
+
exports.default = ScrollAndFocusLock;
|
|
71
|
+
//# sourceMappingURL=ScrollAndFocusLock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScrollAndFocusLock.js","sourceRoot":"","sources":["../../../../src/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAoE;AAEpE;;IAEI;AACJ,SAAwB,kBAAkB,CAAC,EACzC,IAAI,EACJ,QAAQ,GAGR;IACA,MAAM,WAAW,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IACjD,MAAM,UAAU,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IAChD,MAAM,YAAY,GAAG,IAAA,cAAM,EAAiB,IAAI,CAAC,CAAC;IAClD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,IAAI;YAAE,YAAY,CAAC,OAAQ,CAAC,KAAK,EAAE,CAAC;IAC1C,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,IAAI,EAAE;YACR,YAAY,CAAC,OAAQ,CAAC,KAAK,EAAE,CAAC;YAC9B,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAExC,OAAO,GAAG,EAAE;gBACV,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC;YACpC,CAAC,CAAC;SACH;IACH,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEX,SAAS,cAAc,CAAC,CAAmC;QACzD,MAAM,mBAAmB,GAAG,GAAG,EAAE;YAC/B,MAAM,WAAW,GAAG,WAAW,CAAC,OAAQ,CAAC,kBAAkB,CAAC;YAC5D,IAAI,WAAW,YAAY,cAAc;gBAAE,WAAW,CAAC,KAAK,EAAE,CAAC;QACjE,CAAC,CAAC;QACF,IAAI,CAAC,CAAC,MAAM,KAAK,WAAW,CAAC,OAAO,EAAE;YACpC,IAAI,CAAC,CAAC,aAAa,KAAK,YAAY,CAAC,OAAO;gBAAE,UAAU,CAAC,OAAQ,CAAC,KAAK,EAAE,CAAC;;gBACrE,mBAAmB,EAAE,CAAC;SAC5B;aAAM,IACL,CAAC,CAAC,MAAM,KAAK,UAAU,CAAC,OAAO;YAC/B,CAAC,CAAC,aAAa,KAAK,WAAW,CAAC,OAAO,EACvC;YACA,mBAAmB,EAAE,CAAC;SACvB;IACH,CAAC;IACD,OAAO,CACL;QACE,uCAAK,GAAG,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,cAAc,GAAI;QAC/D,uCAAK,GAAG,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAC,GAAI;QACtC,QAAQ;QACT,uCAAK,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,cAAc,GAAI,CAC7D,CACJ,CAAC;AACJ,CAAC;AA9CD,qCA8CC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './ScrollAndFocusLock';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var ScrollAndFocusLock_1 = require("./ScrollAndFocusLock");
|
|
8
|
+
Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(ScrollAndFocusLock_1).default; } });
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/utilitary/ScrollAndFocusLock/index.tsx"],"names":[],"mappings":";;;;;;AAAA,2DAA+C;AAAtC,8HAAA,OAAO,OAAA"}
|
|
@@ -1,9 +1,19 @@
|
|
|
1
|
+
import React from "react";
|
|
1
2
|
import { PropsWithChildren } from "react";
|
|
2
3
|
declare type DeepPartial<T> = {
|
|
3
4
|
[P in keyof T]?: T[P] extends Function ? T[P] : DeepPartial<T[P]>;
|
|
4
5
|
};
|
|
5
6
|
declare type ContextSpecs = {
|
|
6
7
|
component: {
|
|
8
|
+
text: {
|
|
9
|
+
className: {
|
|
10
|
+
[k in React.ComponentProps<typeof import("../components/Text")["default"]>["type"]]?: string;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
input: {
|
|
14
|
+
className: string;
|
|
15
|
+
border: boolean;
|
|
16
|
+
};
|
|
7
17
|
fileInput: {
|
|
8
18
|
Icon: () => JSX.Element;
|
|
9
19
|
};
|
|
@@ -43,6 +53,9 @@ declare type ContextSpecs = {
|
|
|
43
53
|
}) => JSX.Element;
|
|
44
54
|
};
|
|
45
55
|
};
|
|
56
|
+
tooltip: {
|
|
57
|
+
className?: string;
|
|
58
|
+
};
|
|
46
59
|
};
|
|
47
60
|
};
|
|
48
61
|
declare type ContextConfigSpecs = DeepPartial<ContextSpecs>;
|
|
@@ -17,6 +17,7 @@ const debouncedError = (0, lodash_1.debounce)((message) => {
|
|
|
17
17
|
event.error = new Error(message);
|
|
18
18
|
window.dispatchEvent(event);
|
|
19
19
|
}, 100);
|
|
20
|
+
const IGNORED_KEYS = ["className"];
|
|
20
21
|
function ProtectVariableAccess(obj, basePath = []) {
|
|
21
22
|
const proxyInstance = new Proxy(() => obj || {}, {
|
|
22
23
|
apply: (target) => {
|
|
@@ -28,8 +29,16 @@ function ProtectVariableAccess(obj, basePath = []) {
|
|
|
28
29
|
return () => value;
|
|
29
30
|
if (value === undefined) {
|
|
30
31
|
const path = [...basePath, variable.toString()];
|
|
31
|
-
if (/[^A-Z]/.test(String(variable).charAt(0)))
|
|
32
|
-
|
|
32
|
+
if (/[^A-Z]/.test(String(variable).charAt(0))) {
|
|
33
|
+
switch (basePath.join(".")) {
|
|
34
|
+
case "component.text.className":
|
|
35
|
+
return undefined;
|
|
36
|
+
case "component.text":
|
|
37
|
+
case "component.input":
|
|
38
|
+
return {};
|
|
39
|
+
}
|
|
40
|
+
if (!IGNORED_KEYS.includes(path[path.length - 1]))
|
|
41
|
+
debouncedError(`A component is using the UI config ${path.join(".")}.
|
|
33
42
|
|
|
34
43
|
Please define it using:
|
|
35
44
|
import OneUIProvider from "@onepercent/one-ui/dist/context/OneUIProvider";
|
|
@@ -37,8 +46,10 @@ import OneUIProvider from "@onepercent/one-ui/dist/context/OneUIProvider";
|
|
|
37
46
|
<OneUIProvider config={THE_MISSING_CONFIG}>
|
|
38
47
|
...
|
|
39
48
|
</OneUIProvider>`);
|
|
40
|
-
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
41
51
|
debouncedError.cancel();
|
|
52
|
+
}
|
|
42
53
|
}
|
|
43
54
|
if ((typeof value === "object" && !Array.isArray(value)) ||
|
|
44
55
|
(value === undefined && /[^A-Z]/.test(String(variable).charAt(0))))
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OneUIProvider.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.tsx"],"names":[],"mappings":";;;;;;AAAA,mCAAkC;AAClC,kDAA0B;AAC1B,iCAAqE;
|
|
1
|
+
{"version":3,"file":"OneUIProvider.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const OneUIProvider_1 = require("./OneUIProvider");
|
|
4
4
|
const loggingSpy = jest.spyOn(console, "error");
|
|
5
5
|
loggingSpy.mockImplementation(() => { });
|
|
6
|
-
jest.mock("lodash", () => ({ debounce: () => (a) => console.error(a) }));
|
|
7
6
|
describe("The proxy that protects variable access", () => {
|
|
8
7
|
it("Should work when there is no object (the provider is not added yet)", () => {
|
|
9
8
|
(0, OneUIProvider_1.ProtectVariableAccess)();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OneUIProvider.test.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.test.ts"],"names":[],"mappings":";;AAAA,mDAAwD;AAExD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;AAEhD,UAAU,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;AAExC,
|
|
1
|
+
{"version":3,"file":"OneUIProvider.test.js","sourceRoot":"","sources":["../../src/context/OneUIProvider.test.ts"],"names":[],"mappings":";;AAAA,mDAAwD;AAExD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;AAEhD,UAAU,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;AAExC,QAAQ,CAAC,yCAAyC,EAAE,GAAG,EAAE;IACvD,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;QAC7E,IAAA,qCAAqB,GAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,GAAG,GAAG,IAAA,qCAAqB,EAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,GAAG,GAAG,IAAA,qCAAqB,EAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QAC5C,MAAM,CAAC,GAAG,IAAI,gBAAgB,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,GAAG,IAAA,qCAAqB,EAAC,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC;QAC9D,6DAA6D;QAC7D,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,4DAA4D,EAAE,GAAG,EAAE;QACpE,MAAM,eAAe,GAAG,IAAA,qCAAqB,EAAC,EAAE,CAAC,CAAC;QAClD,eAAe,CAAC,iBAAiB,CAAC;QAClC,MAAM,CAAC,UAAU,CAAC,CAAC,oBAAoB,CACrC,MAAM,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,CAC7C,CAAC;QAEF,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,wCAAwC,GAAG,IAAA,qCAAqB,EAAC;YACrE,iBAAiB,EAAE,EAAE;SACtB,CAAC,CAAC;QACH,wCAAwC,CAAC,iBAAiB;aACvD,kBAAkB,CAAC;QACtB,MAAM,CAAC,UAAU,CAAC,CAAC,oBAAoB,CACrC,MAAM,CAAC,gBAAgB,CAAC,sCAAsC,CAAC,CAChE,CAAC;QAEF,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,wCAAwC,GAAG,IAAA,qCAAqB,EAAC;YACrE,iBAAiB,EAAE;gBACjB,kBAAkB,EAAE,EAAE;aACvB;SACF,CAAC,CAAC;QACH,wCAAwC,CAAC,iBAAiB;aACvD,kBAAkB,CAAC,6BAA6B,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,oBAAoB,CACrC,MAAM,CAAC,gBAAgB,CACrB,oEAAoE,CACrE,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,6 +1,25 @@
|
|
|
1
1
|
import { ComponentProps } from "react";
|
|
2
2
|
export declare function useOneUIContext(): {
|
|
3
3
|
component?: {
|
|
4
|
+
text?: {
|
|
5
|
+
className?: {
|
|
6
|
+
link?: string | undefined;
|
|
7
|
+
caption?: string | undefined;
|
|
8
|
+
title?: string | undefined;
|
|
9
|
+
content?: string | undefined;
|
|
10
|
+
description?: string | undefined;
|
|
11
|
+
error?: string | undefined;
|
|
12
|
+
highlightTitle?: string | undefined;
|
|
13
|
+
highlight?: string | undefined;
|
|
14
|
+
subtitle?: string | undefined;
|
|
15
|
+
boldTitle?: string | undefined;
|
|
16
|
+
boldTitleBig?: string | undefined;
|
|
17
|
+
} | undefined;
|
|
18
|
+
} | undefined;
|
|
19
|
+
input?: {
|
|
20
|
+
className?: string | undefined;
|
|
21
|
+
border?: boolean | undefined;
|
|
22
|
+
} | undefined;
|
|
4
23
|
fileInput?: {
|
|
5
24
|
Icon?: (() => JSX.Element) | undefined;
|
|
6
25
|
} | undefined;
|
|
@@ -40,6 +59,9 @@ export declare function useOneUIContext(): {
|
|
|
40
59
|
}) => JSX.Element) | undefined;
|
|
41
60
|
} | undefined;
|
|
42
61
|
} | undefined;
|
|
62
|
+
tooltip?: {
|
|
63
|
+
className?: string | undefined;
|
|
64
|
+
} | undefined;
|
|
43
65
|
} | undefined;
|
|
44
66
|
};
|
|
45
67
|
export declare function setupMock(ctx: ComponentProps<typeof import("../OneUIProvider")["default"]>["config"]): void;
|
|
File without changes
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
// object.watch
|
|
4
|
+
if (!Object.prototype.watch)
|
|
5
|
+
Object.prototype.watch = function (propsToWatchFor, handler) {
|
|
6
|
+
propsToWatchFor.forEach((prop) => {
|
|
7
|
+
var oldval = this[prop], newval = oldval, getter = function () {
|
|
8
|
+
return newval;
|
|
9
|
+
}, setter = function (val) {
|
|
10
|
+
if (this._watchTimer)
|
|
11
|
+
clearTimeout(this._watchTimer);
|
|
12
|
+
this._watchTimer = setTimeout(() => {
|
|
13
|
+
handler.call();
|
|
14
|
+
clearTimeout(this._watchTimer);
|
|
15
|
+
delete this._watchTimer;
|
|
16
|
+
}, 0);
|
|
17
|
+
oldval = newval;
|
|
18
|
+
newval = val;
|
|
19
|
+
return true;
|
|
20
|
+
};
|
|
21
|
+
if (delete this[prop]) {
|
|
22
|
+
// can't watch constants
|
|
23
|
+
if (Object.defineProperty)
|
|
24
|
+
// ECMAScript 5
|
|
25
|
+
Object.defineProperty(this, prop, {
|
|
26
|
+
get: getter,
|
|
27
|
+
set: setter,
|
|
28
|
+
});
|
|
29
|
+
else if (Object.prototype.__defineGetter__ &&
|
|
30
|
+
Object.prototype.__defineSetter__) {
|
|
31
|
+
// legacy
|
|
32
|
+
Object.prototype.__defineGetter__.call(this, prop, getter);
|
|
33
|
+
Object.prototype.__defineSetter__.call(this, prop, setter);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
function _unwatch(prop) {
|
|
38
|
+
var val = this[prop];
|
|
39
|
+
delete this[prop]; // remove accessors
|
|
40
|
+
this[prop] = val;
|
|
41
|
+
}
|
|
42
|
+
this.unwatch = function () {
|
|
43
|
+
propsToWatchFor.forEach((prop) => {
|
|
44
|
+
_unwatch(prop);
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=ObjectWatchShim.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ObjectWatchShim.js","sourceRoot":"","sources":["../../../src/hooks/shims/ObjectWatchShim.ts"],"names":[],"mappings":";AAAA,cAAc;AACd,eAAe;AACf,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK;IACzB,MAAM,CAAC,SAAS,CAAC,KAAK,GAAG,UAAU,eAAe,EAAE,OAAO;QACzD,eAAe,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/B,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,EACrB,MAAM,GAAG,MAAM,EACf,MAAM,GAAG;gBACP,OAAO,MAAM,CAAC;YAChB,CAAC,EACD,MAAM,GAAG,UAAU,GAAG;gBACpB,IAAI,IAAI,CAAC,WAAW;oBAAE,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBACrD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,GAAG,EAAE;oBACjC,OAAO,CAAC,IAAI,EAAE,CAAC;oBACf,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBAC/B,OAAO,IAAI,CAAC,WAAW,CAAC;gBAC1B,CAAC,EAAE,CAAC,CAAC,CAAC;gBACN,MAAM,GAAG,MAAM,CAAC;gBAChB,MAAM,GAAG,GAAG,CAAC;gBACb,OAAO,IAAI,CAAC;YACd,CAAC,CAAC;YACJ,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE;gBACrB,wBAAwB;gBACxB,IAAI,MAAM,CAAC,cAAc;oBACvB,eAAe;oBACf,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE;wBAChC,GAAG,EAAE,MAAM;wBACX,GAAG,EAAE,MAAM;qBACZ,CAAC,CAAC;qBACA,IACH,MAAM,CAAC,SAAS,CAAC,gBAAgB;oBACjC,MAAM,CAAC,SAAS,CAAC,gBAAgB,EACjC;oBACA,SAAS;oBACT,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;oBAC3D,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;iBAC5D;aACF;QACH,CAAC,CAAC,CAAC;QACH,SAAS,QAAQ,CAAC,IAAI;YACpB,IAAI,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;YACrB,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,mBAAmB;YACtC,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC;QACnB,CAAC;QACD,IAAI,CAAC,OAAO,GAAG;YACb,eAAe,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBAC/B,QAAQ,CAAC,IAAI,CAAC,CAAC;YACjB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const react_1 = require("react");
|
|
4
|
+
require("./shims/ObjectWatchShim.js");
|
|
5
|
+
function useObserve(object, keysToObserve) {
|
|
6
|
+
const [_, ss] = (0, react_1.useState)(0);
|
|
7
|
+
(0, react_1.useLayoutEffect)(() => {
|
|
8
|
+
return object.watch(keysToObserve, () => {
|
|
9
|
+
ss((p) => p + 1);
|
|
10
|
+
});
|
|
11
|
+
}, [object]);
|
|
12
|
+
}
|
|
13
|
+
exports.default = useObserve;
|
|
14
|
+
//# sourceMappingURL=useObserve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useObserve.js","sourceRoot":"","sources":["../../src/hooks/useObserve.ts"],"names":[],"mappings":";;AAAA,iCAA6D;AAC7D,sCAAoC;AAOpC,SAAwB,UAAU,CAChC,MAAS,EACT,aAA0B;IAE1B,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAA,gBAAQ,EAAC,CAAC,CAAC,CAAC;IAC5B,IAAA,uBAAe,EAAC,GAAG,EAAE;QACnB,OAAQ,MAAiB,CAAC,KAAK,CAAC,aAAoB,EAAE,GAAG,EAAE;YACzD,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;AACf,CAAC;AAVD,6BAUC"}
|