@dgui/react-native 1.0.0 → 1.1.0-beta.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.
@@ -5,7 +5,7 @@ const NativeCarousel_1 = require("../../../../Generics/NativeCarousel");
5
5
  const NativeGateway_1 = require("../../../../Generics/NativeGateway");
6
6
  const react_shared_1 = require("@dgui/react-shared");
7
7
  const react_1 = require("react");
8
- const Scene = ({ tabId, drawerId }) => {
8
+ const Scene = ({ drawerId, tabId }) => {
9
9
  const { tabs } = (0, react_1.useContext)(react_shared_1.TabContext);
10
10
  const { swipe = true } = tabs[tabId];
11
11
  const gatewayId = (0, react_1.useMemo)(() => {
@@ -8,34 +8,8 @@ const NativeCarousel_1 = require("../../../../Generics/NativeCarousel");
8
8
  const Scene_1 = __importDefault(require("./Scene"));
9
9
  const react_shared_1 = require("@dgui/react-shared");
10
10
  const react_1 = require("react");
11
- const Context = ({ drawerId, tabIndex: givenTabIndex, onSelectTab }) => {
11
+ const Context = ({ drawerId }) => {
12
12
  const { selectTab, tabIndex } = (0, react_1.useContext)(react_shared_1.TabIndexContext);
13
- (0, react_1.useEffect)(() => {
14
- const safeIndex = Number.isSafeInteger(givenTabIndex) &&
15
- Number(givenTabIndex);
16
- if (safeIndex) {
17
- selectTab((currentIndex) => {
18
- if (safeIndex === currentIndex) {
19
- return currentIndex;
20
- }
21
- else {
22
- return safeIndex;
23
- }
24
- });
25
- }
26
- }, [
27
- givenTabIndex,
28
- selectTab
29
- ]);
30
- const handleSelectTab = (0, react_1.useCallback)((index) => {
31
- selectTab(index);
32
- if (onSelectTab) {
33
- onSelectTab(index);
34
- }
35
- }, [
36
- onSelectTab,
37
- selectTab
38
- ]);
39
13
  const { tabOrder } = (0, react_1.useContext)(react_shared_1.TabContext);
40
14
  const tabs = (0, react_1.useMemo)(() => {
41
15
  return tabOrder.map((tab) => {
@@ -45,7 +19,7 @@ const Context = ({ drawerId, tabIndex: givenTabIndex, onSelectTab }) => {
45
19
  drawerId,
46
20
  tabOrder
47
21
  ]);
48
- return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: handleSelectTab, swipe: false, tabIndex: tabIndex, children: tabs }));
22
+ return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: selectTab, swipe: false, tabIndex: tabIndex, children: tabs }));
49
23
  };
50
24
  Context.displayName = 'NativeDrawerTabsSceneContext';
51
25
  exports.default = (0, react_1.memo)(Context);
@@ -11,11 +11,11 @@ const react_shared_1 = require("@dgui/react-shared");
11
11
  const react_1 = require("react");
12
12
  const Scene = ({ drawerId }) => {
13
13
  const { drawers } = (0, react_1.useContext)(react_shared_1.DrawerContext);
14
- const { swipe = true, tabId } = drawers[drawerId];
14
+ const { swipe = true, tabs } = drawers[drawerId];
15
15
  const gatewayId = (0, react_1.useMemo)(() => {
16
16
  return `drawer-${drawerId}`;
17
17
  }, []);
18
- return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeHorse, { swipe: swipe, children: tabId ?
18
+ return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeHorse, { swipe: swipe, children: tabs ?
19
19
  ((0, jsx_runtime_1.jsx)(Context_1.default, { drawerId: drawerId })) :
20
20
  ((0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayDest, { gatewayId: gatewayId })) }));
21
21
  };
@@ -8,34 +8,8 @@ const NativeCarousel_1 = require("../../../Generics/NativeCarousel");
8
8
  const Scene_1 = __importDefault(require("./Scene"));
9
9
  const react_shared_1 = require("@dgui/react-shared");
10
10
  const react_1 = require("react");
11
- const Drawers = ({ tabIndex: givenDrawerIndex, onSelectTab: onSelectDrawer }) => {
12
- const { selectDrawer, drawerIndex } = (0, react_1.useContext)(react_shared_1.DrawerIndexContext);
13
- (0, react_1.useEffect)(() => {
14
- const safeIndex = Number.isSafeInteger(givenDrawerIndex) &&
15
- Number(givenDrawerIndex);
16
- if (safeIndex) {
17
- selectDrawer((currentIndex) => {
18
- if (safeIndex === currentIndex) {
19
- return currentIndex;
20
- }
21
- else {
22
- return safeIndex;
23
- }
24
- });
25
- }
26
- }, [
27
- givenDrawerIndex,
28
- selectDrawer
29
- ]);
30
- const handleSelectTab = (0, react_1.useCallback)((index) => {
31
- selectDrawer(index);
32
- if (onSelectDrawer) {
33
- onSelectDrawer(index);
34
- }
35
- }, [
36
- onSelectDrawer,
37
- selectDrawer
38
- ]);
11
+ const Drawers = () => {
12
+ const { drawerIndex, selectDrawer } = (0, react_1.useContext)(react_shared_1.DrawerIndexContext);
39
13
  const { drawerOrder } = (0, react_1.useContext)(react_shared_1.DrawerContext);
40
14
  const drawers = (0, react_1.useMemo)(() => {
41
15
  return drawerOrder.map((drawerId) => {
@@ -44,7 +18,7 @@ const Drawers = ({ tabIndex: givenDrawerIndex, onSelectTab: onSelectDrawer }) =>
44
18
  }, [
45
19
  drawerOrder
46
20
  ]);
47
- return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: handleSelectTab, tabIndex: drawerIndex, children: drawers }));
21
+ return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: selectDrawer, tabIndex: drawerIndex, children: drawers }));
48
22
  };
