added js code script for scrab image urls and content and create react native app for webview
This commit is contained in:
		
							parent
							
								
									cb0ec68fc2
								
							
						
					
					
						commit
						28802f8882
					
				
					 11 changed files with 2269 additions and 56 deletions
				
			
		
							
								
								
									
										3
									
								
								.idea/.gitignore
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.idea/.gitignore
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | |||
| # Default ignored files | ||||
| /shelf/ | ||||
| /workspace.xml | ||||
							
								
								
									
										329
									
								
								.idea/caches/deviceStreaming.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										329
									
								
								.idea/caches/deviceStreaming.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,329 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="DeviceStreaming"> | ||||
|     <option name="deviceSelectionList"> | ||||
|       <list> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="27" /> | ||||
|           <option name="brand" value="DOCOMO" /> | ||||
|           <option name="codename" value="F01L" /> | ||||
|           <option name="id" value="F01L" /> | ||||
|           <option name="manufacturer" value="FUJITSU" /> | ||||
|           <option name="name" value="F-01L" /> | ||||
|           <option name="screenDensity" value="360" /> | ||||
|           <option name="screenX" value="720" /> | ||||
|           <option name="screenY" value="1280" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="28" /> | ||||
|           <option name="brand" value="DOCOMO" /> | ||||
|           <option name="codename" value="SH-01L" /> | ||||
|           <option name="id" value="SH-01L" /> | ||||
|           <option name="manufacturer" value="SHARP" /> | ||||
|           <option name="name" value="AQUOS sense2 SH-01L" /> | ||||
|           <option name="screenDensity" value="480" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2160" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="Lenovo" /> | ||||
|           <option name="codename" value="TB370FU" /> | ||||
|           <option name="id" value="TB370FU" /> | ||||
|           <option name="manufacturer" value="Lenovo" /> | ||||
|           <option name="name" value="Tab P12" /> | ||||
|           <option name="screenDensity" value="340" /> | ||||
|           <option name="screenX" value="1840" /> | ||||
|           <option name="screenY" value="2944" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="31" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="a51" /> | ||||
|           <option name="id" value="a51" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy A51" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="akita" /> | ||||
|           <option name="id" value="akita" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 8a" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="b0q" /> | ||||
|           <option name="id" value="b0q" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy S22 Ultra" /> | ||||
|           <option name="screenDensity" value="600" /> | ||||
|           <option name="screenX" value="1440" /> | ||||
|           <option name="screenY" value="3088" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="32" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="bluejay" /> | ||||
|           <option name="id" value="bluejay" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 6a" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="caiman" /> | ||||
|           <option name="id" value="caiman" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 9 Pro" /> | ||||
|           <option name="screenDensity" value="360" /> | ||||
|           <option name="screenX" value="960" /> | ||||
|           <option name="screenY" value="2142" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="comet" /> | ||||
|           <option name="id" value="comet" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 9 Pro Fold" /> | ||||
|           <option name="screenDensity" value="390" /> | ||||
|           <option name="screenX" value="2076" /> | ||||
|           <option name="screenY" value="2152" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="29" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="crownqlteue" /> | ||||
|           <option name="id" value="crownqlteue" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy Note9" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="2220" /> | ||||
|           <option name="screenY" value="1080" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="dm3q" /> | ||||
|           <option name="id" value="dm3q" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy S23 Ultra" /> | ||||
|           <option name="screenDensity" value="600" /> | ||||
|           <option name="screenX" value="1440" /> | ||||
|           <option name="screenY" value="3088" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="e1q" /> | ||||
|           <option name="id" value="e1q" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy S24" /> | ||||
|           <option name="screenDensity" value="480" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2340" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="felix" /> | ||||
|           <option name="id" value="felix" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel Fold" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="2208" /> | ||||
|           <option name="screenY" value="1840" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="felix" /> | ||||
|           <option name="id" value="felix" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel Fold" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="2208" /> | ||||
|           <option name="screenY" value="1840" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="felix_camera" /> | ||||
|           <option name="id" value="felix_camera" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel Fold (Camera-enabled)" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="2208" /> | ||||
|           <option name="screenY" value="1840" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="gts8uwifi" /> | ||||
|           <option name="id" value="gts8uwifi" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy Tab S8 Ultra" /> | ||||
|           <option name="screenDensity" value="320" /> | ||||
|           <option name="screenX" value="1848" /> | ||||
|           <option name="screenY" value="2960" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="husky" /> | ||||
|           <option name="id" value="husky" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 8 Pro" /> | ||||
|           <option name="screenDensity" value="390" /> | ||||
|           <option name="screenX" value="1008" /> | ||||
|           <option name="screenY" value="2244" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="30" /> | ||||
|           <option name="brand" value="motorola" /> | ||||
|           <option name="codename" value="java" /> | ||||
|           <option name="id" value="java" /> | ||||
|           <option name="manufacturer" value="Motorola" /> | ||||
|           <option name="name" value="G20" /> | ||||
|           <option name="screenDensity" value="280" /> | ||||
|           <option name="screenX" value="720" /> | ||||
|           <option name="screenY" value="1600" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="komodo" /> | ||||
|           <option name="id" value="komodo" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 9 Pro XL" /> | ||||
|           <option name="screenDensity" value="360" /> | ||||
|           <option name="screenX" value="1008" /> | ||||
|           <option name="screenY" value="2244" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="lynx" /> | ||||
|           <option name="id" value="lynx" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 7a" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="31" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="oriole" /> | ||||
|           <option name="id" value="oriole" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 6" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="panther" /> | ||||
|           <option name="id" value="panther" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 7" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="q5q" /> | ||||
|           <option name="id" value="q5q" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy Z Fold5" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1812" /> | ||||
|           <option name="screenY" value="2176" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="samsung" /> | ||||
|           <option name="codename" value="q6q" /> | ||||
|           <option name="id" value="q6q" /> | ||||
|           <option name="manufacturer" value="Samsung" /> | ||||
|           <option name="name" value="Galaxy Z Fold6" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1856" /> | ||||
|           <option name="screenY" value="2160" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="30" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="r11" /> | ||||
|           <option name="id" value="r11" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel Watch" /> | ||||
|           <option name="screenDensity" value="320" /> | ||||
|           <option name="screenX" value="384" /> | ||||
|           <option name="screenY" value="384" /> | ||||
|           <option name="type" value="WEAR_OS" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="30" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="redfin" /> | ||||
|           <option name="id" value="redfin" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 5" /> | ||||
|           <option name="screenDensity" value="440" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2340" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="shiba" /> | ||||
|           <option name="id" value="shiba" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 8" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2400" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="33" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="tangorpro" /> | ||||
|           <option name="id" value="tangorpro" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel Tablet" /> | ||||
|           <option name="screenDensity" value="320" /> | ||||
|           <option name="screenX" value="1600" /> | ||||
|           <option name="screenY" value="2560" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|         <PersistentDeviceSelectionData> | ||||
|           <option name="api" value="34" /> | ||||
|           <option name="brand" value="google" /> | ||||
|           <option name="codename" value="tokay" /> | ||||
|           <option name="id" value="tokay" /> | ||||
|           <option name="manufacturer" value="Google" /> | ||||
|           <option name="name" value="Pixel 9" /> | ||||
|           <option name="screenDensity" value="420" /> | ||||
|           <option name="screenX" value="1080" /> | ||||
|           <option name="screenY" value="2424" /> | ||||
|         </PersistentDeviceSelectionData> | ||||
|       </list> | ||||
|     </option> | ||||
|   </component> | ||||
| </project> | ||||
							
								
								
									
										9
									
								
								.idea/fake-check-bd.iml
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								.idea/fake-check-bd.iml
									
										
									
										generated
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,9 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <module type="JAVA_MODULE" version="4"> | ||||
|   <component name="NewModuleRootManager" inherit-compiler-output="true"> | ||||
|     <exclude-output /> | ||||
|     <content url="file://$MODULE_DIR$" /> | ||||
|     <orderEntry type="inheritedJdk" /> | ||||
|     <orderEntry type="sourceFolder" forTests="false" /> | ||||
|   </component> | ||||
| </module> | ||||
							
								
								
									
										5
									
								
								.idea/misc.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.idea/misc.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| <project version="4"> | ||||
