Greasy Fork is available in English.

Download Apple ARkit Models

This script allows you to hover in the top right of the apple website, and allows you to click a button to download a 3D model of the product of which's page you are on

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         Download Apple ARkit Models
// @namespace    http://duckwithsunglasses.com/
// @version      1.0
// @description  This script allows you to hover in the top right of the apple website, and allows you to click a button to download a 3D model of the product of which's page you are on
// @author       Liam
// @match        https://www.apple.com/*
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

var styleElement = document.createElement('style');

var css = `
.charmsbar {
    width: 70px;
    background-color: black;
    height: 100vh;
    position: fixed;
    top: 0px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 50px;
    font-size: 0.7em;
    color: #8b8b8b;
    font-family: Segoe UI, sans-serif;
    z-index: 99999999999998;
    right: -71px;
    transition-duration: 1s;
    transition-timing-function: cubic-bezier(0.090, 0.420, 0.000, 1.010); /* custom */
}

.charmsbar > div > p {
    width: 62px;
    user-select: none;
    cursor: default;
    margin: 0;
}

.charmsbar > div {
    transition-duration: .1s;
    padding-top: 10px;
    padding-bottom: 10px;
}

.charmsbar > div:hover {
    background-color: #4a4a4a;
}

.charmsbar > div:active {
    transition-duration: 0s;
    background-color: #242424;
}

.charmshover {
    width: 70px;
    height: 100px;
    position: fixed;
    top: 0px;
    right: 0;
    /* outline: solid 2px red; */
    z-index: 99999999999999;
}

.charmshover:hover > .charmsbar {
    right: 0px;
}
`;
styleElement.innerHTML = css;
document.head.appendChild(styleElement);
const charmshoverDiv = document.createElement("div");
charmshoverDiv.classList.add("charmshover");
const charmsbarDiv = document.createElement("div");
charmsbarDiv.classList.add("charmsbar");
const downloadModelDiv = document.createElement("div");
downloadModelDiv.classList.add("downloadmodel");
downloadModelDiv.id = "downloadcharm";
const downloadModelImage = document.createElement("img");
downloadModelImage.src = "";
const downloadModelParagraph = document.createElement("p");
downloadModelParagraph.textContent = "Download model";
downloadModelDiv.appendChild(downloadModelImage);
downloadModelDiv.appendChild(downloadModelParagraph);
const whatIsThisDiv = document.createElement("div");
whatIsThisDiv.classList.add("whatisthis");
whatIsThisDiv.id = "wtfcharm";
const whatIsThisImage = document.createElement("img");
whatIsThisImage.src = "";
const whatIsThisParagraph = document.createElement("p");
whatIsThisParagraph.textContent = "What is this?";
whatIsThisDiv.appendChild(whatIsThisImage);
whatIsThisDiv.appendChild(whatIsThisParagraph);
charmsbarDiv.appendChild(downloadModelDiv);
charmsbarDiv.appendChild(whatIsThisDiv);
charmshoverDiv.appendChild(charmsbarDiv);
document.body.appendChild(charmshoverDiv);
const download = document.getElementById("downloadcharm");
download.addEventListener("click", function() {
const spanElements = document.querySelectorAll('span[data-component-list="ArLink"]');
const arAnchorElements = document.querySelectorAll('a[rel="ar"]');

if (spanElements.length > 0) {
  spanElements.forEach((span) => {
    const anchorElements = span.querySelectorAll('a');

    anchorElements.forEach((anchor) => {
      const modelURL = anchor.getAttribute('href');
      anchor.click();
      console.log(`Model URL: ${modelURL}`);
    });
  });

  console.log(`shits done, found ${spanElements.length} models`);
} else if (arAnchorElements.length > 0) {
  arAnchorElements.forEach((anchor) => {
    const modelURL = anchor.getAttribute('href');
    anchor.click();
    console.log(`Found a fuckin URL!: ${modelURL}`);
  });

  console.log(`%cshits done, found ${arAnchorElements.length} models`, 'font-size: 40px; color: lime; text-shadow: 3px 3px 0 #000, -3px 3px 0 #000, -3px -3px 0 #000, 3px -3px 0 #000;');
} else {
  console.log('%ccouldnt find anything you arse.', 'font-size: 40px; color: red; text-shadow: 3px 3px 0 #000, -3px 3px 0 #000, -3px -3px 0 #000, 3px -3px 0 #000;');
}
console.log('cheers liam @z2r 4 da swag n charm bar')
});

const wtfdialogue = document.getElementById("wtfcharm");
wtfdialogue.addEventListener("click", function() {
alert('The point of this tool is to allow you to download a model from Apples ARkit enabled websites, mainly, apples site themself. For example, if you go to Apples site right now, and click on iPhone, and click Learn More on whatever new sparkly phone there is, then, hover to the top right, and click Download Model, youll see its downloaded a 3D model of the iPhone you clicked on. super neat and handy for 3D artists.')
});

})();