@modern-js/plugin-state 1.2.0 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,31 @@
1
1
  # @modern-js/plugin-state
2
2
 
3
+ ## 1.2.3
4
+
5
+ ### Patch Changes
6
+
7
+ - bebb39b6: chore: improve devDependencies and peerDependencies
8
+
9
+ ## 1.2.2
10
+
11
+ ### Patch Changes
12
+
13
+ - 94d02b35: feat(plugin-runtime): convert to new plugin
14
+ - 681a1ff9: feat: remove unnecessary peerDependencies
15
+ - e8bbc315: feat(plugin-state): convert to new plugin
16
+
17
+ ## 1.2.1
18
+
19
+ ### Patch Changes
20
+
21
+ - 83166714: change .npmignore
22
+ - Updated dependencies [83166714]
23
+ - Updated dependencies [c3de9882]
24
+ - Updated dependencies [33ff48af]
25
+ - Updated dependencies [c74597bd]
26
+ - @modern-js/core@1.3.2
27
+ - @modern-js/runtime-core@1.2.1
28
+
3
29
  ## 1.2.0
4
30
 
5
31
  ### Minor Changes
@@ -1,62 +1,61 @@
1
1
  import path from 'path';
2
2
  import { getEntryOptions, createRuntimeExportsUtils, PLUGIN_SCHEMAS } from '@modern-js/utils';
3
- import { createPlugin, useAppContext, useResolvedConfigContext } from '@modern-js/core';
4
3
  import "../types";
5
4
  const PLUGIN_IDENTIFIER = 'state';
