@minimaltech/ra-core-infra 0.0.1

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 (144) hide show
  1. package/LICENSE +26 -0
  2. package/README.md +119 -0
  3. package/dist/base/applications/base.application.d.ts +12 -0
  4. package/dist/base/applications/base.application.js +22 -0
  5. package/dist/base/applications/base.application.js.map +1 -0
  6. package/dist/base/applications/index.d.ts +1 -0
  7. package/dist/base/applications/index.js +2 -0
  8. package/dist/base/applications/index.js.map +1 -0
  9. package/dist/base/index.d.ts +3 -0
  10. package/dist/base/index.js +4 -0
  11. package/dist/base/index.js.map +1 -0
  12. package/dist/base/providers/base.provider.d.ts +10 -0
  13. package/dist/base/providers/base.provider.js +8 -0
  14. package/dist/base/providers/base.provider.js.map +1 -0
  15. package/dist/base/providers/count-rest-data.provider.d.ts +19 -0
  16. package/dist/base/providers/count-rest-data.provider.js +28 -0
  17. package/dist/base/providers/count-rest-data.provider.js.map +1 -0
  18. package/dist/base/providers/default-auth.provider.d.ts +17 -0
  19. package/dist/base/providers/default-auth.provider.js +116 -0
  20. package/dist/base/providers/default-auth.provider.js.map +1 -0
  21. package/dist/base/providers/default-i18n.provider.d.ts +8 -0
  22. package/dist/base/providers/default-i18n.provider.js +42 -0
  23. package/dist/base/providers/default-i18n.provider.js.map +1 -0
  24. package/dist/base/providers/default-rest-data.provider.d.ts +66 -0
  25. package/dist/base/providers/default-rest-data.provider.js +355 -0
  26. package/dist/base/providers/default-rest-data.provider.js.map +1 -0
  27. package/dist/base/providers/index.d.ts +5 -0
  28. package/dist/base/providers/index.js +6 -0
  29. package/dist/base/providers/index.js.map +1 -0
  30. package/dist/base/services/base-crud.service.d.ts +34 -0
  31. package/dist/base/services/base-crud.service.js +157 -0
  32. package/dist/base/services/base-crud.service.js.map +1 -0
  33. package/dist/base/services/base-network-request.service.d.ts +18 -0
  34. package/dist/base/services/base-network-request.service.js +43 -0
  35. package/dist/base/services/base-network-request.service.js.map +1 -0
  36. package/dist/base/services/default-auth.service.d.ts +22 -0
  37. package/dist/base/services/default-auth.service.js +38 -0
  38. package/dist/base/services/default-auth.service.js.map +1 -0
  39. package/dist/base/services/default-network-data.service.d.ts +173 -0
  40. package/dist/base/services/default-network-data.service.js +158 -0
  41. package/dist/base/services/default-network-data.service.js.map +1 -0
  42. package/dist/base/services/index.d.ts +4 -0
  43. package/dist/base/services/index.js +5 -0
  44. package/dist/base/services/index.js.map +1 -0
  45. package/dist/common/constants.d.ts +52 -0
  46. package/dist/common/constants.js +86 -0
  47. package/dist/common/constants.js.map +1 -0
  48. package/dist/common/index.d.ts +4 -0
  49. package/dist/common/index.js +5 -0
  50. package/dist/common/index.js.map +1 -0
  51. package/dist/common/keys.d.ts +15 -0
  52. package/dist/common/keys.js +16 -0
  53. package/dist/common/keys.js.map +1 -0
  54. package/dist/common/locales/en.d.ts +2 -0
  55. package/dist/common/locales/en.js +207 -0
  56. package/dist/common/locales/en.js.map +1 -0
  57. package/dist/common/locales/index.d.ts +2 -0
  58. package/dist/common/locales/index.js +3 -0
  59. package/dist/common/locales/index.js.map +1 -0
  60. package/dist/common/locales/vi.d.ts +2 -0
  61. package/dist/common/locales/vi.js +206 -0
  62. package/dist/common/locales/vi.js.map +1 -0
  63. package/dist/common/types.d.ts +147 -0
  64. package/dist/common/types.js +2 -0
  65. package/dist/common/types.js.map +1 -0
  66. package/dist/helpers/di-container.helper.d.ts +8 -0
  67. package/dist/helpers/di-container.helper.js +20 -0
  68. package/dist/helpers/di-container.helper.js.map +1 -0
  69. package/dist/helpers/index.d.ts +3 -0
  70. package/dist/helpers/index.js +4 -0
  71. package/dist/helpers/index.js.map +1 -0
  72. package/dist/helpers/logger.helper.d.ts +37 -0
  73. package/dist/helpers/logger.helper.js +65 -0
  74. package/dist/helpers/logger.helper.js.map +1 -0
  75. package/dist/helpers/network.helper.d.ts +25 -0
  76. package/dist/helpers/network.helper.js +56 -0
  77. package/dist/helpers/network.helper.js.map +1 -0
  78. package/dist/index.d.ts +5 -0
  79. package/dist/index.js +6 -0
  80. package/dist/index.js.map +1 -0
  81. package/dist/ui/components/CoreRaApplication.d.ts +3 -0
  82. package/dist/ui/components/CoreRaApplication.js +31 -0
  83. package/dist/ui/components/CoreRaApplication.js.map +1 -0
  84. package/dist/ui/components/index.d.ts +1 -0
  85. package/dist/ui/components/index.js +2 -0
  86. package/dist/ui/components/index.js.map +1 -0
  87. package/dist/ui/context.d.ts +8 -0
  88. package/dist/ui/context.js +7 -0
  89. package/dist/ui/context.js.map +1 -0
  90. package/dist/ui/hooks/index.d.ts +10 -0
  91. package/dist/ui/hooks/index.js +11 -0
  92. package/dist/ui/hooks/index.js.map +1 -0
  93. package/dist/ui/hooks/use-application-context.d.ts +2 -0
  94. package/dist/ui/hooks/use-application-context.js +22 -0
  95. package/dist/ui/hooks/use-application-context.js.map +1 -0
  96. package/dist/ui/hooks/use-autosave.d.ts +8 -0
  97. package/dist/ui/hooks/use-autosave.js +38 -0
  98. package/dist/ui/hooks/use-autosave.js.map +1 -0
  99. package/dist/ui/hooks/use-before-unload.d.ts +5 -0
  100. package/dist/ui/hooks/use-before-unload.js +22 -0
  101. package/dist/ui/hooks/use-before-unload.js.map +1 -0
  102. package/dist/ui/hooks/use-confirm.d.ts +10 -0
  103. package/dist/ui/hooks/use-confirm.js +29 -0
  104. package/dist/ui/hooks/use-confirm.js.map +1 -0
  105. package/dist/ui/hooks/use-copy-to-clipboard.d.ts +6 -0
  106. package/dist/ui/hooks/use-copy-to-clipboard.js +20 -0
  107. package/dist/ui/hooks/use-copy-to-clipboard.js.map +1 -0
  108. package/dist/ui/hooks/use-debounce.d.ts +9 -0
  109. package/dist/ui/hooks/use-debounce.js +20 -0
  110. package/dist/ui/hooks/use-debounce.js.map +1 -0
  111. package/dist/ui/hooks/use-document-title.d.ts +5 -0
  112. package/dist/ui/hooks/use-document-title.js +11 -0
  113. package/dist/ui/hooks/use-document-title.js.map +1 -0
  114. package/dist/ui/hooks/use-injectable.d.ts +10 -0
  115. package/dist/ui/hooks/use-injectable.js +15 -0
  116. package/dist/ui/hooks/use-injectable.js.map +1 -0
  117. package/dist/ui/hooks/use-sizer.d.ts +6 -0
  118. package/dist/ui/hooks/use-sizer.js +33 -0
  119. package/dist/ui/hooks/use-sizer.js.map +1 -0
  120. package/dist/ui/hooks/use-window-dimensions.d.ts +4 -0
  121. package/dist/ui/hooks/use-window-dimensions.js +21 -0
  122. package/dist/ui/hooks/use-window-dimensions.js.map +1 -0
  123. package/dist/ui/index.d.ts +4 -0
  124. package/dist/ui/index.js +5 -0
  125. package/dist/ui/index.js.map +1 -0
  126. package/dist/ui/types.d.ts +14 -0
  127. package/dist/ui/types.js +2 -0
  128. package/dist/ui/types.js.map +1 -0
  129. package/dist/utilities/boolean.utility.d.ts +6 -0
  130. package/dist/utilities/boolean.utility.js +26 -0
  131. package/dist/utilities/boolean.utility.js.map +1 -0
  132. package/dist/utilities/error.utility.d.ts +18 -0
  133. package/dist/utilities/error.utility.js +35 -0
  134. package/dist/utilities/error.utility.js.map +1 -0
  135. package/dist/utilities/index.d.ts +4 -0
  136. package/dist/utilities/index.js +5 -0
  137. package/dist/utilities/index.js.map +1 -0
  138. package/dist/utilities/parse.utility.d.ts +14 -0
  139. package/dist/utilities/parse.utility.js +130 -0
  140. package/dist/utilities/parse.utility.js.map +1 -0
  141. package/dist/utilities/url.utility.d.ts +4 -0
  142. package/dist/utilities/url.utility.js +27 -0
  143. package/dist/utilities/url.utility.js.map +1 -0
  144. package/package.json +117 -0