|   <component name="ProjectRootManager"> | ||||
|     <output url="file://$PROJECT_DIR$/out" /> | ||||
|   </component> | ||||
| </project> | ||||
							
								
								
									
										8
									
								
								.idea/modules.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								.idea/modules.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,8 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="ProjectModuleManager"> | ||||
|     <modules> | ||||
|       <module fileurl="file://$PROJECT_DIR$/.idea/fake-check-bd.iml" filepath="$PROJECT_DIR$/.idea/fake-check-bd.iml" /> | ||||
|     </modules> | ||||
|   </component> | ||||
| </project> | ||||
							
								
								
									
										6
									
								
								.idea/vcs.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								.idea/vcs.xml
									
										
									
										generated
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,6 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="VcsDirectoryMappings"> | ||||
|     <mapping directory="" vcs="Git" /> | ||||
|   </component> | ||||
| </project> | ||||
|  | @ -1,63 +1,143 @@ | |||
| import { Image, StyleSheet, Platform } from 'react-native'; | ||||
| 
 | ||||
| import { HelloWave } from '@/components/HelloWave'; | ||||
| import ParallaxScrollView from '@/components/ParallaxScrollView'; | ||||
| import { ThemedText } from '@/components/ThemedText'; | ||||
| import { ThemedView } from '@/components/ThemedView'; | ||||
| import { Image, StyleSheet, Platform } from "react-native"; | ||||
| import { WebView } from "react-native-webview"; | ||||
| import { useRef } from "react"; | ||||
| 
 | ||||
