react-native-salespanda 0.2.0 → 0.3.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.
- package/lib/module/SalespandaApp.js +56 -0
- package/lib/module/SalespandaApp.js.map +1 -0
- package/lib/module/config/SalespandaConfig.js +68 -0
- package/lib/module/config/SalespandaConfig.js.map +1 -0
- package/lib/module/index.js +27 -6
- package/lib/module/index.js.map +1 -1
- package/lib/module/navigation/AppNavigator.js +9 -2
- package/lib/module/navigation/AppNavigator.js.map +1 -1
- package/lib/module/navigation/BottomTabNavigator.js +82 -73
- package/lib/module/navigation/BottomTabNavigator.js.map +1 -1
- package/lib/module/navigation/DrawerNavigator.js +7 -1
- package/lib/module/navigation/DrawerNavigator.js.map +1 -1
- package/lib/module/screens/HomeScreen.js +70 -111
- package/lib/module/screens/HomeScreen.js.map +1 -1
- package/lib/typescript/src/SalespandaApp.d.ts +39 -0
- package/lib/typescript/src/SalespandaApp.d.ts.map +1 -0
- package/lib/typescript/src/config/SalespandaConfig.d.ts +52 -0
- package/lib/typescript/src/config/SalespandaConfig.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +17 -1
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/navigation/AppNavigator.d.ts.map +1 -1
- package/lib/typescript/src/navigation/BottomTabNavigator.d.ts.map +1 -1
- package/lib/typescript/src/navigation/DrawerNavigator.d.ts.map +1 -1
- package/lib/typescript/src/screens/HomeScreen.d.ts.map +1 -1
- package/package.json +18 -11
- package/src/SalespandaApp.tsx +92 -0
- package/src/config/SalespandaConfig.ts +105 -0
- package/src/index.tsx +34 -6
- package/src/navigation/AppNavigator.tsx +5 -2
- package/src/navigation/BottomTabNavigator.tsx +54 -50
- package/src/navigation/DrawerNavigator.tsx +5 -1
- package/src/screens/HomeScreen.tsx +41 -87
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
import React from 'react';
|
|
4
|
-
import { View, Text, StyleSheet, TouchableOpacity, ScrollView
|
|
4
|
+
import { View, Text, StyleSheet, TouchableOpacity, ScrollView } from 'react-native';
|
|
5
5
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
6
|
const MenuItem = ({
|
|
7
7
|
title,
|
|
@@ -24,125 +24,84 @@ const MenuItem = ({
|
|
|
24
24
|
});
|
|
25
25
|
};
|
|
26
26
|
export default function HomeScreen() {
|
|
27
|
-
return /*#__PURE__*/_jsxs(
|
|
28
|
-
style: styles.
|
|
27
|
+
return /*#__PURE__*/_jsxs(ScrollView, {
|
|
28
|
+
style: styles.scrollView,
|
|
29
29
|
children: [/*#__PURE__*/_jsxs(View, {
|
|
30
|
-
style: styles.
|
|
31
|
-
children: [/*#__PURE__*/_jsx(TouchableOpacity, {
|
|
32
|
-
style: styles.menuButton,
|
|
33
|
-
children: /*#__PURE__*/_jsx(Text, {
|
|
34
|
-
style: styles.menuIcon,
|
|
35
|
-
children: "\u2630"
|
|
36
|
-
})
|
|
37
|
-
}), /*#__PURE__*/_jsx(Text, {
|
|
38
|
-
style: styles.headerTitle,
|
|
39
|
-
children: "Home Page"
|
|
40
|
-
}), /*#__PURE__*/_jsx(Image, {
|
|
41
|
-
source: {
|
|
42
|
-
uri: 'https://via.placeholder.com/40x40'
|
|
43
|
-
},
|
|
44
|
-
style: styles.logo
|
|
45
|
-
})]
|
|
46
|
-
}), /*#__PURE__*/_jsxs(ScrollView, {
|
|
47
|
-
style: styles.scrollView,
|
|
30
|
+
style: styles.banner,
|
|
48
31
|
children: [/*#__PURE__*/_jsxs(View, {
|
|
49
|
-
style: styles.
|
|
50
|
-
children: [/*#__PURE__*/_jsxs(
|
|
51
|
-
style: styles.
|
|
52
|
-
children: [
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
style: styles.
|
|
57
|
-
children:
|
|
58
|
-
style: styles.startButtonText,
|
|
59
|
-
children: "Start Sharing \u2192"
|
|
60
|
-
})
|
|
61
|
-
})]
|
|
62
|
-
}), /*#__PURE__*/_jsx(View, {
|
|
63
|
-
style: styles.whatsappIconContainer,
|
|
64
|
-
children: /*#__PURE__*/_jsx(View, {
|
|
65
|
-
style: styles.whatsappIcon,
|
|
66
|
-
children: /*#__PURE__*/_jsx(Text, {
|
|
67
|
-
style: styles.whatsappText,
|
|
68
|
-
children: "\uD83D\uDCF1"
|
|
69
|
-
})
|
|
32
|
+
style: styles.bannerContent,
|
|
33
|
+
children: [/*#__PURE__*/_jsxs(Text, {
|
|
34
|
+
style: styles.bannerText,
|
|
35
|
+
children: ["Build strong relationships,", '\n', "improve relations & productivity", '\n', "by having conversations on", '\n', "WhatsAppppppppp."]
|
|
36
|
+
}), /*#__PURE__*/_jsx(TouchableOpacity, {
|
|
37
|
+
style: styles.startButton,
|
|
38
|
+
children: /*#__PURE__*/_jsx(Text, {
|
|
39
|
+
style: styles.startButtonText,
|
|
40
|
+
children: "Start Sharing \u2192"
|
|
70
41
|
})
|
|
71
42
|
})]
|
|
72
|
-
}), /*#__PURE__*/
|
|
73
|
-
style: styles.
|
|
74
|
-
children:
|
|
75
|
-
style:
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
})
|
|
81
|
-
})
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
43
|
+
}), /*#__PURE__*/_jsx(View, {
|
|
44
|
+
style: styles.whatsappIconContainer,
|
|
45
|
+
children: /*#__PURE__*/_jsx(View, {
|
|
46
|
+
style: styles.whatsappIcon,
|
|
47
|
+
children: /*#__PURE__*/_jsx(Text, {
|
|
48
|
+
style: styles.whatsappText,
|
|
49
|
+
children: "\uD83D\uDCF1"
|
|
50
|
+
})
|
|
51
|
+
})
|
|
52
|
+
})]
|
|
53
|
+
}), /*#__PURE__*/_jsxs(View, {
|
|
54
|
+
style: styles.carouselIndicators,
|
|
55
|
+
children: [/*#__PURE__*/_jsx(View, {
|
|
56
|
+
style: [styles.indicator, styles.activeIndicator]
|
|
57
|
+
}), /*#__PURE__*/_jsx(View, {
|
|
58
|
+
style: styles.indicator
|
|
59
|
+
}), /*#__PURE__*/_jsx(View, {
|
|
60
|
+
style: styles.indicator
|
|
61
|
+
})]
|
|
62
|
+
}), /*#__PURE__*/_jsxs(View, {
|
|
63
|
+
style: styles.menuGrid,
|
|
64
|
+
children: [/*#__PURE__*/_jsx(MenuItem, {
|
|
65
|
+
title: "Content Library",
|
|
66
|
+
icon: "\uD83D\uDCDA"
|
|
67
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
68
|
+
title: "Buy Now",
|
|
69
|
+
icon: "\uD83D\uDED2"
|
|
70
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
71
|
+
title: "Quiz & Calculator",
|
|
72
|
+
icon: "\uD83E\uDDEE"
|
|
73
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
74
|
+
title: "Social Setup",
|
|
75
|
+
icon: "\uD83D\uDCE2"
|
|
76
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
77
|
+
title: "Microsite Setup",
|
|
78
|
+
icon: "\u2699\uFE0F"
|
|
79
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
80
|
+
title: "Proposal",
|
|
81
|
+
icon: "\uD83D\uDCCB"
|
|
82
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
83
|
+
title: "Email Campaign",
|
|
84
|
+
icon: "\uD83D\uDCE7"
|
|
85
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
86
|
+
title: "View Microsite",
|
|
87
|
+
icon: "\uD83C\uDFB5"
|
|
88
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
89
|
+
title: "Import Contact",
|
|
90
|
+
icon: "\uD83D\uDCC4"
|
|
91
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
92
|
+
title: "Poster Of The Week",
|
|
93
|
+
icon: "\uD83D\uDDBC\uFE0F"
|
|
94
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
95
|
+
title: "DigiCard",
|
|
96
|
+
icon: "\uD83D\uDC64"
|
|
97
|
+
}), /*#__PURE__*/_jsx(MenuItem, {
|
|
98
|
+
title: "Help Videos",
|
|
99
|
+
icon: "\u2753"
|
|
111
100
|
})]
|
|
112
101
|
})]
|
|
113
102
|
});
|
|
114
103
|
}
|
|
115
104
|
const styles = StyleSheet.create({
|
|
116
|
-
container: {
|
|
117
|
-
flex: 1,
|
|
118
|
-
backgroundColor: '#fff'
|
|
119
|
-
},
|
|
120
|
-
header: {
|
|
121
|
-
flexDirection: 'row',
|
|
122
|
-
alignItems: 'center',
|
|
123
|
-
justifyContent: 'space-between',
|
|
124
|
-
padding: 16,
|
|
125
|
-
backgroundColor: '#fff',
|
|
126
|
-
borderBottomWidth: 1,
|
|
127
|
-
borderBottomColor: '#e0e0e0'
|
|
128
|
-
},
|
|
129
|
-
menuButton: {
|
|
130
|
-
padding: 4
|
|
131
|
-
},
|
|
132
|
-
menuIcon: {
|
|
133
|
-
fontSize: 24,
|
|
134
|
-
color: '#333'
|
|
135
|
-
},
|
|
136
|
-
headerTitle: {
|
|
137
|
-
fontSize: 18,
|
|
138
|
-
fontWeight: '600',
|
|
139
|
-
color: '#333'
|
|
140
|
-
},
|
|
141
|
-
logo: {
|
|
142
|
-
width: 40,
|
|
143
|
-
height: 40,
|
|
144
|
-
borderRadius: 20
|
|
145
|
-
},
|
|
146
105
|
scrollView: {
|
|
147
106
|
flex: 1
|
|
148
107
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","View","Text","StyleSheet","TouchableOpacity","ScrollView","
|
|
1
|
+
{"version":3,"names":["React","View","Text","StyleSheet","TouchableOpacity","ScrollView","jsx","_jsx","jsxs","_jsxs","MenuItem","title","icon","onPress","style","styles","menuItem","children","iconContainer","iconText","menuItemText","HomeScreen","scrollView","banner","bannerContent","bannerText","startButton","startButtonText","whatsappIconContainer","whatsappIcon","whatsappText","carouselIndicators","indicator","activeIndicator","menuGrid","create","flex","backgroundColor","margin","borderRadius","padding","flexDirection","justifyContent","alignItems","minHeight","color","fontSize","lineHeight","marginBottom","borderWidth","borderColor","paddingVertical","paddingHorizontal","alignSelf","fontWeight","marginLeft","width","height","marginVertical","marginHorizontal","flexWrap","aspectRatio","shadowColor","shadowOffset","shadowOpacity","shadowRadius","elevation","textAlign"],"sourceRoot":"../../../src","sources":["screens/HomeScreen.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface SalespandaAppProps {
|
|
3
|
+
/**
|
|
4
|
+
* Custom navigation container ref for external navigation control
|
|
5
|
+
*/
|
|
6
|
+
navigationRef?: React.RefObject<any>;
|
|
7
|
+
/**
|
|
8
|
+
* Optional theme configuration
|
|
9
|
+
*/
|
|
10
|
+
theme?: {
|
|
11
|
+
primaryColor?: string;
|
|
12
|
+
backgroundColor?: string;
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* If true, the app will not render NavigationContainer
|
|
16
|
+
* (useful when embedding in an existing navigation structure)
|
|
17
|
+
*/
|
|
18
|
+
standalone?: boolean;
|
|
19
|
+
/**
|
|
20
|
+
* Callback when app is ready
|
|
21
|
+
*/
|
|
22
|
+
onReady?: () => void;
|
|
23
|
+
/**
|
|
24
|
+
* If true, uses drawer navigation (default), otherwise uses bottom tabs only
|
|
25
|
+
*/
|
|
26
|
+
useDrawer?: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* If false, will not wrap with GestureHandlerRootView
|
|
29
|
+
* Set to false if your app already has gesture handler imported at the entry point
|
|
30
|
+
* @default true
|
|
31
|
+
*/
|
|
32
|
+
wrapWithGestureHandler?: boolean;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Main Salespanda App Component
|
|
36
|
+
* Can be used as a standalone app or embedded in another React Native app
|
|
37
|
+
*/
|
|
38
|
+
export default function SalespandaApp({ navigationRef, theme, standalone, onReady, useDrawer, wrapWithGestureHandler, }?: SalespandaAppProps): import("react/jsx-runtime").JSX.Element;
|
|
39
|
+
//# sourceMappingURL=SalespandaApp.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SalespandaApp.d.ts","sourceRoot":"","sources":["../../../src/SalespandaApp.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAO1B,MAAM,WAAW,kBAAkB;IACjC;;OAEG;IACH,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAErC;;OAEG;IACH,KAAK,CAAC,EAAE;QACN,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC1B,CAAC;IAEF;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IAErB;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;;;OAIG;IACH,sBAAsB,CAAC,EAAE,OAAO,CAAC;CAClC;AAED;;;GAGG;AACH,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EACpC,aAAa,EACb,KAAK,EACL,UAAkB,EAClB,OAAO,EACP,SAAgB,EAChB,sBAA8B,GAC/B,GAAE,kBAAuB,2CAmCzB"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Salespanda SDK Configuration
|
|
3
|
+
*/
|
|
4
|
+
export interface SalespandaConfig {
|
|
5
|
+
/**
|
|
6
|
+
* Theme configuration
|
|
7
|
+
*/
|
|
8
|
+
theme?: {
|
|
9
|
+
primaryColor?: string;
|
|
10
|
+
secondaryColor?: string;
|
|
11
|
+
backgroundColor?: string;
|
|
12
|
+
textColor?: string;
|
|
13
|
+
accentColor?: string;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* API configuration
|
|
17
|
+
*/
|
|
18
|
+
api?: {
|
|
19
|
+
baseUrl?: string;
|
|
20
|
+
apiKey?: string;
|
|
21
|
+
timeout?: number;
|
|
22
|
+
};
|
|
23
|
+
/**
|
|
24
|
+
* Feature flags
|
|
25
|
+
*/
|
|
26
|
+
features?: {
|
|
27
|
+
enablePremium?: boolean;
|
|
28
|
+
enableNotifications?: boolean;
|
|
29
|
+
enableReports?: boolean;
|
|
30
|
+
enableDrawer?: boolean;
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Analytics configuration
|
|
34
|
+
*/
|
|
35
|
+
analytics?: {
|
|
36
|
+
enabled?: boolean;
|
|
37
|
+
trackingId?: string;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Initialize Salespanda SDK with custom configuration
|
|
42
|
+
*/
|
|
43
|
+
export declare function initializeSalespanda(config: SalespandaConfig): void;
|
|
44
|
+
/**
|
|
45
|
+
* Get current Salespanda configuration
|
|
46
|
+
*/
|
|
47
|
+
export declare function getSalespandaConfig(): SalespandaConfig;
|
|
48
|
+
/**
|
|
49
|
+
* Reset configuration to defaults
|
|
50
|
+
*/
|
|
51
|
+
export declare function resetSalespandaConfig(): void;
|
|
52
|
+
//# sourceMappingURL=SalespandaConfig.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SalespandaConfig.d.ts","sourceRoot":"","sources":["../../../../src/config/SalespandaConfig.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,gBAAgB;IAC/B;;OAEG;IACH,KAAK,CAAC,EAAE;QACN,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,CAAC;IAEF;;OAEG;IACH,GAAG,CAAC,EAAE;QACJ,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC;IAEF;;OAEG;IACH,QAAQ,CAAC,EAAE;QACT,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB,mBAAmB,CAAC,EAAE,OAAO,CAAC;QAC9B,aAAa,CAAC,EAAE,OAAO,CAAC;QACxB,YAAY,CAAC,EAAE,OAAO,CAAC;KACxB,CAAC;IAEF;;OAEG;IACH,SAAS,CAAC,EAAE;QACV,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;CACH;AAkBD;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI,CAanE;AAED;;GAEG;AACH,wBAAgB,mBAAmB,IAAI,gBAAgB,CAEtD;AAED;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,IAAI,CAgB5C"}
|
|
@@ -1,4 +1,20 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Salespanda SDK
|
|
3
|
+
*
|
|
4
|
+
* This SDK can be used in two ways:
|
|
5
|
+
*
|
|
6
|
+
* 1. As a complete standalone app:
|
|
7
|
+
* import SalespandaApp from 'react-native-salespanda';
|
|
8
|
+
* <SalespandaApp />
|
|
9
|
+
*
|
|
10
|
+
* 2. As individual components/screens in your app:
|
|
11
|
+
* import { HomeScreen, ProfileScreen } from 'react-native-salespanda';
|
|
12
|
+
*/
|
|
13
|
+
export { default } from './SalespandaApp';
|
|
14
|
+
export { default as SalespandaApp } from './SalespandaApp';
|
|
15
|
+
export type { SalespandaAppProps } from './SalespandaApp';
|
|
16
|
+
export { initializeSalespanda, getSalespandaConfig, resetSalespandaConfig, } from './config/SalespandaConfig';
|
|
17
|
+
export type { SalespandaConfig } from './config/SalespandaConfig';
|
|
2
18
|
export { default as AppNavigator } from './navigation/AppNavigator';
|
|
3
19
|
export { default as DrawerNavigator } from './navigation/DrawerNavigator';
|
|
4
20
|
export { default as BottomTabNavigator } from './navigation/BottomTabNavigator';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAK1D,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EACnB,qBAAqB,GACtB,MAAM,2BAA2B,CAAC;AACnC,YAAY,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAKlE,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAKhF,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAC/E,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AppNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/AppNavigator.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AppNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/AppNavigator.tsx"],"names":[],"mappings":"AAIA,MAAM,CAAC,OAAO,UAAU,YAAY,4CAQnC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BottomTabNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/BottomTabNavigator.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BottomTabNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/BottomTabNavigator.tsx"],"names":[],"mappings":"AAUA,MAAM,CAAC,OAAO,UAAU,kBAAkB,4CAyDzC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DrawerNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/DrawerNavigator.tsx"],"names":[],"mappings":"AA4IA,MAAM,CAAC,OAAO,UAAU,eAAe,
|
|
1
|
+
{"version":3,"file":"DrawerNavigator.d.ts","sourceRoot":"","sources":["../../../../src/navigation/DrawerNavigator.tsx"],"names":[],"mappings":"AA4IA,MAAM,CAAC,OAAO,UAAU,eAAe,4CAoCtC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HomeScreen.d.ts","sourceRoot":"","sources":["../../../../src/screens/HomeScreen.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"HomeScreen.d.ts","sourceRoot":"","sources":["../../../../src/screens/HomeScreen.tsx"],"names":[],"mappings":"AA0BA,MAAM,CAAC,OAAO,UAAU,UAAU,4CAkDjC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-salespanda",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "sdk",
|
|
5
5
|
"main": "./lib/module/index.js",
|
|
6
6
|
"types": "./lib/typescript/src/index.d.ts",
|
|
@@ -59,6 +59,7 @@
|
|
|
59
59
|
"registry": "https://registry.npmjs.org/"
|
|
60
60
|
},
|
|
61
61
|
"devDependencies": {
|
|
62
|
+
"@babel/core": "^7.28.5",
|
|
62
63
|
"@commitlint/config-conventional": "^19.8.1",
|
|
63
64
|
"@eslint/compat": "^1.3.2",
|
|
64
65
|
"@eslint/eslintrc": "^3.3.1",
|
|
@@ -67,9 +68,13 @@
|
|
|
67
68
|
"@react-native-community/cli": "20.0.1",
|
|
68
69
|
"@react-native/babel-preset": "0.81.1",
|
|
69
70
|
"@react-native/eslint-config": "^0.81.1",
|
|
71
|
+
"@react-navigation/bottom-tabs": "^7.8.2",
|
|
72
|
+
"@react-navigation/drawer": "^7.7.2",
|
|
73
|
+
"@react-navigation/native": "^7.1.19",
|
|
70
74
|
"@release-it/conventional-changelog": "^10.0.1",
|
|
71
75
|
"@types/jest": "^29.5.14",
|
|
72
76
|
"@types/react": "^19.1.0",
|
|
77
|
+
"babel-plugin-module-resolver": "^5.0.2",
|
|
73
78
|
"commitlint": "^19.8.1",
|
|
74
79
|
"del-cli": "^6.0.0",
|
|
75
80
|
"eslint": "^9.35.0",
|
|
@@ -80,13 +85,24 @@
|
|
|
80
85
|
"react": "19.1.0",
|
|
81
86
|
"react-native": "0.81.1",
|
|
82
87
|
"react-native-builder-bob": "^0.40.13",
|
|
88
|
+
"react-native-gesture-handler": "^2.29.1",
|
|
89
|
+
"react-native-reanimated": "^3.15.4",
|
|
90
|
+
"react-native-safe-area-context": "^5.6.2",
|
|
91
|
+
"react-native-screens": "^4.18.0",
|
|
83
92
|
"release-it": "^19.0.4",
|
|
84
93
|
"turbo": "^2.5.6",
|
|
85
94
|
"typescript": "^5.9.2"
|
|
86
95
|
},
|
|
87
96
|
"peerDependencies": {
|
|
97
|
+
"@react-navigation/bottom-tabs": ">=6.0.0",
|
|
98
|
+
"@react-navigation/drawer": ">=6.0.0",
|
|
99
|
+
"@react-navigation/native": ">=6.0.0",
|
|
88
100
|
"react": "*",
|
|
89
|
-
"react-native": "*"
|
|
101
|
+
"react-native": "*",
|
|
102
|
+
"react-native-gesture-handler": ">=2.0.0",
|
|
103
|
+
"react-native-reanimated": ">=3.0.0",
|
|
104
|
+
"react-native-safe-area-context": ">=4.0.0",
|
|
105
|
+
"react-native-screens": ">=3.0.0"
|
|
90
106
|
},
|
|
91
107
|
"workspaces": [
|
|
92
108
|
"example"
|
|
@@ -160,14 +176,5 @@
|
|
|
160
176
|
"languages": "kotlin-objc",
|
|
161
177
|
"type": "turbo-module",
|
|
162
178
|
"version": "0.54.8"
|
|
163
|
-
},
|
|
164
|
-
"dependencies": {
|
|
165
|
-
"@react-navigation/bottom-tabs": "^7.8.2",
|
|
166
|
-
"@react-navigation/drawer": "^7.7.2",
|
|
167
|
-
"@react-navigation/native": "^7.1.19",
|
|
168
|
-
"react-native-gesture-handler": "^2.29.1",
|
|
169
|
-
"react-native-reanimated": "^4.1.3",
|
|
170
|
-
"react-native-safe-area-context": "^5.6.2",
|
|
171
|
-
"react-native-screens": "^4.18.0"
|
|
172
179
|
}
|
|
173
180
|
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { NavigationContainer } from '@react-navigation/native';
|
|
3
|
+
import { GestureHandlerRootView } from 'react-native-gesture-handler';
|
|
4
|
+
import DrawerNavigator from './navigation/DrawerNavigator';
|
|
5
|
+
import BottomTabNavigator from './navigation/BottomTabNavigator';
|
|
6
|
+
import { SafeAreaProvider } from 'react-native-safe-area-context';
|
|
7
|
+
|
|
8
|
+
export interface SalespandaAppProps {
|
|
9
|
+
/**
|
|
10
|
+
* Custom navigation container ref for external navigation control
|
|
11
|
+
*/
|
|
12
|
+
navigationRef?: React.RefObject<any>;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Optional theme configuration
|
|
16
|
+
*/
|
|
17
|
+
theme?: {
|
|
18
|
+
primaryColor?: string;
|
|
19
|
+
backgroundColor?: string;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* If true, the app will not render NavigationContainer
|
|
24
|
+
* (useful when embedding in an existing navigation structure)
|
|
25
|
+
*/
|
|
26
|
+
standalone?: boolean;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Callback when app is ready
|
|
30
|
+
*/
|
|
31
|
+
onReady?: () => void;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* If true, uses drawer navigation (default), otherwise uses bottom tabs only
|
|
35
|
+
*/
|
|
36
|
+
useDrawer?: boolean;
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* If false, will not wrap with GestureHandlerRootView
|
|
40
|
+
* Set to false if your app already has gesture handler imported at the entry point
|
|
41
|
+
* @default true
|
|
42
|
+
*/
|
|
43
|
+
wrapWithGestureHandler?: boolean;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Main Salespanda App Component
|
|
48
|
+
* Can be used as a standalone app or embedded in another React Native app
|
|
49
|
+
*/
|
|
50
|
+
export default function SalespandaApp({
|
|
51
|
+
navigationRef,
|
|
52
|
+
theme,
|
|
53
|
+
standalone = false,
|
|
54
|
+
onReady,
|
|
55
|
+
useDrawer = true,
|
|
56
|
+
wrapWithGestureHandler = false,
|
|
57
|
+
}: SalespandaAppProps = {}) {
|
|
58
|
+
// TODO: Apply theme to app (future enhancement)
|
|
59
|
+
// Currently theme is managed through SalespandaConfig
|
|
60
|
+
void theme;
|
|
61
|
+
|
|
62
|
+
// Use drawer navigation by default, or bottom tabs only if specified
|
|
63
|
+
const AppContent = () =>
|
|
64
|
+
useDrawer ? <DrawerNavigator /> : <BottomTabNavigator />;
|
|
65
|
+
|
|
66
|
+
// If standalone mode, don't wrap with NavigationContainer
|
|
67
|
+
// (parent app will provide it)
|
|
68
|
+
if (standalone) {
|
|
69
|
+
return <AppContent />;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// Navigation content with SafeAreaProvider
|
|
73
|
+
const NavigationContent = (
|
|
74
|
+
<NavigationContainer ref={navigationRef} onReady={onReady}>
|
|
75
|
+
<SafeAreaProvider>
|
|
76
|
+
<AppContent />
|
|
77
|
+
</SafeAreaProvider>
|
|
78
|
+
</NavigationContainer>
|
|
79
|
+
);
|
|
80
|
+
|
|
81
|
+
// Wrap with GestureHandlerRootView only if requested
|
|
82
|
+
// (default is false since most apps already have gesture handler imported)
|
|
83
|
+
if (wrapWithGestureHandler) {
|
|
84
|
+
return (
|
|
85
|
+
<GestureHandlerRootView style={{ flex: 1 }}>
|
|
86
|
+
{NavigationContent}
|
|
87
|
+
</GestureHandlerRootView>
|
|
88
|
+
);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return NavigationContent;
|
|
92
|
+
}
|