@@ -0,0 +1,37 @@
1
+ export type TLogLevel = 'debug' | 'info' | 'warn' | 'error';
2
+ export interface ILogger {
3
+ debug(message: string, ...args: any[]): void;
4
+ info(message: string, ...args: any[]): void;
5
+ warn(message: string, ...args: any[]): void;
6
+ error(message: string, ...args: any[]): void;
7
+ }
8
+ export declare class Logger implements ILogger {
9
+ private static instance;
10
+ protected scope: string;
11
+ protected isDebugEnabled: boolean;
12
+ constructor(opts: {
13
+ scope: string;
14
+ enableDebug?: boolean;
15
+ });
16
+ static getInstance(opts: {
17
+ scope: string;
18
+ enableDebug?: boolean;
19
+ }): Logger;
20
+ getTimestamp(): string;
21
+ toggleDebug(opts?: {
22
+ state: boolean;
23
+ }): void;
24
+ generateLog(opts: {
25
+ level: TLogLevel;
26
+ message: any;
27
+ args: any[];
28
+ }): {
29
+ message: string;
30
+ args: any[];
31
+ };
32
+ private log;
33
+ debug(message: any, ...args: any[]): void;
34
+ info(message: any, ...args: any[]): void;
35
+ warn(message: any, ...args: any[]): void;
36
+ error(message: any, ...args: any[]): void;
37
+ }
@@ -0,0 +1,65 @@
1
+ import { getError } from '@/utilities';
2
+ const applicationLogger = console;
3
+ export class Logger {
4
+ static instance;
5
+ scope;
6
+ isDebugEnabled;
7
+ constructor(opts) {
8
+ this.scope = opts.scope;
9
+ this.isDebugEnabled = opts?.enableDebug ?? false;
10
+ }
11
+ static getInstance(opts) {
12
+ if (!this.instance) {
13
+ this.instance = new Logger(opts);
14
+ }
15
+ this.instance.isDebugEnabled = opts?.enableDebug ?? false;
16
+ return this.instance;
17
+ }
18
+ getTimestamp() {
19
+ return new Date().toISOString();
20
+ }
21
+ toggleDebug(opts) {
22
+ this.isDebugEnabled = opts?.state || !this.isDebugEnabled;
23
+ }
24
+ generateLog(opts) {
25
+ const { level, message, args } = opts;
26
+ const timestamp = this.getTimestamp();
27
+ switch (typeof message) {
28
+ case 'string': {
29
+ return {
30
+ message: `${timestamp} - [${level}]\t[${this.scope}]${message}`,
31
+ args,
32
+ };
33
+ }
34
+ default: {
35
+ return {
36
+ message: `${timestamp} - [${level}]\t[${this.scope}]`,
37
+ args: [message, ...args],
38
+ };
39
+ }
40
+ }
41
+ }
42
+ log(level, message, ...args) {
43
+ if (!applicationLogger) {
44
+ throw getError({ message: '[info] Invalid logger instance!' });
45
+ }
46
+ if (level === 'debug' && !this.isDebugEnabled) {
47
+ return;
48
+ }
49
+ const generated = this.generateLog({ level, message, args });
50
+ applicationLogger.info(generated.message, ...generated.args);
51
+ }
52
+ debug(message, ...args) {
53
+ this.log('debug', message, ...args);
54
+ }
55
+ info(message, ...args) {
56
+ this.log('info', message, ...args);
57
+ }
58
+ warn(message, ...args) {
59
+ this.log('warn', message, ...args);
60
+ }
61
+ error(message, ...args) {
62
+ this.log('error', message, ...args);
63
+ }
64
+ }
65
+ //# sourceMappingURL=logger.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.helper.js","sourceRoot":"","sources":["../../src/helpers/logger.helper.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { AnyObject, TRequestMethod } from '@/common';
2
+ interface IRequestOptions {
3
+ url: string;
4
+ method: TRequestMethod;
5
+ params?: AnyObject;
6
+ body?: AnyObject;
7
+ headers?: AnyObject;
8
+ configs?: AnyObject;
9
+ }
10
+ export declare class NetworkHelper {
11
+ private name;
12
+ private logger?;
13
+ constructor(opts: {
14
+ name: string;
15
+ logger?: any;
16
+ });
17
+ getProtocol(url: string): "http" | "https";
18
+ send(opts: IRequestOptions): Promise<Response>;
19
+ get(opts: IRequestOptions): Promise<Response>;
20
+ post(opts: IRequestOptions): Promise<Response>;
21
+ put(opts: IRequestOptions): Promise<Response>;
22
+ patch(opts: IRequestOptions): Promise<Response>;
23
+ delete(opts: IRequestOptions): Promise<Response>;
24
+ }
25
+ export {};
@@ -0,0 +1,56 @@
1
+ import { RequestMethods } from '@/common';
2
+ import { stringify } from '@/utilities';
3
+ const HTTP = 'http';
4
+ const HTTPS = 'https';
5
+ export class NetworkHelper {
6
+ name;
7
+ logger;
8
+ constructor(opts) {
9
+ const { name, logger } = opts;
10
+ this.name = name;
11
+ this.logger = logger;
12
+ this.logger?.info('Creating new network request worker instance! Name: %s', this.name);
13
+ }
14
+ getProtocol(url) {
15
+ return url.startsWith('http:') ? HTTP : HTTPS;
16
+ }
17
+ send(opts) {
18
+ const t = new Date().getTime();
19
+ const { url, method, params, body, headers = {}, configs = {} } = opts;
20
+ const props = {
21
+ method,
22
+ body: body instanceof FormData ? body : JSON.stringify(body),
23
+ headers,
24
+ ...configs,
25
+ };
26
+ let requestUrl = url;
27
+ if (params) {
28
+ requestUrl = `${url}?${stringify(params)}`;
29
+ }
30
+ return new Promise((resolve, reject) => {
31
+ this.logger?.info('[send] URL: %s | Props: %o', requestUrl, props);
32
+ fetch(requestUrl, props)
33
+ .then(rs => {
34
+ this.logger?.info('[network]][send] Took: %s(ms)', new Date().getTime() - t);
35
+ resolve(rs);
36
+ })
37
+ .catch(reject);
38
+ });
39
+ }
40
+ get(opts) {
41
+ return this.send({ ...opts, method: RequestMethods.GET });
42
+ }
43
+ post(opts) {
44
+ return this.send({ ...opts, method: RequestMethods.POST });
45
+ }
46
+ put(opts) {
47
+ return this.send({ ...opts, method: RequestMethods.PUT });
48
+ }
49
+ patch(opts) {
50
+ return this.send({ ...opts, method: RequestMethods.PATCH });
51
+ }
52
+ delete(opts) {
53
+ return this.send({ ...opts, method: RequestMethods.DELETE });
54
+ }
55
+ }
56
+ //# sourceMappingURL=network.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"network.helper.js","sourceRoot":"","sources":["../../src/helpers/network.helper.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export * from './base';
2
+ export * from './common';
3
+ export * from './helpers';
4
+ export * from './ui';
5
+ export * from './utilities';
package/dist/index.js ADDED
@@ -0,0 +1,6 @@
1
+ export * from './base';
2
+ export * from './common';
3
+ export * from './helpers';
4
+ export * from './ui';
5
+ export * from './utilities';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,MAAM,CAAC;AACrB,cAAc,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ import { IApplication } from '../types';
3
+ export declare const CoreRaApplication: React.FC<IApplication>;
@@ -0,0 +1,31 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { CoreAdmin, CustomRoutes, Resource } from 'ra-core';
4
+ import { Provider as ReduxProvider } from 'react-redux';
5
+ import { Route } from 'react-router-dom';
6
+ import { CoreBindings } from '@/common';
7
+ import { Logger } from '@/helpers';
8
+ import { ApplicationContext } from '../context';
9
+ const Wrapper = ({ applicationName = 'CoreRaApplication', context, reduxStore, suspense, enableDebug = false, children, }) => {
10
+ return (_jsx(ApplicationContext.Provider, { value: {
11
+ context,
12
+ registry: context,
13
+ logger: Logger.getInstance({ scope: applicationName, enableDebug }),
14
+ }, children: _jsx(ReduxProvider, { store: reduxStore, children: _jsx(React.Suspense, { fallback: suspense, children: children }) }) }));
15
+ };
16
+ export const CoreRaApplication = (props) => {
17
+ const { context, reduxStore, suspense, enableDebug = false, resources, customRoutes, ...raProps } = props;
18
+ const { routes } = customRoutes ?? {};
19
+ const adminProps = React.useMemo(() => {
20
+ const dataProvider = context.getSync(CoreBindings.DEFAULT_REST_DATA_PROVIDER);
21
+ const authProvider = context.getSync(CoreBindings.DEFAULT_AUTH_PROVIDER);
22
+ const i18nProvider = context.getSync(CoreBindings.DEFAULT_I18N_PROVIDER);
23
+ return { dataProvider, authProvider, i18nProvider, ...raProps };
24
+ }, [context, raProps]);
25
+ return (_jsx(Wrapper, { context: context, reduxStore: reduxStore, suspense: suspense, enableDebug: enableDebug, children: _jsxs(CoreAdmin, { ...adminProps, children: [resources.map(resource => {
26
+ return _jsx(Resource, { ...resource }, resource.name);
27
+ }), _jsx(CustomRoutes, { children: routes?.map(resource => {
28
+ return _jsx(Route, { ...resource }, resource.id ?? resource.path);
29
+ }) })] }) }));
30
+ };
31
+ //# sourceMappingURL=CoreRaApplication.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CoreRaApplication.js","sourceRoot":"","sources":["../../../src/ui/components/CoreRaApplication.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,OAAO,EAAE,SAAS,EAAE,YAAY,EAAgB,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,QAAQ,IAAI,aAAa,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,OAAO,EAAE,YAAY,EAAgC,MAAM,UAAU,CAAC;AACtE,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAGhD,MAAM,OAAO,GAOR,CAAC,EACJ,eAAe,GAAG,mBAAmB,EACrC,OAAO,EACP,UAAU,EACV,QAAQ,EACR,WAAW,GAAG,KAAK,EACnB,QAAQ,GACT,EAAE,EAAE;IACH,OAAO,CACL,KAAC,kBAAkB,CAAC,QAAQ,IAC1B,KAAK,EAAE;YACL,OAAO;YACP,QAAQ,EAAE,OAAO;YACjB,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC;SACpE,YAED,KAAC,aAAa,IAAC,KAAK,EAAE,UAAU,YAC9B,KAAC,KAAK,CAAC,QAAQ,IAAC,QAAQ,EAAE,QAAQ,YAAG,QAAQ,GAAkB,GACjD,GACY,CAC/B,CAAC;AACJ,CAAC,CAAC;AAGF,MAAM,CAAC,MAAM,iBAAiB,GAA2B,CAAC,KAAmB,EAAE,EAAE;IAC/E,MAAM,EACJ,OAAO,EACP,UAAU,EACV,QAAQ,EACR,WAAW,GAAG,KAAK,EACnB,SAAS,EACT,YAAY,EACZ,GAAG,OAAO,EACX,GAAG,KAAK,CAAC;IAEV,MAAM,EAAE,MAAM,EAAE,GAAG,YAAY,IAAI,EAAE,CAAC;IAGtC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACpC,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAClC,YAAY,CAAC,0BAA0B,CACxC,CAAC;QACF,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAClC,YAAY,CAAC,qBAAqB,CACnC,CAAC;QACF,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAClC,YAAY,CAAC,qBAAqB,CACnC,CAAC;QAEF,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,OAAO,EAAE,CAAC;IAClE,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAGvB,OAAO,CACL,KAAC,OAAO,IACN,OAAO,EAAE,OAAO,EAChB,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,QAAQ,EAClB,WAAW,EAAE,WAAW,YAExB,MAAC,SAAS,OAAK,UAAU,aACtB,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;oBACxB,OAAO,KAAC,QAAQ,OAAyB,QAAQ,IAA3B,QAAQ,CAAC,IAAI,CAAkB,CAAC;gBACxD,CAAC,CAAC,EAEF,KAAC,YAAY,cACV,MAAM,EAAE,GAAG,CAAC,QAAQ,CAAC,EAAE;wBACtB,OAAO,KAAC,KAAK,OAAwC,QAAQ,IAA1C,QAAQ,CAAC,EAAE,IAAI,QAAQ,CAAC,IAAI,CAAkB,CAAC;oBACpE,CAAC,CAAC,GACW,IACL,GACJ,CACX,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export * from './CoreRaApplication';
@@ -0,0 +1,2 @@
1
+ export * from './CoreRaApplication';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ui/components/index.tsx"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { Context } from '@loopback/context';
3
+ import { Logger } from '@/helpers';
4
+ export declare const ApplicationContext: React.Context<{
5
+ context: Context | null;
6
+ registry: Context | null;
7
+ logger: Logger | null;
8
+ }>;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ export const ApplicationContext = React.createContext({
3
+ context: null,
4
+ registry: null,
5
+ logger: null,
6
+ });
7
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/ui/context.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,CAAC,aAAa,CAIlD;IACD,OAAO,EAAE,IAAI;IACb,QAAQ,EAAE,IAAI;IACd,MAAM,EAAE,IAAI;CACb,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ export * from './use-application-context';
2
+ export * from './use-autosave';
3
+ export * from './use-before-unload';
4
+ export * from './use-confirm';
5
+ export * from './use-copy-to-clipboard';
6
+ export * from './use-debounce';
7
+ export * from './use-document-title';
8
+ export * from './use-injectable';
9
+ export * from './use-sizer';
10
+ export * from './use-window-dimensions';
@@ -0,0 +1,11 @@
1
+ export * from './use-application-context';
2
+ export * from './use-autosave';
3
+ export * from './use-before-unload';
4
+ export * from './use-confirm';
5
+ export * from './use-copy-to-clipboard';
6
+ export * from './use-debounce';
7
+ export * from './use-document-title';
8
+ export * from './use-injectable';
9
+ export * from './use-sizer';
10
+ export * from './use-window-dimensions';
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ui/hooks/index.tsx"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC;AAC1C,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,cAAc,yBAAyB,CAAC;AACxC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC;AAC5B,cAAc,yBAAyB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const useApplicationContext: () => import("@loopback/context").Context;
2
+ export declare const useApplicationLogger: () => import("../..").Logger;
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { getError } from '@/utilities';
3
+ import { ApplicationContext } from '../context';
4
+ export const useApplicationContext = () => {
5
+ const rs = React.useContext(ApplicationContext);
6
+ if (!rs?.context) {
7
+ throw getError({
8
+ message: '[useApplicationContext] must be used within a ApplicationContextProvider',
9
+ });
10
+ }
11
+ return rs.context;
12
+ };
13
+ export const useApplicationLogger = () => {
14
+ const rs = React.useContext(ApplicationContext);
15
+ if (!rs?.logger) {
16
+ throw getError({
17
+ message: '[useApplicationLogger] must be used within a ApplicationContextProvider',
18
+ });
19
+ }
20
+ return rs.logger;
21
+ };
22
+ //# sourceMappingURL=use-application-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-application-context.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-application-context.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAEhD,MAAM,CAAC,MAAM,qBAAqB,GAAG,GAAG,EAAE;IACxC,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;IAEhD,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,CAAC;QACjB,MAAM,QAAQ,CAAC;YACb,OAAO,EAAE,0EAA0E;SACpF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,EAAE,CAAC,OAAO,CAAC;AACpB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;IAChD,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC;QAChB,MAAM,QAAQ,CAAC;YACb,OAAO,EAAE,yEAAyE;SACnF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,EAAE,CAAC,MAAM,CAAC;AACnB,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ export interface IUseAutosaveParams<TData, TReturn> {
2
+ data: TData;
3
+ onSave: (data: TData) => Promise<TReturn> | TReturn | void;
4
+ interval?: number;
5
+ enableSaveOnUnmount?: boolean;
6
+ disabled?: boolean;
7
+ }
8
+ export declare const useAutosave: <TData, TReturn>(params: IUseAutosaveParams<TData, TReturn>) => void;
@@ -0,0 +1,38 @@
1
+ import React from 'react';
2
+ import { useDebounce } from './use-debounce';
3
+ export const useAutosave = (params) => {
4
+ const { data, onSave, interval = 2000, enableSaveOnUnmount, disabled } = params;
5
+ const valueOnCleanup = React.useRef(data);
6
+ const initialRender = React.useRef(true);
7
+ const handleSave = React.useRef(onSave);
8
+ const { debouncedValue: debouncedValueToSave } = useDebounce({
9
+ value: data,
10
+ delay: interval,
11
+ disabled,
12
+ });
13
+ React.useEffect(() => {
14
+ if (initialRender.current) {
15
+ initialRender.current = false;
16
+ return;
17
+ }
18
+ handleSave.current(debouncedValueToSave);
19
+ return () => { };
20
+ }, [debouncedValueToSave]);
21
+ React.useEffect(() => {
22
+ valueOnCleanup.current = data;
23
+ return () => { };
24
+ }, [data]);
25
+ React.useEffect(() => {
26
+ handleSave.current = onSave;
27
+ return () => { };
28
+ }, [onSave]);
29
+ React.useEffect(() => {
30
+ return () => {
31
+ if (!enableSaveOnUnmount) {
32
+ return;
33
+ }
34
+ handleSave.current(valueOnCleanup.current);
35
+ };
36
+ }, [enableSaveOnUnmount]);
37
+ };
38
+ //# sourceMappingURL=use-autosave.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-autosave.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-autosave.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AA0B7C,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,MAA0C,EAC1C,EAAE;IACF,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,GAAG,IAAI,EAAE,mBAAmB,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;IAGhF,MAAM,cAAc,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1C,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACzC,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAGxC,MAAM,EAAE,cAAc,EAAE,oBAAoB,EAAE,GAAG,WAAW,CAAC;QAC3D,KAAK,EAAE,IAAI;QACX,KAAK,EAAE,QAAQ;QACf,QAAQ;KACT,CAAC,CAAC;IAGH,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,aAAa,CAAC,OAAO,EAAE,CAAC;YAC1B,aAAa,CAAC,OAAO,GAAG,KAAK,CAAC;YAC9B,OAAO;QACT,CAAC;QACD,UAAU,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;QACzC,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC;IAG3B,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,cAAc,CAAC,OAAO,GAAG,IAAI,CAAC;QAC9B,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAGX,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,UAAU,CAAC,OAAO,GAAG,MAAM,CAAC;QAC5B,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAGb,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,OAAO,GAAG,EAAE;YACV,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBACzB,OAAO;YACT,CAAC;YACD,UAAU,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QAC7C,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC;AAC5B,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export interface IUseBeforeUnloadParams {
2
+ enabled: boolean | (() => boolean);
3
+ message?: string;
4
+ }
5
+ export declare const useBeforeUnload: (params: IUseBeforeUnloadParams) => void;
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ export const useBeforeUnload = (params) => {
3
+ const { enabled, message } = params;
4
+ const handleBeforeUnload = React.useCallback((event) => {
5
+ const isEnabled = enabled instanceof Function ? enabled() : enabled;
6
+ if (!isEnabled) {
7
+ return;
8
+ }
9
+ event.preventDefault();
10
+ if (message) {
11
+ event.returnValue = message;
12
+ }
13
+ return message;
14
+ }, [enabled, message]);
15
+ React.useEffect(() => {
16
+ window.addEventListener('beforeunload', handleBeforeUnload);
17
+ return () => {
18
+ window.removeEventListener('beforeunload', handleBeforeUnload);
19
+ };
20
+ }, [handleBeforeUnload]);
21
+ };
22
+ //# sourceMappingURL=use-before-unload.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-before-unload.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-before-unload.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,MAA8B,EAAE,EAAE;IAChE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;IAGpC,MAAM,kBAAkB,GAAG,KAAK,CAAC,WAAW,CAC1C,CAAC,KAAwB,EAAE,EAAE;QAC3B,MAAM,SAAS,GAAG,OAAO,YAAY,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;QACpE,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO;QACT,CAAC;QAED,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,OAAO,EAAE,CAAC;YACZ,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC;QAC9B,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC,EACD,CAAC,OAAO,EAAE,OAAO,CAAC,CACnB,CAAC;IAGF,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;QAC5D,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;QACjE,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC;AAC3B,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ export interface IUseConfirmReturn {
2
+ message?: string;
3
+ confirm: (opts: {
4
+ message: string;
5
+ }) => Promise<boolean>;
6
+ handleClose: () => void;
7
+ handleConfirm: () => void;
8
+ handleAbort: () => void;
9
+ }
10
+ export declare const useConfirm: () => IUseConfirmReturn;
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ export const useConfirm = () => {
3
+ const [resolve, setResolve] = React.useState();
4
+ const [message, setMessage] = React.useState();
5
+ const confirm = React.useCallback((opts) => {
6
+ return new Promise(_resolve => {
7
+ setResolve(() => {
8
+ return (value) => {
9
+ return _resolve(value);
10
+ };
11
+ });
12
+ setMessage(opts.message);
13
+ });
14
+ }, []);
15
+ const handleClose = React.useCallback(() => {
16
+ setResolve(undefined);
17
+ setMessage(undefined);
18
+ }, []);
19
+ const handleConfirm = React.useCallback(() => {
20
+ resolve?.(true);
21
+ handleClose();
22
+ }, [handleClose, resolve]);
23
+ const handleAbort = React.useCallback(() => {
24
+ resolve?.(false);
25
+ handleClose();
26
+ }, [handleClose, resolve]);
27
+ return { message, confirm, handleClose, handleConfirm, handleAbort };
28
+ };
29
+ //# sourceMappingURL=use-confirm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-confirm.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-confirm.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAU1B,MAAM,CAAC,MAAM,UAAU,GAAG,GAAsB,EAAE;IAEhD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,KAAK,CAAC,QAAQ,EAA4B,CAAC;IAGzE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IAGvD,MAAM,OAAO,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,IAAyB,EAAE,EAAE;QAC9D,OAAO,IAAI,OAAO,CAAU,QAAQ,CAAC,EAAE;YACrC,UAAU,CAAC,GAAG,EAAE;gBACd,OAAO,CAAC,KAAc,EAAE,EAAE;oBACxB,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACzB,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAGP,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QACzC,UAAU,CAAC,SAAS,CAAC,CAAC;QACtB,UAAU,CAAC,SAAS,CAAC,CAAC;IACxB,CAAC,EAAE,EAAE,CAAC,CAAC;IAGP,MAAM,aAAa,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QAC3C,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QAChB,WAAW,EAAE,CAAC;IAChB,CAAC,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;IAG3B,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC,GAAG,EAAE;QACzC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;QACjB,WAAW,EAAE,CAAC;IAChB,CAAC,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;IAE3B,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;AACvE,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ export interface IUseCopyToClipboardReturn {
2
+ copy: (opts: {
3
+ value: string;
4
+ }) => Promise<boolean>;
5
+ }
6
+ export declare const useCopyToClipboard: () => IUseCopyToClipboardReturn;
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ export const useCopyToClipboard = () => {
3
+ const copy = React.useCallback(async (opts) => {
4
+ if (!navigator?.clipboard) {
5
+ console.warn('Clipboard not supported');
6
+ return false;
7
+ }
8
+ const { value } = opts;
9
+ try {
10
+ await navigator.clipboard.writeText(value);
11
+ return true;
12
+ }
13
+ catch (error) {
14
+ console.warn('Copy failed', error);
15
+ return false;
16
+ }
17
+ }, []);
18
+ return { copy };
19
+ };
20
+ //# sourceMappingURL=use-copy-to-clipboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-copy-to-clipboard.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-copy-to-clipboard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAA8B,EAAE;IAEhE,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,IAAuB,EAAE,EAAE;QAC/D,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,CAAC;YAC1B,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;YACxC,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;QAEvB,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC3C,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YACnC,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,EAAE,IAAI,EAAE,CAAC;AAClB,CAAC,CAAC"}
@@ -0,0 +1,9 @@
1
+ export interface IUseDebounceParams<TValue> {
2
+ value: TValue;
3
+ delay?: number;
4
+ disabled?: boolean;
5
+ }
6
+ export interface IUseDebounceReturn<TValue> {
7
+ debouncedValue: TValue;
8
+ }
9
+ export declare const useDebounce: <TValue>(params: IUseDebounceParams<TValue>) => IUseDebounceReturn<TValue>;
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { App } from '@/common/constants';
3
+ import { isBrowser } from '@/utilities/boolean.utility';
4
+ export const useDebounce = (params) => {
5
+ const { value, delay, disabled } = params;
6
+ const [debouncedValue, setDebouncedValue] = React.useState(value);
7
+ React.useEffect(() => {
8
+ if (!isBrowser() || disabled) {
9
+ return;
10
+ }
11
+ const timer = setTimeout(() => {
12
+ setDebouncedValue(value);
13
+ }, delay || App.DEFAULT_DEBOUNCE_TIME);
14
+ return () => {
15
+ clearTimeout(timer);
16
+ };
17
+ }, [value, delay, disabled]);
18
+ return { debouncedValue };
19
+ };
20
+ //# sourceMappingURL=use-debounce.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-debounce.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-debounce.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAYxD,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,MAAkC,EACN,EAAE;IAC9B,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;IAG1C,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAS,KAAK,CAAC,CAAC;IAG1E,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,CAAC,SAAS,EAAE,IAAI,QAAQ,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC,EAAE,KAAK,IAAI,GAAG,CAAC,qBAAqB,CAAC,CAAC;QAEvC,OAAO,GAAG,EAAE;YACV,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;IAE7B,OAAO,EAAE,cAAc,EAAE,CAAC;AAC5B,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export interface IUseDocumentTitleParams {
2
+ value?: string;
3
+ defaultValue?: string;
4
+ }
5
+ export declare const useDocumentTitle: (params: IUseDocumentTitleParams) => void;
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ export const useDocumentTitle = (params) => {
3
+ const { value = '', defaultValue = '' } = params;
4
+ React.useEffect(() => {
5
+ document.title = value;
6
+ return () => {
7
+ document.title = defaultValue;
8
+ };
9
+ }, [value, defaultValue]);
10
+ };
11
+ //# sourceMappingURL=use-document-title.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-document-title.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-document-title.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,MAA+B,EAAE,EAAE;IAClE,MAAM,EAAE,KAAK,GAAG,EAAE,EAAE,YAAY,GAAG,EAAE,EAAE,GAAG,MAAM,CAAC;IAGjD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QAEvB,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,KAAK,GAAG,YAAY,CAAC;QAChC,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC;AAC5B,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { Context } from '@loopback/context';
2
+ import { CoreBindings, ValueOf } from '@/common';
3
+ export interface IUseInjectableKeysOverrides {
4
+ }
5
+ export type TUseInjectableKeysDefault = Extract<ValueOf<typeof CoreBindings>, string>;
6
+ export type TUseInjectableKeys = TUseInjectableKeysDefault | keyof IUseInjectableKeysOverrides;
7
+ export declare const useInjectable: <T>(opts: {
8
+ context?: Context;
9
+ key: TUseInjectableKeys;
10
+ }) => T;
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { getError } from '@/utilities';
3
+ import { ApplicationContext } from '../context';
4
+ export const useInjectable = (opts) => {
5
+ const requestContext = opts?.context;
6
+ const applicationContext = React.useContext(ApplicationContext);
7
+ const context = requestContext ?? applicationContext.context;
8
+ if (!context) {
9
+ throw getError({
10
+ message: '[useInjectable] Failed to determine injectable context!',
11
+ });
12
+ }
13
+ return context.getSync(opts.key);
14
+ };
15
+ //# sourceMappingURL=use-injectable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-injectable.js","sourceRoot":"","sources":["../../../src/ui/hooks/use-injectable.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAK1B,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAUhD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAK,IAGjC,EAAE,EAAE;IACH,MAAM,cAAc,GAAG,IAAI,EAAE,OAAO,CAAC;IACrC,MAAM,kBAAkB,GAAG,KAAK,CAAC,UAAU,CAAC,kBAAkB,CAAC,CAAC;IAEhE,MAAM,OAAO,GAAG,cAAc,IAAI,kBAAkB,CAAC,OAAO,CAAC;IAC7D,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,QAAQ,CAAC;YACb,OAAO,EAAE,yDAAyD;SACnE,CAAC,CAAC;IACL,CAAC;IAED,OAAO,OAAO,CAAC,OAAO,CAAI,IAAI,CAAC,GAAG,CAAC,CAAC;AACtC,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ export declare const useSizer: (props: {
2
+ containerId: string;
3
+ }) => {
4
+ width: number;
5
+ height: number;
6
+ };