| export default function HomeScreen() { | ||||
|   const webviewRef = useRef(null); | ||||
| 
 | ||||
|   const injectedJavaScript = ` | ||||
|     function collectPostData(post) { | ||||
|       if (post.dataset.processed === "true") return; | ||||
|       const captionElement = post.querySelector("div.m div.m div[data-type='text'] div.native-text"); | ||||
|       let caption = captionElement ? captionElement.textContent.trim() : null; | ||||
| 
 | ||||
|       const imageElements = post.querySelectorAll("div.m.bg-s13 img"); | ||||
|       let imageURLs = []; | ||||
|       if (imageElements.length > 1) { | ||||
|         imageElements.forEach((imageElement) => { | ||||
|           if (imageElement.src) imageURLs.push(imageElement.src); | ||||
|         }); | ||||
|       } else if (imageElements.length === 1) { | ||||
|         const singleImageSrc = imageElements[0].src; | ||||
|         if (singleImageSrc) imageURLs.push(singleImageSrc); | ||||
|       } | ||||
|       console.log("Caption:", caption); | ||||
|       console.log("Image URLs:", imageURLs); | ||||
| 
 | ||||
|       post.dataset.processed = "true"; | ||||
| 
 | ||||
|       const button = document.createElement("button"); | ||||
|       button.textContent = "Check"; | ||||
|       button.innerHTML = button.textContent; | ||||
| 
 | ||||
|       button.style.position = "absolute"; | ||||
|       button.style.fontSize = "20px"; | ||||
|       button.style.right = "10px"; | ||||
|       button.style.bottom = "10px"; | ||||
|       button.style.background = "linear-gradient(135deg, #6a11cb, #2575fc)"; | ||||
|       button.style.color = "#fff"; | ||||
|       button.style.border = "none"; | ||||
|       button.style.padding = "12px 20px"; | ||||
|       button.style.borderRadius = "8px"; | ||||
|       button.style.cursor = "pointer"; | ||||
|       button.style.zIndex = 999999; | ||||
|       button.style.pointerEvents = "auto"; | ||||
|       button.style.display = "flex"; | ||||
|       button.style.justifyContent = "center"; | ||||
|       button.style.alignItems = "center"; | ||||
|       button.style.gap = "8px"; | ||||
| 
 | ||||
|       button.addEventListener("click", async () => { | ||||
|         button.disabled = true; | ||||
|         button.textContent = "Loading..."; | ||||
|         const seeMoreElement = post.querySelector("span[style*='color:#65676b']"); | ||||
|         if (seeMoreElement) { | ||||
|           handleSeeMoreClick(seeMoreElement, post, button); | ||||
|         } else { | ||||
|           collectDataImmediately(post, button); | ||||
|         } | ||||
|       }); | ||||
| 
 | ||||
|       if (caption && imageURLs.length > 0) { | ||||
|         post.style.position = "relative"; | ||||
|         post.appendChild(button); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     function collectDataImmediately(post, button) { | ||||
|       const captionElement = post.querySelector("div.m div.m div[data-type='text'] div.native-text"); | ||||
|       let caption = captionElement ? captionElement.textContent.trim() : null; | ||||
|       const imageElements = post.querySelectorAll("div.m img"); | ||||
|       let imageURLs = []; | ||||
|       imageElements.forEach((imageElement) => { | ||||
|         if (imageElement.src) imageURLs.push(imageElement.src); | ||||
|       }); | ||||
|         if(caption && imageURLs){ | ||||
|             alert("good"); | ||||
|             } | ||||
|       console.log("Caption:", caption); | ||||
|       console.log("Image URLs:", imageURLs); | ||||
| 
 | ||||
|       button.remove(); | ||||
|     } | ||||
| 
 | ||||
|     function handleSeeMoreClick(seeMoreElement, post, button) { | ||||
|       setTimeout(() => { | ||||
|         seeMoreElement.dispatchEvent(new PointerEvent("pointerdown", { bubbles: true })); | ||||
|         seeMoreElement.dispatchEvent(new PointerEvent("pointerup", { bubbles: true })); | ||||
|         seeMoreElement.click(); | ||||
| 
 | ||||
|         setTimeout(() => { | ||||
|           collectDataImmediately(post, button); | ||||
|         }, 1000); | ||||
|       }, 100); | ||||
|     } | ||||
| 
 | ||||
|     function handleMutations(mutationsList) { | ||||
|       mutationsList.forEach((mutation) => { | ||||
|         if (mutation.type === "childList" || mutation.type === "subtree") { | ||||
|           const posts = document.querySelectorAll("div.m.bg-s3"); | ||||
|           posts.forEach((post) => { | ||||
|             if (!post.querySelector("button")) { | ||||
|               collectPostData(post); | ||||
|             } | ||||
|           }); | ||||
|         } | ||||
|       }); | ||||
|     } | ||||
| 
 | ||||
|     const observer = new MutationObserver(handleMutations); | ||||
|     observer.observe(document.querySelector(".m"), { childList: true, subtree: true }); | ||||
| 
 | ||||
|     document.addEventListener("DOMContentLoaded", () => { | ||||
|       const posts = document.querySelectorAll("div.m.bg-s3"); | ||||
|       posts.forEach((post) => { | ||||
|         if (!post.dataset.processed) { | ||||
|           collectPostData(post); | ||||
|         } | ||||
|       }); | ||||
|     }); | ||||
|   `;
 | ||||
| 
 | ||||
|   return ( | ||||
|     <ParallaxScrollView | ||||
|       headerBackgroundColor={{ light: '#A1CEDC', dark: '#1D3D47' }} | ||||
|       headerImage={ | ||||
|         <Image | ||||
|           source={require('@/assets/images/partial-react-logo.png')} | ||||
|           style={styles.reactLogo} | ||||
|         /> | ||||
|       }> | ||||
|       <ThemedView style={styles.titleContainer}> | ||||
|         <ThemedText type="title">Welcome!</ThemedText> | ||||
|         <HelloWave /> | ||||
|       </ThemedView> | ||||
|       <ThemedView style={styles.stepContainer}> | ||||
|         <ThemedText type="subtitle">Step 1: Try it</ThemedText> | ||||
|         <ThemedText> | ||||
|           Edit <ThemedText type="defaultSemiBold">app/(tabs)/index.tsx</ThemedText> to see changes. | ||||
|           Press{' '} | ||||
|           <ThemedText type="defaultSemiBold"> | ||||
|             {Platform.select({ | ||||
|               ios: 'cmd + d', | ||||
|               android: 'cmd + m', | ||||
|               web: 'F12' | ||||
|             })} | ||||
|           </ThemedText>{' '} | ||||
|           to open developer tools. | ||||
|         </ThemedText> | ||||
|       </ThemedView> | ||||
|       <ThemedView style={styles.stepContainer}> | ||||
|         <ThemedText type="subtitle">Step 2: Explore</ThemedText> | ||||
|         <ThemedText> | ||||
|           Tap the Explore tab to learn more about what's included in this starter app. | ||||
|         </ThemedText> | ||||
|       </ThemedView> | ||||
|       <ThemedView style={styles.stepContainer}> | ||||
|         <ThemedText type="subtitle">Step 3: Get a fresh start</ThemedText> | ||||
|         <ThemedText> | ||||
|           When you're ready, run{' '} | ||||
|           <ThemedText type="defaultSemiBold">npm run reset-project</ThemedText> to get a fresh{' '} | ||||
|           <ThemedText type="defaultSemiBold">app</ThemedText> directory. This will move the current{' '} | ||||
|           <ThemedText type="defaultSemiBold">app</ThemedText> to{' '} | ||||
|           <ThemedText type="defaultSemiBold">app-example</ThemedText>. | ||||
|         </ThemedText> | ||||
|       </ThemedView> | ||||
|     </ParallaxScrollView> | ||||
|     <WebView | ||||
|       ref={webviewRef} | ||||
|       source={{ uri: "https://www.facebook.com" }} | ||||
|       injectedJavaScript={injectedJavaScript} | ||||
|       startInLoadingState={true} | ||||
|       onLoadEnd={() => { | ||||
|         if (webviewRef.current) { | ||||
|           webviewRef.current.injectJavaScript(injectedJavaScript); | ||||
|         } | ||||
|       }} | ||||
|     /> | ||||
|   ); | ||||
| } | ||||
| 
 | ||||
