Menu
Portfolio
Blog
Snippets
Login
Confirm
exit_to_app
Close
Entries
library_add
Utility(Event,Mouse): Log Movement X,Y
delete
Utility(txt): Basic Sentence Generator
delete
Utility(Event,Keyboard): Logger
delete
Utility(txt): Expanded Phrase Generator
delete
Scrape(General|Multi): Paginated Crawler
delete
Scrape(Sunbiz|Multi): Get Biz's By Zip
delete
Utility(Time): Test Load Speed
delete
Scrape(General|Single|NLP): Get Keyword Stats
delete
Scrape(General|Single): Get Text Near Links
delete
Utility(Event|Mouse): Press Down,Up, & Dragend
delete
Utility(Number): Between Range
delete
Utility(Event|Window): On Resize
delete
Scrape(Youtube|Single): Crawl Channel Videos
delete
Scrape(General|Multi): Tiny Link Crawler
delete
Utility(Time): Day of Week Report
delete
Utility(Number): Aspect Ratio Size Pairs
delete
Utility(Data): Sort Object Properties
delete
Scrape(General|Single): RiTa Sentences & Words
delete
Scrape(General|Single): Investigate Element Layers
delete
Scrape(NLP|Single): Using Compromise Plugins
delete
Utility(General): Remote Script Loader
delete
Scrape(General|Single|NLP): Compromise RiTa D3
delete
Scrape(General|Multi|Node): Grouped Node Crawler
delete
Scrape(Amazon|Multi): Crawl Product SERPs
delete
Scrape(Amazon|Multi): Get Paginated Brands
delete
Utility (Data): Download JSON in Browser
delete
Utility (Data): JSON AutoTypes
delete
Scrape(YouTube|Single): Video Page
delete
Utility (Text): Make Page Editable
delete
Utility (Text): Article Editor
delete
Scrape(General|Single|Text): Get Text On Click
delete
Utility (File): DnD File Parser (CSV,JSON,TXT)
delete
Scrape(General|Single): Get Links (Examples)
delete
Scrape(General|Single|Text): Get Sentences by Tag
delete
Utility (File): JSON to CSV via D3.js
delete
Scrape(General|Single): Auto Parse by Content Type
delete
Scrape(General|Single): Get Paragraphs & Sentences
delete
Scrape(Amazon|Multi): Get Reviews by ASIN
delete
Scrape(General|Single): Download Images on Page
delete
Utility(Event,Form): Custom Submit Function
delete
Utility (Fetch): Basic API Post Request
delete
Utility (Event,Form,Fetch): Form Data to API
delete
Utility (Time): Async Delay
delete
Utility (Time): Async Repeat Every N Secs
delete
Scrape(coj): Crawl Property SERPs
delete
Utility (Data): Promise Chain
delete
Utility (Fetch): Examples - JSON,Text,HTML
delete
Scrape(Amazon|Single): Product Review NLP
delete
Utility (Nodejs): Streaming Collections
delete
Scrape(Rate My Professor|Multi): Crawl Prof SERPs
delete
Utility (Time): JS Timer
delete
Utility (Text): Proper Case
delete
Scrape(Thingiverse API): Get Things via Search API
delete
Scrape(General|Single|Node): Get Node Attributes
delete
Scrape(General|Single|Node): Node Attributes + Text
delete
Scrape(Thesaurus): Get Words from SERPs
delete
Scrape(Walmart): Crawl Product SERPs
delete
Scrape(free3d): Crawl 3D Model SERPs
delete
Scrape(Aliexpress|Single): Get Products From SERP
delete
Scrape(simplify3d): Crawl Post SERPs
delete
Scrape(Twitter): Crawl Post Feed (infinite scroll)
delete
Scrape(DDuckGo|Single): Get Links from SERP
delete
Scrape(General|Single): Get Tokens String Distance
delete
Scrape(General|Single): Content Report
delete
Scrape(General|Single|Node): Node Recon (CSV)
delete
Utility (File): D3 JSON to CSV
delete
Scrape(coj|Multi): Crawl Property SERPs
delete
Scrape(coj|Single): sidenote
delete
Scrape(General|Single): Recursive Node Crawler
delete
Utility (Event,Window): Scroll to Root ScrollHeight
delete
Scrape(Indeed|Multi): Crawl Job SERPs
delete
Scrape(Thingiverse API): Get Things By Id
delete
Scrape(Thingiverse): Crawl Things by Category
delete
Scrape(Thingiverse API): Get Thing Batches by Id via DnD
delete
Scrape(YouTube|Single): Get Video Playlist
delete
Utility (Data): Join Thing Metrics & Meta
delete
Utility(Data): Get Nested Array Lengths
delete
Utility (Twitter): Hide Followed Profiles
delete
Utility (Time): YYYY-MM-DD HH:MM:SS
delete
Scrape(Thangs|Multi): Crawl 3D Model SERPs
delete
Scrape(PrusaPrints,Multi): Get Prints
delete
Scrape(Reddit,Single): Get Posts
delete
Userscript(Youtube): Scrape Channel Videos
delete
Userscript(Youtube): Tab Manager
delete
Scrape(Sunbiz|Multi): Biz Details
delete
Utility(Data):DnD View Types
delete
Scrape(General|Single|Node): Select Nodes by Attr
delete
Scrape(Aliexpress|Multi) Get Products via API
delete
Utility(Text): Strip Web Page CSS, Script, Events, Media
delete
Scrape(Youtube|Single) Get Subs
delete
Scrape(General|Single): SelectAll ReduceByProp
delete
Scrape(General|Single): SelectAll ReduceMultiProps
delete
Scrape(General|Multi): Tiny Link Crawler + Delay & Node Reports
delete
Scrape(P5|Multi): Get Examples
delete
Scrape(LinkedIn|Single): Find New Connections
delete
UserScript(linkedIn|Single) Get Jobs
delete
Utility (Time): Date From Days Ago
delete
Utility(General|Single) Keep Scrolling
delete
Scrape(YouTube) Videos From Search
delete
Utility(General|Single): getOffset
delete
Utility(Event,Form): Get Data On Form Input
delete
Utility(Event,Element): ResizeObserver
delete
COCO-SSD Object Categories
delete
Scrape(Wikipedia|Multi): What Links Here?
delete
Scrape(DDuckGo|Single): Download Images
delete
Scrape(General|Single|NLP): Compromise nGram
delete
Scrape(Aliexpress|Single): Get Products From SERP
Edit Snippet
var collection = []; var ids = new Set(); (async () => { var maxScroll = (selector,percent=1) => Math.round(document.querySelector(selector).scrollHeight*percent); var scrollPage = (scrollHeight) => window.scrollTo(0,scrollHeight); var prevScroll = 0; var maxTime = 8000; var start = performance.now(); var loopEvery = (seconds) => new Promise((resolve) => { var stop = () => clearInterval(timer); var timer = setInterval(() => { var ms = Math.round(performance.now()-start); var newMax = maxScroll(".list-items",(ms/maxTime)); var toScroll = newMax > prevScroll && maxTime >= ms; console.log({toScroll,newMax,ms,prevScroll}) if(toScroll){ prevScroll = newMax; scrollPage(newMax); }else{ stop(); var data = [...document.querySelectorAll(".product-card")].reduce((data,el,i) => { !el.querySelector(".item-ad-tag") ? data.products.push(el) : data.ads.push(el); return data; },{products:[],ads:[]}); var products = data.products.forEach((el) => { var obj = {}; var img = el.querySelector(".item-img"); var info = el.querySelector(".product-info"); obj.title = info.querySelector("a.item-title").title; obj.id = info.querySelector("a.item-title").href.split(".html?")[0].split("/item/")[1]; obj.url = info.querySelector("a.item-title").href.split("?")[0]; obj.price = info.querySelector(".price-current").innerText.split("$")[1].split("-").reduce((price,v,i) => { v = +(v.trim()); i == 0 ? price.low = v : price.high = v; return price; },{low:0,high:0}); obj.price.high = obj.price.low > obj.price.high ? obj.price.low : obj.price.high; obj.price.avg = Math.round((obj.price.low + obj.price.high)/2*100)/100; var shipping = info.querySelector(".shipping-value") || false; obj.price.shipping = shipping ? shipping.innerText.indexOf("Free Ship") > -1 ? 0 : +(info.querySelector(".shipping-value").innerText.split("$")[1]) : "NA"; if(!isNaN(obj.price.shipping)){ obj.price.total = { low: obj.price.shipping + obj.price.low, high: obj.price.shipping + obj.price.high }; obj.price.total.avg = Math.round((obj.price.total.low + obj.price.total.high)/2*100)/100; } var rating = info.querySelector(".rating-value") || false; obj.rating = rating ? +rating.innerText.trim() : "NA"; var store = info.querySelector(".store-name") || false; obj.store = { name: store ? store.innerText.trim() : "NA", url: store ? store.href.split("?")[0].trim() : "NA" } var sold = info.querySelector(".sale-value-link") || false; obj.sold = sold ? +sold.innerText.replace("Sold","").trim() : "NA"; var prev = ids.size; ids.add(obj.id); if(prev < ids.size){ collection.push(obj); } }) console.log({collection}) } resolve }, seconds*1000) }) await loopEvery(1.25); })()