49
23
  Drawers.displayName = 'NativeDrawerTabs';
50
24
  exports.default = (0, react_1.memo)(Drawers);
@@ -1,7 +1,4 @@
1
1
  import { type FunctionComponent, type PropsWithChildren } from 'react';
2
2
  declare const Drawers: FunctionComponent<DrawersProps>;
3
3
  export default Drawers;
4
- export type DrawersProps = PropsWithChildren<{
5
- readonly drawerIndex?: number;
6
- readonly onSelectDrawer?: (drawerIndex: number) => void;
7
- }>;
4
+ export type DrawersProps = PropsWithChildren<{}>;
@@ -9,14 +9,11 @@ const Tabs_1 = __importDefault(require("./Tabs"));
9
9
  const react_native_shared_1 = require("@dgui/react-native-shared");
10
10
  const react_shared_1 = require("@dgui/react-shared");
11
11
  const react_1 = require("react");
12
- const Drawers = ({ children, drawerIndex, onSelectDrawer }) => {
12
+ const Drawers = ({ children }) => {
13
13
  const { drawerOpen } = (0, react_1.useContext)(react_shared_1.DrawerToggleContext);
14
14
  const appBar = (0, react_1.useMemo)(() => {
15
- return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayDest, { gatewayId: 'ReactNativeDigestDrawerBar' }), (0, jsx_runtime_1.jsx)(Tabs_1.default, { onSelectTab: onSelectDrawer, tabIndex: drawerIndex })] }));
16
- }, [
17
- drawerIndex,
18
- onSelectDrawer
19
- ]);
15
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayDest, { gatewayId: 'ReactNativeDigestDrawerBar' }), (0, jsx_runtime_1.jsx)(Tabs_1.default, {})] }));
16
+ }, []);
20
17
  return ((0, jsx_runtime_1.jsx)(react_native_shared_1.NativeBaseDrawers, { drawerContent: appBar, open: drawerOpen, children: children }));
21
18
  };
22
19
  Drawers.displayName = 'NativeDrawers';
@@ -17,7 +17,7 @@ const react_shared_1 = require("@dgui/react-shared");
17
17
  const react_1 = require("react");
