@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.
Files changed (103) hide show
  1. package/cypress/support/commands.js +25 -0
  2. package/cypress/support/index.js +47 -0
  3. package/dist/__test__/analytics.d.ts +3 -0
  4. package/dist/__test__/analytics.js +20 -0
  5. package/dist/__test__/analytics.js.map +1 -0
  6. package/dist/__test__/firestore.d.ts +2 -0
  7. package/dist/__test__/firestore.js +26 -0
  8. package/dist/__test__/firestore.js.map +1 -0
  9. package/dist/__test__/utils.d.ts +16 -0
  10. package/dist/__test__/utils.js +184 -2
  11. package/dist/__test__/utils.js.map +1 -1
  12. package/dist/assets/styles/variables.scss +2 -0
  13. package/dist/components/AdaptiveButton/AdaptiveButton.js.map +1 -1
  14. package/dist/components/AdaptiveDialog/AdaptiveDialog.js +6 -36
  15. package/dist/components/AdaptiveDialog/AdaptiveDialog.js.map +1 -1
  16. package/dist/components/AdaptiveDialog/AdaptiveDialog.module.scss +3 -1
  17. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.d.ts +4 -1
  18. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js +10 -3
  19. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js.map +1 -1
  20. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.module.scss +4 -2
  21. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.stories.d.ts +3 -0
  22. package/dist/components/AnchoredTooltip/AnchoredTooltip.d.ts +1 -0
  23. package/dist/components/AnchoredTooltip/AnchoredTooltip.js +45 -37
  24. package/dist/components/AnchoredTooltip/AnchoredTooltip.js.map +1 -1
  25. package/dist/components/Button/Button.d.ts +6 -6
  26. package/dist/components/Button/Button.js +27 -4
  27. package/dist/components/Button/Button.js.map +1 -1
  28. package/dist/components/Button/Button.module.scss +2 -2
  29. package/dist/components/Button/Button.stories.d.ts +5 -1
  30. package/dist/components/Collapsable/Collapsable.d.ts +1 -1
  31. package/dist/components/Collapsable/Collapsable.js +5 -0
  32. package/dist/components/Collapsable/Collapsable.js.map +1 -1
  33. package/dist/components/Collapsable/Collapsable.module.scss +2 -1
  34. package/dist/components/EmailInput/EmailInput.d.ts +5 -2
  35. package/dist/components/EmailInput/EmailInput.js +2 -0
  36. package/dist/components/EmailInput/EmailInput.js.map +1 -1
  37. package/dist/components/EmailInput/EmailInput.stories.d.ts +4 -2
  38. package/dist/components/EmailInput/index.d.ts +1 -1
  39. package/dist/components/EmailInput/index.js +2 -1
  40. package/dist/components/EmailInput/index.js.map +1 -1
  41. package/dist/components/Form/Form.d.ts +3 -2
  42. package/dist/components/Form/Form.js +1 -1
  43. package/dist/components/Form/Form.js.map +1 -1
  44. package/dist/components/Header/Header.d.ts +1 -0
  45. package/dist/components/Header/Header.js +1 -1
  46. package/dist/components/Header/Header.js.map +1 -1
  47. package/dist/components/Header/Header.module.scss +15 -5
  48. package/dist/components/Header/Header.stories.d.ts +1 -0
  49. package/dist/components/HeaderCloseBtn/HeaderCloseBtn.stories.d.ts +1 -1
  50. package/dist/components/Input/Input.d.ts +6 -2
  51. package/dist/components/Input/Input.js +12 -4
  52. package/dist/components/Input/Input.js.map +1 -1
  53. package/dist/components/Input/Input.module.scss +1 -1
  54. package/dist/components/Input/Input.stories.d.ts +3 -1
  55. package/dist/components/MainGrid/MainGrid.d.ts +3 -2
  56. package/dist/components/MainGrid/MainGrid.js.map +1 -1
  57. package/dist/components/MainGrid/MainGrid.stories.d.ts +3 -2
  58. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.d.ts +4 -3
  59. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.js +14 -2
  60. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.js.map +1 -1
  61. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.module.scss +23 -0
  62. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.stories.d.ts +3 -2
  63. package/dist/components/PasswordInput/PasswordInput.d.ts +3 -1
  64. package/dist/components/Select/Select.module.scss +0 -1
  65. package/dist/components/Select/Select.stories.d.ts +6 -2
  66. package/dist/components/Table/Table.js.map +1 -1
  67. package/dist/components/Text/Text.d.ts +7 -7
  68. package/dist/components/Text/Text.js +29 -4
  69. package/dist/components/Text/Text.js.map +1 -1
  70. package/dist/components/Text/Text.stories.d.ts +7 -2
  71. package/dist/components/Transition/Transition.d.ts +2 -5
  72. package/dist/components/Transition/Transition.js +3 -3
  73. package/dist/components/Transition/Transition.js.map +1 -1
  74. package/dist/components/Transition/Transition.stories.d.ts +3 -3
  75. package/dist/components/UncontrolledTransition/UncontrolledTransition.d.ts +1 -0
  76. package/dist/components/UncontrolledTransition/UncontrolledTransition.js +6 -2
  77. package/dist/components/UncontrolledTransition/UncontrolledTransition.js.map +1 -1
  78. package/dist/components/UncontrolledTransition/UncontrolledTransition.stories.d.ts +2 -0
  79. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.d.ts +16 -5
  80. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js +36 -12
  81. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js.map +1 -1
  82. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.d.ts +26 -3
  83. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js +13 -4
  84. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.stories.js.map +1 -1
  85. package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.d.ts +7 -0
  86. package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js +71 -0
  87. package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.js.map +1 -0
  88. package/dist/components/utilitary/ScrollAndFocusLock/index.d.ts +1 -0
  89. package/dist/components/utilitary/ScrollAndFocusLock/index.js +9 -0
  90. package/dist/components/utilitary/ScrollAndFocusLock/index.js.map +1 -0
  91. package/dist/context/OneUIProvider.d.ts +13 -0
  92. package/dist/context/OneUIProvider.js +14 -3
  93. package/dist/context/OneUIProvider.js.map +1 -1
  94. package/dist/context/OneUIProvider.test.js +0 -1
  95. package/dist/context/OneUIProvider.test.js.map +1 -1
  96. package/dist/context/__mocks__/OneUIProvider.d.ts +22 -0
  97. package/dist/hooks/shims/ObjectWatchShim.d.ts +0 -0
  98. package/dist/hooks/shims/ObjectWatchShim.js +48 -0
  99. package/dist/hooks/shims/ObjectWatchShim.js.map +1 -0
  100. package/dist/hooks/useObserve.d.ts +2 -0
  101. package/dist/hooks/useObserve.js +14 -0
  102. package/dist/hooks/useObserve.js.map +1 -0
  103. package/package.json +18 -10
