@steroidsjs/core 2.1.0-beta.15 → 2.1.0-beta.19

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 (97) hide show
  1. package/actions/list.d.ts +1 -0
  2. package/actions/list.js +1 -0
  3. package/components/ClientStorageComponent.d.ts +3 -3
  4. package/components/ClientStorageComponent.js +28 -22
  5. package/components/HttpComponent.js +32 -15
  6. package/components/LocaleComponent.js +9 -9
  7. package/components/MetricsComponent.js +3 -1
  8. package/components/StoreComponent.d.ts +6 -0
  9. package/components/StoreComponent.js +5 -6
  10. package/components/UiComponent.d.ts +1 -1
  11. package/components/WebSocketComponent.d.ts +1 -1
  12. package/hoc/components.d.ts +1 -1
  13. package/hoc/components.js +1 -1
  14. package/hooks/index.d.ts +2 -1
  15. package/hooks/index.js +3 -1
  16. package/hooks/useApplication.d.ts +29 -26
  17. package/hooks/useApplication.js +17 -82
  18. package/hooks/useComponents.d.ts +1 -14
  19. package/hooks/useComponents.js +5 -5
  20. package/hooks/useFetch.d.ts +11 -3
  21. package/hooks/useFetch.js +34 -31
  22. package/hooks/useLayout.d.ts +9 -0
  23. package/hooks/useLayout.js +64 -44
  24. package/hooks/useList.d.ts +45 -0
  25. package/hooks/useList.js +83 -53
  26. package/hooks/useModel.js +1 -1
  27. package/hooks/useScreen.d.ts +1 -1
  28. package/hooks/useScreen.js +2 -2
  29. package/hooks/useSsr.d.ts +2 -0
  30. package/hooks/useSsr.js +8 -0
  31. package/index.d.ts +8 -2
  32. package/package.json +4 -2
  33. package/providers/ComponentsProvider.d.ts +26 -0
  34. package/providers/ComponentsProvider.js +28 -0
  35. package/providers/ScreenProvider.d.ts +20 -0
  36. package/providers/ScreenProvider.js +87 -0
  37. package/providers/SsrProvider.d.ts +17 -0
  38. package/providers/SsrProvider.js +32 -0
  39. package/providers/index.d.ts +4 -0
  40. package/providers/index.js +12 -0
  41. package/reducers/form.d.ts +1 -1
  42. package/reducers/form.js +1 -1
  43. package/reducers/list.js +1 -3
  44. package/reducers/router.js +1 -1
  45. package/ui/content/Alert/Alert.d.ts +50 -0
  46. package/ui/content/Alert/Alert.js +39 -0
  47. package/ui/content/Alert/index.d.ts +2 -0
  48. package/ui/content/Alert/index.js +7 -0
  49. package/ui/content/Avatar/Avatar.d.ts +53 -12
  50. package/ui/content/Avatar/Avatar.js +25 -4
  51. package/ui/content/Avatar/index.d.ts +6 -1
  52. package/ui/content/Avatar/index.js +4 -0
  53. package/ui/content/Card/Card.d.ts +61 -13
  54. package/ui/content/Card/Card.js +3 -2
  55. package/ui/content/Collapse/Collapse.d.ts +63 -0
  56. package/ui/content/Collapse/Collapse.js +75 -0
  57. package/ui/content/Collapse/CollapseItem.d.ts +67 -0
  58. package/ui/content/Collapse/CollapseItem.js +22 -0
  59. package/ui/content/Collapse/index.d.ts +7 -0
  60. package/ui/content/Collapse/index.js +8 -0
  61. package/ui/content/index.d.ts +13 -0
  62. package/ui/content/index.js +22 -0
  63. package/ui/crud/Crud/Crud.d.ts +1 -1
  64. package/ui/crud/index.d.ts +1 -0
  65. package/ui/form/Button/Button.d.ts +1 -0
  66. package/ui/form/Button/Button.js +1 -0
  67. package/ui/form/DropDownField/DropDownField.js +4 -2
  68. package/ui/form/Form/Form.js +1 -1
  69. package/ui/form/InputField/InputField.d.ts +7 -0
  70. package/ui/form/InputField/InputField.js +1 -0
  71. package/ui/form/TextField/TextField.d.ts +2 -1
  72. package/ui/form/TextField/TextField.js +1 -1
  73. package/ui/icon/Icon/Icon.js +3 -0
  74. package/ui/layout/Meta/Meta.d.ts +56 -0
  75. package/ui/layout/Meta/Meta.js +38 -0
  76. package/ui/layout/Meta/index.d.ts +2 -0
  77. package/ui/layout/Meta/index.js +7 -0
  78. package/ui/layout/Notifications/Notifications.js +1 -1
  79. package/ui/layout/Portal.js +3 -0
  80. package/ui/layout/ProgressBar/ProgressBar.d.ts +55 -0
  81. package/ui/layout/ProgressBar/ProgressBar.js +52 -0
  82. package/ui/layout/ProgressBar/index.d.ts +2 -0
  83. package/ui/layout/ProgressBar/index.js +7 -0
  84. package/ui/layout/Skeleton/Skeleton.d.ts +25 -0
  85. package/ui/layout/Skeleton/Skeleton.js +11 -0
  86. package/ui/layout/Skeleton/index.d.ts +2 -0
  87. package/ui/layout/Skeleton/index.js +7 -0
  88. package/ui/list/Steps/Steps.d.ts +32 -0
  89. package/ui/list/Steps/Steps.js +23 -0
  90. package/ui/list/Steps/index.d.ts +2 -0
  91. package/ui/list/Steps/index.js +7 -0
  92. package/ui/nav/Router/Router.d.ts +13 -0
  93. package/ui/nav/Router/Router.js +1 -1
  94. package/ui/content/Avatar/SizeContext.d.ts +0 -1
  95. package/ui/content/Avatar/SizeContext.js +0 -14
  96. package/ui/nav/Router/SsrProvider.d.ts +0 -15
  97. package/ui/nav/Router/SsrProvider.js +0 -55
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ var ProgressBar_1 = __importDefault(require("./ProgressBar"));
7
+ exports["default"] = ProgressBar_1["default"];
@@ -0,0 +1,25 @@
1
+ import * as React from "react";
2
+ export interface ISkeletonViewProps {
3
+ className?: string;
4
+ children?: React.ReactNode;
5
+ animation?: 'pulse' | 'wave';
6
+ type?: 'text' | 'rect' | 'circle';
7
+ height?: string | number;
8
+ width?: string | number;
9
+ }
10
+ interface ISkeletonProps {
11
+ className?: string;
12
+ children?: React.ReactNode;
13
+ animation?: 'pulse' | 'wave';
14
+ type?: 'text' | 'rect' | 'circle';
15
+ height?: string | number;
16
+ width?: string | number;
17
+ }
18
+ declare function Skeleton(props: ISkeletonProps): JSX.Element;
19
+ declare namespace Skeleton {
20
+ var defaultProps: {
21
+ animation: string;
22
+ type: string;
23
+ };
24
+ }
25
+ export default Skeleton;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ exports.__esModule = true;
3
+ var hooks_1 = require("../../../hooks");
4
+ function Skeleton(props) {
5
+ return hooks_1.useComponents().ui.renderView('layout.SkeletonView', props);
6
+ }
7
+ Skeleton.defaultProps = {
8
+ animation: 'pulse',
9
+ type: 'text'
10
+ };
11
+ exports["default"] = Skeleton;
@@ -0,0 +1,2 @@
1
+ import Skeleton from "./Skeleton";
2
+ export default Skeleton;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ var Skeleton_1 = __importDefault(require("./Skeleton"));
7
+ exports["default"] = Skeleton_1["default"];
@@ -0,0 +1,32 @@
1
+ import React from "react";
2
+ interface IStepsProps {
3
+ stepItems: IStepItem[];
4
+ currentStep: number;
5
+ isChangeable?: boolean;
6
+ className?: string;
7
+ onChange?: (index: number) => void;
8
+ }
9
+ export interface IStepsViewProps {
10
+ className?: string;
11
+ children?: React.ReactNode;
12
+ }
13
+ export interface IStepItemViewProps {
14
+ stepItem: IStepItem;
15
+ className?: string;
16
+ index: number;
17
+ status: string;
18
+ disabled: boolean;
19
+ onChange: () => void;
20
+ }
21
+ export interface IStepItem {
22
+ title?: string;
23
+ subtitle?: string;
24
+ description?: string;
25
+ icon?: string | React.ReactNode;
26
+ isError?: boolean;
27
+ }
28
+ declare function Steps(props: IStepsProps): JSX.Element;
29
+ declare namespace Steps {
30
+ var defaultProps: {};
31
+ }
32
+ export default Steps;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ exports.__esModule = true;
3
+ var hooks_1 = require("../../../hooks");
4
+ var react_1 = require("react");
5
+ function Steps(props) {
6
+ var _a = react_1.useState(false), isChangeable = _a[0], setIsChangeable = _a[1];
7
+ react_1.useEffect(function () { return setIsChangeable(props.isChangeable); }, [props.isChangeable]);
8
+ function getStepStatus(index, stepItem) {
9
+ if (stepItem.isError)
10
+ return 'error';
11
+ if (props.currentStep < index)
12
+ return 'wait';
13
+ if (props.currentStep === index)
14
+ return 'active';
15
+ return 'finish';
16
+ }
17
+ return hooks_1.useComponents().ui.renderView("list.StepsView", { className: props.className, children: props.stepItems.map(function (stepItem, index) {
18
+ return hooks_1.useComponents().ui.renderView("list.StepItemView", { stepItem: stepItem, index: index + 1, status: getStepStatus(index, stepItem), disabled: !isChangeable, onChange: function () { if (isChangeable)
19
+ props.onChange(index); } });
20
+ }) });
21
+ }
22
+ Steps.defaultProps = {};
23
+ exports["default"] = Steps;
@@ -0,0 +1,2 @@
1
+ import Steps from "./Steps";
2
+ export default Steps;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ var Steps_1 = __importDefault(require("./Steps"));
7
+ exports["default"] = Steps_1["default"];
@@ -1,4 +1,6 @@
1
1
  import * as React from 'react';