18
18
  const NativeTab = (_a) => {
19
19
  var { children } = _a, props = __rest(_a, ["children"]);
20
- const { tabId, gatewayId } = (0, react_1.useMemo)(() => {
20
+ const { gatewayId, tabId } = (0, react_1.useMemo)(() => {
21
21
  return {
22
22
  gatewayId: `tab-${props.tabId}`,
23
23
  tabId: props.tabId
@@ -8,34 +8,8 @@ const NativeCarousel_1 = require("../../Generics/NativeCarousel");
8
8
  const Scene_1 = __importDefault(require("./Scene"));
9
9
  const react_shared_1 = require("@dgui/react-shared");
10
10
  const react_1 = require("react");
11
- const Tabs = ({ tabIndex: givenTabIndex, onSelectTab }) => {
11
+ const Tabs = () => {
12
12
  const { selectTab, tabIndex } = (0, react_1.useContext)(react_shared_1.TabIndexContext);
13
- (0, react_1.useEffect)(() => {
14
- const safeIndex = Number.isSafeInteger(givenTabIndex) &&
15
- Number(givenTabIndex);
16
- if (safeIndex) {
17
- selectTab((currentIndex) => {
18
- if (safeIndex === currentIndex) {
19
- return currentIndex;
20
- }
21
- else {
22
- return safeIndex;
23
- }
24
- });
25
- }
26
- }, [
27
- givenTabIndex,
28
- selectTab
29
- ]);
30
- const handleSelectTab = (0, react_1.useCallback)((index) => {
31
- selectTab(index);
32
- if (onSelectTab) {
33
- onSelectTab(index);
34
- }
35
- }, [
36
- onSelectTab,
37
- selectTab
38
- ]);
39
13
  const { tabOrder } = (0, react_1.useContext)(react_shared_1.TabContext);
40
14
  const tabs = (0, react_1.useMemo)(() => {
41
15
  const orderedTabs = tabOrder.map((tab) => {
@@ -45,6 +19,6 @@ const Tabs = ({ tabIndex: givenTabIndex, onSelectTab }) => {
45
19
  }, [
46
20
  tabOrder
47
21
  ]);
48
- return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: handleSelectTab, tabIndex: tabIndex, children: tabs }));
22
+ return ((0, jsx_runtime_1.jsx)(NativeCarousel_1.NativeCarousel, { onSelectTab: selectTab, tabIndex: tabIndex, children: tabs }));
49
23
  };
50
24
  exports.default = (0, react_1.memo)(Tabs);
@@ -1,4 +1,5 @@
1
+ import { type ProvidersProps as BaseProvidersProps } from '@dgui/react-shared';
1
2
  import { type FunctionComponent, type PropsWithChildren } from 'react';
2
3
  declare const Providers: FunctionComponent<ProvidersProps>;
3
4
  export default Providers;
4
- export type ProvidersProps = PropsWithChildren<{}>;
5
+ export type ProvidersProps = BaseProvidersProps & PropsWithChildren<{}>;
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const jsx_runtime_1 = require("react/jsx-runtime");
4
4
  const NativeGateway_1 = require("../Generics/NativeGateway");
5
5
  const react_shared_1 = require("@dgui/react-shared");
6
- const Providers = ({ children }) => {
7
- return ((0, jsx_runtime_1.jsx)(react_shared_1.Providers, { children: (0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayProvider, { children: children }) }));
6
+ const Providers = ({ children, drawerIndex, drawerOpen, onDrawerToggle, onSelectDrawer, onSelectTab, tabIndex }) => {
7
+ return ((0, jsx_runtime_1.jsx)(react_shared_1.Providers, { drawerIndex: drawerIndex, drawerOpen: drawerOpen, onDrawerToggle: onDrawerToggle, onSelectDrawer: onSelectDrawer, onSelectTab: onSelectTab, tabIndex: tabIndex, children: (0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayProvider, { children: children }) }));
8
8
  };
9
9
  Providers.displayName = 'NativeProviders';
10
10
  exports.default = Providers;
@@ -14,8 +14,8 @@ const styles = react_native_1.StyleSheet.create({
14
14
  zIndex: 1
15
15
  }
16
16
  });
17
- const ReactNativeDigest = ({ children, drawerIndex, onSelectDrawer, onSelectTab, tabIndex }) => {
18
- return ((0, jsx_runtime_1.jsxs)(Providers_1.default, { children: [(0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayDest, { gatewayId: 'ReactNativeDigestAppBar', style: styles.appbar }), (0, jsx_runtime_1.jsx)(Drawers_1.default, { drawerIndex: drawerIndex, onSelectDrawer: onSelectDrawer, children: (0, jsx_runtime_1.jsx)(Tabs_1.default, { onSelectTab: onSelectTab, tabIndex: tabIndex }) }), children] }));
17
+ const ReactNativeDigest = ({ children, drawerIndex, drawerOpen, onDrawerToggle, onSelectDrawer, onSelectTab, tabIndex }) => {
18
+ return ((0, jsx_runtime_1.jsxs)(Providers_1.default, { drawerIndex: drawerIndex, drawerOpen: drawerOpen, onDrawerToggle: onDrawerToggle, onSelectDrawer: onSelectDrawer, onSelectTab: onSelectTab, tabIndex: tabIndex, children: [(0, jsx_runtime_1.jsx)(NativeGateway_1.NativeGatewayDest, { gatewayId: 'ReactNativeDigestAppBar', style: styles.appbar }), (0, jsx_runtime_1.jsx)(Drawers_1.default, { children: (0, jsx_runtime_1.jsx)(Tabs_1.default, {}) }), children] }));
19
19
  };
20
20
  ReactNativeDigest.displayName = 'ReactNativeDigest';
21
21
  exports.default = ReactNativeDigest;
package/dist/Types.d.ts CHANGED
@@ -1,10 +1,6 @@
1
- import { type ReactNativeDigestDrawer, type ReactNativeDigestTab } from '.';
2
- import { type DigestProps, type DrawerType, type TabType } from '@dgui/react-shared';
3
- import { type PropsWithChildren, type ReactElement } from 'react';
4
- export type ReactNativeDigestProps = DigestProps & {
5
- children: Array<ReactElement<typeof ReactNativeDigestDrawer>> | Array<ReactElement<typeof ReactNativeDigestTab>> | ReactElement<typeof ReactNativeDigestDrawer> | ReactElement<typeof ReactNativeDigestTab>;
6
- };
7
- export type ReactNativeDigestAppBarProps = PropsWithChildren<{}>;
8
- export type ReactNativeDigestDrawerProps = DrawerType & PropsWithChildren<{}>;
9
- export type ReactNativeDigestDrawerBarProps = PropsWithChildren<{}>;
10
- export type ReactNativeDigestTabProps = PropsWithChildren<{}> & TabType;
1
+ import { type ReactDigestAppBarProps, type ReactDigestDrawerBarProps, type ReactDigestDrawerProps, type ReactDigestProps, type ReactDigestTabProps } from '@dgui/react-shared';
2
+ export type ReactNativeDigestProps = ReactDigestProps;
3
+ export type ReactNativeDigestAppBarProps = ReactDigestAppBarProps;
4
+ export type ReactNativeDigestDrawerProps = ReactDigestDrawerProps;
5
+ export type ReactNativeDigestDrawerBarProps = ReactDigestDrawerBarProps;
6
+ export type ReactNativeDigestTabProps = ReactDigestTabProps;
package/dist/index.d.ts CHANGED
@@ -4,4 +4,4 @@ export { default as ReactNativeDigestDrawerBar } from './Components/NativeDrawer
4
4
  export { default as ReactNativeDigestTab } from './Components/NativeTab';
5
5
  export { default as ReactNativeDigest } from './ReactNativeDigest';
6
6
  export * from './Types';
7
- export { DrawerContext, type DrawerContextProps, DrawerIndexContext, type DrawerIndexContextProps, DrawerToggleContext, type DrawerToggleContextProps, TabContext, type TabContextProps, TabIndexContext, type TabIndexContextProps } from '@dgui/react-shared';
7
+ export * from '@dgui/react-shared';
package/dist/index.js CHANGED
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.TabIndexContext = exports.TabContext = exports.DrawerToggleContext = exports.DrawerIndexContext = exports.DrawerContext = exports.ReactNativeDigest = exports.ReactNativeDigestTab = exports.ReactNativeDigestDrawerBar = exports.ReactNativeDigestDrawer = exports.ReactNativeDigestAppBar = void 0;
20
+ exports.ReactNativeDigest = exports.ReactNativeDigestTab = exports.ReactNativeDigestDrawerBar = exports.ReactNativeDigestDrawer = exports.ReactNativeDigestAppBar = void 0;
21
21
  var NativeAppBar_1 = require("./Components/NativeAppBar");
22
22
  Object.defineProperty(exports, "ReactNativeDigestAppBar", { enumerable: true, get: function () { return __importDefault(NativeAppBar_1).default; } });
23
23
  var NativeDrawer_1 = require("./Components/NativeDrawer");
@@ -29,9 +29,4 @@ Object.defineProperty(exports, "ReactNativeDigestTab", { enumerable: true, get:
29
29
  var ReactNativeDigest_1 = require("./ReactNativeDigest");
30
30
  Object.defineProperty(exports, "ReactNativeDigest", { enumerable: true, get: function () { return __importDefault(ReactNativeDigest_1).default; } });
31
31
  __exportStar(require("./Types"), exports);
32
- var react_shared_1 = require("@dgui/react-shared");
33
- Object.defineProperty(exports, "DrawerContext", { enumerable: true, get: function () { return react_shared_1.DrawerContext; } });
34
- Object.defineProperty(exports, "DrawerIndexContext", { enumerable: true, get: function () { return react_shared_1.DrawerIndexContext; } });
35
- Object.defineProperty(exports, "DrawerToggleContext", { enumerable: true, get: function () { return react_shared_1.DrawerToggleContext; } });
36
- Object.defineProperty(exports, "TabContext", { enumerable: true, get: function () { return react_shared_1.TabContext; } });
37
- Object.defineProperty(exports, "TabIndexContext", { enumerable: true, get: function () { return react_shared_1.TabIndexContext; } });
32
+ __exportStar(require("@dgui/react-shared"), exports);
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@dgui/react-native",
3
3
  "title": "Digested React GUI Native Components",
4
4
  "license": "LGPL-3.0-or-later",
5
- "version": "1.0.0",
5
+ "version": "1.1.0-beta.1",
6
6
  "private": false,
7
7
  "description": "Native Components for a boilerplate React GUI",
8
8
  "author": "wallzero @wallzeroblog (http://wallzero.com)",
@@ -39,40 +39,39 @@
39
39
  "lint:es": "eslint --resolve-plugins-relative-to . 'src/**/*.[jt]s?(x)' --ignore-pattern 'src/**/*.(d.ts|json)'",
40
40
  "clean": "run-s clean:dist clean:node_modules",
41
41
  "clean:node_modules": "rimraf node_modules yarn.lock package-lock.json",
42
- "clean:dist": "rimraf dist",
43
- "set:version": "npm version --allow-same-version --no-commit-hooks --no-git-tag-version --no-workspaces-update $(npm --silent view $(node -p \"require('./package.json').name\") version)"
42
+ "clean:dist": "rimraf dist"
44
43
  },
45
44
  "devDependencies": {
46
- "@digest/eslint-config-jest": "^4.2.5",
47
- "@digest/eslint-config-react": "^4.2.5",
48
- "@digest/eslint-config-typescript": "^4.2.5",
49
- "@digest/jest-junit": "^4.2.5",
50
- "@digest/jest-react": "^4.2.5",
51
- "@digest/jest-typescript": "^4.2.5",
52
- "@digest/typescript": "^4.2.5",
53
- "@types/jest": "^29.5.3",
54
- "@types/react": "^18.2.17",
55
- "@types/react-native": "^0.72.2",
56
- "@types/react-test-renderer": "^18.0.0",
45
+ "@digest/eslint-config-jest": "^4.3.0",
46
+ "@digest/eslint-config-react": "^4.3.0",
47
+ "@digest/eslint-config-typescript": "^4.3.0",
48
+ "@digest/jest-junit": "^4.3.0",
49
+ "@digest/jest-react": "^4.3.0",
50
+ "@digest/jest-typescript": "^4.3.0",
51
+ "@digest/typescript": "^4.3.0",
52
+ "@types/jest": "^29.5.12",
53
+ "@types/react": "^18.2.55",
54
+ "@types/react-native": "^0.73.0",
55
+ "@types/react-test-renderer": "^18.0.7",
57
56
  "cross-env": "^7.0.3",
58
- "jest-environment-jsdom": "^29.6.2",
57
+ "jest-environment-jsdom": "^29.7.0",
59
58
  "jest-environment-jsdom-global": "^4.0.0",
60
59
  "npm-run-all": "^4.1.5",
61
60
  "react": "^18.2.0",
62
- "react-native": "^0.72.3",
63
- "react-native-pager-view": "^7.0.0-rc.0",
64
- "react-native-reanimated": "^3.4.1",
61
+ "react-native": "^0.73.4",
62
+ "react-native-pager-view": "^7.0.0-rc.1",
63
+ "react-native-reanimated": "^3.7.0",
65
64
  "react-test-renderer": "^18.2.0",
66
- "rimraf": "^5.0.1"
65
+ "rimraf": "^5.0.5"
67
66
  },
68
67
  "dependencies": {
69
- "@dgui/react-native-shared": "^1.0.0",
70
- "@dgui/react-shared": "^1.0.0"
68
+ "@dgui/react-native-shared": "^0.8.0",
69
+ "@dgui/react-shared": "^0.8.0"
71
70
  },
72
71
  "peerDependencies": {
73
72
  "react": "^16.0.0 || ^17.0.0 || ^18.0.0",
74
- "react-native": "^0.72.0",
75
- "react-native-pager-view": "^6.0.0 || ^7.0.0-rc.0",
73
+ "react-native": "^0.73.0",
74
+ "react-native-pager-view": "^6.0.0 || ^7.0.0-rc.1",
76
75
  "react-native-reanimated": "^2.0.0 || ^3.0.0"
77
76
  },
78
77
  "keywords": [
@@ -83,5 +82,5 @@
83
82
  "react-native",
84
83
  "typescript"
85
84
  ],
86
- "gitHead": "ac0d0964d66c9c11f50b625d5ca5aec4e20bb72a"
85
+ "gitHead": "29925392dfd790c7844dcfea551b2ecb640c089e"
87
86
  }