6
- const index = createPlugin(() => {
7
- const stateConfigMap = new Map();
8
- let pluginsExportsUtils;
9
- const stateModulePath = path.resolve(__dirname, '../../../../');
10
- return {
11
- config() {
12
- // eslint-disable-next-line react-hooks/rules-of-hooks
13
- const appContext = useAppContext();
14
- pluginsExportsUtils = createRuntimeExportsUtils(appContext.internalDirectory, 'plugins');
15
- return {
16
- source: {
17
- alias: {
18
- '@modern-js/runtime/plugins': pluginsExportsUtils.getPath()
5
+ export default (() => ({
6
+ name: '@modern-js/plugin-state',
7
+ required: ['@modern-js/runtime'],
8
+ setup: api => {
9
+ const stateConfigMap = new Map();
10
+ let pluginsExportsUtils;
11
+ const stateModulePath = path.resolve(__dirname, '../../../../');
12
+ return {
13
+ config() {
14
+ const appContext = api.useAppContext();
15
+ pluginsExportsUtils = createRuntimeExportsUtils(appContext.internalDirectory, 'plugins');
16
+ return {
17
+ source: {
18
+ alias: {
19
+ '@modern-js/runtime/plugins': pluginsExportsUtils.getPath()
20
+ }
19
21
  }
20
- }
21
- };
22
- },
23
-
24
- modifyEntryImports({
25
- entrypoint,
26
- imports
27
- }) {
28
- var _getEntryOptions;
22
+ };
23
+ },
29
24
 
30
- const {
31
- entryName
32
- } = entrypoint; // eslint-disable-next-line react-hooks/rules-of-hooks
33
-
34
- const userConfig = useResolvedConfigContext(); // eslint-disable-next-line react-hooks/rules-of-hooks
25
+ modifyEntryImports({
26
+ entrypoint,
27
+ imports
28
+ }) {
29
+ var _getEntryOptions;
35
30
 
36
- const {
37
- packageName
38
- } = useAppContext();
39
- const stateConfig = (_getEntryOptions = getEntryOptions(entryName, userConfig.runtime, userConfig.runtimeByEntries, packageName)) === null || _getEntryOptions === void 0 ? void 0 : _getEntryOptions.state;
40
- stateConfigMap.set(entryName, stateConfig);
31
+ const {
32
+ entryName
33
+ } = entrypoint;
34
+ const userConfig = api.useResolvedConfigContext();
35
+ const {
36
+ packageName
37
+ } = api.useAppContext();
38
+ const stateConfig = (_getEntryOptions = getEntryOptions(entryName, userConfig.runtime, userConfig.runtimeByEntries, packageName)) === null || _getEntryOptions === void 0 ? void 0 : _getEntryOptions.state;
39
+ stateConfigMap.set(entryName, stateConfig);
41
40
 
42
- const getEnabledPlugins = () => {
43
- const internalPlugins = ['immer', 'effects', 'autoActions', 'devtools'];
44
- return internalPlugins.filter(name => stateConfig[name] !== false);
45
- };
41
+ const getEnabledPlugins = () => {
42
+ const internalPlugins = ['immer', 'effects', 'autoActions', 'devtools'];
43
+ return internalPlugins.filter(name => stateConfig[name] !== false);
44
+ };
46
45
 
47
- if (stateConfig) {
48
- imports.push({
49
- value: '@modern-js/runtime/plugins',
50
- specifiers: [{
51
- imported: PLUGIN_IDENTIFIER
52
- }]
53
- });
54
- imports.push({
55
- value: '@modern-js/runtime/model',
56
- specifiers: getEnabledPlugins().map(imported => ({
57
- imported
58
- })),
59
- initialize: `
46
+ if (stateConfig) {
47
+ imports.push({
48
+ value: '@modern-js/runtime/plugins',
49
+ specifiers: [{
50
+ imported: PLUGIN_IDENTIFIER
51
+ }]
52
+ });
53
+ imports.push({
54
+ value: '@modern-js/runtime/model',
55
+ specifiers: getEnabledPlugins().map(imported => ({
56
+ imported
57
+ })),
58
+ initialize: `
60
59
  const createStatePlugins = (config) => {
61
60
  const plugins = [];
62
61
 
@@ -67,48 +66,45 @@ const index = createPlugin(() => {
67
66
  return plugins;
68
67
  }
69
68
  `
70
- });
71
- }
72
-
73
- return {
74
- entrypoint,
75
- imports
76
- };
77
- },
69
+ });
70
+ }
78
71
 
79
- modifyEntryRuntimePlugins({
80
- entrypoint,
81
- plugins
82
- }) {
83
- const stateOptions = stateConfigMap.get(entrypoint.entryName);
72
+ return {
73
+ entrypoint,
74
+ imports
75
+ };
76
+ },
84
77
 
85
- if (stateOptions) {
86
- const isBoolean = typeof stateOptions === 'boolean';
87
- let options = isBoolean ? '{}' : JSON.stringify(stateOptions);
88
- options = `${options.substr(0, options.length - 1)}${isBoolean ? '' : ','}plugins: createStatePlugins(${JSON.stringify(stateConfigMap.get(entrypoint.entryName))})}`;
89
- plugins.push({
90
- name: PLUGIN_IDENTIFIER,
91
- options
92
- });
93
- }
94
-
95
- return {
78
+ modifyEntryRuntimePlugins({
96
79
  entrypoint,
97
80
  plugins
98
- };
99
- },
81
+ }) {
82
+ const stateOptions = stateConfigMap.get(entrypoint.entryName);
100
83
 
101
- validateSchema() {
102
- return PLUGIN_SCHEMAS['@modern-js/plugin-state'];
103
- },
84
+ if (stateOptions) {
85
+ const isBoolean = typeof stateOptions === 'boolean';
86
+ let options = isBoolean ? '{}' : JSON.stringify(stateOptions);
87
+ options = `${options.substr(0, options.length - 1)}${isBoolean ? '' : ','}plugins: createStatePlugins(${JSON.stringify(stateConfigMap.get(entrypoint.entryName))})}`;
88
+ plugins.push({
89
+ name: PLUGIN_IDENTIFIER,
90
+ options
91
+ });
92
+ }
104
93
 
105
- addRuntimeExports() {
106
- pluginsExportsUtils.addExport(`export { default as state } from '${stateModulePath}'`);
107
- }
94
+ return {
95
+ entrypoint,
96
+ plugins
97
+ };
98
+ },
108
99
 
109
- };
110
- }, {
111
- name: '@modern-js/plugin-state',
112
- required: ['@modern-js/runtime']
113
- });
114
- export default index;
100
+ validateSchema() {
101
+ return PLUGIN_SCHEMAS['@modern-js/plugin-state'];
102
+ },
103
+
104
+ addRuntimeExports() {
105
+ pluginsExportsUtils.addExport(`export { default as state } from '${stateModulePath}'`);
106
+ }
107
+
108
+ };
109
+ }
110
+ }));
@@ -4,64 +4,66 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
4
4
 
5
5
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
6
 
7
- // eslint-disable-next-line filenames/match-exported
8
7
  import { useContext } from 'react';
9
- import { createPlugin, RuntimeReactContext } from '@modern-js/runtime-core';
8
+ import { RuntimeReactContext } from '@modern-js/runtime-core';
10
9
  import { createStore } from '@modern-js-reduck/store';
11
10
  import { Provider } from '@modern-js-reduck/react';
12
11
  import hoistNonReactStatics from 'hoist-non-react-statics';
13
12
  import { jsx as _jsx } from "react/jsx-runtime";
14
13
 
15
- const state = config => createPlugin(() => ({
16
- hoc({
17
- App
18
- }, next) {
19
- const getStateApp = props => {
20
- // eslint-disable-next-line react-hooks/rules-of-hooks
21
- const context = useContext(RuntimeReactContext);
22
- return /*#__PURE__*/_jsx(Provider, {
23
- store: context.store,
24
- config: config,
25
- children: /*#__PURE__*/_jsx(App, _objectSpread({}, props))
26
- });
27
- };
14
+ const state = config => ({
15
+ name: '@modern-js/plugin-state',
16
+ setup: () => {
17
+ return {
18
+ hoc({
19
+ App
20
+ }, next) {
21
+ const getStateApp = props => {
22
+ // eslint-disable-next-line react-hooks/rules-of-hooks
23
+ const context = useContext(RuntimeReactContext);
24
+ return /*#__PURE__*/_jsx(Provider, {
25
+ store: context.store,
26
+ config: config,
27
+ children: /*#__PURE__*/_jsx(App, _objectSpread({}, props))
28
+ });
29
+ };
28
30
 
29
- return next({
30
- App: hoistNonReactStatics(getStateApp, App)
31
- });
32
- },
31
+ return next({
32
+ App: hoistNonReactStatics(getStateApp, App)
33
+ });
34
+ },
33
35
 
34
- init({
35
- context
36
- }, next) {
37
- const storeConfig = config || {};
36
+ init({
37
+ context
38
+ }, next) {
39
+ const storeConfig = config || {};
38
40
 
39
- if (typeof window !== 'undefined') {
40
- var _window, _window$_SSR_DATA, _window$_SSR_DATA$dat;
41
+ if (typeof window !== 'undefined') {
42
+ var _window, _window$_SSR_DATA, _window$_SSR_DATA$dat;
41
43
 
42
- storeConfig.initialState = storeConfig.initialState || ((_window = window) === null || _window === void 0 ? void 0 : (_window$_SSR_DATA = _window._SSR_DATA) === null || _window$_SSR_DATA === void 0 ? void 0 : (_window$_SSR_DATA$dat = _window$_SSR_DATA.data) === null || _window$_SSR_DATA$dat === void 0 ? void 0 : _window$_SSR_DATA$dat.storeState) || {};
43
- }
44
+ storeConfig.initialState = storeConfig.initialState || ((_window = window) === null || _window === void 0 ? void 0 : (_window$_SSR_DATA = _window._SSR_DATA) === null || _window$_SSR_DATA === void 0 ? void 0 : (_window$_SSR_DATA$dat = _window$_SSR_DATA.data) === null || _window$_SSR_DATA$dat === void 0 ? void 0 : _window$_SSR_DATA$dat.storeState) || {};
45
+ }
44
46
 
45
- context.store = createStore(storeConfig);
46
- next({
47
- context
48
- });
49
- },
47
+ context.store = createStore(storeConfig);
48
+ next({
49
+ context
50
+ });
51
+ },
50
52
 
51
- pickContext({
52
- context,
53
- pickedContext
54
- }, next) {
55
- return next({
56
- context,
57
- pickedContext: _objectSpread(_objectSpread({}, pickedContext), {}, {
58
- store: context.store
59
- })
60
- });
61
- }
53
+ pickContext({
54
+ context,
55
+ pickedContext
56
+ }, next) {
57
+ return next({
58
+ context,
59
+ pickedContext: _objectSpread(_objectSpread({}, pickedContext), {}, {
60
+ store: context.store
61
+ })
62
+ });
63
+ }
62
64
 
63
- }), {
64
- name: '@modern-js/plugin-state'
65
+ };
66
+ }
65
67
  });
66
68
 
67
69
  export default state;
@@ -9,69 +9,68 @@ var _path = _interopRequireDefault(require("path"));
9
9
 
10
10
  var _utils = require("@modern-js/utils");
11
11
 
12
- var _core = require("@modern-js/core");
13
-
14
12
  require("../types");
15
13
 
16
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
15
 
18
16
  const PLUGIN_IDENTIFIER = 'state';
19
- const index = (0, _core.createPlugin)(() => {
20
- const stateConfigMap = new Map();
21
- let pluginsExportsUtils;
22
-
23
- const stateModulePath = _path.default.resolve(__dirname, '../../../../');
24
-
25
- return {
26
- config() {
27
- // eslint-disable-next-line react-hooks/rules-of-hooks
28
- const appContext = (0, _core.useAppContext)();
29
- pluginsExportsUtils = (0, _utils.createRuntimeExportsUtils)(appContext.internalDirectory, 'plugins');
30
- return {
31
- source: {
32
- alias: {
33
- '@modern-js/runtime/plugins': pluginsExportsUtils.getPath()
17
+
18
+ var _default = () => ({
19
+ name: '@modern-js/plugin-state',
20
+ required: ['@modern-js/runtime'],
21
+ setup: api => {
22
+ const stateConfigMap = new Map();
23
+ let pluginsExportsUtils;
24
+
25
+ const stateModulePath = _path.default.resolve(__dirname, '../../../../');
26
+
27
+ return {
28
+ config() {
29
+ const appContext = api.useAppContext();
30
+ pluginsExportsUtils = (0, _utils.createRuntimeExportsUtils)(appContext.internalDirectory, 'plugins');
31
+ return {
32
+ source: {
33
+ alias: {
34
+ '@modern-js/runtime/plugins': pluginsExportsUtils.getPath()
35
+ }
34
36
  }
35
- }
36
- };
37
- },
38
-
39
- modifyEntryImports({
40
- entrypoint,
41
- imports
42
- }) {
43
- var _getEntryOptions;
44
-
45
- const {
46
- entryName
47
- } = entrypoint; // eslint-disable-next-line react-hooks/rules-of-hooks
48
-
49
- const userConfig = (0, _core.useResolvedConfigContext)(); // eslint-disable-next-line react-hooks/rules-of-hooks
50
-
51
- const {
52
- packageName
53
- } = (0, _core.useAppContext)();
54
- const stateConfig = (_getEntryOptions = (0, _utils.getEntryOptions)(entryName, userConfig.runtime, userConfig.runtimeByEntries, packageName)) === null || _getEntryOptions === void 0 ? void 0 : _getEntryOptions.state;
55
- stateConfigMap.set(entryName, stateConfig);
56
-
57
- const getEnabledPlugins = () => {
58
- const internalPlugins = ['immer', 'effects', 'autoActions', 'devtools'];
59
- return internalPlugins.filter(name => stateConfig[name] !== false);
60
- };
61
-
62
- if (stateConfig) {
63
- imports.push({
64
- value: '@modern-js/runtime/plugins',
65
- specifiers: [{
66
- imported: PLUGIN_IDENTIFIER
67
- }]
68
- });
69
- imports.push({
70
- value: '@modern-js/runtime/model',
71
- specifiers: getEnabledPlugins().map(imported => ({
72
- imported
73
- })),
74
- initialize: `
37
+ };
38
+ },
39
+
40
+ modifyEntryImports({
41
+ entrypoint,
42
+ imports
43
+ }) {
44
+ var _getEntryOptions;
45
+
46
+ const {
47
+ entryName
48
+ } = entrypoint;
49
+ const userConfig = api.useResolvedConfigContext();
50
+ const {
51
+ packageName
52
+ } = api.useAppContext();
53
+ const stateConfig = (_getEntryOptions = (0, _utils.getEntryOptions)(entryName, userConfig.runtime, userConfig.runtimeByEntries, packageName)) === null || _getEntryOptions === void 0 ? void 0 : _getEntryOptions.state;
54
+ stateConfigMap.set(entryName, stateConfig);
55
+
56
+ const getEnabledPlugins = () => {
57
+ const internalPlugins = ['immer', 'effects', 'autoActions', 'devtools'];
58
+ return internalPlugins.filter(name => stateConfig[name] !== false);
59
+ };
60
+
61
+ if (stateConfig) {
62
+ imports.push({
63
+ value: '@modern-js/runtime/plugins',
64
+ specifiers: [{
65
+ imported: PLUGIN_IDENTIFIER
66
+ }]
67
+ });
68
+ imports.push({
69
+ value: '@modern-js/runtime/model',
70
+ specifiers: getEnabledPlugins().map(imported => ({
71
+ imported
72
+ })),
73
+ initialize: `
75
74
  const createStatePlugins = (config) => {
76
75
  const plugins = [];
77
76
 
@@ -82,49 +81,47 @@ const index = (0, _core.createPlugin)(() => {
82
81
  return plugins;
83
82
  }
84
83
  `
85
- });
86
- }
84
+ });
85
+ }
87
86
 
88
- return {
89
- entrypoint,
90
- imports
91
- };
92
- },
93
-
94
- modifyEntryRuntimePlugins({
95
- entrypoint,
96
- plugins
97
- }) {
98
- const stateOptions = stateConfigMap.get(entrypoint.entryName);
99
-
100
- if (stateOptions) {
101
- const isBoolean = typeof stateOptions === 'boolean';
102
- let options = isBoolean ? '{}' : JSON.stringify(stateOptions);
103
- options = `${options.substr(0, options.length - 1)}${isBoolean ? '' : ','}plugins: createStatePlugins(${JSON.stringify(stateConfigMap.get(entrypoint.entryName))})}`;
104
- plugins.push({
105
- name: PLUGIN_IDENTIFIER,
106
- options
107
- });
108
- }
87
+ return {
88
+ entrypoint,
89
+ imports
90
+ };
91
+ },
109
92
 
110
- return {
93
+ modifyEntryRuntimePlugins({
111
94
  entrypoint,
112
95
  plugins
113
- };
114
- },
96
+ }) {
97
+ const stateOptions = stateConfigMap.get(entrypoint.entryName);
98
+
99
+ if (stateOptions) {
100
+ const isBoolean = typeof stateOptions === 'boolean';
101
+ let options = isBoolean ? '{}' : JSON.stringify(stateOptions);
102
+ options = `${options.substr(0, options.length - 1)}${isBoolean ? '' : ','}plugins: createStatePlugins(${JSON.stringify(stateConfigMap.get(entrypoint.entryName))})}`;
103
+ plugins.push({
104
+ name: PLUGIN_IDENTIFIER,
105
+ options
106
+ });
107
+ }
115
108
 
116
- validateSchema() {
117
- return _utils.PLUGIN_SCHEMAS['@modern-js/plugin-state'];
118
- },
109
+ return {
110
+ entrypoint,
111
+ plugins
112
+ };
113
+ },
119
114
 
120
- addRuntimeExports() {
121
- pluginsExportsUtils.addExport(`export { default as state } from '${stateModulePath}'`);
122
- }
115
+ validateSchema() {
116
+ return _utils.PLUGIN_SCHEMAS['@modern-js/plugin-state'];
117
+ },
123
118
 
124
- };
125
- }, {
126
- name: '@modern-js/plugin-state',
127
- required: ['@modern-js/runtime']
119
+ addRuntimeExports() {
120
+ pluginsExportsUtils.addExport(`export { default as state } from '${stateModulePath}'`);
121
+ }
122
+
123
+ };
124
+ }
128
125
  });
129
- var _default = index;
126
+
130
127
  exports.default = _default;
@@ -40,56 +40,59 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
40
40
 
41
41
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
42
42
 
43
- const state = config => (0, _runtimeCore.createPlugin)(() => ({
44
- hoc({
45
- App
46
- }, next) {
47
- const getStateApp = props => {
48
- // eslint-disable-next-line react-hooks/rules-of-hooks
49
- const context = (0, _react.useContext)(_runtimeCore.RuntimeReactContext);
50
- return /*#__PURE__*/(0, _jsxRuntime.jsx)(_react2.Provider, {
51
- store: context.store,
52
- config: config,
53
- children: /*#__PURE__*/(0, _jsxRuntime.jsx)(App, _objectSpread({}, props))
54
- });
55
- };
56
-
57
- return next({
58
- App: (0, _hoistNonReactStatics.default)(getStateApp, App)
59
- });
60
- },
61
-
62
- init({
63
- context
64
- }, next) {
65
- const storeConfig = config || {};
66
-
67
- if (typeof window !== 'undefined') {
68
- var _window, _window$_SSR_DATA, _window$_SSR_DATA$dat;
43
+ const state = config => ({
44
+ name: '@modern-js/plugin-state',
45
+ setup: () => {
46
+ return {
47
+ hoc({
48
+ App
49
+ }, next) {
50
+ const getStateApp = props => {
51
+ // eslint-disable-next-line react-hooks/rules-of-hooks
52
+ const context = (0, _react.useContext)(_runtimeCore.RuntimeReactContext);
53
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)(_react2.Provider, {
54
+ store: context.store,
55
+ config: config,
56
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(App, _objectSpread({}, props))
57
+ });
58
+ };
59
+
60
+ return next({
61
+ App: (0, _hoistNonReactStatics.default)(getStateApp, App)
62
+ });
63
+ },
64
+
65
+ init({
66
+ context
67
+ }, next) {
68
+ const storeConfig = config || {};
69
+
70
+ if (typeof window !== 'undefined') {
71
+ var _window, _window$_SSR_DATA, _window$_SSR_DATA$dat;
72
+
73
+ storeConfig.initialState = storeConfig.initialState || ((_window = window) === null || _window === void 0 ? void 0 : (_window$_SSR_DATA = _window._SSR_DATA) === null || _window$_SSR_DATA === void 0 ? void 0 : (_window$_SSR_DATA$dat = _window$_SSR_DATA.data) === null || _window$_SSR_DATA$dat === void 0 ? void 0 : _window$_SSR_DATA$dat.storeState) || {};
74
+ }
75
+
76
+ context.store = (0, _store.createStore)(storeConfig);
77
+ next({
78
+ context
79
+ });
80
+ },
81
+
82
+ pickContext({
83
+ context,
84
+ pickedContext
85
+ }, next) {
86
+ return next({
87
+ context,
88
+ pickedContext: _objectSpread(_objectSpread({}, pickedContext), {}, {
89
+ store: context.store
90
+ })
91
+ });
92
+ }
69
93
 
70
- storeConfig.initialState = storeConfig.initialState || ((_window = window) === null || _window === void 0 ? void 0 : (_window$_SSR_DATA = _window._SSR_DATA) === null || _window$_SSR_DATA === void 0 ? void 0 : (_window$_SSR_DATA$dat = _window$_SSR_DATA.data) === null || _window$_SSR_DATA$dat === void 0 ? void 0 : _window$_SSR_DATA$dat.storeState) || {};
71
- }
72
-
73
- context.store = (0, _store.createStore)(storeConfig);
74
- next({
75
- context
76
- });
77
- },
78
-
79
- pickContext({
80
- context,
81
- pickedContext
82
- }, next) {
83
- return next({
84
- context,
85
- pickedContext: _objectSpread(_objectSpread({}, pickedContext), {}, {
86
- store: context.store
87
- })
88
- });
94
+ };
89
95
  }
90
-
91
- }), {
92
- name: '@modern-js/plugin-state'
93
96
  });
94
97
 
95
98
  var _default = state;