2
+ import { IFetchConfig } from '../../../hooks/useFetch';
3
+ import { IListProps } from '../../list/List/List';
2
4
  import { IFetchHocConfigFunc } from '../../../hoc/fetch';
3
5
  /**
4
6
  * Router
@@ -89,6 +91,17 @@ export interface IRouteItem {
89
91
  items?: IRouteItem[] | {
90
92
  [key: string]: IRouteItem;
91
93
  };
94
+ /**
95
+ * Обработчик, который принимает параметры URL и возвращает массив с пропсами для хука useFetch и компонента
96
+ * List.
97
+ * Функция запускается перед рендерингом приложения в режиме SSR и используется для предварительной
98
+ * загрузки данных, необходимых на текущей странице.
99
+ * Хук useFetch и компонент List не будут повторно инициализироваться и делать запросы на клиенте,
100
+ * если подгруженные данные существуют.
101
+ * @param {Object} match
102
+ * @return {Array} Например, [{url: '/api/v1/some-data'}, {listId: 'someList', action: '/api/v1/some-list'}]
103
+ */
104
+ preloadData?: (match: Record<string, any>) => (IFetchConfig | IListProps)[];
92
105
  [key: string]: any;
93
106
  }
94
107
  export interface IRouterProps {
@@ -49,7 +49,7 @@ var hoc_1 = require("../../../hoc");
49
49
  var router_1 = require("../../../actions/router");
50
50
  var useDispatch_1 = __importDefault(require("../../../hooks/useDispatch"));
51
51
  var router_2 = require("../../../reducers/router");
52
- var SsrProvider_1 = require("./SsrProvider");
52
+ var SsrProvider_1 = require("../../../providers/SsrProvider");
53
53
  var findRedirectPathRecursive = function (route) {
54
54
  if (!route) {
55
55
  return null;
@@ -1 +0,0 @@
1
- export {};
@@ -1,14 +0,0 @@
1
- "use strict";
2
- exports.__esModule = true;
3
- // const SizeContext = React.createContext<Size>('medium');
4
- // export interface SizeContextProps {
5
- // size?: Size
6
- // }
7
- // export const SizeContextProvider = ({ children, size }) => (
8
- // <SizeContext.Consumer>
9
- // {originSize => (
10
- // <SizeContext.Provider value={size || originSize}>{children}</SizeContext.Provider>
11
- // )}
12
- // </SizeContext.Consumer>
13
- // );
14
- // export default SizeContext;
@@ -1,15 +0,0 @@
1
- import * as React from 'react';
2
- interface ISsrProviderContext {
3
- history?: any;
4
- staticContext?: any;
5
- }
6
- export declare const SsrProviderContext: React.Context<ISsrProviderContext>;
7
- interface ISsrProviderProps {
8
- history?: any;
9
- store?: any;
10
- staticContext?: any;
11
- }
12
- export default class SsrProvider extends React.PureComponent<ISsrProviderProps> {
13
- render(): JSX.Element;
14
- }
15
- export {};
@@ -1,55 +0,0 @@
1
- "use strict";
2
- var __extends = (this && this.__extends) || (function () {
3
- var extendStatics = function (d, b) {
4
- extendStatics = Object.setPrototypeOf ||
5
- ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
- function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
- return extendStatics(d, b);
8
- };
9
- return function (d, b) {
10
- if (typeof b !== "function" && b !== null)
11
- throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
- extendStatics(d, b);
13
- function __() { this.constructor = d; }
14
- d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
- };
16
- })();
17
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
- if (k2 === undefined) k2 = k;
19
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
20
- }) : (function(o, m, k, k2) {
21
- if (k2 === undefined) k2 = k;
22
- o[k2] = m[k];
23
- }));
24
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
- Object.defineProperty(o, "default", { enumerable: true, value: v });
26
- }) : function(o, v) {
27
- o["default"] = v;
28
- });
29
- var __importStar = (this && this.__importStar) || function (mod) {
30
- if (mod && mod.__esModule) return mod;
31
- var result = {};
32
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
- __setModuleDefault(result, mod);
34
- return result;
35
- };
36
- exports.__esModule = true;
37
- exports.SsrProviderContext = void 0;
38
- var React = __importStar(require("react"));
39
- var react_redux_1 = require("react-redux");
40
- exports.SsrProviderContext = React.createContext(null);
41
- var SsrProvider = /** @class */ (function (_super) {
42
- __extends(SsrProvider, _super);
43
- function SsrProvider() {
44
- return _super !== null && _super.apply(this, arguments) || this;
45
- }
46
- SsrProvider.prototype.render = function () {
47
- return (React.createElement(exports.SsrProviderContext.Provider, { value: {
48
- history: this.props.history,
49
- staticContext: this.props.staticContext
50
- } },
51
- React.createElement(react_redux_1.Provider, { store: this.props.store }, this.props.children)));
52
- };
53
- return SsrProvider;
54
- }(React.PureComponent));
55
- exports["default"] = SsrProvider;