App.tsx 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /**
  2. * Copyright © 2014-2025 PDF Technologies, Inc. All Rights Reserved.
  3. *
  4. * THIS SOURCE CODE AND ANY ACCOMPANYING DOCUMENTATION ARE PROTECTED BY INTERNATIONAL COPYRIGHT LAW
  5. * AND MAY NOT BE RESOLD OR REDISTRIBUTED. USAGE IS BOUND TO THE ComPDFKit LICENSE AGREEMENT.
  6. * UNAUTHORIZED REPRODUCTION OR DISTRIBUTION IS SUBJECT TO CIVIL AND CRIMINAL PENALTIES.
  7. * This notice may not be removed from this file.
  8. */
  9. import React, { Component } from 'react';
  10. import { Image, Platform, TouchableOpacity } from 'react-native';
  11. import { ComPDFKit } from '@compdfkit_pdf_sdk/react_native';
  12. import { NavigationContainer } from '@react-navigation/native';
  13. import { createNativeStackNavigator } from '@react-navigation/native-stack';
  14. import RNFS from 'react-native-fs';
  15. import HomeScreen from './src/screens/HomeScreen';
  16. import CPDFReaderViewExampleScreen from './src/CPDFReaderViewExample';
  17. import SettingScreen from './src/screens/SettingScreen';
  18. import CPDFReaderViewControllerExampleScreen from './src/CPDFReaderViewControllerExample';
  19. import CPDFAnnotationsExampleScreen from './src/CPDFAnnotationsExample';
  20. import CPDFSecurityExampleScreen from './src/CPDFSecurityExample';
  21. import CPDFPagesExampleScreen from './src/CPDFPagesExample';
  22. var androidLicense = "c4r34cNxld6pdUSsM2EgGQ9purMEZN7JuumHbNx9w+OJ6lYqF7WRYAFV0jvA5CEEX7J1+wGrF68mo8YP3qL5b6lmS60TMw2/wJ+TPtmeKkJMRMaiQ2nF2pwSevBj2HIHbnTLfr2btYHL/TRKFbfG0SUp/tZVjUwOC91rcrlaLkThWpc13/3SOi/34uHyjQszJ6PmDeg8X+qxfNheOBX/JZofPOjKpWpAAXXKT9kgtbZKKc6VAmMPAdRth7FnJjPieXkHkvW3fX2kNcgX6cb8IBnu/7Q3C4776P6IVIQKlDItMGNJIV7IPMADRnsLMqdC9FZcF3mV0laocg8qlFuKdmu0lH1oY17eVN2TRW5amzrVRSqpTOyx2LGvW1Ilra90nzlp2dEBHH+rU3Jo93jy94eWecFWMwgKBD5sABvhJFteiZTpP6NufkmmJm5UhS1bbWwQ3416ecpKs8D9TAlLLO+rbIocuxdoPE2dxWFYLq6zF8kJV3z7dKYtAwQKdoQiS08ryGXVZybCx2GjZp97I7zNemiorRWKQUrxpNk0vCLwL1yz7NzjlB6YQ8UxvmTkX/GU7T7Ubg9LoyZuVo4tLHLplMSlHIcA4guqZL7JbQ6/jomhcJGFpGo+X7tbrCvMTnbvjZoxJRlcNN1+9x100WEfF4A2XbJZEjcpxV9tk1rTt+jS8dkX803ij16yHI1THSycP2aKkWjgDAsAUt98KL+h4U+jgXH+NDKksS1nHNjVoJYvPaW7TLcBzT0GegIgNKELjvoahi+wfYUt79velJ1uEBhEcnvnIjlShtHdqKbE/lMbb2sG0lJnFUhViYIpkjXvy5b9ucuZfz1pm7f173QY75AXVUGgMkMI0XuV2tjDFnThFHtTgDnaOzHyyOwRiOuiM74ieBmwFqkOo4SQtUrUWPDK459l8FoqAa8XlJoWZXcbU1OotvnT9I1MMGTsC2l+b6sDxoJ4wc1wj9IhAmx7tmXnQyD/0q8NOKUk9E1AtfrYSdkTjCzdEI1HZ08LcyYnRNJNARTHNh8okrNDwA4seKyLl/XIfxmIx7IaLGx0VavXDAus9AAd+knf5we5iXWY7SJO2ZrxRJgotLWE/jY7Pg8FofBwr9sBt/VEJDcb1pbHKvag2rGKlyAigV4KkFoi+kJdO9xKXMBDKAZnsA==";
  23. var iosLicense = "pK3jYP2WpjMMxnh3h6rfCYYfGmC+UBVo0gUMVTUPFJAOnn7n2KlSDYYFoROfARAO5cco1M72URpb87XQVVvV+sI/mzReM6Sbl78n89xVI/wacDVcn9lVGZH6rKg5q/f+17rHUH1JQCEilQFUxvoer4kuymdeME6Ux+CsXiD9U3GqMAwDAuvCazhwWWYdZSeQEo/KzTL1/ZbF6AdfEFP9K7Gk2q7RcuwX0WaH22At997+WnwH2EpwfXQGtUSVYO7LGMn7kCs+m+CU6hMmG0S9YRz9oTm7jAk99+y3RaJXkIETmZj5OWTIPVGjNuDKhNASTddpPc68mSFrBmizUniO1Wu0lH1oY17eVN2TRW5amzrVRSqpTOyx2LGvW1Ilra90nzlp2dEBHH+rU3Jo93jy94eWecFWMwgKBD5sABvhJFteiZTpP6NufkmmJm5UhS1bbWwQ3416ecpKs8D9TAlLLO+rbIocuxdoPE2dxWFYLq6zF8kJV3z7dKYtAwQKdoQiS08ryGXVZybCx2GjZp97I7zNemiorRWKQUrxpNk0vCLwL1yz7NzjlB6YQ8UxvmTkX/GU7T7Ubg9LoyZuVo4tLHLplMSlHIcA4guqZL7JbQ6/jomhcJGFpGo+X7tbrCvMTnbvjZoxJRlcNN1+9x100WEfF4A2XbJZEjcpxV9tk1rTt+jS8dkX803ij16yHI1THSycP2aKkWjgDAsAUt98KJfMhDVdBtIWgg2xXbvUdZdPA+MDYbxOt/kTCqmTNMCBL4i4/N1Dqxvl8Me6vei5LeecqlBZbInEmA+87xsmNJ+d5MxP+EIac9+yqaQ0YIYE4wnAzUkp/0SfANyT5mw/EcTvSxlFmdNPXMpAygK4Q1n/S3QjnpAZJCMhg6hUDQi1TPHJO1WCWdGg50xVd4e9cvnNaN633IvvL9TFBGBu4xx7FHUdlWeiIkfzaiP8Y+58lPpC7x05cs28uc/hwXiZGx2KvdF+199pSLVUIrj85m/7+SqS01Dz6t4RwV7CZ/nQ4KOAyptnYBkUNyyOx7Q7j3CUXnxUN5HL5Yhqq2FFaD/HTTVwcjun3kBQWAiUV1AWYY/lHA5ERHysKmgUkhba8MlQCnsGD2o4KGBScfS0N2kQ3Eg6AtwSRVmQZHRUOuFrRzDh6w9DqXG/2btsFdOOfQ==";
  24. const Stack = createNativeStackNavigator();
  25. type Props = {
  26. navigation: any;
  27. };
  28. export default class App extends Component<Props> {
  29. constructor(props: Props) {
  30. super(props)
  31. this.initialize()
  32. }
  33. async initialize() {
  34. const fontDir = await copyAssetsFolderToStorage('extraFonts');
  35. console.log('ComPDFKitRN', "fontDir:", fontDir)
  36. await ComPDFKit.setImportFontDir(fontDir, true);
  37. // Online certification, Fill in your online license
  38. // Returns true if initialization is successful, otherwise returns false.
  39. // var result = await ComPDFKit.initialize('Njc4NzI1OGQ3ZGQyZQ==', 'Njc4NzI1OGQ3ZGQyZQ==')
  40. // console.log("ComPDFKitRN", "initialize:", result)
  41. // Offline authentication, Fill in your offline license
  42. var result = await ComPDFKit.init_(Platform.OS == "android" ? androidLicense : iosLicense)
  43. console.log("ComPDFKitRN", "init_:", result)
  44. }
  45. render() {
  46. return (
  47. <NavigationContainer>
  48. <Stack.Navigator>
  49. <Stack.Screen name="Home" component={HomeScreen} options={({ navigation }) => ({
  50. title: 'ComPDFKit PDF SDK for ReactNative',
  51. headerStyle: {
  52. backgroundColor: '#FAFCFF',
  53. },
  54. headerTitleStyle: { fontSize: 16 },
  55. headerRight: () => (
  56. <TouchableOpacity onPress={() => navigation.navigate('Settings')}>
  57. <Image source={require('./assets/ic_setting.png')} style={{ width: 24, height: 24 }} />
  58. </TouchableOpacity>
  59. ),
  60. })} />
  61. <Stack.Screen name='Settings' component={SettingScreen} options={{
  62. headerStyle: {
  63. backgroundColor: '#FAFCFF',
  64. },
  65. }}/>
  66. <Stack.Screen name='CPDFReaderViewExample' component={CPDFReaderViewExampleScreen} options={{
  67. headerShadowVisible: false,
  68. headerTitleStyle: { fontSize: 16 },
  69. headerStyle: {
  70. backgroundColor: '#FAFCFF',
  71. },
  72. }} />
  73. <Stack.Screen
  74. name='CPDFReaderViewControllerExample'
  75. component={CPDFReaderViewControllerExampleScreen}
  76. options={() => ({
  77. headerShown: false,
  78. })}
  79. />
  80. <Stack.Screen
  81. name='CPDFAnnotationsExample'
  82. component={CPDFAnnotationsExampleScreen}
  83. options={() => ({
  84. headerShown: false,
  85. })}
  86. />
  87. <Stack.Screen
  88. name='CPDFSecurityExample'
  89. component={CPDFSecurityExampleScreen}
  90. options={() => ({
  91. headerShown: false,
  92. })}
  93. />
  94. <Stack.Screen
  95. name='CPDFPagesExample'
  96. component={CPDFPagesExampleScreen}
  97. options={() => ({
  98. headerShown: false,
  99. })}
  100. />
  101. </Stack.Navigator>
  102. </NavigationContainer>
  103. );
  104. }
  105. }
  106. const copyAssetsFolderToStorage = async (folderName : string) => {
  107. try {
  108. // Define the target storage directory
  109. const targetDir = `${RNFS.DocumentDirectoryPath}/${folderName}`;
  110. // Ensure the target directory exists
  111. const dirExists = await RNFS.exists(targetDir);
  112. if (!dirExists) {
  113. await RNFS.mkdir(targetDir);
  114. }
  115. if (Platform.OS === 'android') {
  116. // Android: Read all files in the folder
  117. const files = await RNFS.readDirAssets(folderName); // Returns an array of file objects
  118. for (const file of files) {
  119. if (file.isFile()) {
  120. const fileContents = await RNFS.readFileAssets(`${folderName}/${file.name}`, 'base64'); // Read file from assets
  121. const targetFilePath = `${targetDir}/${file.name}`;
  122. await RNFS.writeFile(targetFilePath, fileContents, 'base64'); // Write to target
  123. }
  124. }
  125. } else if (Platform.OS === 'ios') {
  126. // iOS: Copy files directly
  127. const files = await RNFS.readDir(`${RNFS.MainBundlePath}/${folderName}`);
  128. for (const file of files) {
  129. if (file.isFile()) {
  130. const sourcePath = file.path;
  131. const targetFilePath = `${targetDir}/${file.name}`;
  132. if(await RNFS.exists(targetFilePath)){
  133. continue;
  134. }
  135. await RNFS.copyFile(sourcePath, targetFilePath);
  136. }
  137. }
  138. } else {
  139. throw new Error('Unsupported platform');
  140. }
  141. return targetDir; // Return the target directory path
  142. } catch (error) {
  143. console.error('Error copying folder:', error);
  144. throw new Error('Failed to copy folder to storage.');
  145. }
  146. };