@@ -1 +1 @@
1
- {"version":3,"file":"UncontrolledTransition.js","sourceRoot":"","sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"names":[],"mappings":"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"}
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
- allowedChainId: number;
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 & React.RefAttributes<{
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, allowedChainId, Content, compRef, }) {
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 === allowedChainId : true), [wallet, allowedChainId]);
71
+ const isChainIdValid = (0, react_1.useMemo)(() => (wallet.isConnected() ? wallet.chainId === chain.id : true), [wallet, chain.id]);
72
72
  function changeChainId() {
73
- wallet.reset();
74
- window.ethereum.request({
75
- method: "wallet_switchEthereumChain",
76
- params: [
77
- {
78
- chainId: `0x${allowedChainId.toString(16).padStart(2, "0")}`,
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":"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"}
1
+ {"version":3,"file":"WalletConnectionWrapper.js","sourceRoot":"","sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CASe;AACf,2CAA0D;AAC1D,kFAA0D;AA+C1D;;IAEI;AACJ,SAAS,uBAAuB,CAC9B,KAA+B,EAC/B,GAGE;IAEF,OAAO,CACL,8BAAC,8BAAiB;QAChB,8BAAC,OAAO,kBAAC,OAAO,EAAE,GAAG,IAAI,IAAA,iBAAS,GAAE,IAAM,KAAK,EAAI,CACjC,CACrB,CAAC;AACJ,CAAC;AAED,SAAS,OAAO,CAAC,EACf,mBAAmB,EACnB,cAAc,EACd,KAAK,EACL,OAAO,EACP,OAAO,EACP,QAAQ,GAQT;IACC,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAC3B,MAAM,sBAAsB,GAAG,IAAA,yBAAe,GAAE,CAAC;IACjD,MAAM,OAAO,GAAG,GAAS,EAAE;QACzB,sBAAsB,CAAC,OAAO,CAAC,GAAS,EAAE;YACxC,MAAM,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YACjC,YAAY,CAAC,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;QAC/C,CAAC,CAAA,CAAC,CAAC;IACL,CAAC,CAAA,CAAC;IACF,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,MAAM,CAAC,KAAK,EAAE,CAAC;QACf,YAAY,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;IAC1C,CAAC,CAAC;IACF,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,WAAW,GAAG,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAC3D,IAAI,WAAW;YAAE,OAAO,EAAE,CAAC;IAC7B,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,IAAA,2BAAmB,EACjB,OAAO,EACP,GAAG,EAAE,CAAC,CAAC;QACL,OAAO;QACP,UAAU;KACX,CAAC,EACF,CAAC,MAAM,CAAC,CACT,CAAC;IACF,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAA,gBAAQ,EAAC,GAAG,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAChE,MAAM,cAAc,GAAG,IAAA,eAAO,EAC5B,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,KAAK,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EACjE,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,CACnB,CAAC;IAEF,SAAe,aAAa;;YAC1B,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,IAAI;gBACF,MAAM,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;oBAC5B,MAAM,EAAE,4BAA4B;oBACpC,MAAM,EAAE;wBACN;4BACE,OAAO,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;yBACvD;qBACF;iBACF,CAAC,CAAC;aACJ;YAAC,OAAO,CAAM,EAAE;gBACf,QAAQ,CAAC,CAAC,IAAI,EAAE;oBACd,KAAK,IAAI;wBACP,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC;4BACtB,MAAM,EAAE,yBAAyB;4BACjC,MAAM,EAAE;gCACN;oCACE,OAAO,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE;oCACtD,SAAS,EAAE,KAAK,CAAC,IAAI;oCACrB,OAAO,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC;oCACvB,iBAAiB,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC;oCACtC,cAAc,EAAE;wCACd,MAAM,EAAE,KAAK,CAAC,QAAQ;wCACtB,QAAQ,EAAE,EAAE;qCACb;iCACF;6BACF;yBACF,CAAC,CAAC;iBACN;aACF;YACD,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC7B,CAAC;KAAA;IACD,OAAO,CACL;QACG,mBAAmB,IAAI,CAAC,mBAAmB,IAAI,8BAAC,mBAAmB,OAAG;QACtE,cAAc,IAAI,CAAC,cAAc,IAAI,CACpC,8BAAC,cAAc,IAAC,aAAa,EAAE,aAAa,GAAI,CACjD;QAEC,8BAAC,OAAO,oBACF,sBAAsB,IAC1B,cAAc,EAAE,cAAc,EAC9B,mBAAmB,EAAE,mBAAmB,EACxC,wBAAwB,EAAE,cAAc,IAAI,MAAM,CAAC,WAAW,EAAE,EAChE,OAAO,EAAE,OAAO,EAChB,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,EAC5B,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,WAAW,EAAE,MAAM,CAAC,WAAW,EAAE,EACjC,MAAM,EAAE,MAAM,CAAC,OAAO,KAErB,QAAQ,CACD,CAEX,CACJ,CAAC;AACJ,CAAC;AAED,kBAAe,IAAA,kBAAU,EAAC,uBAAuB,CAAC,CAAC"}
@@ -3,12 +3,20 @@ import WalletConnectionWrapper from "./WalletConnectionWrapper";
3
3
  declare const _default: {
4
4
  title: string;
5
5
  component: React.ForwardRefExoticComponent<{
6
- allowedChainId: number;
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
- allowedChainId: number;
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
- allowedChainId: number;
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.allowedChainId,
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
- allowedChainId: 80001, ///MUMBAI
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,kDAAgE;AAChE,wFAAgE;AAGhE,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,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,cAAc;;gBAAK,MAAM,CAAC,cAAc,CAAC,CAC1D;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;AA1CW,QAAA,UAAU,cA0CrB;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,cAAc,EAAE,KAAK,EAAE,SAAS;CACiB,CAAC;AAEpD,4BAAoB,CAAC,IAAI,qBACpB,kBAAU,CAAC,IAAI,CACnB,CAAC"}
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
- debouncedError(`A component is using the UI config ${path.join(".")}.
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
- else
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;AA4CrE,MAAM,OAAO,GAAG,IAAA,qBAAa,EAAqB,IAAW,CAAC,CAAC;AAE/D,SAAwB,aAAa,CAAC,EACpC,QAAQ,EACR,MAAM,GAC4C;IAClD,OAAO,8BAAC,OAAO,CAAC,QAAQ,IAAC,KAAK,EAAE,MAAM,IAAG,QAAQ,CAAoB,CAAC;AACxE,CAAC;AALD,gCAKC;AAED,MAAM,cAAc,GAAG,IAAA,iBAAQ,EAAC,CAAC,OAAe,EAAE,EAAE;IAClD,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;IAChC,KAAa,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;IAC1C,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC,EAAE,GAAG,CAAC,CAAC;AACR,SAAgB,qBAAqB,CAAC,GAAS,EAAE,WAAqB,EAAE;IACtE,MAAM,aAAa,GAAG,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE;QAC/C,KAAK,EAAE,CAAC,MAAM,EAAE,EAAE;YAChB,OAAO,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;QAC1B,CAAC;QACD,GAAG,EAAE,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE;YACrB,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,QAAwC,CAAC,CAAC;YAC9D,IAAI,QAAQ,KAAK,MAAM,CAAC,WAAW;gBAAE,OAAO,GAAG,EAAE,CAAC,KAAK,CAAC;YACxD,IAAI,KAAK,KAAK,SAAS,EAAE;gBACvB,MAAM,IAAI,GAAG,CAAC,GAAG,QAAQ,EAAE,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;gBAChD,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;oBAC3C,cAAc,CACZ,sCAAsC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;;;;;;;mBAO7C,CACR,CAAC;;oBACC,cAAc,CAAC,MAAM,EAAE,CAAC;aAC9B;YACD,IACE,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBACpD,CAAC,KAAK,KAAK,SAAS,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBAElE,OAAO,qBAAqB,CAAC,KAAK,EAAE,CAAC,GAAG,QAAQ,EAAE,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAC1E,OAAO,KAAK,CAAC;QACf,CAAC;KACF,CAAC,CAAC;IACH,OAAO,aAAa,CAAC;AACvB,CAAC;AAhCD,sDAgCC;AAED,SAAgB,eAAe;IAC7B,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,OAAO,CAAC,CAAC;IAEpC,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,EAAE;QAC1C,OAAO,qBAAqB,CAAC,OAAO,CAAiB,CAAC;KACvD;IAED,OAAO,OAAuB,CAAC;AACjC,CAAC;AARD,0CAQC"}
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,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAE9E,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
+ {"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,2 @@
1
+ import "./shims/ObjectWatchShim.js";
2
+ export default function useObserve<T extends any>(object: T, keysToObserve: (keyof T)[]): void;
@@ -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"}