| const styles = StyleSheet.create({ | ||||
|   titleContainer: { | ||||
|     flexDirection: 'row', | ||||
|     alignItems: 'center', | ||||
|     flexDirection: "row", | ||||
|     alignItems: "center", | ||||
|     gap: 8, | ||||
|   }, | ||||
|   stepContainer: { | ||||
|  | @ -69,6 +149,6 @@ const styles = StyleSheet.create({ | |||
|     width: 290, | ||||
|     bottom: 0, | ||||
|     left: 0, | ||||
|     position: 'absolute', | ||||
|     position: "absolute", | ||||
|   }, | ||||
| }); | ||||
|  |  | |||
							
								
								
									
										35
									
								
								app/webview.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								app/webview.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| // app/webview.tsx
 | ||||
| import React, { useRef } from 'react'; | ||||
| import { WebView } from 'react-native-webview'; | ||||
| 
 | ||||
| const WebViewScreen = () => { | ||||
|   const webviewRef = useRef(null); | ||||
| 
 | ||||
|   const injectedJavaScript = ` | ||||
|     const filterPosts = () => { | ||||
|       const posts = document.querySelectorAll('div[data-testid="post_message"]'); | ||||
|       posts.forEach(post => { | ||||
|         if (post.innerText.includes('some keyword')) { | ||||
|           post.style.display = 'none'; // Hide post
 | ||||
|         } | ||||
|       }); | ||||
|     }; | ||||
|     filterPosts(); | ||||
|   `;
 | ||||
| 
 | ||||
|   return ( | ||||
|     <WebView | ||||
|       ref={webviewRef} | ||||
|       source={{ uri: 'https://www.facebook.com' }} | ||||
|       injectedJavaScript={injectedJavaScript} | ||||
|       startInLoadingState={true} | ||||
|       onLoadEnd={() => { | ||||
|         if (webviewRef.current) { | ||||
|           webviewRef.current.injectJavaScript(injectedJavaScript); | ||||
|         } | ||||
|       }} | ||||
|     /> | ||||
|   ); | ||||
| }; | ||||
| 
 | ||||
| export default WebViewScreen; | ||||
							
								
								
									
										36
									
								
								components/WebViewScreen.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								components/WebViewScreen.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | |||
| // WebViewScreen.tsx
 | ||||
| 
 | ||||
| import React, { useRef } from 'react'; | ||||
| import { WebView } from 'react-native-webview'; | ||||
| 
 | ||||
| const WebViewScreen = () => { | ||||
|   const webviewRef = useRef(null); | ||||
| 
 | ||||
|   const injectedJavaScript = ` | ||||
|     const filterPosts = () => { | ||||
|       const posts = document.querySelectorAll('div[data-testid="post_message"]'); | ||||
|       posts.forEach(post => { | ||||
|         if (post.innerText.includes('some keyword')) { | ||||
|           post.style.display = 'none'; // Hide post
 | ||||
|         } | ||||
|       }); | ||||
|     }; | ||||
|     filterPosts(); | ||||
|   `;
 | ||||
| 
 | ||||
|   return ( | ||||
|     <WebView | ||||
|       ref={webviewRef} | ||||
|       source={{ uri: 'https://www.facebook.com' }} | ||||
|       injectedJavaScript={injectedJavaScript} | ||||
|       startInLoadingState={true} | ||||
|       onLoadEnd={() => { | ||||
|         if (webviewRef.current) { | ||||
|           webviewRef.current.injectJavaScript(injectedJavaScript); | ||||
|         } | ||||
|       }} | ||||
|     /> | ||||
|   ); | ||||
| }; | ||||
| 
 | ||||
| export default WebViewScreen; | ||||
							
								
								
									
										1703
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										1703
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -38,7 +38,7 @@ | |||
|     "react-native-safe-area-context": "4.12.0", | ||||
|     "react-native-screens": "~4.1.0", | ||||
|     "react-native-web": "~0.19.13", | ||||
|     "react-native-webview": "13.12.5" | ||||
|     "react-native-webview": "^13.12.5" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@babel/core": "^7.25.2", | ||||
|  | @ -48,7 +48,8 @@ | |||
|     "jest": "^29.2.1", | ||||
|     "jest-expo": "~52.0.2", | ||||
|     "react-test-renderer": "18.3.1", | ||||
|     "typescript": "^5.3.3" | ||||
|     "typescript": "^5.3.3", | ||||
|     "@react-native-community/cli": "latest" | ||||
|   }, | ||||
|   "private": true | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 smfahim25
						smfahim25