diff --git a/404.html b/404.html
deleted file mode 100644
index 69e637c..0000000
--- a/404.html
+++ /dev/null
@@ -1,181 +0,0 @@
-
-
-
-
-
- Page Not Found | Shop Archives
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Page Not Found
- 404
- The page you’re looking for doesn’t exist.
-
-
-
-
-
-
-
-
-
-
-
diff --git a/assets/1.js b/assets/1.js
deleted file mode 100644
index 6303d32..0000000
--- a/assets/1.js
+++ /dev/null
@@ -1,246 +0,0 @@
-if (localStorage.full_client_rework === "false") {
- const mainsTab = document.querySelector("[data-mains-template]");
- const mainsTabsHolder = document.querySelector("[data-mains-tabs]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/main-tabs')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = mainsTab.content.cloneNode(true).children[0];
- const mainstitle = card.querySelector("[data-mains-title]");
- const mainsButton = card; // Corrected the selection of the button element
-
- mainstitle.textContent = user.title;
-
- mainsButton.classList.add(user.class);
-
- if (user.titleText) {
- mainsButton.title = user.titleText;
- }
-
- // Set the button's click event to redirect to the URL stored in the API
- mainsButton.onclick = function() {
- window.location.href = user.url;
- };
-
- // Check if 'isNew' is true, and show the "NEW" icon if it is
- if (user.isNew === "true") {
- card.querySelector(".dm-new-icon").style.display = 'block';
- }
-
- mainsTabsHolder.append(card);
-
- document.getElementById("loading-api-dm-mains").classList.add('hidden');
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("loading-api-dm-mains").classList.add('hidden');
- document.getElementById("mains-fetch-error").classList.remove('hidden');
- });
-
- function reFetchMainTabs() {
- document.getElementById("loading-api-dm-mains").classList.remove('hidden');
- document.getElementById("mains-fetch-error").classList.add('hidden');
- const mainsTab = document.querySelector("[data-mains-template]");
- const mainsTabsHolder = document.querySelector("[data-mains-tabs]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/main-tabs')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = mainsTab.content.cloneNode(true).children[0];
- const mainstitle = card.querySelector("[data-mains-title]");
- const mainsButton = card; // Corrected the selection of the button element
-
- mainstitle.textContent = user.title;
-
- mainsButton.classList.add(user.class);
-
- if (user.titleText) {
- mainsButton.title = user.titleText;
- }
-
- // Set the button's click event to redirect to the URL stored in the API
- mainsButton.onclick = function() {
- window.location.href = user.url;
- };
-
- // Check if 'isNew' is true, and show the "NEW" icon if it is
- if (user.isNew === "true") {
- card.querySelector(".dm-new-icon").style.display = 'block';
- }
-
- mainsTabsHolder.append(card);
-
- document.getElementById("loading-api-dm-mains").classList.add('hidden');
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("loading-api-dm-mains").classList.add('hidden');
- document.getElementById("mains-fetch-error").classList.remove('hidden');
- });
- }
-
-
- const funTab = document.querySelector("[data-fun-template]");
- const funTabsHolder = document.querySelector("[data-fun-output]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/fun')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = funTab.content.cloneNode(true).children[0];
- const funtitle = card.querySelector("[data-fun-title]");
- const funButton = card; // Corrected the selection of the button element
-
- funtitle.textContent = user.title;
-
- funButton.classList.add(user.class);
-
- if (user.titleText) {
- funButton.title = user.titleText;
- }
-
- // Set the button's click event to redirect to the URL stored in the API
- funButton.onclick = function() {
- window.location.href = user.url;
- };
-
- // Check if 'isNew' is true, and show the "NEW" icon if it is
- if (user.isNew === "true") {
- card.querySelector(".dm-new-icon").style.display = 'block';
- }
-
- funTabsHolder.append(card);
-
- document.getElementById("loading-api-dm-fun").classList.add('hidden');
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("loading-api-dm-fun").classList.add('hidden');
-
- });
-
-
-
-
-
-
- const NewsTab = document.querySelector("[data-news-template]");
- const NewsTabsHolder = document.querySelector("[data-news-tabs]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/news')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = NewsTab.content.cloneNode(true).children[0];
- const newstitle = card.querySelector("[data-news-title]");
- const newsButton = card; // Corrected the selection of the button element
-
- newstitle.textContent = user.title;
-
- if (user.titleText) {
- newsButton.title = user.titleText;
- }
-
- // Set the button's click event to redirect to the URL stored in the API
- newsButton.onclick = function() {
- window.location.href = user.url;
- };
-
- // Check if 'isNew' is true, and show the "NEW" icon if it is
- if (user.isNew === "true") {
- card.querySelector(".dm-new-icon").style.display = 'block';
- }
-
- NewsTabsHolder.append(card);
-
- document.getElementById("loading-api-dm-news").classList.add('hidden');
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("loading-api-dm-news").classList.add('hidden');
- document.getElementById("news-fetch-error").classList.remove('hidden');
- });
-
- function reFetchNewsTabs() {
- document.getElementById("loading-api-dm-news").classList.remove('hidden');
- document.getElementById("news-fetch-error").classList.add('hidden');
- const NewsTab = document.querySelector("[data-news-template]");
- const NewsTabsHolder = document.querySelector("[data-news-tabs]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/news')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = NewsTab.content.cloneNode(true).children[0];
- const newstitle = card.querySelector("[data-news-title]");
- const newsButton = card; // Corrected the selection of the button element
-
- newstitle.textContent = user.title;
-
- if (user.titleText) {
- newsButton.title = user.titleText;
- }
-
- // Set the button's click event to redirect to the URL stored in the API
- newsButton.onclick = function() {
- window.location.href = user.url;
- };
-
- // Check if 'isNew' is true, and show the "NEW" icon if it is
- if (user.isNew === "true") {
- card.querySelector(".dm-new-icon").style.display = 'block';
- }
-
- NewsTabsHolder.append(card);
-
- document.getElementById("loading-api-dm-news").classList.add('hidden');
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("loading-api-dm-news").classList.add('hidden');
- document.getElementById("news-fetch-error").classList.remove('hidden');
- });
- }
-
-
- const servers = document.querySelector("[data-servers-template]");
- const serversList = document.querySelector("[data-servers]");
-
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/servers')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = servers.content.cloneNode(true).children[0];
- const serversButton = card; // Corrected the selection of the button element
-
- serversButton.classList.add(user.class);
-
- if (user.titleText) {
- serversButton.title = user.titleText;
- }
-
- const userImage = card.querySelector("[data-server-icon]");
- userImage.src = user.image;
- userImage.alt = user.title;
-
- // Set the button's click event to redirect to the URL stored in the API
- serversButton.onclick = function() {
- window.location.href = user.url;
- };
-
- serversList.append(card);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-} else {
- location.href='/';
-}
\ No newline at end of file
diff --git a/assets/10.js b/assets/10.js
deleted file mode 100644
index f6f0650..0000000
--- a/assets/10.js
+++ /dev/null
@@ -1,656 +0,0 @@
-// tbh i forgot what this experiment was
-EXPERIMENT_ID_1 = 1
-
-// 2024-11_item_data_downloads
-EXPERIMENT_ID_2 = -1
-
-// 2024-11_top_selling_item_tag
-EXPERIMENT_ID_3 = -1
-
-// 2024-11_epic_profiles_plus_category_changes
-EXPERIMENT_ID_4 = 1
-
-// 2024-11_full_client_rework
-EXPERIMENT_ID_5 = 1
-
-
-EXPERIMENT_ID_6 = 1
-
-const experimentsList = [
- {
- title: "Render Orbs Shop As Home",
- id: "2025-05_orbs_shop_home",
- name: "experiment_2025_05_orbs_shop_home",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "XP Redeem Gift Codes",
- id: "2025-05_redeem_gift_codes",
- name: "experiment_2025_05_redeem_gift_codes",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "XP System",
- id: "2025-05_xp_system",
- name: "experiment_2025_05_xp_system",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Reviews V2 User Profile",
- id: "2025-05_reviews_v2_user_profile",
- name: "experiment_2025_05_reviews_v2_user_profile",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Account Creator",
- id: "2025-05_account_creator",
- name: "experiment_2025_05_account_creator",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- needs_api_token: "true"
- },
- {
- title: "m",
- id: "2025-05_m",
- name: "experiment_2025_05_m",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Item Search",
- id: "2025-04_item_search",
- name: "experiment_2025_04_item_search",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- title: "Purchasable Items",
- id: "2025-04_purchasable_items",
- name: "experiment_2025_04_purchasable_items",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- needs_api_token: "true"
- },
- {
- title: "See You Next Year",
- id: "2025-04_see_you_next_year",
- name: "experiment_2025_04_see_you_next_year",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Reviews V2 Warning System",
- id: "2025-04_reviews_v2_warning_system",
- name: "experiment_2025_04_reviews_v2_warning_system",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Extended Styles",
- id: "2025-04_extended_styles",
- name: "experiment_2025_04_extended_styles",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled",
- "Treatment 2: Card Styles"
- ],
- rollout: "Treatment 1: Enabled"
- },
- {
- title: "Reviews V2 Hide Beta Tag",
- id: "2025-04_reviews_v2_hide_beta_tag",
- name: "experiment_2025_04_reviews_v2_hide_beta_tag",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled"
- },
- {
- title: "Reviews V2 Custom Emojis Render",
- id: "2025-04_reviews_v2_custom_emojis_render",
- name: "experiment_2025_04_reviews_v2_custom_emojis_render",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- title: "Reviews V2 Report",
- id: "2025-04_reviews_v2_report",
- name: "experiment_2025_04_reviews_v2_report",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- needs_api_token: "true"
- },
- {
- title: "Reviews V2",
- id: "2025-04_reviews_v2",
- name: "experiment_2025_04_reviews_v2",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- needs_api_token: "true"
- },
- {
- title: "Accessibility V2",
- id: "2025-04_accessibility_v2",
- name: "experiment_2025_04_accessibility_v2",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- title: "Profile Tab V2",
- id: "2025-04_profile_tab_v2",
- name: "experiment_2025_04_profile_tab_v2",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled"
- },
- {
- title: "Theme Picker V2 Color",
- id: "2025-04_theme_picker_v2_color",
- name: "experiment_2025_04_theme_picker_v2_color",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- title: "Theme Picker V2 Custom",
- id: "2025-04_theme_picker_v2_custom",
- name: "experiment_2025_04_theme_picker_v2_custom",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- title: "Theme Picker V2 Community",
- id: "2025-04_theme_picker_v2_community",
- name: "experiment_2025_04_theme_picker_v2_community",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 2: As banners"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Use api.yapper.shop for api",
- id: "2025-04_use_api_dot_yapper_dot_shop",
- name: "experiment_2025_04_use_api_dot_yapper_dot_shop",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Collectibles Marketing Page",
- id: "2025-04_collectibles_marketing_page",
- name: "experiment_2025_04_collectibles_marketing_page",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 2: Enable v2"
- ],
- rollout: "Treatment 2: Enable v2",
- needs_api_token: "true"
- },
- {
- title: "Discord Sign In Dismissible",
- id: "2025-04_discord_sign_in_dismissible",
- name: "experiment_2025_04_discord_sign_in_dismissible",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: V1"
- ],
- rollout: "Treatment 1: V1"
- },
- {
- title: "Discord Sign In",
- id: "2025-04_discord_sign_in",
- name: "experiment_2025_04_discord_sign_in",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Dynamic",
- "Treatment 2: Force Logged Out",
- "Treatment 3: Force Logged In",
- "Treatment 4: Dynamic v2",
- "Treatment 6: Force Logged In v2"
- ],
- rollout: "Treatment 4: Dynamic v2",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Show items with no skus in misc tab",
- id: "2025-03_items_with_no_sku",
- name: "experiment_2025_03_items_with_no_sku",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "View Raw Modal",
- id: "2025-03_view_raw_modal",
- name: "experiment_2025_03_view_raw_modal",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- not_needed: "true"
- },
- {
- title: "Copy SKU Card",
- id: "2025-03_copy_sku_card",
- name: "experiment_2025_03_copy_sku_card",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled",
- "Treatment 2: w/ share button",
- "Treatment 3: only share button"
- ],
- rollout: "Treatment 1: Enabled"
- },
- {
- title: "Quick Info Tab",
- id: "2025-03_quick_info",
- name: "experiment_2025_03_quick_info",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Extra Options Dismissible Content",
- id: "2025-03_extra_options_dismissible_content",
- name: "experiment_2025_03_extra_options_dismissible_content",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: V1"
- ],
- rollout: "Treatment -1: Disabled",
- not_needed: "true"
- },
- {
- title: "Early Nameplate Warning",
- id: "2025-03_early_nameplate_warning",
- name: "experiment_2025_03_early_nameplate_warning",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Nameplate Test Warning",
- "Treatment 2: Nameplate & Nameplate Test Warning"
- ],
- rollout: "Treatment -1: Disabled"
- },
- {
- //21
- title: "Item Reviews",
- id: "2025-03_item_reviews",
- name: "experiment_2025_03_item_reviews",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled",
- "Treatment 2: Simulate not logged in",
- "Treatment 3: Simulate logged in"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Heartbeat",
- id: "2025-03_heartbeat",
- name: "experiment_2025_03_heartbeat",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Fetch once on startup",
- "Treatment 2: Fetch every 60 seconds"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Fetch From Vercel Endpoits",
- id: "2025-02_fetch_from_vercel_endpoits",
- name: "experiment_2025_02_fetch_from_vercel_endpoits",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- not_needed: "true"
- },
- {
- title: "Extra Options",
- id: "2025-02_extra_options",
- name: "experiment_2025_02_extra_options",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 4: Enabled",
- "Treatment 6: Settings like discord"
- ],
- rollout: "Treatment 6: Settings like discord",
- not_needed: "true"
- },
- {
- title: "Profiles Plus Home",
- id: "2025-02_profiles_plus_home",
- name: "experiment_2025_02_profiles_plus_home",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 2: Enabled",
- "Treatment 3: Hide All Profiles Plus Tabs"
- ],
- rollout: "Treatment 3: Hide All Profiles Plus Tabs",
- needs_api_token: "true"
- },
- {
- title: "Shop Category Modals",
- id: "2025-02_shop_category_modals",
- name: "experiment_2025_02_shop_category_modals",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enable category modals",
- "Treatment 2: Enable category modals w/ data downloads"
- ],
- rollout: "Treatment 1: Enable category modals",
- not_needed: "true"
- },
- {
- title: "Shop Card Modals",
- id: "2025-02_shop_card_modals",
- name: "experiment_2025_02_shop_card_modals",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enable modals",
- "Treatment 2: Enable modals w/ data downloads",
- "Treatment 3: Enable modals w/ p+",
- "Treatment 4: Enable modals w/ p+ on p+ page",
- "Treatment 5: Enable modals w/ data downloads and p+",
- "Treatment 6: Enable modals w/ data downloads and p+ on p+ page"
- ],
- rollout: "Treatment 4: Enable modals w/ p+ on p+ page",
- not_needed: "true"
- },
- {
- title: "Mobile Render",
- id: "2025-02_mobile_render",
- name: "experiment_2025_02_mobile_render",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Use new mobile check",
- "Treatment 2: Use old mobile check"
- ],
- rollout: "Treatment 1: Use new mobile check"
- },
- {
- title: "Orbs Shop",
- id: "2025-02_orbs_shop",
- name: "experiment_2025_02_orbs_shop",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 2: Orb Shop done like default",
- "Treatment 3: Default + New tag"
- ],
- rollout: "Treatment 2: Orb Shop done like default",
- needs_api_token: "true",
- not_needed: "true"
- },
- {
- title: "Orb Testing",
- id: "2025-01_orb_testing",
- name: "experiment_2025_01_orb_testing",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 4: Orb Converter"
- ],
- rollout: "Treatment -1: Disabled",
- needs_api_token: "true"
- },
- {
- title: "Show Leaks On Home Page",
- id: "2025-01_show_leaks_on_home_page",
- name: "experiment_2025_01_show_leaks_on_home_page",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment -1: Disabled",
- not_needed: "true"
- },
- {
- title: "Theme Picker",
- id: "2024-12_theme_picker",
- name: "experiment_2024_12_theme_picker",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled",
- "Treatment 2: Enabled with custom css"
- ],
- rollout: "Treatment 1: Enabled",
- not_needed: "true"
- },
- {
- title: "Profiles Plus Marketing Variants",
- id: "2024-12_profiles_plus_marketing_variants",
- name: "experiment_2024_12_profiles_plus_marketing_variants",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Paper Beach V2",
- "Treatment 2: Roblox Doors"
- ],
- rollout: "Treatment -1: Disabled",
- not_needed: "true"
- },
- {
- title: "Collectibles Variants",
- id: "2024-11_collectibles_variants",
- name: "experiment_2024_11_collectibles_variants",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled"
- ],
- rollout: "Treatment 1: Enabled",
- not_needed: "true"
- },
- {
- title: "2024 Recap",
- id: "2024-11_recap",
- name: "experiment_2024_11_recap",
- treatments: [
- "Treatment -1: Disabled",
- "Treatment 1: Enabled",
- "Treatment 2: Nameplate Marketing"
- ],
- rollout: "Treatment -1: Disabled"
- }
-];
-
-const dismissibleContentList = [
- {
- title: "XP notice",
- id: "dismissible_content_XPnotice",
- name: "dismissible_XPnotice",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- },
- {
- title: "Claim 100 XP for free",
- id: "dismissible_content_new100FreeXP",
- name: "dismissible_new100FreeXP",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- },
- {
- title: "Discord Sign In",
- id: "dismissible_content_newLogInWithDiscord",
- name: "dismissible_newLogInWithDiscord",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- },
- {
- title: "Open In Shop Notice",
- id: "dismissible_content_open_in_shop_notice",
- name: "dismissible_open_in_shop_notice",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- },
- {
- title: "Orbs Shop New Tag",
- id: "dismissible_content_orbs_shop_new_tag",
- name: "dismissible_orbs_shop_new_tag",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- },
- {
- title: "New Profile Settings",
- id: "dismissible_content_newProfileSettings",
- name: "dismissible_newProfileSettings",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ],
- not_needed: "true"
- },
- {
- title: "Roblox Doors Marketing",
- id: "dismissible_content_roblox_doors_marketing",
- name: "dismissible_roblox_doors_marketing",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ],
- not_needed: "true"
- },
- {
- title: "Paper Beach V2 Marketing",
- id: "dismissible_content_paper_beach_v2_marketing",
- name: "dismissible_paper_beach_v2_marketing",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ],
- not_needed: "true"
- },
- {
- title: "Recap 2024",
- id: "dismissible_content_recap_2024",
- name: "dismissible_recap_2024",
- treatments: [
- "Treatment -1: Unseen",
- "Treatment 1: Seen"
- ]
- }
-];
-
-const testFetchAPIList = [
- {
- title: "Test Fetch Collectibles Shop API",
- id: "testfetch_collectibles-shop",
- name: "testfetch_testfetchnew",
- treatments: [
- "none",
- "home",
- "shop",
- "orbs",
- "leaks",
- "nameplates",
- "consumables",
- "miscellaneous",
- "marketing",
- "pplus-home",
- "pplus"
- ],
- rollout: "none",
- needs_api_token: "true"
- },
- {
- title: "Test Fetch Profile Effects API",
- id: "testfetch_profile-effects",
- name: "testfetch_testfetcheffects",
- treatments: [
- "none",
- "discord",
- "pplus"
- ],
- rollout: "none",
- needs_api_token: "true"
- }
-];
\ No newline at end of file
diff --git a/assets/11.js b/assets/11.js
deleted file mode 100644
index ba50b3b..0000000
--- a/assets/11.js
+++ /dev/null
@@ -1,204 +0,0 @@
-
-let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/leaks';
-
-fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image]").classList.add('shop-logo-sway');
- }
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "UNOBTAINABLE";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / (1000 * 60));
- const seconds = Math.floor((timeDiff % (1000 * 60)) / 1000);
-
- timerElement.textContent = `${days} DAYS LEFT IN SHOP`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
- // Function to create a card
- function createCard(item, sku, price, priceNitro, emojiCopy, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- card.classList.add('shop-category-card');
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- Unable to confirm item availability
-
- NEW
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- Unable to confirm item availability
-
- NEW
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- return card;
- }
-
- // Sort and display the products: Bundle, Decoration, Effect
- const bundleProducts = [];
- const decorationProducts = [];
- const effectProducts = [];
-
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const sku = product.sku_id || ""; // Get credits from the product
- const price = product.price || "";
- const priceNitro = product.price_nitro || "";
- const emojiCopy = product.emojiCopy || ""; // Get emojiCopy from the product
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- // Add bundle card with bundled items
- bundleProducts.push({ product, sku, price, priceNitro, emojiCopy, isNew });
- } else {
- // Handle individual items
- product.items.forEach(item => {
- if (item.item_type === 'deco') {
- decorationProducts.push({ item, sku, price, priceNitro, emojiCopy, isNew });
- } else if (item.item_type === 'effect') {
- effectProducts.push({ item, sku, price, priceNitro, emojiCopy, isNew });
- }
- });
- }
- });
-
- // Append Bundle, Decoration, and Effect cards in that order
- bundleProducts.forEach(({ product, sku, price, priceNitro, emojiCopy, isNew }) => cardHolder.appendChild(createCard(product, sku, price, priceNitro, emojiCopy, true, isNew)));
- decorationProducts.forEach(({ item, sku, price, priceNitro, emojiCopy, isNew }) => cardHolder.appendChild(createCard(item, sku, price, priceNitro, emojiCopy, false, isNew)));
- effectProducts.forEach(({ item, sku, price, priceNitro, emojiCopy, isNew }) => cardHolder.appendChild(createCard(item, sku, price, priceNitro, emojiCopy, false, isNew)));
-
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-
-// Function to copy emoji to clipboard
-function copyEmoji(emoji) {
- navigator.clipboard.writeText(emoji).then(() => {
- console.log('emoji yes');
- }).catch(err => {
- console.error("Failed to copy emoji: ", err);
- });
-}
-
-// Function to redirect to Google
-function redirectToGoogle() {
- window.location.href = 'https://discord.gg/Mcwh7hGcWb';
-}
\ No newline at end of file
diff --git a/assets/12.js b/assets/12.js
deleted file mode 100644
index 9bf0466..0000000
--- a/assets/12.js
+++ /dev/null
@@ -1,375 +0,0 @@
-
-if (localStorage.full_client_rework != "true") {
-
- let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/home-page-preview';
-
- fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.hero_banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image]").classList.add('shop-logo-sway');
- }
-
- const previewCategoryButton = category.querySelector("[data-preview-new-categoey-button]");
-
- const newCategoryName = user.name;
-
- previewCategoryButton.innerHTML = `
- Shop the ${newCategoryName} Collection
- `;
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "UNOBTAINABLE";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- timerElement.textContent = `${days} DAYS LEFT IN SHOP`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
- // Function to create a card
- function createCard(item, sku, price, priceNitro, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- card.classList.add('shop-category-card');
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- Open In Shop
-
- NEW
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- Open In Shop
-
- NEW
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- return card;
- }
-
- // Display the products in the order they appear in the API
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const sku = product.sku_id || ""; // Get SKU from the product
- const price = product.price || "";
- const priceNitro = product.price_nitro || "";
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- cardHolder.appendChild(createCard(product, sku, price, priceNitro, true, isNew));
- } else {
- // Handle individual items
- product.items.forEach(item => {
- cardHolder.appendChild(createCard(item, sku, price, priceNitro, false, isNew));
- });
- }
- });
-
- output.append(category);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
-
- let apiUrlplus = 'https://raw.githubusercontent.com/Yappering/api/main/v1/home-page-p-plus';
-
- fetch(apiUrlplus)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template-plus]");
- const output = document.querySelector("[data-shop-output-plus]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const oneImage = category.querySelector("[data-shop-preview-image-plus]");
- oneImage.src = user.src;
- oneImage.alt = user.name;
-
- output.append(category);
- });
-
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
-
-
- let apiUrlp = 'https://raw.githubusercontent.com/Yappering/api/main/v1/popular-picks';
-
- fetch(apiUrlp)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template-p]");
- const output = document.querySelector("[data-shop-output-p]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image-p]");
- bannerImage.src = user.banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image-p]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc-p]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image-p]").classList.add('shop-logo-sway');
- }
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "UNOBTAINABLE";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- timerElement.textContent = `${days} DAYS LEFT IN SHOP`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
- // Function to create a card
- function createCard(item, sku, price, priceNitro, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- card.classList.add('shop-category-card');
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- Open In Shop
-
- NEW
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- Open In Shop
-
- NEW
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- return card;
- }
-
- // Display the products in the order they appear in the API
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const sku = product.sku_id || ""; // Get SKU from the product
- const price = product.price || "";
- const priceNitro = product.price_nitro || "";
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- cardHolder.appendChild(createCard(product, sku, price, priceNitro, true, isNew));
- } else {
- // Handle individual items
- product.items.forEach(item => {
- cardHolder.appendChild(createCard(item, sku, price, priceNitro, false, isNew));
- });
- }
- });
-
- output.append(category);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
-
-}
diff --git a/assets/13.svg b/assets/13.svg
deleted file mode 100644
index b5093a0..0000000
--- a/assets/13.svg
+++ /dev/null
@@ -1,4 +0,0 @@
-
-
-
-
diff --git a/assets/14.js b/assets/14.js
deleted file mode 100644
index 937aed7..0000000
--- a/assets/14.js
+++ /dev/null
@@ -1,401 +0,0 @@
-
-const customDecorationInput = document.getElementById('customDecorationInput');
-const customDecorationUrlInput = document.getElementById('customDecorationUrlInput');
-const loadCustomDecorationUrlButton = document.getElementById('loadCustomDecorationUrl');
-const customDecorationPreview = document.getElementById('customDecorationPreview');
-const decoDataUrlOutput = document.getElementById('deco-dataUrlOutput');
-
-// Function to handle file upload
-customDecorationInput.addEventListener('change', function(event) {
- const file = event.target.files[0];
- if (file) {
- const reader = new FileReader();
-
- reader.onload = function(e) {
- const dataUrl = e.target.result;
-
- // Display custom decoration preview
- customDecorationPreview.src = dataUrl;
- customDecorationPreview.style.display = 'block';
-
- // Display Data URL
- decoDataUrlOutput.textContent = dataUrl;
- };
-
- reader.readAsDataURL(file);
- }
-});
-
-// Function to handle custom decoration URL input
-loadCustomDecorationUrlButton.addEventListener('click', function() {
- const customDecorationUrl = customDecorationUrlInput.value;
-
- if (customDecorationUrl) {
- const img = new Image();
- img.crossOrigin = 'Anonymous'; // This is needed to avoid CORS issues
-
- img.onload = function() {
- const canvas = document.createElement('canvas');
- canvas.width = img.width;
- canvas.height = img.height;
- const ctx = canvas.getContext('2d');
-
- ctx.drawImage(img, 0, 0);
-
- // Convert custom decoration to Data URL
- const dataUrl = canvas.toDataURL('image/png');
-
- // Display custom decoration preview
- customDecorationPreview.src = dataUrl;
- customDecorationPreview.style.display = 'block';
-
- // Display Data URL
- decoDataUrlOutput.textContent = dataUrl;
- };
-
- img.src = customDecorationUrl;
- }
-});
-
-
-
-
-
-
-const inputs = {
- name: document.getElementById('deco-name-intput-box'),
- description: document.getElementById('deco-desc-intput-box'),
- id: document.getElementById('deco-skuid-input-box'),
- animatedLink: document.getElementById('deco-animated-link-input-box'),
- staticLink: document.getElementById('deco-static-link-input-box'),
- price: document.getElementById('deco-price-input-box'),
- price2: document.getElementById('deco-price2-input-box')
-};
-
-// Define output elements
-const outputs = {
- name: document.getElementById('deco-name-output-text'),
- description: document.getElementById('deco-desc-output-text'),
- id: document.getElementById('deco-skuid-output-text'),
- animatedLink: document.getElementById('deco-animated-link-output-text'),
- staticLink: document.getElementById('deco-static-link-output-text'),
- price: document.getElementById('deco-price-output-text'),
- price2: document.getElementById('deco-price2-output-text')
-};
-
-const decoImagePreview = document.getElementById('customDecorationPreview');
-const decoPreviewCard = document.getElementById('deco-preview-card');
-let DecoStaticLink = '';
-let DecoAnimatedLink = '';
-
-// Add event listeners to update text live
-for (const key in inputs) {
- inputs[key].addEventListener('input', function() {
- outputs[key].textContent = `${inputs[key].value}`;
-
- if (key === 'staticLink') {
- DecoStaticLink = inputs.staticLink.value;
- decoImagePreview.src = DecoStaticLink;
- } else if (key === 'animatedLink') {
- DecoAnimatedLink = inputs.animatedLink.value;
- }
- });
-}
-
-decoPreviewCard.addEventListener('mouseenter', function() {
- if (DecoAnimatedLink) {
- decoImagePreview.src = DecoAnimatedLink;
- }
-});
-
-// Reset image source to static link on mouse leave
-decoPreviewCard.addEventListener('mouseleave', function() {
- if (DecoStaticLink) {
- decoImagePreview.src = DecoStaticLink;
- }
-});
-
-// Load JSON from textarea into inputs
-document.getElementById('deco-load-json-button').addEventListener('click', function() {
- try {
- const jsonData = JSON.parse(document.getElementById('deco-json-input').value);
-
- // Populate the input fields with the JSON data
- inputs.name.value = jsonData.name || "";
- inputs.description.value = jsonData.summary || "";
- inputs.id.value = jsonData.sku_id || "";
- inputs.price.value = jsonData.price || "";
- inputs.price2.value = jsonData.price_nitro || "";
- inputs.staticLink.value = jsonData.items[0].static || "";
- inputs.animatedLink.value = jsonData.items[0].animated || "";
-
- // Trigger input events to update the live preview
- for (const key in inputs) {
- inputs[key].dispatchEvent(new Event('input'));
- }
- } catch (e) {
- alert("Invalid JSON! Please check the format.");
- }
-});
-
-// Copy button functionality
-document.getElementById('custom-deco-copy-button').addEventListener('click', function() {
- // Create JSON string for API use
- const jsonData = {
- name: inputs.name.value,
- summary: inputs.description.value,
- sku_id: inputs.id.value,
- price: inputs.price.value,
- price_nitro: inputs.price2.value,
- unpublished_at: null,
- isNew: "false",
- emojiCopy: null,
- items: [
- {
- item_type: "deco",
- name: inputs.name.value,
- static: inputs.staticLink.value,
- animated: inputs.animatedLink.value,
- summary: inputs.description.value
- }
- ]
- };
-
- // Stringify JSON data with indentation for better formatting
- const jsonString = JSON.stringify(jsonData, null, 4);
-
- // Create a temporary textarea to hold the text
- const tempTextarea = document.createElement('textarea');
- tempTextarea.value = jsonString;
- document.body.appendChild(tempTextarea);
- tempTextarea.select();
- document.execCommand('copy');
- document.body.removeChild(tempTextarea);
-});
-
-
-
-
-
-const customEffectInput = document.getElementById('customEffectInput');
-const customEffectUrlInput = document.getElementById('customEffectUrlInput');
-const loadCustomEffectUrlButton = document.getElementById('loadCustomEffectUrl');
-const customEffectPreview = document.getElementById('customEffectPreview');
-const effectDataUrlOutput = document.getElementById('effect-dataUrlOutput');
-
-// Function to handle file upload
-customEffectInput.addEventListener('change', function(event) {
- const file = event.target.files[0];
- if (file) {
- const reader = new FileReader();
-
- reader.onload = function(e) {
- const dataUrl = e.target.result;
-
- // Display custom Effect preview
- customEffectPreview.src = dataUrl;
- customEffectPreview.style.display = 'block';
-
- // Display Data URL
- effectDataUrlOutput.textContent = dataUrl;
- };
-
- reader.readAsDataURL(file);
- }
-});
-
-// Function to handle custom Effect URL input
-loadCustomEffectUrlButton.addEventListener('click', function() {
- const customEffectUrl = customEffectUrlInput.value;
-
- if (customEffectUrl) {
- const img = new Image();
- img.crossOrigin = 'Anonymous'; // This is needed to avoid CORS issues
-
- img.onload = function() {
- const canvas = document.createElement('canvas');
- canvas.width = img.width;
- canvas.height = img.height;
- const ctx = canvas.getContext('2d');
-
- ctx.drawImage(img, 0, 0);
-
- // Convert custom Effect to Data URL
- const dataUrl = canvas.toDataURL('image/png');
-
- // Display custom Effect preview
- customEffectPreview.src = dataUrl;
- customEffectPreview.style.display = 'block';
-
- // Display Data URL
- effectDataUrlOutput.textContent = dataUrl;
- };
-
- img.src = customEffectUrl;
- }
-});
-
-
-
-
-
-
-const effectinputs = {
- name: document.getElementById('effect-name-intput-box'),
- description: document.getElementById('effect-desc-intput-box'),
- id: document.getElementById('effect-skuid-input-box'),
- animatedLink: document.getElementById('effect-animated-link-input-box'),
- staticLink: document.getElementById('effect-static-link-input-box'),
- price: document.getElementById('effect-price-input-box'),
- price2: document.getElementById('effect-price2-input-box')
-};
-
-// Define output elements
-const effectoutputs = {
- name: document.getElementById('effect-name-output-text'),
- description: document.getElementById('effect-desc-output-text'),
- id: document.getElementById('effect-skuid-output-text'),
- animatedLink: document.getElementById('effect-animated-link-output-text'),
- staticLink: document.getElementById('effect-static-link-output-text'),
- price: document.getElementById('effect-price-output-text'),
- price2: document.getElementById('effect-price2-output-text')
-};
-
-const effectImagePreview = document.getElementById('customEffectPreview');
-const effectPreviewCard = document.getElementById('effect-preview-card');
-let effectStaticLink = '';
-let effectAnimatedLink = '';
-
-// Add event listeners to update text live
-for (const key in effectinputs) {
- effectinputs[key].addEventListener('input', function() {
- effectoutputs[key].textContent = `${effectinputs[key].value}`;
-
- if (key === 'staticLink') {
- effectStaticLink = effectinputs.staticLink.value;
- effectImagePreview.src = effectStaticLink;
- } else if (key === 'animatedLink') {
- effectAnimatedLink = effectinputs.animatedLink.value;
- }
- });
-}
-
-effectPreviewCard.addEventListener('mouseenter', function() {
- if (effectAnimatedLink) {
- effectImagePreview.src = effectAnimatedLink;
- }
-});
-
-// Reset image source to static link on mouse leave
-effectPreviewCard.addEventListener('mouseleave', function() {
- if (effectStaticLink) {
- effectImagePreview.src = effectStaticLink;
- }
-});
-
-// Load JSON from textarea into inputs
-document.getElementById('effect-load-json-button').addEventListener('click', function() {
- try {
- const jsonData = JSON.parse(document.getElementById('effect-json-input').value);
-
- // Populate the input fields with the JSON data
- effectinputs.name.value = jsonData.name || "";
- effectinputs.description.value = jsonData.summary || "";
- effectinputs.id.value = jsonData.sku_id || "";
- effectinputs.price.value = jsonData.price || "";
- effectinputs.price2.value = jsonData.price_nitro || "";
- effectinputs.staticLink.value = jsonData.items[0].static || "";
- effectinputs.animatedLink.value = jsonData.items[0].animated || "";
-
- // Trigger input events to update the live preview
- for (const key in effectinputs) {
- effectinputs[key].dispatchEvent(new Event('input'));
- }
- } catch (e) {
- alert("Invalid JSON! Please check the format.");
- }
-});
-
-// Copy button functionality
-document.getElementById('custom-effect-copy-button').addEventListener('click', function() {
- // Create JSON string for API use
- const jsonData = {
- name: effectinputs.name.value,
- summary: effectinputs.description.value,
- sku_id: effectinputs.id.value,
- price: effectinputs.price.value,
- price_nitro: effectinputs.price2.value,
- unpublished_at: null,
- isNew: "false",
- emojiCopy: null,
- items: [
- {
- item_type: "effect",
- name: effectinputs.name.value,
- static: effectinputs.staticLink.value,
- animated: effectinputs.animatedLink.value,
- summary: effectinputs.description.value
- }
- ]
- };
-
- // Stringify JSON data with indentation for better formatting
- const jsonString = JSON.stringify(jsonData, null, 4);
-
- // Create a temporary textarea to hold the text
- const tempTextarea = document.createElement('textarea');
- tempTextarea.value = jsonString;
- document.body.appendChild(tempTextarea);
- tempTextarea.select();
- document.execCommand('copy');
- document.body.removeChild(tempTextarea);
-});
-
-
-
-
-
-
-
-
-
-document.getElementById('convert-button').addEventListener('click', function() {
- try {
- // Parse the input JSON
- const inputJson = JSON.parse(document.getElementById('api-input').value);
-
- // Extract values from the input JSON
- const name = inputJson.name;
- const summary = inputJson.summary;
- const sku_id = inputJson.sku_id;
- const asset = inputJson.items[0]?.asset || "";
- const staticLink = `https://cdn.discordapp.com/avatar-decoration-presets/${asset}.png?size=4096&passthrough=false`;
- const animatedLink = `https://cdn.discordapp.com/avatar-decoration-presets/${asset}.png?size=4096&passthrough=true`;
-
- // Create the converted JSON object
- const convertedJson = {
- name: name,
- summary: summary,
- sku_id: sku_id,
- price: null,
- price_nitro: null,
- unpublished_at: null,
- isNew: "true",
- emojiCopy: null,
- items: [
- {
- item_type: "deco",
- name: name,
- static: staticLink,
- animated: animatedLink,
- summary: summary
- }
- ]
- };
-
- // Display the converted JSON
- document.getElementById('converted-api').value = JSON.stringify(convertedJson, null, 4);
- } catch (e) {
- alert("Invalid JSON! Please check the format.");
- }
-});
\ No newline at end of file
diff --git a/assets/15.css b/assets/15.css
deleted file mode 100644
index b685448..0000000
--- a/assets/15.css
+++ /dev/null
@@ -1,8 +0,0 @@
-.pplus-tab {
- background-image:
- url(https://cdn.yapper.shop/assets/38.png),
- linear-gradient(90deg, rgba(43, 45, 49, 0.00) 28.13%, rgba(255, 107, 0, 0.55) 67.3%, #FFFD00 100%);
- background-repeat: no-repeat;
- background-size: cover;
- background-position: right;
-}
\ No newline at end of file
diff --git a/assets/16.js b/assets/16.js
deleted file mode 100644
index 0922795..0000000
--- a/assets/16.js
+++ /dev/null
@@ -1,59 +0,0 @@
-let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/refs/heads/main/v1/consumables';
-
-// Function to clear the shop data
-function clearShopData() {
- const output = document.querySelector("[data-shop-output]");
- output.innerHTML = ''; // Clears the content of the shop category
- document.getElementById("shop-category-loading").classList.remove('hidden');
-}
-
-// Function to fetch and display shop data
-function fetchData() {
-
- // Clear the previous data
- clearShopData();
-
- // Fetch new data
- fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-potion-card-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const banner = category.querySelector("[data-potion-card-holder]");
- banner.id = user.sku_id;
-
- const logoImage = category.querySelector("[data-potion-card-preview-image]");
- logoImage.src = user.preview;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-potion-card-desc]");
- summary.textContent = user.summary;
-
- const title = category.querySelector("[data-potion-card-title]");
- title.textContent = user.name;
-
- const price = category.querySelector("[data-potion-card-price]");
- price.textContent = user.price;
-
- const sku = category.querySelector("[data-potion-card-sku]");
- sku.textContent = 'SKU ID: ' + user.sku_id;
-
- // Append the category to the output section
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
-
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-}
-
-// Initial data fetch when the page loads
-window.onload = fetchData;
\ No newline at end of file
diff --git a/assets/17.js b/assets/17.js
deleted file mode 100644
index c364312..0000000
--- a/assets/17.js
+++ /dev/null
@@ -1,66 +0,0 @@
-const formatPrice = (amount) => {
- const amountStr = amount.toString();
- return amountStr.slice(0, -2) + '.' + amountStr.slice(-2);
-};
-
-let apiUrl = 'https://canary.discord.com/api/v9/store/published-listings/skus?application_id=1096190356233670716';
-
-// Function to clear the shop data
-function clearShopData() {
- const output = document.querySelector("[data-shop-output]");
- output.innerHTML = ''; // Clears the content of the shop category
- document.getElementById("shop-category-loading").classList.remove('hidden');
-}
-
-// Function to fetch and display shop data
-function fetchData() {
-
- // Clear the previous data
- clearShopData();
-
- // Fetch new data
- fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- // Sort data by id in descending order (smallest id at the bottom)
- const sortedData = data.sort((b, a) => a.sku.id - b.sku.id);
-
- sortedData.forEach(user => {
- const template = document.querySelector("[data-potion-card-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const banner = category.querySelector("[data-potion-card-holder]");
- banner.id = user.sku_id;
-
- const summary = category.querySelector("[data-potion-card-desc]");
- summary.textContent = user.summary;
-
- const title = category.querySelector("[data-potion-card-title]");
- title.textContent = user.sku.name;
-
- const price = category.querySelector("[data-potion-card-price]");
- // Display "US$" only if a valid price amount is present
- price.textContent = user?.sku?.price?.amount
- ? 'US$' + formatPrice(user.sku.price.amount)
- : 'UNAVAILABLE';
-
- const sku = category.querySelector("[data-potion-card-sku]");
- sku.textContent = 'SKU ID: ' + user.sku.id;
-
- // Append the category to the output section
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
-
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-}
-
-// Initial data fetch when the page loads
-window.onload = fetchData;
diff --git a/assets/18.js b/assets/18.js
deleted file mode 100644
index f539014..0000000
--- a/assets/18.js
+++ /dev/null
@@ -1,76 +0,0 @@
-let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/collectible-assets';
-
-// Function to clear the shop data
-function clearShopData() {
- const output = document.querySelector("[data-shop-output]");
- output.innerHTML = ''; // Clears the content of the shop category
- document.getElementById("shop-category-loading").classList.remove('hidden');
-}
-
-// Function to fetch and display shop data
-function fetchData() {
-
- // Clear the previous data
- clearShopData();
-
- // Fetch new data
- fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- // Sort data by id in descending order (smallest id at the bottom)
-
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.banner;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
-
- const hero_logo = category.querySelector("[data-shop-category-hero_logo-image]");
- hero_logo.src = user.hero_logo;
-
- const logoImage1 = category.querySelector("[data-shop-category-logo-image-1]");
- logoImage1.src = user.logo;
-
- const mobile_bg = category.querySelector("[data-shop-category-mobile_bg-image]");
- mobile_bg.src = user.mobile_bg;
-
- const pdp_bg = category.querySelector("[data-shop-category-pdp_bg-image]");
- pdp_bg.src = user.pdp_bg;
-
- const success_modal_bg = category.querySelector("[data-shop-category-success_modal_bg-image]");
- success_modal_bg.src = user.success_modal_bg;
-
- const mobile_banner = category.querySelector("[data-shop-category-mobile_banner-image]");
- mobile_banner.src = user.mobile_banner;
-
- const featured_block = category.querySelector("[data-shop-category-featured_block-image]");
- featured_block.src = user.featured_block;
-
- const hero_banner = category.querySelector("[data-shop-category-hero_banner-image]");
- hero_banner.src = user.hero_banner;
-
- output.append(category);
- });
- document.querySelectorAll('.shop-category-assets-holder').forEach(element => {
- element.addEventListener('click', function() {
- this.classList.toggle('expanded');
- });
- });
- document.getElementById("shop-category-loading").classList.add('hidden');
-
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-}
-
-// Initial data fetch when the page loads
-window.onload = fetchData;
diff --git a/assets/19.js b/assets/19.js
deleted file mode 100644
index c57ef4c..0000000
--- a/assets/19.js
+++ /dev/null
@@ -1,22405 +0,0 @@
-
-
-app_version1 = "427"
-app_version2 = "Dev"
-tcbx926n29 = app_version2 + " " + app_version1;
-
-let modalIsAlreadyOpen = false;
-let discordProfileEffectsCache = null;
-let pplusProfileEffectsCache = null;
-let communityThemesCache = null;
-let atMeUsercache = null;
-let claimablesShopcache = null;
-let myXPBalancecache = null;
-let myClaimablesClaimedCache = null;
-let claimablesPromotionsCache = null;
-
-defaultAvatar1 = ``;
-defaultAvatar2 = ``;
-defaultAvatar3 = ``;
-defaultAvatar4 = ``;
-defaultAvatar5 = ``;
-defaultAvatar6 = ``;
-
-localStorage.experiment_2025_02_mobile_render = "Treatment 1: Use new mobile check";
-
-if (!localStorage.ext_sty_category_tab) {
- localStorage.ext_sty_category_tab = "1";
-}
-
-if (!localStorage.reviews_filter_type) {
- localStorage.reviews_filter_type = "2";
-}
-
-if (!localStorage.reviews_privacy_type) {
- localStorage.reviews_privacy_type = "1";
-}
-
-if (!localStorage.reviews_time_type) {
- localStorage.reviews_time_type = "us";
-}
-
-if (localStorage.sa_theme) {
- document.body.classList.add('theme-' + localStorage.sa_theme);
-} else if (!localStorage.sa_theme) {
- localStorage.sa_theme = "dark";
- document.body.classList.add('theme-dark');
-}
-
-let communityThemeImport = document.createElement("style");
-
-communityThemeImport.id = 'community-theme-import';
-if (localStorage.community_theme_raw) {
- communityThemeImport.innerHTML = `${localStorage.community_theme_raw}`;
-}
-
-document.body.appendChild(communityThemeImport);
-
-if (localStorage.discord_banner) {
-
-} else {
- localStorage.discord_banner = ``;
-}
-
-if (localStorage.discord_banner_color) {
-
-} else {
- localStorage.discord_banner_color = `#829ff4`;
-}
-
-if (localStorage.discord_avatar && localStorage.discord_avatar != '') {
-
-} else {
- setRandomDiscordAvatar()
-}
-
-function setRandomDiscordAvatar() {
- localStorage.discord_avatar = ``;
- const randomAvatar = Math.floor(Math.random() * (6 - 1 + 1)) + 1;
-
- if (randomAvatar === 1) {
- localStorage.discord_avatar = defaultAvatar1;
- } else if (randomAvatar === 2) {
- localStorage.discord_avatar = defaultAvatar2;
- } else if (randomAvatar === 3) {
- localStorage.discord_avatar = defaultAvatar3;
- } else if (randomAvatar === 4) {
- localStorage.discord_avatar = defaultAvatar4;
- } else if (randomAvatar === 5) {
- localStorage.discord_avatar = defaultAvatar5;
- } else if (randomAvatar === 6) {
- localStorage.discord_avatar = defaultAvatar6;
- }
-}
-
-
-if (localStorage.discord_username && localStorage.discord_username != '') {
-
-} else {
- setRandomDiscordUsername()
-}
-
-function setRandomDiscordUsername() {
- localStorage.discord_username = `default_user`;
- // fetch('https://apis.kahoot.it/namerator')
- // .then(response => response.json())
- // .then((data) => {
- // localStorage.discord_username = data.name.toLowerCase();
- // localStorage.discord_displayname = data.name;
- // })
-
-}
-
-
-if(/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)){
- if (localStorage.experiment_2025_02_mobile_render === "Treatment 1: Use new mobile check") {
-
-
-
-
-
- document.getElementById("options-sidebar-container").remove();
-
- sessionStorage.setItem('api-token', 'token');
-
- const api_password = localStorage.getItem("api-password");
- const discord_token = localStorage.getItem("discord_token");
- const api_token = sessionStorage.getItem("api-token");
- api = 'https://api.yapper.shop/v2';
- discordsupport = 'https://support.discord.com/hc/en-us/articles/';
- discordblog = 'https://discord.com/blog/';
- yapperblog = 'https://yapper.shop/blog/';
- cdn = 'https://cdn.yapper.shop/';
- tmpapi = 'https://api.yapper.shop/tmp';
-
-
- endpoints = [
- COLLECTIBLES = "/collectibles-shop?tab=shop&has-leaks=true",
- COLLECTIBLES_IN_SHOP = "/collectibles-categories-published",
- CONSUMABLES = "/consumables",
- MISCELLANEOUS = "/collectibles-shop?tab=miscellaneous",
- PROFILES_PLUS = "/collectibles-shop?tab=pplus",
- HOME_PAGE_ALL = "/preview-1",
- HOME_PAGE_LEAKS = "/preview-2",
- HOME_PAGE_PPLUS = "/preview-3",
- PROFILE_EFFECTS = "/profile-effects?tab=discord",
- DOWNLOADABLE_DATA = "/downloads",
- PROFILES_PLUS_EFFECTS = "/profile-effects?tab=pplus",
- LEAKS = "/leaked-categories",
- COLLECTIBLES_MARKETING = "/collectibles-marketing",
- COLLECTIBLES_VARIANTS = "/collectibles-categories-variants",
- EXPERIMENT_ROLLOUTS = "/rollout-handler",
- COLLECTIBLES_SHOP_HOME = "/collectibles-shop-home",
- NEW_ITEMS = "/new-items",
- ORBS_SHOP = "/orbs-shop",
- ORBS_SHOP_DEFAULT = "/orbs-shop-default"
- ]
-
- yapper_categories = [
- WINDOWKILL = "profiles-plus-1",
- BOPL_BATTLE = "profiles-plus-2",
- PAPER_BEACH = "profiles-plus-3",
- WINDOWKILL_V2 = "profiles-plus-4",
- FIVE_NIGHTS_AT_FREDDYS = "profiles-plus-5",
- PLUS_SPECIAL_EVENT = "profiles-plus-6",
- GEOMETRY_DASH = "profiles-plus-7",
- PAPER_BEACH_V2 = "profiles-plus-8",
- RBXDOORS = "profiles-plus-9"
- ]
-
-
- discord_categories = [
- FANTASY = "1144003461608906824",
- ANIME = "1144302037593497701",
- BREAKFAST = "1144054000099012659",
- DISXCORE = "1144058340327047249",
- FALL = "1157406994873991284",
- HALLOWEEN = "1157410718711304313",
- WINTER = "1174459301239197856",
- MONSTERS = "1179493515038818325",
- CYBERPUNK = "1197342727608746044",
- LUNAR_NEW_YEAR = "1202069709281828935",
- ELEMENTS = "1207046915880124426",
- ANIME_V2 = "1212565175790473246",
- SPECIAL_EVENTS = "1217175518781243583",
- SPECIAL_EVENTS_2 = "1309309974266118144",
- SPRINGTOONS = "1217622942175727736",
- SHY = "1220513972189663413",
- LOFI_VIBES = "1228243842684162121",
- GALAXY = "1232029045928099922",
- FEELIN_RETRO = "1237649643073044491",
- PIRATES = "1237653589896200272",
- ARCADE = "1245086656973901894",
- TIDE = "1252404112650407998",
- DARK_FANTASY = "1256321669388308595",
- ROBERT = "1262491137386614805",
- STORM = "1265375293397270650",
- DOJO = "1266520267946201099",
- THE_VAULT = "1277733175191277721",
- AUTUMN_EQUINOX = "1282816432056569866",
- BAND = "1285465421339693076",
- SPOOKY_NIGHT = "1287835634089594972",
- CHANCE = "1293373563494993952",
- MYTHICAL_CREATURES = "1298033986811068497",
- WARRIOR = "1303490165284802580",
- KAWAII_MODE = "1306330663213072494",
- LOFI_GIRL = "1309668861943218229",
- WINTER_WONDERLAND = "1314020997204283476",
- FANTASY_V2 = "1324454241254903829",
- STEAMPUNK = "1326333074241486859",
- PROGRESS = "1333278032999485461",
- RADIATE = "1336483992429658112",
- VALENTINES = "1333866045521395723",
- ORB = "1332505418219655258",
- ANIME_V3 = "1341506445249609728",
- INSOMNIA = "1343751621364027462",
- NAMEPLATE_TEST = "1344802365307621427",
- AESPA = "1346499610977243196"
- ]
-
- category_types = [
- HERO = 0,
- FEATURED = 1,
- FEED = 2,
- WIDE_BANNER = 3
- ]
-
- item_types = [
- NONE = 100,
- AVATAR_DECORATION = 0,
- PROFILE_EFFECT = 1,
- NAMEPLATE = 2,
- BUNDLE = 1e3,
- VARIANTS_GROUP = 2e3,
- EXTERNAL_SKU = 3e3
- ]
-
- const nameplate_palettes = {
- crimson: {
- "darkBackground": "#900007",
- "lightBackground": "#E7040F"
- },
- berry: {
- "darkBackground": "#893A99",
- "lightBackground": "#B11FCF"
- },
- sky: {
- "darkBackground": "#0080B7",
- "lightBackground": "#56CCFF"
- },
- teal: {
- "darkBackground": "#086460",
- "lightBackground": "#7DEED7"
- },
- forest: {
- "darkBackground": "#2D5401",
- "lightBackground": "#6AA624"
- },
- bubble_gum: {
- "darkBackground": "#DC3E97",
- "lightBackground": "#F957B3"
- },
- violet: {
- "darkBackground": "#730BC8",
- "lightBackground": "#972FED"
- },
- cobalt: {
- "darkBackground": "#0131C2",
- "lightBackground": "#4278FF"
- },
- clover: {
- "darkBackground": "#047B20",
- "lightBackground": "#63CD5A"
- }
- }
-
- const params = new URLSearchParams(window.location.search);
-
- function setParams(params) {
- const url = new URL(window.location);
-
- // Clear all existing query parameters
- url.search = '';
-
- // Set the new query parameters from the provided object
- Object.entries(params).forEach(([key, value]) => {
- url.searchParams.set(key, value);
- });
-
- // Update the address bar without reloading the page
- history.replaceState(null, '', url);
- }
-
- function addParams(params) {
- const url = new URL(window.location);
-
- Object.entries(params).forEach(([key, value]) => {
- url.searchParams.set(key, value);
- });
-
- history.replaceState(null, '', url);
- }
-
- const clickable_side_tabs_container = document.getElementById('clickable-side-tabs-container');
- if (clickable_side_tabs_container) { // Check if element exists
- document.getElementById('clickable-side-tabs-container').innerHTML = `
-
- Shop
-
-
-
- `;
-
- if (localStorage.experiment_2025_02_profiles_plus_home === "Treatment 2: Enabled") {
- document.getElementById('new-profiles-plus-tab-container').innerHTML = `
- Profiles Plus
-
- `;
- }
-
- if (localStorage.experiment_2025_02_profiles_plus_home === "Treatment 3: Hide All Profiles Plus Tabs") {
- document.getElementById('new-profiles-plus-tab-container').innerHTML = ``;
- }
- }
-
- function pageCheck() {
- // if (params.get("page") === "home") {
- // document.title = "Featured | Shop Archives";
- // if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- // if (localStorage.unreleased_discord_collectibles == "true") {
- // url = api + HOME_PAGE_ALL;
- // apiUrl = new URL(url);
- // apiUrl.searchParams.set("include-unpublished", "true");
- // } else {
- // apiUrl = api + HOME_PAGE_ALL;
- // }
- // } else {
- // apiUrl = api + HOME_PAGE_ALL;
- // }
- // createHomePageElement()
- // document.getElementById("home-tab").classList.add('dm-button-selected');
- // document.getElementById("top-bar-container").innerHTML = `
- // Featured
- //
- // `;
- // } else if (params.get("page") === "year_recap") {
- // document.title = "2025 Recap | Shop Archives";
- // document.getElementById("recap-2024-tab").classList.add('dm-button-selected');
- // localStorage.dismissible_recap_2024 = "Treatment 1: Seen";
- // document.getElementById("top-bar-container").innerHTML = `
- // 2025 Recap
- //
- // `;
- // } else
-
- if (params.get("page") === "shop") {
- document.title = "Shop All | Shop Archives";
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- if (localStorage.unreleased_discord_collectibles == "true") {
- url = api + COLLECTIBLES;
- apiUrl = new URL(url);
- apiUrl.searchParams.set("include-unpublished", "true");
- } else {
- apiUrl = api + COLLECTIBLES;
- }
- } else {
- apiUrl = api + COLLECTIBLES;
- }
- createMainShopElement()
- document.getElementById("shop-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Shop > Shop All
-
- `;
- }
-
- // else if (params.get("page") === "orbs") {
- // document.title = "Orb Rewards | Shop Archives";
- // if (localStorage.experiment_2025_02_orbs_shop === "Treatment 2: Orb Shop done like default") {
- // apiUrl = api + ORBS_SHOP_DEFAULT;
- // } else {
- // apiUrl = api + ORBS_SHOP;
- // }
- // createMainPotionsElement()
- // document.getElementById("top-bar-container").innerHTML = `
- // Shop > Orb Rewards
- //
- // `;
- // }
- // else if (params.get("page") === "leaks") {
- // document.title = "Leaks | Shop Archives";
- // if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- // if (localStorage.unreleased_discord_collectibles == "true") {
- // url = api + LEAKS;
- // apiUrl = new URL(url);
- // apiUrl.searchParams.set("include-unpublished", "true");
- // } else {
- // apiUrl = api + LEAKS;
- // }
- // } else {
- // apiUrl = api + LEAKS;
- // }
- // createMainShopElement()
- // document.getElementById("top-bar-container").innerHTML = `
- // Shop > Leaks
- //
- // `;
- // }
- else if (params.get("page") === "consumables") {
- document.title = "Potions | Shop Archives";
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- if (localStorage.unreleased_discord_collectibles == "true") {
- url = api + CONSUMABLES;
- apiUrl = new URL(url);
- apiUrl.searchParams.set("include-unpublished", "true");
- } else {
- apiUrl = api + CONSUMABLES;
- }
- } else {
- apiUrl = api + CONSUMABLES;
- }
- createMainPotionsElement()
- document.getElementById("potions-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Shop > Potions
-
- `;
- } else if (params.get("page") === "miscellaneous") {
- document.title = "Miscellaneous | Shop Archives";
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- if (localStorage.unreleased_discord_collectibles == "true") {
- url = api + MISCELLANEOUS;
- apiUrl = new URL(url);
- apiUrl.searchParams.set("include-unpublished", "true");
- } else {
- apiUrl = api + MISCELLANEOUS;
- }
- } else {
- apiUrl = api + MISCELLANEOUS;
- }
- createMainShopElement()
- document.getElementById("miscellaneous-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Shop > Miscellaneous
-
- `;
- }
- // else if (params.get("page") === "pplus-home") {
- // document.title = "Featured | Shop Archives";
- // if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- // if (localStorage.unreleased_profiles_plus == "true") {
- // url = api + HOME_PAGE_PPLUS;
- // apiUrl = new URL(url);
- // apiUrl.searchParams.set("include-unpublished", "true");
- // } else {
- // apiUrl = api + HOME_PAGE_PPLUS;
- // }
- // } else {
- // apiUrl = api + HOME_PAGE_PPLUS;
- // }
- // createHomePageElement()
- // document.getElementById("pplus-home-tab").classList.add('dm-button-selected');
- // document.getElementById("top-bar-container").innerHTML = `
- // Profiles Plus > Featured
- //
- // `;
- // }
-
- else if (params.get("page") === "pplus") {
- document.title = "Profiles Plus | Shop Archives";
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- if (localStorage.unreleased_profiles_plus == "true") {
- url = api + PROFILES_PLUS;
- apiUrl = new URL(url);
- apiUrl.searchParams.set("include-unpublished", "true");
- } else {
- apiUrl = api + PROFILES_PLUS;
- }
- } else {
- apiUrl = api + PROFILES_PLUS;
- }
- if (localStorage.experiment_2024_12_profiles_plus_marketing_variants == "Treatment 1: Paper Beach V2") {
- localStorage.dismissible_paper_beach_v2_marketing = "Treatment 1: Seen";
- } else if (localStorage.experiment_2024_12_profiles_plus_marketing_variants == "Treatment 2: Roblox Doors") {
- localStorage.dismissible_roblox_doors_marketing = "Treatment 1: Seen";
- }
- createMainShopElement()
- document.getElementById("pplus-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Profiles Plus > Browse All
-
- `;
- } else if (params.get("page") === "published_listings") {
- document.title = "Published Listings | Shop Archives";
- createPublishedListingsPageElement()
- document.getElementById("published-listings-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Published Listings
-
- `;
- } else if (params.get("page") === "orb_converter") {
- document.title = "Orb Converter | Shop Archives";
- createOrbConverterPageElement()
- document.getElementById("orb-converter-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Orb Converter
-
- `;
- } else if (params.get("page") === "item_tool") {
- document.title = "Item Tool | Shop Archives";
- createItemToolPageElement()
- document.getElementById("avatar-decorations-debug-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- Item Tool | Staff Only
-
- `;
- } else {
- setParams({page: 'shop',err: '404'});
- document.title = "Shop All | Shop Archives";
- location.reload();
- }
- }
-
- pageCheck();
-
- function fetchData() {
- if (params.get("page") != "home" && params.get("page") != "pplus-home" && params.get("page") != "year-recap") {
-
-
- // Make the function async
- fetch(apiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
-
- if (data.message === "Missing Access") {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
Well, this is awkward.
-
Hmmm, we weren’t able to load the shop. Check back later.
-
Error: Missing Access
-
Reload
-
- `;
- } else {
- processCategories();
- }
- // Define async function inside the .then block
- async function processCategories() {
- const categoryTemplate = document.querySelector("[data-shop-category-template]");
- const potionTemplate = document.querySelector("[data-potion-card-template]");
- const categoryOutput = document.querySelector("[data-shop-output]");
- const page = params.get("page");
-
- for (const apiCategory of data) {
- if (page === "pplus") {
- // Existing code for 'pplus' page
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.mobile_banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = 'No Mobile Banner';
-
- if (apiCategory.category_bg != null) {
- category.querySelector("[data-shop-category-marketing-bg]").src = `https://cdn.yapper.shop/assets/${apiCategory.category_bg}.png`;
- }
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- if (product.type === NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === AVATAR_DECORATION) {
- product.items.forEach(item => {
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `Made By: ${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/${item.animated}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (product.type === PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = `Made By: ${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILES_PLUS_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === NAMEPLATE) {
- card.classList.add("type_2");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
- `;
-
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
-
- nameplatePreview.style.backgroundImage = `linear-gradient(10deg, #00000000 40%,rgb(144, 0, 7) 180%), linear-gradient(170deg, #00000000 40%,rgb(144, 0, 7) 180%)`;
- nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- } else if (product.type === BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = "Bundle Includes: ";
- if (type0Product) {
- bundleSummary += `${type0Product.name} Decoration`;
- }
- if (type1Product) {
- bundleSummary += ` & ${type1Product.name} Profile Effect`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- card.querySelector("[data-product-card-sku-id]").textContent = `Made By: ${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.animated}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- let discordProfileEffectsCache = null; // Cache profile effects to avoid multiple fetches
-
- (async () => {
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILES_PLUS_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === VARIANTS_GROUP) {
- // Update SKU and summary
- card.querySelector("[data-product-card-sku-id]").textContent = `Made By: ${product.credits}`;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.animated}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.animated}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/${item.static}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILES_PLUS_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- previewHolder.innerHTML = `
- item type 3000 (EXTERNAL_SKU) is not yet defined on the client, please remove it from the api
- `;
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `Plus More...`;
- card.querySelector("[data-product-card-summary]").textContent = `There are more items in this category that are coming soon.`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
-
- if (product.emojiCopy === null) {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- Request to P+
- `;
- } else {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- Copy P+ Emoji
- `;
- }
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days} DAYS LEFT TO REQUEST
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
EXPIRES IN ${days}D ${hours}H
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- card.classList.add('shop-category-card-transparent')
- cardOutput.append(card);
- }
- }
-
- categoryOutput.append(category);
-
-
- } else if (page === "consumables") {
- // Existing code for 'consumables' page
- const potionCard = potionTemplate.content.cloneNode(true).children[0];
- potionCard.querySelector("[data-potion-card-holder]").id = apiCategory.sku_id;
-
- potionCard.id = apiCategory.sku_id;
-
- potionCard.querySelector("[data-potion-card-holder]").classList.add('potion-card-gradient1');
-
- if (apiCategory.src === null) {
- potionCard.querySelector("[data-potion-card-preview-image]").src = `https://cdn.yapper.shop/assets/31.png`;
- } else {
- potionCard.querySelector("[data-potion-card-preview-image]").src = `https://cdn.yapper.shop/${apiCategory.endpoint}/${apiCategory.src}.${apiCategory.format}`;
- }
- potionCard.querySelector("[data-potion-card-preview-image]").alt = apiCategory.name;
-
- if (apiCategory.new_text != null) {
- potionCard.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${apiCategory.new_text}
-
- `;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- potionCard.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- potionCard.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${apiCategory.sku_id}`;
- }
- potionCard.querySelector("[data-product-card-name]").textContent = apiCategory.name;
- potionCard.querySelector("[data-product-card-summary]").textContent = apiCategory.summary;
-
- let priceStandard = "N/A";
-
- if (apiCategory.price) {
- priceStandard = apiCategory.price.amount;
- }
-
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- potionCard.classList.add('clickable');
-
- potionCard.addEventListener("click", () => {
- openItemModal();
- });
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-potion-img');
-
- const imgElement = document.createElement("img");
- imgElement.classList.add('potion-card-preview');
- imgElement.src = `https://cdn.yapper.shop/${apiCategory.endpoint}/${apiCategory.src}.${apiCategory.format}`;
-
- previewHolder.appendChild(imgElement);
-
- // Set the product details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${apiCategory.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = apiCategory.name;
- modal.querySelector("[data-product-modal-summary]").textContent = apiCategory.summary;
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else {
- button_container.innerHTML = `
- Open Support Article
- `;
- }
-
-
- let priceStandard = "N/A";
-
- if (apiCategory.price) {
- priceStandard = apiCategory.price.amount;
- }
-
-
- const priceTextNitro = modal.querySelector("[data-price-nitro]");
- const priceTextStandard = modal.querySelector("[data-price-standard]");
-
- const priceContainerNitro = modal.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = modal.querySelector("[data-price-standard-container]");
-
- const priceContainer = modal.querySelector("[data-shop-price-container]");
-
- if (localStorage.experiment_2025_01_orb_testing === "Treatment 1: Default Prices") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 2: 50 Orbs") {
- if (priceTextStandard) {
- priceTextStandard.textContent = `50`;
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 3: Dynamic") {
-
- if (apiCategory.price.currency === "discord_orb") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- if (apiCategory.new_text != null) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${apiCategory.new_text}
-
- `;
- }
-
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- modal.classList.add('potion-wobble')
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- modal.classList.remove('potion-wobble')
- });
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
-
- const priceTextNitro = potionCard.querySelector("[data-price-nitro]");
- const priceTextStandard = potionCard.querySelector("[data-price-standard]");
-
- const priceContainerNitro = potionCard.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = potionCard.querySelector("[data-price-standard-container]");
-
- const priceContainer = potionCard.querySelector("[data-shop-price-container]");
-
- if (localStorage.experiment_2025_01_orb_testing === "Treatment 1: Default Prices") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 2: 50 Orbs") {
- if (priceTextStandard) {
- priceTextStandard.textContent = `50`;
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- potionCard.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- Open Support Article
- `;
-
- potionCard.addEventListener("mouseenter", () => {
- potionCard.classList.add('potion-wobble')
- });
-
- potionCard.addEventListener("mouseleave", () => {
- potionCard.classList.remove('potion-wobble')
- });
-
- categoryOutput.append(potionCard);
- } else {
- // Default page handling
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
-
- // Banner Image/Video asset
-
- if (apiCategory.mobile_banner === null) {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.banner}.png?size=4096`;
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.mobile_banner}.png?size=4096`;
- }
- category.querySelector("[data-shop-category-banner-image]").alt = 'No Mobile Banner';
-
- if (apiCategory.mobile_bg != null) {
- category.querySelector("[data-shop-category-marketing-bg]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.mobile_bg}.png?size=4096`;
- }
-
-
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-banner-banner-container`;
-
-
- const unpublishedAt = new Date(apiCategory.unpublished_at);
-
- if (apiCategory.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- category.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- category.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days} DAYS LEFT IS SHOP
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- if (product.type === NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === AVATAR_DECORATION) {
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.type === PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === NAMEPLATE) {
- card.classList.add("type_2");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}asset.webm`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- const videoElement = previewHolder.querySelector("[data-user-nameplate-preview-img]");
-
- videoElement.src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(10deg, #00000000 40%, ${bgcolor} 180%), linear-gradient(170deg, #00000000 40%, ${bgcolor} 180%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- videoElement.play();
- });
- card.addEventListener("mouseleave", () => {
- videoElement.pause();
- });
- }
- });
-
- } else if (product.type === BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = "Bundle Includes: ";
- if (type0Product) {
- bundleSummary += `${type0Product.name} Decoration`;
- }
- if (type1Product) {
- bundleSummary += ` & ${type1Product.name} Profile Effect`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- // Fetch profile effects if not cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === VARIANTS_GROUP) {
- // Update SKU and summary
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals != "Treatment 1: Enable modals" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 2: Enable modals w/ data downloads" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 3: Enable modals w/ p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 4: Enable modals w/ p+ on p+ page" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 5: Enable modals w/ data downloads and p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
- }
-
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- previewHolder.innerHTML = `
- item type 3000 (EXTERNAL_SKU) is not yet defined on the client, please remove it from the api
- `;
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `Plus More...`;
- card.querySelector("[data-product-card-summary]").textContent = `There are more items in this category that are coming soon.`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
- const priceTextNitro = card.querySelector("[data-price-nitro]");
- const priceTextStandard = card.querySelector("[data-price-standard]");
-
- const priceContainerNitro = card.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = card.querySelector("[data-price-standard-container]");
-
- const priceContainer = card.querySelector("[data-shop-price-container]");
-
- let priceStandard = "N/A";
- let priceNitro = "N/A";
- let priceOrb = "N/A";
-
- if (localStorage.experiment_2025_02_extra_options === "Treatment 4: Enabled") {
- if (localStorage.discord_premium_type === "2") {
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- standardPriceOutput = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- priceContainerStandard.innerHTML = `
- ${standardPriceOutput}
-
- `;
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- if (priceOrb != 'N/A') {
- priceContainer.appendChild(orb_price);
- }
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- if (priceOrb != 'N/A') {
- priceContainer.appendChild(orb_price);
- }
- }
-
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceNitro = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- if (priceTextNitro) {
- priceTextNitro.textContent = priceNitro !== "N/A" ? `US$${(priceNitro / 100).toFixed(2)} with Nitro` : "null";
- }
- }
-
- if (priceTextStandard.textContent === "null" || priceTextNitro.textContent === "null") {
- let error_warning = document.createElement("div");
-
- error_warning.classList.add('card_error');
- error_warning.innerHTML = `
- ERROR
- `;
-
- card.appendChild(error_warning);
- }
-
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- Open In Shop
- `;
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days} DAYS LEFT IN SHOP
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
EXPIRES IN ${days}D ${hours}H
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- cardOutput.append(card);
- }
- }
-
- categoryOutput.append(category);
- }
- }
- }
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
Well, this is awkward.
-
Hmmm, we weren’t able to load the shop. Check back later.
-
${error}
-
Reload
-
- `;
- });
-
- }
- }
-
- fetchData()
-
-
- function createMainShopElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Open In Shop
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
-
-
- }
-} else if (localStorage.full_client_rework != "false") {
-
- experimentsList.forEach(({ name, rollout }) => {
- try {
- if (localStorage.experiment_force_rollout != "false") {
- localStorage.setItem(name, rollout);
- } else if (localStorage.getItem(name) == null) {
- localStorage.setItem(name, rollout);
- }
-
- } catch (error) {
- console.error(`Error setting up experiment: ${name}`, error);
- }
- });
-
- function clearSetExperiment(experimentName) {
- const experiment = experimentsList.find(exp => exp.name === experimentName);
-
- if (!experiment) {
- console.warn(`Experiment "${experimentName}" not found.`);
- return;
- }
-
- const { rollout } = experiment;
- const treatmentPicker = document.getElementById(`${experimentName}_treatment_container`);
-
- if (treatmentPicker) {
- treatmentPicker.value = rollout;
- localStorage.setItem(experimentName, rollout);
- }
- }
-
- sessionStorage.setItem('api-token', 'token');
-
- const api_password = localStorage.getItem("api-password");
- const discord_token = localStorage.getItem("discord_token");
- const shop_archives_token = localStorage.getItem("shop_archives_token");
- const api_token = sessionStorage.getItem("api-token");
-
- // api = 'https://raw.githubusercontent.com/Yappering/api/main/v2';
- api = 'https://api.yapper.shop/v2';
- prvapi = 'https://raw.githubusercontent.com/Yappering/private-api/refs/heads/main/v2';
- discordsupport = 'https://support.discord.com/hc/en-us/articles/';
- discordblog = 'https://discord.com/blog/';
- apidesignedurl = 'https://api.yapper.shop/v2';
- yapperblog = 'https://yapper.shop/blog/';
- yappersupport = 'https://support.yapper.shop/?page=';
- cdn = 'https://cdn.yapper.shop/';
- tmpapi = 'https://api.yapper.shop/tmp';
-
- function privateAPICheck() {
- // if (localStorage.force_all_api_to_fectch_private_api == "true") {
- // api = prvapi;
- // tmpapi = 'https://raw.githubusercontent.com/Yappering/api/main/tmp';
- // } else if (localStorage.api_designed_url != "false") {
- // api = apidesignedurl;
- // } else {
- // api = 'https://raw.githubusercontent.com/Yappering/api/main/v2';
- // tmpapi = 'https://raw.githubusercontent.com/Yappering/api/main/tmp';
- // }
- }
-
-
- endpoints = [
- DOWNLOADABLE_DATA = "/downloads",
- COLLECTIBLES_SHOP = "/collectibles-shop",
- PROFILE_EFFECTS = "/profile-effects",
- COMMUNITY = "/community",
- APISTATUS = "/status",
- REVIEWSAPI = "/reviews",
- CLAIMABLES_SHOP = "/claimables-shop",
- XP_BALANCE = "/users/@me/xp-balance",
- CLAIMABLES_CLAIMED = "/users/@me/claimables-claimed",
- CLAIMABLES_PROMOTIONS = "/users/@me/claimables-promotions",
- REDEEM_GIFT_CODE = "/redeem-gift-code/"
- ]
- if (app_version2 === "Dev") {
- LOGIN_CALLBACK = "/dev/callback"
- } else {
- LOGIN_CALLBACK = "/callback"
- }
-
- const CUSTOM_EMOJIS = {
- ":thing:": "https://cdn.discordapp.com/emojis/1322807908471275561.webp?size=24",
- ":yapping_head:": "https://cdn.discordapp.com/emojis/1243471467392274544.webp?size=24",
- ":no_yapping:": "https://cdn.discordapp.com/emojis/1280620352338264207.webp?size=24"
- };
-
-
- yapper_categories = [
- WINDOWKILL = "1",
- BOPL_BATTLE = "7",
- PAPER_BEACH = "20",
- WINDOWKILL_V2 = "35",
- FIVE_NIGHTS_AT_FREDDYS = "54",
- PLUS_SPECIAL_EVENT = "55",
- GEOMETRY_DASH = "68",
- PAPER_BEACH_V2 = "77",
- RBXDOORS = "82",
- DATA_EXTRACTION_PROCESS = "85",
- HOAX = "86"
- ]
-
- claimable_types = {
- REWARD: 0,
- PURCHASE: 1
- };
-
- discord_categories = {
- FANTASY: "1144003461608906824",
- ANIME: "1144302037593497701",
- BREAKFAST: "1144054000099012659",
- DISXCORE: "1144058340327047249",
- FALL: "1157406994873991284",
- HALLOWEEN: "1157410718711304313",
- WINTER: "1174459301239197856",
- MONSTERS: "1179493515038818325",
- CYBERPUNK: "1197342727608746044",
- LUNAR_NEW_YEAR: "1202069709281828935",
- ELEMENTS: "1207046915880124426",
- ANIME_V2: "1212565175790473246",
- SPECIAL_EVENTS: "1217175518781243583",
- SPECIAL_EVENTS_2: "1309309974266118144",
- SPRINGTOONS: "1217622942175727736",
- SHY: "1220513972189663413",
- LOFI_VIBES: "1228243842684162121",
- GALAXY: "1232029045928099922",
- FEELIN_RETRO: "1237649643073044491",
- PIRATES: "1237653589896200272",
- ARCADE: "1245086656973901894",
- TIDE: "1252404112650407998",
- DARK_FANTASY: "1256321669388308595",
- ROBERT: "1262491137386614805",
- STORM: "1265375293397270650",
- DOJO: "1266520267946201099",
- THE_VAULT: "1277733175191277721",
- AUTUMN_EQUINOX: "1282816432056569866",
- BAND: "1285465421339693076",
- SPOOKY_NIGHT: "1287835634089594972",
- CHANCE: "1293373563494993952",
- MYTHICAL_CREATURES: "1298033986811068497",
- WARRIOR: "1303490165284802580",
- KAWAII_MODE: "1306330663213072494",
- LOFI_GIRL: "1309668861943218229",
- WINTER_WONDERLAND: "1314020997204283476",
- FANTASY_V2: "1324454241254903829",
- STEAMPUNK: "1326333074241486859",
- PROGRESS: "1333278032999485461",
- RADIATE: "1336483992429658112",
- VALENTINES: "1333866045521395723",
- ORB: "1332505418219655258",
- ANIME_V3: "1341506445249609728",
- INSOMNIA: "1343751621364027462",
- NAMEPLATE_TEST: "1344802365307621427",
- AESPA: "1346499610977243196",
- NAMEPLATE: "1349849614353829990",
- HOLIDAYS: "1349486948942745691",
- SHENANIGANS: "1352407446500675708",
- CHIBI_CAFE: "1354894010849820852",
- GGEZ: "1357589632723849316",
- HELLO: "1365410896222097539",
- COZY_VALLEY: "1369434230962262128",
- RC_TEST: "1370467303782617118",
- LEAF: "1373015260595884082"
- };
-
- discord_app_ids = {
- COLLECTIBLES_SHOP: "1096190356233670716",
- SHOP_ARCHIVES: "1342635740768501886"
- };
-
- external_skus = [
- NITRO_CREDITS_3_DAYS = "1333912750274904064",
- ORB_PROFILE_BADGE = "1342211853484429445"
- ]
-
- category_types = [
- HERO = 0,
- FEATURED = 1,
- FEED = 2,
- WIDE_BANNER = 3
- ]
-
- item_types = {
- NONE: 100,
- AVATAR_DECORATION: 0,
- PROFILE_EFFECT: 1,
- NAMEPLATE: 2,
- BUNDLE: 1e3,
- VARIANTS_GROUP: 2e3,
- EXTERNAL_SKU: 3e3
- }
-
- const nameplate_palettes = {
- crimson: {
- "darkBackground": "#900007",
- "lightBackground": "#E7040F"
- },
- berry: {
- "darkBackground": "#893A99",
- "lightBackground": "#B11FCF"
- },
- sky: {
- "darkBackground": "#0080B7",
- "lightBackground": "#56CCFF"
- },
- teal: {
- "darkBackground": "#086460",
- "lightBackground": "#7DEED7"
- },
- forest: {
- "darkBackground": "#2D5401",
- "lightBackground": "#6AA624"
- },
- bubble_gum: {
- "darkBackground": "#DC3E97",
- "lightBackground": "#F957B3"
- },
- violet: {
- "darkBackground": "#730BC8",
- "lightBackground": "#972FED"
- },
- cobalt: {
- "darkBackground": "#0131C2",
- "lightBackground": "#4278FF"
- },
- clover: {
- "darkBackground": "#047B20",
- "lightBackground": "#63CD5A"
- }
- }
-
-
- HELP_AVATAR_DECORATIONS = "13410113109911"
- HELP_SHOP = "17162747936663"
- HELP_PROFILE_EFFECTS = "17828465914263"
- HELP_HD_STREAMING_POTION = "27343254089623"
- HELP_CONFETTI_POTION = "29133681590679"
-
-
- BLOG_AVATAR_DECORATIONS_PROFILE_EFFECTS = "avatar-decorations-collect-and-keep-the-newest-styles"
-
-
- YAPPER_BLOG_2024_RECAP = "2024-recap"
- YAPPER_BLOG_2025_RECAP = "2025-recap"
-
-
- DISMISSIBLE_2024_RECAP = "assets/103.svg"
- DISMISSIBLE_2025_RECAP = "assets/160.png"
-
-
- m = ["1329609528441831537", "1329609528471195659", "1329609528492429332", "1329609528504746075", "1329609528525979658", "1329609528546693170", "1329609528571858975", "1329611507381829702", "1329611507402801312"];
- g = new Date('2025-01-31');
- newColorsSKUIDS = ["1144308439720394944", "1154896005045694555", "1144307257807491094", "1144305233707671573", "1144307629225672846", "1144308196723408958", "1144307957425778779", "1212569856189407352", "1212570343567261736", "1212570596970467378", "1212581390936178768", "1212569433839636530", "1212581147675205652", "1139323101881061466", "1139323093551165533", "1139323101008642101", "1212582298893946880", "1212582372877541427", "1212582452640350238", "1139323100568244355"];
- newColorsExpireDate = new Date('2025-03-08');
- N = new Date();
- I = ["1212569433839636530", "1144308439720394944", "1314020996201713685", "1212570343567261736", "1314020996776329279", "1271174640026255380", "1271175049168031815", "1232073608168472638", "1293373563407175680", "1314020996327542894", "1139323093991575696", "1232071157746765906", "1232071712695386162", "1144307957425778779", "1306330662990643252", "1280621222496964630", "1306330663015809024", "1306330663070334996", "1243617249974288404", "1309668861578186803", "1303490165213237338", "1306330662898372639", "1298033986508951685", "1282816432026943488", "1306330663137443991", "1197344764174008452", "1298033986727055370", "1298033986571866112", "1271175120437641261", "1314020996361093171", "1309668861645426729", "1256321669467865088", "1314020996864413717", "1306752744278982737", "1271174732577767626", "1144307257807491094", "1144308196723408958", "1287835633787732070", "1306330663162609685", "1306330662940311726", "1309668861901279422", "1282816431871754281", "1287835633485877369", "1228234634379132958", "1144305233707671573", "1298033986643169360", "1139323093551165533", "1212569856189407352", "1282816431850782730", "1144307629225672846", "1232070870093008937", "1207047014769234001", "1212582298893946880", "1232073286582538261", "1282816431985004594", "1293373563381878836", "1282816431964028958", "1306752744258011166", "1309668861846753372", "1271174324375519273", "1256321669426053198", "1287835633615765524", "1286504131325853739", "1306330663183581247", "1139323099687436419", "1287835633590734848", "1256321669493166214", "1286504131518791816", "1243620093431119922", "1262492035558932604", "1306330662927859723", "1197344326133502032", "1228251351415263242", "1232073448415821854", "1158572178179108968", "1298033986752221204", "1262491137394868311", "1309668861620260874", "1271174241860980907", "1220513989729976411", "1282820582408192061", "1154896005045694555", "1207047597294886923", "1306330663036780695", "1309668861674786877", "1197344693630009424", "1306330662965477478", "1174460780842856588", "1271174907081789524", "1282816431813169272", "1298033986622328842", "1139323101881061466", "1262491690900656267", "1303490165171294268", "1139323100568244355", "1243619479645065287", "1262491690971955284", "1316087100260483174", "1139323101008642101", "1228251144065777765", "1207048289610899526", "1287835633561239683", "1232072121950146560", "1303490165045727317", "1228246010116050965", "1309668861871919316", "1207049364464345158", "1243618816639107223", "1265421074514841751", "1316087100277395607", "1159280677246742548", "1262492035558932607", "1207047808838799410", "1306752744299954306", "1298033986668335135", "1266160780928352268", "1262491137386614812", "1139323092645183591", "1220513977683935373", "1256321669467865091", "1237654942202990602", "1287835633536209079", "1262491137394868305", "1256321669493166217", "1212582452640350238", "1158572275507937342", "1306752744228524052", "1174459546748600481", "1262491137394868308", "1309668861599285249", "1262492035558932610", "1144046002110738634", "1293373563184877618", "1298033986693500960", "1285465421260263464", "1306330663091306608", "1287835633645125653", "1303490165074825296", "1298033986538569781", "1303490165150322698", "1262491690900656261", "1256321669467865094", "1207048656289534022", "1285681070196396177", "1287835633674620949", "1237654224712765440", "1293373563121696891", "1303490165255180298", "1303490165120962651", "1212582372877541427", "1287835634005970994", "1303490165099991143", "1271564593746939904", "1314020996629532686", "1316087100260483176", "1228233390260486164", "1287835633867559022", "1158572263411556373", "1303490165192265799", "1237654783209508904", "1309668861704146984", "1212581147675205652", "1309668861548957738", "1245088205330710539", "1287835633896783952", "1316087100260483178", "1139323099251232828", "1262491690900656258", "1232072859485208687", "1197344396983664670", "1309668861788033074", "1314020996600172554", "1159280847262859364", "1314020996461760542", "1220514048068812901", "1293373563302318110", "1228251846032756796", "1197344636558114986", "1282820582223642624", "1287835634035331072", "1298033986777387059", "1243619781362450442", "1282816432001777794", "1212570596970467378", "1157409074422481023", "1256321669426053195", "1146328961417224193", "1293373563327483984", "1303490165234208810", "1266160780978556969", "1228237157554978817", "1287835633947115570", "1282820582345408595", "1271174810227179562", "1282816431830077542", "1287835633842258022", "1283211414323990538", "1282820582303334482", "1282820582429298748", "1306330663116472371", "1157407831348228141", "1293373563210043442", "1287835633515102228", "1309668861758672997", "1287835633703845888", "1287835633733341224", "1197344575832981605", "1316087100260483180", "1237653964582031400", "1287835633817227297", "1266493591207940133", "1309668861817393263", "1316087100260483182", "1298033986555351132", "1237650542772228096", "1207049498065375343", "1287835633980669972", "1314020996516286485", "1285465421193154560", "1268362891946627103", "1282820582244880496", "1293373563352649961", "1220432740638523543", "1243620329331626044", "1220432697718083614", "1267521289330102344", "1146328960951668776", "1293373563457507463", "1245088094437507163", "1262491690900656264", "1314020996432400404", "1220513984273186816", "1293373563159449653", "1314020996721803306", "1285681070196396179", "1285465421050548345", "1282820582366511229", "1256321669467865097", "1285465421285429258", "1293373563239272458", "1271174154514595891", "1217625794382401577", "1228252219502100530", "1285465421029576704", "1243618548673417298", "1220432647453409384", "1266493591275044903", "1217626024540508170", "1232072520249643028", "1245088254647205991", "1237654867330469949", "1314020996570812506", "1314020996227006484", "1245087968759382207", "1144006094134456352", "1314020997166403624", "1144048390594908212", "1287835633762701382", "1212581390936178768", "1285465420995756065", "1217626509737459852", "1314020996491116575", "1309668861729312898", "1237650411410685972", "1245087661316898877", "1217627230818009171", "1256321669388308601", "1314020996310896672", "1274105879238676561", "1293373563432341574", "1314020996273016863", "1282816431943057460", "1220513995308400680", "1293373563264569416", "1228252042791878707", "1314020997078323200", "1237654031732703272", "1267521289355268154", "1298033986592837754", "1285465421214126100", "1245087724265013299", "1314020996990242816", "1314020996663087154", "1282820582282629171", "1282816431922085888", "1314020997107683411", "1237654124443734026", "1314020997137043578", "1266161342801383434", "1285465421096685639", "1237654692985700352", "1174459480348565554", "1314020997019602984", "1314020996252176444", "1144003752978829455", "1282816431901118474", "1285465421306400858", "1285465421239291904", "1285465420979245087", "1314020996692447234", "1144048977138946230", "1217627051217911848", "1217626219651006495", "1217625572168044604", "1286504131392962641", "1237650618777075712", "1207048049571139584", "1314020996289921154", "1237654615474962472", "1314020996927328276", "1286504131439366184", "1285465421016862730", "1217625289681801316", "1243619153688920206", "1217624148080332820", "1144049316009353338", "1245481938202918912", "1245088023452975104", "1314020996960882789", "1285465421121851445", "1243617981435478102", "1144049603109470370", "1285465421071519825", "1256321669426053192", "1245087912350187520", "1207049115339591681", "1144049924397334651", "1237649939027333232", "1237650103980920872", "1237650023794081823", "1237650179721527347", "1245087850177888356", "1285465421167988758", "1277733174797008931"];
-
- async function setDiscordProfileEffectCache() {
- url = api + PROFILE_EFFECTS;
- pfxapiUrl = new URL(url);
- pfxapiUrl.searchParams.append("tab", "discord");
- const response = await fetch(pfxapiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- setDiscordProfileEffectCache()
-
- async function setPplusProfileEffectCache() {
- url = api + PROFILE_EFFECTS;
- pfxapiUrl = new URL(url);
- pfxapiUrl.searchParams.append("tab", "pplus");
- const response = await fetch(pfxapiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- pplusProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- setPplusProfileEffectCache()
-
- async function setCommunityThemesCache() {
- url = api + COMMUNITY;
- communityapiUrl = new URL(url);
- communityapiUrl.searchParams.append("tab", "themes");
- if (localStorage.staff_unpublished_community_features == "true") {
- communityapiUrl.searchParams.append("include-unpublished", "true");
- }
- const response = await fetch(communityapiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const themesData = await response.json();
- communityThemesCache = themesData;
- }
-
- setCommunityThemesCache()
-
- if (!atMeUsercache && shop_archives_token) {
- fetch(api + `/users/@me`, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- atMeUsercache = data;
- localStorage.admin_level = data.admin_level;
-
- if (Array.isArray(data.rollouts)) {
- data.rollouts.forEach(rollout => {
-
- if (localStorage.experiment_force_rollout != "false") {
- localStorage.setItem(rollout.name, rollout.rollout);
- }
-
- });
- }
-
- if (localStorage.experiment_2025_05_xp_system === "Treatment 1: Enabled" && localStorage.dismissible_new100FreeXP != "Treatment 1: Seen" && data.claimed_100_free_xp === false) {
- let new100FreeXPDismissible = document.createElement("div");
-
- new100FreeXPDismissible.innerHTML = `
-
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_TITLE")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_SUMMARY_1")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_TAKE_ME_THERE")}
-
${getTextString("DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_LATER")}
-
-
- `;
-
- new100FreeXPDismissible.classList.add('new100FreeXPDismissible');
-
- new100FreeXPDismissible.id = `new100FreeXPDismissible`;
-
- document.body.appendChild(new100FreeXPDismissible);
-
- }
-
- })
- .catch(error => {
- console.error(error);
- });
- }
-
- async function checkIfValidDiscordToken() {
- if (localStorage.discord_token && !localStorage.discord_profile || localStorage.discord_token && !localStorage.discord_user_id) {
- try {
- if (localStorage.discord_token && !localStorage.discord_profile || localStorage.discord_token && !localStorage.discord_user_id) {
- const userInfo = await fetch('https://discord.com/api/users/@me', {
- headers: { Authorization: `Bearer ${localStorage.discord_token}` }
- });
-
- if (!userInfo.ok) {
- // If the response is not ok (e.g., 401 Unauthorized)
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- return;
- }
-
- const user = await userInfo.json();
- localStorage.discord_profile = JSON.stringify(user, undefined, 4);
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${user.id}/${user.avatar}.webp?size=4096`;
- localStorage.discord_username = user.username;
- localStorage.discord_user_id = user.id;
- if (user.global_name != null) {
- localStorage.discord_displayname = user.global_name;
- } else {
- localStorage.discord_displayname = user.username;
- }
- localStorage.discord_banner_color = user.banner_color;
- localStorage.discord_premium_type = user.premium_type;
-
- if (user.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${user.id}/${user.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
-
- console.log('success');
- setParams({ page: 'home', login: 'true' });
- location.reload();
- }
-
- // Optional: additional check (but `localStorage.discord_profile` is a string, so this check won't work unless parsed)
- const parsedProfile = JSON.parse(localStorage.discord_profile);
- if (parsedProfile.code === 0) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
-
- } catch (error) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
- }
- }
-
- const params = new URLSearchParams(window.location.search);
-
- function setParams(params) {
- const url = new URL(window.location);
-
- // Clear all existing query parameters
- url.search = '';
-
- // Set the new query parameters from the provided object
- Object.entries(params).forEach(([key, value]) => {
- url.searchParams.set(key, value);
- });
-
- // Update the address bar without reloading the page
- history.replaceState(null, '', url);
- }
-
- function addParams(params) {
- const url = new URL(window.location);
-
- Object.entries(params).forEach(([key, value]) => {
- url.searchParams.set(key, value);
- });
-
- history.replaceState(null, '', url);
- }
-
- function removeParams(params) {
- const url = new URL(window.location);
-
- // Convert params to an array if a single key is passed as a string
- if (!Array.isArray(params)) {
- params = [params];
- }
-
- // Remove each specified key from the URL parameters
- params.forEach(key => url.searchParams.delete(key));
-
- // Update the URL without reloading the page
- history.replaceState(null, '', url);
- }
-
- // Function to clear the shop data
- function clearShopData() {
- const output = document.querySelector("[data-shop-output]");
- output.innerHTML = ''; // Clears the content of the shop category
- if (params.get("page") === "consumables") {
- createPotionsCategoryLoadingElement()
- } else if (params.get("page") === "marketing") {
- createMarketingCategoryLoadingElement()
- } else {
- createShopCategoryLoadingElement()
- }
- }
-
- if (localStorage.experiment_2025_05_account_creator != "Treatment 1: Enabled") {
- checkIfValidDiscordToken();
- } else if (params.get("page") != "login" && localStorage.discord_token && !localStorage.discord_profile) {
- console.log("hoax????")
- actuallyLogOutOfDiscord();
- }
-
- // Function to fetch and display shop data
- function fetchData() {
- if (params.get("page") === "home" || params.get("page") === "orbs" && localStorage.experiment_2025_05_orbs_shop_home === "Treatment 1: Enabled") {
-
- fetchFirstHomeData();
-
- function fetchFirstHomeData() {
-
- fetch(apiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message === "Missing Access") {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
${getTextString("SHOP_NOT_LOAD_ERROR_1")}
-
${getTextString("SHOP_NOT_LOAD_ERROR_2")}
-
${getTextString("SHOP_NOT_LOAD_ERROR")}${data.message}
-
${getTextString("SHOP_NOT_LOAD_ERROR_RELOAD")}
-
- `;
- } else {
- data.forEach(apiCategory => {
- async function processCategories() {
- const output = document.querySelector("[data-shop-output]");
- const output0 = document.querySelector("[data-shop-0-output]");
- if (apiCategory.type === HERO) {
- const template = document.querySelector("[data-shop-category-template]");
-
- const category = template.content.cloneNode(true).children[0];
-
- if (apiCategory.hero_banner_asset) {
- if (apiCategory.hero_banner_asset.animated != null) {
- if (apiCategory.hero_banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- }
- } else if (apiCategory.hero_banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.hero_banner_asset.static}`;
- }
- } else if (apiCategory.hero_banner != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.hero_banner}.png?size=4096`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.banner}.png?size=4096`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
-
- if (apiCategory.hero_logo != null) {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.hero_logo}.png?size=4096`;
- } else if (apiCategory.logo != null) {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.logo}.png?size=4096`;
- } else {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/31.png`;
- }
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
-
- if (apiCategory.sku_id === discord_categories.ORB) {
- category.querySelector("[data-shop-banner-banner-container]").style.backgroundImage = 'linear-gradient(to bottom,rgba(39, 30, 173, 0.3) 60%,rgba(0, 0, 0, 0)80%)';
- }
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
-
- category.querySelector("[data-preview-banner-container]").id = apiCategory.sku_id;
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-preview-banner-container`;
-
- if (apiCategory.leaks_type) {
- category.querySelector("[data-preview-new-categoey-button]").innerHTML = `
- Check out New ${apiCategory.name} Leaks
- `;
- } else {
- category.querySelector("[data-preview-new-categoey-button]").innerHTML = `
- ${getTextString("SHOP_CATEGORY_SHOP_THE_COLLECTION_1")}${apiCategory.name}${getTextString("SHOP_CATEGORY_SHOP_THE_COLLECTION_2")}
- `;
- }
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- card.id = product.sku_id;
-
- if (product.type === item_types.NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === item_types.AVATAR_DECORATION) {
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("type_2");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}asset.webm`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- const videoElement = previewHolder.querySelector("[data-user-nameplate-preview-img]");
-
- videoElement.src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- videoElement.play();
- });
- card.addEventListener("mouseleave", () => {
- videoElement.pause();
- });
- }
- });
-
- } else if (product.type === item_types.BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- // Update SKU and summary
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals != "Treatment 1: Enable modals" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 2: Enable modals w/ data downloads" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 3: Enable modals w/ p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 4: Enable modals w/ p+ on p+ page" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 5: Enable modals w/ data downloads and p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
- }
-
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (product.sku_id === ORB_PROFILE_BADGE) {
- previewHolder.classList.add('potion-card-preview-holder');
-
- previewHolder.innerHTML = `
-
- `;
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- card.querySelector("#orb-profile-badge-card-video").play();
- });
- card.addEventListener("mouseleave", () => {
- card.querySelector("#orb-profile-badge-card-video").pause();
- card.querySelector("#orb-profile-badge-card-video").currentTime = 0;
- });
- }
- } else if (product.sku_id === NITRO_CREDITS_3_DAYS) {
- previewHolder.classList.add('potion-card-preview-holder');
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- } else {
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
- }
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- card.querySelector("[data-product-card-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else if (product.items[0].item_type === 'deco') {
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = imgElement.src = item.static;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = item.animated;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = item.static;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.items[0].item_type === 'effect') {
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = product.items[0].animated;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = product.items[0].static;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
- const priceTextNitro = card.querySelector("[data-price-nitro]");
- const priceTextStandard = card.querySelector("[data-price-standard]");
-
- const priceContainerNitro = card.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = card.querySelector("[data-price-standard-container]");
-
- const priceContainer = card.querySelector("[data-shop-price-container]");
-
- let priceStandard = "N/A";
- let priceNitro = "N/A";
- let priceOrb = "N/A";
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- if (localStorage.discord_premium_type === "2") {
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- standardPriceOutput = `US$${(priceStandard / 100).toFixed(2)}`;
-
- priceContainerStandard.innerHTML = `
- ${standardPriceOutput}
-
- `;
-
- } else if (priceStandard != "N/A") {
-
- standardPriceOutput = `US$${(priceStandard / 100).toFixed(2)}`;
-
- priceContainerStandard.innerHTML = `
- ${standardPriceOutput}
-
- `;
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
- orb_price.style.bottom = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- priceTextStandard.textContent = `US$${(priceStandard / 100).toFixed(2)}`;
-
- } else if (priceStandard != "N/A") {
-
- priceTextStandard.textContent = `US$${(priceStandard / 100).toFixed(2)}`;
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
- orb_price.style.bottom = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- }
-
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceNitro = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- if (priceTextNitro) {
- priceTextNitro.textContent = priceNitro !== "N/A" ? `US$${(priceNitro / 100).toFixed(2)} with Nitro` : "null";
- }
- }
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 1: Enabled" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button") {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_OPEN_IN_SHOP_V2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- } else {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_OPEN_IN_SHOP")}
- `;
- }
-
- if (product.items[0] && product.items[0].item_type && product.items[0].item_type === 'deco' || product.items[0] && product.items[0].item_type && product.items[0].item_type === 'effect' || product.sku_id === "0") {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- }
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (product.type === item_types.AVATAR_DECORATION || product.type === item_types.PROFILE_EFFECT || product.type === item_types.NAMEPLATE || product.type === item_types.BUNDLE || product.type === item_types.VARIANTS_GROUP || product.type === item_types.EXTERNAL_SKU) {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]") || event.target.matches(".card-button") || event.target.matches(".shareIcon_f4a996")) {
- } else {
- openItemModal();
- addParams({itemSkuId: product.sku_id})
- }
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === product.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openItemModal();
- }, 1000);
- }
-
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- if (apiCategory.logo != null) {
- modal.querySelector("[data-modalv2-inner-logo]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.logo}.png?size=4096`;
- }
-
- const button_container = document.querySelector("[data-modal-buttons]");
- const top_button_container = document.querySelector("[data-modal-top-product-buttons]");
-
-
- let copyDiscordLink = document.createElement("div");
-
- copyDiscordLink.title = getTextString("SHOP_SHARE_DISCORD_LINK");
- copyDiscordLink.innerHTML = `
-
- `;
-
- top_button_container.appendChild(copyDiscordLink);
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- let downloadItemData = document.createElement("div");
-
- downloadItemData.title = getTextString("SHOP_DOWNLOAD_DATA");
- downloadItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(downloadItemData);
- }
-
- if (localStorage.experiment_2025_03_view_raw_modal === "Treatment 1: Enabled") {
- let rawItemData = document.createElement("div");
-
- rawItemData.title = getTextString("SHOP_VIEW_RAW_DATA");
- rawItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(rawItemData);
-
- modal.querySelector("[data-view-raw-product-card-button]").onclick = function(){
- openRawModal();
- };
-
- async function openRawModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
- button_container.innerHTML = `
- ${getTextString("CARD_OPEN_IN_SHOP")}
- `;
-
- if (product.type === item_types.AVATAR_DECORATION) {
-
- modal.classList.add('modal-0');
-
- product.items.forEach(item => {
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
-
- } else {
-
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- modal.classList.add('modal-1');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (matchingEffect) {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- const imgElement = document.createElement("img");
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- } else {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("modal-2");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('nameplate-modal-preview');
-
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning" && product.category_sku_id === discord_categories.NAMEPLATE) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_1")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- } else if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 1: Nameplate Test Warning" || localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning") {
- if (product.category_sku_id === discord_categories.NAMEPLATE_TEST) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_2")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- }
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
- `;
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}asset.webm`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- const videoElement = previewHolder.querySelector("[data-user-nameplate-preview-img]");
-
- videoElement.src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- videoElement.play();
- }
-
-
-
- const videoElementLeft = previewHolderLeft.querySelector("[data-user-nameplate-preview-img-left]");
- const nameplatePreviewLeft = previewHolderLeft.querySelector("[data-user-nameplate-preview-left]");
- previewHolderLeft.classList.add("modal-left-nameplate-preview");
-
- videoElementLeft.src = asset;
-
- nameplatePreviewLeft.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
-
- const nullUserAvatarLeft = previewHolderLeft.querySelectorAll("[data-nameplate-user-random-avatar-left]");
-
- nullUserAvatarLeft.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- videoElementLeft.addEventListener("mouseenter", () => {
- videoElementLeft.play();
- });
-
- videoElementLeft.addEventListener("mouseleave", () => {
- videoElementLeft.pause();
- });
- }
- });
-
- } else if (product.type === item_types.BUNDLE) {
- modal.classList.add('modal-1000');
-
- const bundledProducts = product.bundled_products || [];
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- modal.querySelector("[data-product-modal-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (item.type === 0) {
- decosrc = item.asset
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- renderProfile(effectUrl)
- }
- }
- })();
- }
-
- function renderProfile(effectUrl) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
-
-
- } else {
- if (item.type === 0) {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("modal-avatar-decoration-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- // Fetch profile effects if not cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("modal-profile-effect-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- effectImage.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- modal.querySelector("[data-shop-modal-var-container-container]").classList.add('show');
- // Update SKU and summary
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Always display the base variant name
- modal.querySelector("[data-product-modal-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = modal.querySelector("[data-shop-modal-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlock = document.createElement("div");
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- modal.querySelector("[data-shop-modal-var-title]").textContent = `(${selectedVariant.variant_label})`;
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- modal.querySelector("[data-share-product-card-button]").onclick = function(){
- copyEmoji(`https://canary.discord.com/shop#itemSkuId=${selectedVariant.sku_id}`);
- };
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- modal.querySelector("[data-download-product-card-button]").onclick = function(){
- window.open(`https://item.yapper.shop/sku/${selectedVariant.sku_id}/data.zip`);
- };
- }
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (selectedVariant.type === 0) {
- selectedVariant.items?.forEach(item => {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-deco-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
-
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
- }
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-effect-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- })();
- }
-
-
- } else {
- if (selectedVariant.type === 0) {
- modal.classList.add("modal-2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- modal.classList.add('modal-3000');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- if (product.sku_id === ORB_PROFILE_BADGE) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- } else if (product.sku_id === NITRO_CREDITS_3_DAYS) {
- previewHolder.classList.add('modal-preview-profile-container');
-
- previewHolder.innerHTML = `
-
-
-
Nitro
-
-
-
Custom emojis anywhere
-
-
-
-
-
-
-
Colour app themes and more!
-
-
- `;
- } else {
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
- }
-
- }
-
-
- const priceTextNitro = modal.querySelector("[data-price-nitro]");
- const priceTextStandard = modal.querySelector("[data-price-standard]");
-
- const priceContainerNitro = modal.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = modal.querySelector("[data-price-standard-container]");
-
- const priceContainer = modal.querySelector("[data-shop-price-container]");
-
- let priceStandard = "N/A";
- let priceNitro = "N/A";
- let priceOrb = "N/A";
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- if (localStorage.discord_premium_type === "2") {
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `20px`;
-
- priceContainer.appendChild(orb_price);
-
- } else if (priceStandard != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
-
- priceContainer.appendChild(orb_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.right = `20px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- } else if (priceStandard != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.left = `23px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `20px`;
-
- priceContainer.appendChild(orb_price);
-
- } else if (priceStandard != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
-
- priceContainer.appendChild(orb_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.right = `20px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- } else if (priceStandard != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.left = `23px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- }
-
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceNitro = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- if (priceTextNitro) {
- priceTextNitro.textContent = priceNitro !== "N/A" ? `US$${(priceNitro / 100).toFixed(2)} with Nitro` : "null";
- }
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_UNPUBLISHED_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && product.type != 3000) {
-
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen") {
- let newLogInWithDiscordDismissible = document.createElement("div");
-
- newLogInWithDiscordDismissible.innerHTML = `
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_TITLE")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_1")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_2")}
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_LOG_IN")}
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_NO_THANKS")}
-
-
- `;
-
- newLogInWithDiscordDismissible.classList.add('newLogInWithDiscordDismissible');
-
- newLogInWithDiscordDismissible.id = `newLogInWithDiscordDismissible`;
-
- modal.appendChild(newLogInWithDiscordDismissible);
- }
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
- }
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 3: only share button") {
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
- }
-
-
- function newItemCheck() {
-
- if (N > g) {
- } else {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_NEW_TAG")}
-
- `;
- }
- }
-
- if (m.includes(product.sku_id)) {
- newItemCheck();
- }
-
- function newColorItemCheck() {
-
- if (N > newColorsExpireDate) {
- } else {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_NEW_COLORS_TAG")}
-
- `;
- }
- }
-
- if (newColorsSKUIDS.includes(product.sku_id) && discord_categories.ANIME_V3 === apiCategory.sku_id) {
- newColorItemCheck();
- }
-
- function popularItemCheck() {
- card.classList.add('popular-item');
- }
-
- if (I.includes(product.sku_id)) {
- popularItemCheck();
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_UNPUBLISHED_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- cardOutput.append(card);
-
- scrollToSKU(product.sku_id, 'true');
- }
- }
- output0.append(category);
-
- document.getElementById("shop-category-loading-container").innerHTML = ``;
- document.getElementById("shop-category-loading-container").style.display = 'none';
-
-
- const lofi_girl_banner = document.getElementById(discord_categories.LOFI_GIRL);
- const kawaii_mode_banner = document.getElementById(discord_categories.KAWAII_MODE);
-
- if (localStorage.reduced_motion != "true") {
-
- if (lofi_girl_banner) { // Check if element exists
- document.getElementById(`${discord_categories.LOFI_GIRL}-preview-banner-container`).innerHTML = `
-
- `;
- }
-
- if (kawaii_mode_banner) { // Check if element exists
- document.getElementById('1306330663213072494-preview-banner-container').innerHTML = `
-
- `;
- }
- }
- if (kawaii_mode_banner) { // Check if element exists
- document.getElementById('1306330663213072494-summary').style.color = 'black';
- }
- } else if (apiCategory.type === FEATURED) {
-
- const featureContainerTemplate = document.querySelector("[data-shop-subblock-container-template]");
-
- const featureBlockContainer = featureContainerTemplate.content.cloneNode(true).children[0];
-
- apiCategory.subblocks.forEach(subblock => {
-
- const template = document.querySelector("[data-shop-category-template-sub]");
-
- const featureblock = template.content.cloneNode(true).children[0];
-
- const oneImage = featureblock.querySelector("[data-shop-preview-image-sub]");
- oneImage.src = subblock.banner_url;
- oneImage.alt = subblock.name;
-
- featureblock.setAttribute("onclick",`setParams({page: '${subblock.page}'}); addParams({scrollTo: '${subblock.sku_id}'}); location.reload();`);
-
- featureBlockContainer.append(featureblock);
-
- });
-
- output.append(featureBlockContainer);
-
- } else if (apiCategory.type === WIDE_BANNER) {
-
- const template = document.querySelector("[data-shop-category-template-wide]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const oneImage = category.querySelector("[data-shop-preview-image-wide]");
- oneImage.src = apiCategory.banner_url;
- oneImage.alt = apiCategory.name;
-
- const title = category.querySelector("[data-shop-output-wide-title]");
- title.textContent = apiCategory.title;
- title.style.color = apiCategory.banner_text_color;
-
- const desc = category.querySelector("[data-shop-output-wide-desc]");
- desc.textContent = apiCategory.body;
- desc.style.color = apiCategory.banner_text_color;
-
- if (apiCategory.disable_cta != true) {
- category.classList.add('clickable');
- }
-
- category.setAttribute("onclick",`setParams({page: '${apiCategory.page}'}); location.reload();`);
-
- output.append(category);
- }
- }
-
- processCategories()
- });
- }
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
- }
- } else if (params.get("page") === "pplus-home") {
-
- fetchFirstHomeData();
-
- function fetchFirstHomeData() {
- let discordProfileEffectsCache = null;
-
- fetch(apiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message === "Missing Access") {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
${getTextString("SHOP_NOT_LOAD_ERROR_1")}
-
${getTextString("SHOP_NOT_LOAD_ERROR_2")}
-
${getTextString("SHOP_NOT_LOAD_ERROR")}${data.message}
-
${getTextString("SHOP_NOT_LOAD_ERROR_RELOAD")}
-
- `;
- } else {
- data.forEach(apiCategory => {
- async function processCategories() {
- const output = document.querySelector("[data-shop-output]");
- const output0 = document.querySelector("[data-shop-0-output]");
- if (apiCategory.type === HERO) {
- const template = document.querySelector("[data-shop-category-template]");
-
- const category = template.content.cloneNode(true).children[0];
-
- if (apiCategory.hero_banner_asset) {
- if (apiCategory.hero_banner_asset.animated != null) {
- if (apiCategory.hero_banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
- `;
- }
- } else if (apiCategory.hero_banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.hero_banner_asset.static}`;
- }
- } else if (apiCategory.hero_banner != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.hero_banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
-
- if (apiCategory.hero_logo != null) {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.hero_logo}.png`;
- } else if (apiCategory.logo != null) {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.logo}.png`;
- } else {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/31.png`;
- }
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
-
- category.querySelector("[data-preview-banner-container]").id = apiCategory.sku_id;
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-preview-banner-container`;
-
- if (apiCategory.leaks_type) {
- category.querySelector("[data-preview-new-categoey-button]").innerHTML = `
- Check out New ${apiCategory.name} Leaks
- `;
- } else {
- category.querySelector("[data-preview-new-categoey-button]").innerHTML = `
- ${getTextString("SHOP_CATEGORY_BROWSE_THE_COLLECTION_1")}${apiCategory.name}${getTextString("SHOP_CATEGORY_BROWSE_THE_COLLECTION_2")}
- `;
- }
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- card.id = product.sku_id;
-
- if (product.type === item_types.NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === item_types.AVATAR_DECORATION) {
- product.items.forEach(item => {
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("type_2");
-
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.yapper.shop/custom-collectibles/${item.asset}.png`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- previewHolder.querySelector("[data-user-nameplate-preview-img]").src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(10deg, #00000000 40%, ${bgcolor} 180%), linear-gradient(170deg, #00000000 40%, ${bgcolor} 180%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
- });
-
- } else if (product.type === item_types.BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
-
- (async () => {
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- // Update SKU and summary
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- card.querySelector("[data-product-card-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 1: Enabled" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button") {
- if (product.emojiCopy === null && product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_REQUEST_PPLUS_EMOJI_v2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- } else if (product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_COPY_PPLUS_EMOJI_V2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- }
- } else {
- if (product.emojiCopy === null && product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_REQUEST_PPLUS_EMOJI")}
- `;
- } else if (product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_COPY_PPLUS_EMOJI")}
- `;
- }
- }
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (product.type === item_types.AVATAR_DECORATION || product.type === item_types.PROFILE_EFFECT || product.type === item_types.NAMEPLATE || product.type === item_types.BUNDLE || product.type === item_types.VARIANTS_GROUP) {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]") || event.target.matches(".card-button") || event.target.matches(".shareIcon_f4a996")) {
- } else {
- openItemModal();
- addParams({itemSkuId: product.sku_id})
- }
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === product.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openItemModal();
- }, 1000);
- }
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- if (product.type === item_types.AVATAR_DECORATION) {
-
- modal.classList.add('modal-0');
-
- product.items.forEach(item => {
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
-
- } else {
-
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolder.appendChild(imgElement);
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- modal.classList.add('modal-1');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (matchingEffect) {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- const imgElement = document.createElement("img");
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- } else {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("modal-2");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('nameplate-modal-preview');
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning" && product.category_sku_id === discord_categories.NAMEPLATE) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_1")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- } else if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 1: Nameplate Test Warning" || localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning") {
- if (product.category_sku_id === discord_categories.NAMEPLATE_TEST) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_2")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- }
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}img.png`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- previewHolder.querySelector("[data-user-nameplate-preview-img]").src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(10deg, #00000000 40%, ${bgcolor} 180%), linear-gradient(170deg, #00000000 40%, ${bgcolor} 180%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
- });
-
- } else if (product.type === item_types.BUNDLE) {
- modal.classList.add('modal-1000');
-
- const bundledProducts = product.bundled_products || [];
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = "Bundle Includes: ";
- if (type0Product) {
- bundleSummary += `${type0Product.name} Decoration`;
- }
- if (type1Product) {
- bundleSummary += ` & ${type1Product.name} Profile Effect`;
- }
-
- // Set the summary text
- modal.querySelector("[data-product-modal-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (item.type === 0) {
- decosrc = item.asset
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
-
- // Find the matching effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- renderProfile(effectUrl)
- }
- }
- })();
- }
-
- function renderProfile(effectUrl) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
-
-
- } else {
- if (item.type === 0) {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("modal-avatar-decoration-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- // Fetch profile effects if not cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("modal-profile-effect-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- effectImage.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- modal.querySelector("[data-shop-modal-var-container-container]").classList.add('show');
- // Update SKU and summary
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Always display the base variant name
- modal.querySelector("[data-product-modal-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = modal.querySelector("[data-shop-modal-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlock = document.createElement("div");
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- modal.querySelector("[data-shop-modal-var-title]").textContent = `(${selectedVariant.variant_label})`;
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${selectedVariant.credits}`;
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- }
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (selectedVariant.type === 0) {
- selectedVariant.items?.forEach(item => {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-deco-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
-
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
- }
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-effect-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- })();
- }
-
-
- } else {
- if (selectedVariant.type === 0) {
- modal.classList.add("modal-2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- }
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads") {
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page") {
- if (typeof product.emojiCopy != 'undefined') {
- button_container.innerHTML = `
- ${product.emojiCopy ? `${getTextString("CARD_COPY_PPLUS_EMOJI")}` : `${getTextString("CARD_REQUEST_PPLUS_EMOJI")}`}
- `;
- } else {
- button_container.innerHTML = `
- ${getTextString("CARD_PPLUS_ERROR")}
- `;
- }
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (typeof product.emojiCopy != 'undefined') {
- button_container.innerHTML = `
- ${product.emojiCopy ? `${getTextString("CARD_COPY_PPLUS_EMOJI")}` : `${getTextString("CARD_REQUEST_PPLUS_EMOJI")}`}
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else {
- button_container.innerHTML = `
- ${getTextString("CARD_PPLUS_ERROR")}
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- }
- } else {
- button_container.innerHTML = ``;
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const expiresAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && product.type != 3000) {
-
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen") {
- let newLogInWithDiscordDismissible = document.createElement("div");
-
- newLogInWithDiscordDismissible.innerHTML = `
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_TITLE")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_1")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_2")}
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_LOG_IN")}
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_NO_THANKS")}
-
-
- `;
-
- newLogInWithDiscordDismissible.classList.add('newLogInWithDiscordDismissible');
-
- newLogInWithDiscordDismissible.id = `newLogInWithDiscordDismissible`;
-
- modal.appendChild(newLogInWithDiscordDismissible);
- }
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- } else if (product.type === "plus_more") {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]")) {
- } else {
- openItemModal();
- }
- });
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- modal.querySelector("[data-product-modal-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- modal.querySelector("[data-product-modal-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-plus-more-question-mark-img');
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
-
- previewHolder.appendChild(plusMoreQuestionMark);
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- button_container.innerHTML = ``;
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const expiresAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- card.classList.add('shop-category-card-transparent')
- cardOutput.append(card);
- }
- }
-
- output0.append(category);
-
- document.getElementById("shop-category-loading-container").innerHTML = ``;
- document.getElementById("shop-category-loading-container").style.display = 'none';
- } else if (apiCategory.type === FEATURED) {
-
- const featureContainerTemplate = document.querySelector("[data-shop-subblock-container-template]");
-
- const featureBlockContainer = featureContainerTemplate.content.cloneNode(true).children[0];
-
- apiCategory.subblocks.forEach(subblock => {
-
- const template = document.querySelector("[data-shop-category-template-sub]");
-
- const featureblock = template.content.cloneNode(true).children[0];
-
- const oneImage = featureblock.querySelector("[data-shop-preview-image-sub]");
- oneImage.src = subblock.banner_url;
- oneImage.alt = subblock.name;
-
- featureblock.setAttribute("onclick",`setParams({page: '${subblock.page}'}); location.reload();`);
-
- featureBlockContainer.append(featureblock);
-
- });
-
- output.append(featureBlockContainer);
-
- } else if (apiCategory.type === WIDE_BANNER) {
-
- const template = document.querySelector("[data-shop-category-template-wide]");
-
- const wide_banner = template.content.cloneNode(true).children[0];
-
- const oneImage = wide_banner.querySelector("[data-shop-preview-image-wide]");
- oneImage.src = apiCategory.banner_url;
- oneImage.alt = apiCategory.name;
-
- const title = wide_banner.querySelector("[data-shop-output-wide-title]");
- title.textContent = apiCategory.title;
- title.style.color = apiCategory.banner_text_color;
-
- const desc = wide_banner.querySelector("[data-shop-output-wide-desc]");
- desc.textContent = apiCategory.body;
- desc.style.color = apiCategory.banner_text_color;
-
- if (apiCategory.disable_cta != true) {
- wide_banner.classList.add('clickable');
- }
-
- wide_banner.setAttribute("onclick",`setParams({page: '${apiCategory.page}'}); location.reload();`);
-
- output.append(wide_banner);
- }
- }
-
- processCategories()
- });
- }
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
- }
- } else {
-
- if (params.get("page") === "consumables") {
- createMainPotionsElement()
- createPotionsCategoryLoadingElement()
- } else {
- createMainShopElement()
- createShopCategoryLoadingElement()
- }
-
-
- // Clear the previous data
- clearShopData();
-
- // Fetch new data
-
- // Make the function async
- fetch(apiUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
-
- if (data.message === "Missing Access") {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
${getTextString("SHOP_NOT_LOAD_ERROR_1")}
-
${getTextString("SHOP_NOT_LOAD_ERROR_2")}
-
${getTextString("SHOP_NOT_LOAD_ERROR")}${data.message}
-
${getTextString("SHOP_NOT_LOAD_ERROR_RELOAD")}
-
- `;
- } else if (data.message === "No Leaks") {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
${getTextString("SHOP_NO_LEAKS_ERROR_1")}
-
${getTextString("SHOP_NO_LEAKS_ERROR_2")}
-
${getTextString("SHOP_NOT_LOAD_ERROR")}${data.message}
-
${getTextString("SHOP_NOT_LOAD_ERROR_RELOAD")}
-
- `;
- } else {
- processCategories();
-
- if (document.getElementById("top-bar-other-things-container") && localStorage.experiment_2025_04_item_search === "Treatment 1: Enabled") {
- document.getElementById("open-help-modals-buttons-holder-new").classList.add("with-search");
- document.getElementById("top-bar-other-things-container").innerHTML = `
-
- `;
- }
- }
- // Define async function inside the .then block
- async function processCategories() {
- const categoryTemplate = document.querySelector("[data-shop-category-template]");
- const potionTemplate = document.querySelector("[data-potion-card-template]");
- const categoryOutput = document.querySelector("[data-shop-output]");
- const page = params.get("page");
-
- for (const apiCategory of data) {
- if (page === "pplus" || page === "leaks_") {
- // Existing code for 'pplus' page
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 1: Enable category modals" || localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- category.querySelector("[data-shop-category-banner]").classList.add('clickable')
- }
-
- if (apiCategory.banner_asset) {
- if (apiCategory.banner_asset.animated != null) {
- if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
- `;
- }
- } else if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.banner_asset.static}`;
- }
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.logo}.png`;
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
- if (apiCategory.banner_text_color && apiCategory.banner_text_color != null) {
- category.querySelector("[data-shop-category-desc]").style.color = apiCategory.banner_text_color;
- }
-
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-banner-banner-container`;
- category.querySelector("[data-shop-category-logo-holder]").id = `${apiCategory.sku_id}-logo-container`;
- category.querySelector("[data-shop-discord-watermark-container]").id = `${apiCategory.sku_id}-discord-watermark-container`;
-
- if (apiCategory.category_bg != null) {
- category.querySelector("[data-shop-category-marketing-bg]").src = `https://cdn.yapper.shop/assets/${apiCategory.category_bg}.png`;
- }
-
-
- if (apiCategory.sku_id === PAPER_BEACH) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === WINDOWKILL_V2) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === FIVE_NIGHTS_AT_FREDDYS) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === PLUS_SPECIAL_EVENT) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === GEOMETRY_DASH) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === PAPER_BEACH_V2) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- }
- if (apiCategory.sku_id === HOAX) {
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 1: Enable category modals" || localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- category.querySelector("[data-shop-category-banner]").classList.add('clickable');
-
- category.querySelector("[data-shop-category-banner]").addEventListener("click", () => {
- openCategoryModal();
- addParams({itemSkuId: apiCategory.sku_id})
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === apiCategory.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openCategoryModal();
- }, 1000);
- }
-
-
- async function openCategoryModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_ITEM_COUNT")}${apiCategory.products.length}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_ASSETS_TAB")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_TAB")}
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.experiment_2025_04_reviews_v2 === "Treatment 1: Enabled") {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").style.display = 'flex';
- }
-
- fillCategoryModalContentContainer('assets');
-
- const tab_button_1 = modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]");
- const tab_button_2 = modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]");
-
- tab_button_1.addEventListener('click', () => {
- if (tab_button_2.classList.contains("selected")) {
- tab_button_2.classList.remove("selected");
- }
- tab_button_1.classList.add("selected");
- fillCategoryModalContentContainer('assets');
- });
-
- tab_button_2.addEventListener('click', () => {
- if (tab_button_1.classList.contains("selected")) {
- tab_button_1.classList.remove("selected");
- }
- tab_button_2.classList.add("selected");
- fillCategoryModalContentContainer('reviews');
- });
-
- function fillCategoryModalContentContainer(tab) {
- if (document.getElementById("shop-category-modal-write-review-container")) {
- document.getElementById("shop-category-modal-write-review-container").remove();
- }
- if (tab === "assets") {
-
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- const asset_container = modal.querySelector("[data-category-modal-inner-content-container]");
-
- if (apiCategory.banner != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.banner}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.banner_asset && apiCategory.banner_asset.static != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_1")}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.banner_asset && apiCategory.banner_asset.animated != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_2")}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.logo != null) {
- let logo_asset = document.createElement("div");
-
- logo_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_LOGO")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.logo}
-
- `;
-
- asset_container.appendChild(logo_asset);
- }
-
- if (apiCategory.mobile_bg != null) {
- let mobile_bg_asset = document.createElement("div");
-
- mobile_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.mobile_bg}
-
- `;
-
- asset_container.appendChild(mobile_bg_asset);
- }
-
- if (apiCategory.pdp_bg != null) {
- let pdp_bg_asset = document.createElement("div");
-
- pdp_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_PDP_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.pdp_bg}
-
- `;
-
- asset_container.appendChild(pdp_bg_asset);
- }
-
- if (apiCategory.success_modal_bg != null) {
- let success_modal_bg_asset = document.createElement("div");
-
- success_modal_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_SUCCESS_MODAL_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.success_modal_bg}
-
- `;
-
- asset_container.appendChild(success_modal_bg_asset);
- }
-
- if (apiCategory.mobile_banner != null) {
- let mobile_banner_asset = document.createElement("div");
-
- mobile_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.mobile_banner}
-
- `;
-
- asset_container.appendChild(mobile_banner_asset);
- }
-
- if (apiCategory.featured_block != null) {
- let featured_block_asset = document.createElement("div");
-
- featured_block_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_FEATURED_BLOCK")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.featured_block}
-
- `;
-
- asset_container.appendChild(featured_block_asset);
- }
-
- if (apiCategory.hero_banner != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.hero_banner}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.hero_banner_asset && apiCategory.hero_banner_asset.static != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_1")}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.hero_banner_asset && apiCategory.hero_banner_asset.animated != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_2")}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.wide_banner != null) {
- let wide_banner_asset = document.createElement("div");
-
- wide_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_WIDE_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.wide_banner}
-
- `;
-
- asset_container.appendChild(wide_banner_asset);
- }
-
- if (apiCategory.hero_logo != null) {
- let hero_logo_asset = document.createElement("div");
-
- hero_logo_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_LOGO")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.hero_logo}
-
- `;
-
- asset_container.appendChild(hero_logo_asset);
- }
-
- if (apiCategory.category_bg != null) {
- let category_bg_asset = document.createElement("div");
-
- category_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_CATEGORY_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.category_bg}
-
- `;
-
- asset_container.appendChild(category_bg_asset);
- }
- } else if (tab === "reviews") {
-
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_PPLUS_WARNING")}
-
- `;
- }
- }
-
- window.fillCategoryModalContentContainer = fillCategoryModalContentContainer;
-
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `${getTextString("SHOP_CATEGORY_MODAL_SKU_ID")}${apiCategory.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = apiCategory.name;
- modal.querySelector("[data-product-modal-summary]").textContent = apiCategory.summary;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- const top_button_container = document.querySelector("[data-modal-top-product-buttons]");
-
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- let downloadItemData = document.createElement("div");
-
- downloadItemData.title = getTextString("SHOP_DOWNLOAD_DATA");
- downloadItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(downloadItemData);
- }
-
- if (localStorage.experiment_2025_03_view_raw_modal === "Treatment 1: Enabled") {
- let rawItemData = document.createElement("div");
-
- rawItemData.title = getTextString("SHOP_VIEW_RAW_DATA");
- rawItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(rawItemData);
-
- modal.querySelector("[data-view-raw-product-card-button]").onclick = function(){
- openRawModal();
- };
-
- async function openRawModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
-
- const unpublishedAt = new Date(apiCategory.unpublished_at);
-
- if (apiCategory.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_NOT_IN_STORE")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("SHOP_CATEGORY_DAYS_LEFT_IN_STORE")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- card.id = product.sku_id;
-
- if (product.type === item_types.NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === item_types.AVATAR_DECORATION) {
- product.items.forEach(item => {
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("type_2");
-
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_NAMEPLATE_PPLUS_ERROR")}
- `;
-
- } else if (product.type === item_types.BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
-
- (async () => {
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- // Update SKU and summary
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_PPLUS_MADE_BY")}${product.credits}`;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
- if (!pplusProfileEffectsCache) {
- await setPplusProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- card.querySelector("[data-product-card-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else if (product.items[0] && product.items[0].item_type === 'deco') {
- card.querySelector("[data-product-card-open-in-shop]").style.display = 'none';
-
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = imgElement.src = item.static;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = item.animated;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = item.static;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.items[0] && product.items[0].item_type === 'effect') {
- card.querySelector("[data-product-card-open-in-shop]").style.display = 'none';
-
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = product.items[0].animated;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = product.items[0].static;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 1: Enabled" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button") {
- if (product.emojiCopy === null && product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_REQUEST_PPLUS_EMOJI_v2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- } else if (product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_COPY_PPLUS_EMOJI_V2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- }
- } else {
- if (product.emojiCopy === null && product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_REQUEST_PPLUS_EMOJI")}
- `;
- } else if (product.type != 'plus_more') {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_COPY_PPLUS_EMOJI")}
- `;
- }
- }
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (product.type === item_types.AVATAR_DECORATION || product.type === item_types.PROFILE_EFFECT || product.type === item_types.BUNDLE || product.type === item_types.VARIANTS_GROUP) {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]") || event.target.matches(".card-button") || event.target.matches(".shareIcon_f4a996")) {
- } else {
- openItemModal();
- addParams({itemSkuId: product.sku_id})
- }
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === product.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openItemModal();
- }, 1000);
- }
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- if (product.type === item_types.AVATAR_DECORATION) {
-
- modal.classList.add('modal-0');
-
- product.items.forEach(item => {
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
-
- } else {
-
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
-
- previewHolder.appendChild(imgElement);
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- modal.classList.add('modal-1');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (matchingEffect) {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- const imgElement = document.createElement("img");
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- } else {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- }
- } else if (product.type === item_types.BUNDLE) {
- modal.classList.add('modal-1000');
-
- const bundledProducts = product.bundled_products || [];
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = "Bundle Includes: ";
- if (type0Product) {
- bundleSummary += `${type0Product.name} Decoration`;
- }
- if (type1Product) {
- bundleSummary += ` & ${type1Product.name} Profile Effect`;
- }
-
- // Set the summary text
- modal.querySelector("[data-product-modal-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (item.type === 0) {
- decosrc = item.asset
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
-
- // Find the matching effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- renderProfile(effectUrl)
- }
- }
- })();
- }
-
- function renderProfile(effectUrl) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
-
-
- } else {
- if (item.type === 0) {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("modal-avatar-decoration-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- // Fetch profile effects if not cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("modal-profile-effect-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- effectImage.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- modal.querySelector("[data-shop-modal-var-container-container]").classList.add('show');
- // Update SKU and summary
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${product.credits}`;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Always display the base variant name
- modal.querySelector("[data-product-modal-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = modal.querySelector("[data-shop-modal-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlock = document.createElement("div");
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- modal.querySelector("[data-shop-modal-var-title]").textContent = `(${selectedVariant.variant_label})`;
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- modal.querySelector("[data-product-modal-credits]").textContent = `Made By: ${selectedVariant.credits}`;
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- }
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (selectedVariant.type === 0) {
- selectedVariant.items?.forEach(item => {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-deco-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${item.asset}.png`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${item.asset}.png`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
-
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
- // Find matching profile effect
- const matchingEffect = pplusProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
- }
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-effect-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- })();
- }
-
-
- } else {
- if (selectedVariant.type === 0) {
- modal.classList.add("modal-2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- }
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads") {
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page") {
- if (typeof product.emojiCopy != 'undefined') {
- button_container.innerHTML = `
- ${product.emojiCopy ? `${getTextString("CARD_COPY_PPLUS_EMOJI")}` : `${getTextString("CARD_REQUEST_PPLUS_EMOJI")}`}
- `;
- } else {
- button_container.innerHTML = `
- ${getTextString("CARD_PPLUS_ERROR")}
- `;
- }
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (typeof product.emojiCopy != 'undefined') {
- button_container.innerHTML = `
- ${product.emojiCopy ? `${getTextString("CARD_COPY_PPLUS_EMOJI")}` : `${getTextString("CARD_REQUEST_PPLUS_EMOJI")}`}
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else {
- button_container.innerHTML = `
- ${getTextString("CARD_PPLUS_ERROR")}
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- }
- } else {
- button_container.innerHTML = ``;
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const expiresAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && product.type != 3000) {
-
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen") {
- let newLogInWithDiscordDismissible = document.createElement("div");
-
- newLogInWithDiscordDismissible.innerHTML = `
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_TITLE")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_1")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_2")}
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_LOG_IN")}
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_NO_THANKS")}
-
-
- `;
-
- newLogInWithDiscordDismissible.classList.add('newLogInWithDiscordDismissible');
-
- newLogInWithDiscordDismissible.id = `newLogInWithDiscordDismissible`;
-
- modal.appendChild(newLogInWithDiscordDismissible);
- }
- }
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- } else if (product.type === "plus_more") {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]")) {
- } else {
- openItemModal();
- }
- });
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- modal.querySelector("[data-product-modal-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- modal.querySelector("[data-product-modal-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-plus-more-question-mark-img');
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
-
- previewHolder.appendChild(plusMoreQuestionMark);
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- button_container.innerHTML = ``;
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const expiresAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ReleasesAt = new Date(product.releases_at);
-
- if (product.releases_at && !isNaN(ReleasesAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ReleasesAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_PUBLISHING_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_PUBLISHING_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- card.classList.add('shop-category-card-transparent')
- cardOutput.append(card);
-
- scrollToSKU(product.sku_id);
- }
- }
-
- categoryOutput.append(category);
-
- scrollToSKU(apiCategory.sku_id);
-
-
- const paper_beach2_banner = document.getElementById(PAPER_BEACH_V2);
- const geometry_dash_banner = document.getElementById(GEOMETRY_DASH);
- const special_event_plus_banner = document.getElementById(PLUS_SPECIAL_EVENT);
- const fnaf_banner = document.getElementById(FIVE_NIGHTS_AT_FREDDYS);
- const windowkill2_banner = document.getElementById(WINDOWKILL_V2);
- const paper_beach_banner = document.getElementById(PAPER_BEACH);
- const bopl_battle_banner = document.getElementById(BOPL_BATTLE);
- const windowkill_banner = document.getElementById(WINDOWKILL);
-
- if (localStorage.disable_client_banner_overrides != "true") {
-
- if (paper_beach2_banner) {
- document.getElementById(`${PAPER_BEACH_V2}-banner-banner-container`).innerHTML = `
-
-
- `;
- document.getElementById(`${PAPER_BEACH_V2}-logo-container`).innerHTML = `
-
- `;
- }
-
- if (windowkill2_banner) {
- document.getElementById(WINDOWKILL_V2).innerHTML = `
-
-
-
-
- `;
- }
-
- if (paper_beach_banner) {
- document.getElementById(PAPER_BEACH).innerHTML = `
-
-
-
-
- `;
- }
-
- if (bopl_battle_banner) {
- document.getElementById(BOPL_BATTLE).innerHTML = `
-
-
-
-
- `;
- }
- }
-
-
-
-
- } else if (page === "consumables") {
- // Existing code for 'consumables' page
- const potionCard = potionTemplate.content.cloneNode(true).children[0];
- potionCard.querySelector("[data-potion-card-holder]").id = apiCategory.sku_id;
-
- potionCard.id = apiCategory.sku_id;
-
- potionCard.querySelector("[data-potion-card-holder]").classList.add('potion-card-gradient1');
-
- if (apiCategory.src === null) {
- potionCard.querySelector("[data-potion-card-preview-image]").src = `https://cdn.yapper.shop/assets/31.png`;
- } else {
- potionCard.querySelector("[data-potion-card-preview-image]").src = `https://cdn.yapper.shop/${apiCategory.endpoint}/${apiCategory.src}.${apiCategory.format}`;
- }
- potionCard.querySelector("[data-potion-card-preview-image]").alt = apiCategory.name;
-
- if (apiCategory.new_text != null) {
- potionCard.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${apiCategory.new_text}
-
- `;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- potionCard.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- potionCard.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${apiCategory.sku_id}`;
- }
- potionCard.querySelector("[data-product-card-name]").textContent = apiCategory.name;
- potionCard.querySelector("[data-product-card-summary]").textContent = apiCategory.summary;
-
- let priceStandard = "N/A";
-
- if (apiCategory.price) {
- priceStandard = apiCategory.price.amount;
- }
-
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- potionCard.classList.add('clickable');
-
- potionCard.addEventListener("click", (event) => {
- if (event.target.matches(".card-button")) {
- } else {
- openItemModal();
- }
- });
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-potion-img');
-
- const imgElement = document.createElement("img");
- imgElement.classList.add('potion-card-preview');
- imgElement.src = `https://cdn.yapper.shop/${apiCategory.endpoint}/${apiCategory.src}.${apiCategory.format}`;
-
- previewHolder.appendChild(imgElement);
-
- // Set the product details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${apiCategory.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = apiCategory.name;
- modal.querySelector("[data-product-modal-summary]").textContent = apiCategory.summary;
-
-
- const button_container = document.querySelector("[data-modal-buttons]");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- button_container.innerHTML = `
- Open Support Article
- `;
- modal.querySelector("[data-download-product-card-button]").innerHTML = `
-
- `;
- } else {
- button_container.innerHTML = `
- Open Support Article
- `;
- }
-
-
- let priceStandard = "N/A";
-
- if (apiCategory.price) {
- priceStandard = apiCategory.price.amount;
- }
-
-
- const priceTextNitro = modal.querySelector("[data-price-nitro]");
- const priceTextStandard = modal.querySelector("[data-price-standard]");
-
- const priceContainerNitro = modal.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = modal.querySelector("[data-price-standard-container]");
-
- const priceContainer = modal.querySelector("[data-shop-price-container]");
-
- if (localStorage.experiment_2025_01_orb_testing === "Treatment 1: Default Prices") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 2: 50 Orbs") {
- if (priceTextStandard) {
- priceTextStandard.textContent = `50`;
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 3: Dynamic") {
-
- if (apiCategory.price.currency === "discord_orb") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- if (apiCategory.new_text != null) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${apiCategory.new_text}
-
- `;
- }
-
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- modal.classList.add('potion-wobble')
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- modal.classList.remove('potion-wobble')
- });
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
-
- const priceTextNitro = potionCard.querySelector("[data-price-nitro]");
- const priceTextStandard = potionCard.querySelector("[data-price-standard]");
-
- const priceContainerNitro = potionCard.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = potionCard.querySelector("[data-price-standard-container]");
-
- const priceContainer = potionCard.querySelector("[data-shop-price-container]");
-
- if (localStorage.experiment_2025_01_orb_testing === "Treatment 1: Default Prices") {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `${priceStandard}` : "Price (USD): N/A";
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else if (localStorage.experiment_2025_01_orb_testing === "Treatment 2: 50 Orbs") {
- if (priceTextStandard) {
- priceTextStandard.textContent = `50`;
- }
-
- let orb_icon = document.createElement("div");
-
- orb_icon.classList.add('orb-icon');
-
- priceContainerStandard.appendChild(orb_icon);
-
- } else {
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "Price (USD): N/A";
- }
- }
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 1: Enabled" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button") {
- potionCard.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_OPEN_IN_SHOP_V2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- } else {
- potionCard.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_OPEN_SUPPORT_ARTICLE")}
- `;
- }
-
- potionCard.addEventListener("mouseenter", () => {
- potionCard.classList.add('potion-wobble')
- });
-
- potionCard.addEventListener("mouseleave", () => {
- potionCard.classList.remove('potion-wobble')
- });
-
- categoryOutput.append(potionCard);
- } else if (page === "marketing") {
- if (localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 1: Enabled") {
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
- if (apiCategory.banner_asset) {
- if (apiCategory.banner_asset.animated != null) {
- if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
- `;
- }
- } else if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.banner_asset.static}`;
- }
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.logo}.png`;
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
- category.querySelector("[data-shop-category-logo-image]").classList.add("shop-category-condensed-banner-img");
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
- if (apiCategory.banner_text_color && apiCategory.banner_text_color != null) {
- category.querySelector("[data-shop-category-desc]").style.color = apiCategory.banner_text_color;
- }
-
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-banner-banner-container`;
- category.querySelector("[data-shop-category-logo-holder]").id = `${apiCategory.sku_id}-logo-container`;
- category.querySelector("[data-shop-discord-watermark-container]").id = `${apiCategory.sku_id}-discord-watermark-container`;
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- card.id = product.sku_id;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
-
- if (apiCategory.type === 0) {
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
- bgimg.style.backgroundImage = `url('${product.src}')`;
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_SHOP_MARKETING_ID")}${product.id}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=true`;
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=false`;
- });
- }
-
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_DOWNLOAD_MARKETING_DATA")}
- `;
- } else if (apiCategory.type === 1) {
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${product.asset}.png`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
- bgimg.style.backgroundImage = `url('${product.src}')`;
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_SHOP_MARKETING_ID")}${product.id}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${product.asset}.png`;
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${product.asset}.png`;
- });
- }
-
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_DOWNLOAD_MARKETING_DATA")}
- `;
- } else {
- card.classList.add("hidden");
- }
-
- cardOutput.append(card);
- }
- }
-
- categoryOutput.append(category);
- } else if (localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 2: Enable v2") {
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
- if (apiCategory.banner_asset) {
- if (apiCategory.banner_asset.animated != null) {
- if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
- `;
- }
- } else if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.banner_asset.static}`;
- }
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.banner}.png`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/${apiCategory.logo}.png`;
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
- category.querySelector("[data-shop-category-logo-image]").classList.add("shop-category-condensed-banner-img");
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
- if (apiCategory.banner_text_color && apiCategory.banner_text_color != null) {
- category.querySelector("[data-shop-category-desc]").style.color = apiCategory.banner_text_color;
- }
-
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-banner-banner-container`;
- category.querySelector("[data-shop-category-logo-holder]").id = `${apiCategory.sku_id}-logo-container`;
- category.querySelector("[data-shop-discord-watermark-container]").id = `${apiCategory.sku_id}-discord-watermark-container`;
-
- category.querySelector("[data-shop-category-banner]").innerHTML = `
-
-
-
-
- `;
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
- if (cardOutput) {
- const sortedData = apiCategory.products.sort((b, a) => a.id - b.id);
- for (const product of sortedData) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- card.classList.add("shop-marketing-card");
- card.innerHTML = `
-
-
-
- ${getTextString("CARD_MARKETING_SHOP_TAB_PREVIEW_TEXT")}
-
-
- `;
-
- if (product.raw != null && product.raw.marketings["2"] && product.raw.marketings["2"].asset != null) {
- card.querySelector("[data-marketing-shop-card-bg]").src = product.raw.marketings["2"].asset;
- }
-
- if (product.raw != null && product.raw.marketings["0"] && product.raw.marketings["0"].ref_target_background != null) {
- card.querySelector("[data-shop-tab-preview]").style.display = 'flex';
- card.querySelector("[data-shop-tab-preview-text]").style.display = 'flex';
- if (product.raw != null && product.raw.marketings["0"] && product.raw.marketings["0"].ref_target_background != null && product.raw.marketings["0"].ref_target_background.asset.resting.dark && product.raw.marketings["0"].ref_target_background.asset.resting.dark != null) {
- card.querySelector("[data-shop-tab-preview-img]").src = product.raw.marketings["0"].ref_target_background.asset.resting.dark;
- }
- card.addEventListener("mouseenter", () => {
- if (product.raw.marketings["0"].ref_target_background.asset.hovered.dark != null) {
- card.querySelector("[data-shop-tab-preview-img]").src = product.raw.marketings["0"].ref_target_background.asset.hovered.dark;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- if (product.raw.marketings["0"].ref_target_background.asset.resting.dark != null) {
- card.querySelector("[data-shop-tab-preview-img]").src = product.raw.marketings["0"].ref_target_background.asset.resting.dark;
- } else {
- card.querySelector("[data-shop-tab-preview-img]").src = 'https://cdn.yapper.shop/assets/31.png';
- }
- });
-
- if (product.raw != null && product.raw.marketings["0"] && product.raw.marketings["0"].ref_target_background != null && product.raw.marketings["0"].ref_target_background.style.resting.dark && product.raw.marketings["0"].ref_target_background.style.resting.dark != null) {
- card.querySelector("[data-shop-tab-preview]").style.backgroundImage = product.raw.marketings["0"].ref_target_background.style.resting.dark;
- }
- card.addEventListener("mouseenter", () => {
- if (product.raw.marketings["0"].ref_target_background.style.hovered.dark != null) {
- card.querySelector("[data-shop-tab-preview]").style.backgroundImage = product.raw.marketings["0"].ref_target_background.style.hovered.dark;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- if (product.raw.marketings["0"].ref_target_background.style.resting.dark != null) {
- card.querySelector("[data-shop-tab-preview]").style.backgroundImage = product.raw.marketings["0"].ref_target_background.style.resting.dark;
- }
- });
- }
-
- card.querySelector("[data-view-raw-product-card-button]").onclick = function(){
- openRawModal();
- };
-
- async function openRawModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
- }
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
-
- if (apiCategory.type === 0) {
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=false`;
- imgElement.style.height = `150px`;
- imgElement.style.width = `150px`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
- bgimg.style.backgroundImage = `url('${product.src}')`;
- bgimg.style.height = `150px`;
- bgimg.style.width = `150px`;
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_SHOP_MARKETING_ID")}${product.id}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
- if (product.raw != null && product.raw.marketings["2"] && product.raw.marketings["2"].revert_text_color === true) {
- card.querySelector("[data-product-card-sku-id]").style.color = `black`;
- card.querySelector("[data-product-card-name]").style.color = `black`;
- card.querySelector("[data-product-card-summary]").style.color = `black`;
- }
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=true`;
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${product.asset}.png?size=4096&passthrough=false`;
- });
- }
-
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_DOWNLOAD_MARKETING_DATA")}
- ${getTextString("CARD_MARKETING_GO_TO_CATEGORY")}
-
- `;
- } else if (apiCategory.type === 1) {
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${product.asset}.png`;
- imgElement.style.height = `150px`;
- imgElement.style.width = `150px`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
- bgimg.style.backgroundImage = `url('${product.src}')`;
- bgimg.style.height = `150px`;
- bgimg.style.width = `150px`;
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = `${getTextString("CARD_SHOP_MARKETING_ID")}${product.id}`;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
- if (product.raw != null && product.raw.marketings["2"] && product.raw.marketings["2"].revert_text_color === true) {
- card.querySelector("[data-product-card-sku-id]").style.color = `black`;
- card.querySelector("[data-product-card-name]").style.color = `black`;
- card.querySelector("[data-product-card-summary]").style.color = `black`;
- }
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/a_${product.asset}.png`;
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.yapper.shop/custom-collectibles/avatar-decorations/${product.asset}.png`;
- });
- }
-
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_DOWNLOAD_MARKETING_DATA")}
- ${getTextString("CARD_MARKETING_GO_TO_CATEGORY")}
-
- `;
- } else {
- card.classList.add("hidden");
- }
-
- cardOutput.append(card);
- }
- }
-
- categoryOutput.append(category);
- }
-
- } else {
- // Default page handling
- const category = categoryTemplate.content.cloneNode(true).children[0];
- category.querySelector("[data-shop-category-banner]").id = apiCategory.sku_id;
-
-
- // Category info modals
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 1: Enable category modals" || localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- category.querySelector("[data-shop-category-banner]").classList.add('clickable')
- }
-
-
- // Banner Image/Video asset
-
- if (apiCategory.banner_asset) {
- if (apiCategory.banner_asset.animated != null) {
- if (localStorage.reduced_motion != "true") {
- if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
-
- `;
- } else {
- category.querySelector("[data-shop-banner-banner-container]").innerHTML = `
-
- `;
- }
- } else if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.banner_asset.static}`;
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.banner}.png?size=4096`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
- } else if (apiCategory.banner_asset.static != null) {
- category.querySelector("[data-shop-category-banner-image]").src = `${apiCategory.banner_asset.static}`;
- }
- } else {
- category.querySelector("[data-shop-category-banner-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.banner}.png?size=4096`;
- category.querySelector("[data-shop-category-banner-image]").alt = apiCategory.name;
- }
-
-
- category.querySelector("[data-shop-banner-banner-container]").id = `${apiCategory.sku_id}-banner-banner-container`;
-
- category.querySelector("[data-shop-category-marketing-bg]").remove();
-
-
- // Logo Image/Video asset
-
- if (apiCategory.logo != null) {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.logo}.png?size=4096`;
- } else {
- category.querySelector("[data-shop-category-logo-image]").src = `https://cdn.yapper.shop/assets/31.png`;
- }
- category.querySelector("[data-shop-category-logo-image]").alt = apiCategory.name;
-
- category.querySelector("[data-shop-category-logo-holder]").id = `${apiCategory.sku_id}-logo-container`;
-
-
-
- category.querySelector("[data-shop-category-desc]").id = `${apiCategory.sku_id}-summary`;
- category.querySelector("[data-shop-category-desc]").textContent = apiCategory.summary;
- if (apiCategory.banner_text_color && apiCategory.banner_text_color != null) {
- category.querySelector("[data-shop-category-desc]").style.color = apiCategory.banner_text_color;
- }
-
-
- category.querySelector("[data-shop-discord-watermark-container]").id = `${apiCategory.sku_id}-discord-watermark-container`;
-
-
- if (apiCategory.sku_id === discord_categories.FANTASY) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.ANIME) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.BREAKFAST) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.DISXCORE) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.FALL) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.HALLOWEEN) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.WINTER) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.MONSTERS) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.CYBERPUNK) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.LUNAR_NEW_YEAR) {
- if (apiCategory.banner === "1202069953306689626") {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- }
- if (apiCategory.sku_id === discord_categories.ELEMENTS) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.ANIME_V2) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
- if (apiCategory.sku_id === discord_categories.SPRINGTOONS) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
- if (apiCategory.sku_id === discord_categories.SHY) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.LOFI_VIBES) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.GALAXY) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.FEELIN_RETRO) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.PIRATES) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.ARCADE) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.TIDE) {
- category.querySelector("[data-shop-category-logo-holder]").style.display = 'unset';
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.DARK_FANTASY) {
- category.querySelector("[data-shop-discord-watermark-container]").style.display = 'unset';
- }
- if (apiCategory.sku_id === discord_categories.ROBERT) {
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
- if (apiCategory.sku_id === discord_categories.DOJO) {
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
- if (apiCategory.sku_id === discord_categories.KAWAII_MODE) {
- category.querySelector("[data-shop-category-desc]").style.color = 'black';
- }
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 1: Enable category modals" || localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- category.querySelector("[data-shop-category-banner]").classList.add('clickable');
-
- category.querySelector("[data-shop-category-banner]").addEventListener("click", () => {
- openCategoryModal();
- addParams({itemSkuId: apiCategory.sku_id})
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === apiCategory.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openCategoryModal();
- }, 1000);
- }
-
-
- async function openCategoryModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- let categoryModalTabCache = null;
-
- modal.innerHTML = `
-
-
-
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_ITEM_COUNT")}${apiCategory.products.length}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_ASSETS_TAB")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_TAB")}
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_BETA_TAB")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REWARDS_TAB")}
-
${getTextString("SHOP_CATEGORY_MODAL_REWARDS_NEW_TAB")}
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.ext_sty_category_tab === "2") {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]").classList.remove("change-category-modal-content-button")
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").classList.remove("change-category-modal-content-button")
-
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]").classList.add("change-category-modal-content-button-transparent")
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").classList.add("change-category-modal-content-button-transparent")
- } else if (localStorage.ext_sty_category_tab === "3") {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]").classList.remove("change-category-modal-content-button")
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").classList.remove("change-category-modal-content-button")
-
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]").classList.add("change-category-modal-content-button-legacy")
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").classList.add("change-category-modal-content-button-legacy")
- }
-
- if (shop_archives_token && localStorage.experiment_2025_05_xp_system === "Treatment 1: Enabled") {
- if (!claimablesPromotionsCache) {
-
- url = api + CLAIMABLES_PROMOTIONS;
- fetchUrl = new URL(url);
- if (localStorage.staff_unpublished_xp_events == "true") {
- fetchUrl.searchParams.append("include-unpublished", "true");
- }
-
- fetch(fetchUrl, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- }) // Replace with your API URL
- .then(response => response.json())
- .then(data => {
- if (data.message) {
-
- } else {
- claimablesPromotionsCache = data;
- if (Array.isArray(data) && modal.querySelector("[data-shop-category-modal-tabs-tab-button-3]")) {
- data.forEach(promo => {
- if (promo.category_data?.sku_id === apiCategory.sku_id) {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-3]").style.display = 'flex';
- }
- });
- }
- }
-
- })
- .catch(error => {
- console.error(error);
- });
- } else {
- if (Array.isArray(claimablesPromotionsCache) && modal.querySelector("[data-shop-category-modal-tabs-tab-button-3]")) {
- claimablesPromotionsCache.forEach(promo => {
- if (promo.category_data?.sku_id === apiCategory.sku_id) {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-3]").style.display = 'flex';
- }
- });
- }
- }
- }
-
- if (localStorage.experiment_2025_04_reviews_v2_hide_beta_tag === "Treatment 1: Enabled") {
- modal.querySelector("[data-review-beta-tag]").style.display = 'none';
- }
-
- if (localStorage.experiment_2025_04_reviews_v2 === "Treatment 1: Enabled" && localStorage.reviews_filter_type != "3") {
- modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]").style.display = 'flex';
- }
-
- fillCategoryModalContentContainer('assets');
-
- const tab_button_1 = modal.querySelector("[data-shop-category-modal-tabs-tab-button-1]");
- const tab_button_2 = modal.querySelector("[data-shop-category-modal-tabs-tab-button-2]");
- const tab_button_3 = modal.querySelector("[data-shop-category-modal-tabs-tab-button-3]");
-
- tab_button_1.addEventListener('click', () => {
- if (tab_button_2.classList.contains("selected")) {
- tab_button_2.classList.remove("selected");
- } else if (tab_button_3.classList.contains("selected")) {
- tab_button_3.classList.remove("selected");
- }
- tab_button_1.classList.add("selected");
- fillCategoryModalContentContainer('assets');
- categoryModalTabCache = "assets";
- });
-
- tab_button_2.addEventListener('click', () => {
- if (tab_button_1.classList.contains("selected")) {
- tab_button_1.classList.remove("selected");
- } else if (tab_button_3.classList.contains("selected")) {
- tab_button_3.classList.remove("selected");
- }
- tab_button_2.classList.add("selected");
- fillCategoryModalContentContainer('reviews');
- categoryModalTabCache = "reviews";
- });
-
- tab_button_3.addEventListener('click', () => {
- if (tab_button_1.classList.contains("selected")) {
- tab_button_1.classList.remove("selected");
- } else if (tab_button_2.classList.contains("selected")) {
- tab_button_2.classList.remove("selected");
- }
- tab_button_3.classList.add("selected");
- fillCategoryModalContentContainer('xp_rewards');
- categoryModalTabCache = "xp_rewards";
- });
-
- function fillCategoryModalContentContainer(tab, bypassCache, bypassCache2) {
- if (document.getElementById("shop-category-modal-write-review-container") && categoryModalTabCache != "reviews" || document.getElementById("shop-category-modal-write-review-container") && bypassCache === true) {
- document.getElementById("shop-category-modal-write-review-container").remove();
- }
- if (document.getElementById("shop-category-modal-write-review-container") && tab != "reviews") {
- document.getElementById("shop-category-modal-write-review-container").remove();
- }
- if (tab === "assets" && categoryModalTabCache != "assets") {
-
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- const asset_container = modal.querySelector("[data-category-modal-inner-content-container]");
-
- if (apiCategory.banner != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.banner}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.banner_asset && apiCategory.banner_asset.static != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_1")}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.banner_asset && apiCategory.banner_asset.animated != null) {
- let banner_asset = document.createElement("div");
-
- banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_2")}
-
- `;
-
- asset_container.appendChild(banner_asset);
- }
-
- if (apiCategory.logo != null) {
- let logo_asset = document.createElement("div");
-
- logo_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_LOGO")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.logo}
-
- `;
-
- asset_container.appendChild(logo_asset);
- }
-
- if (apiCategory.mobile_bg != null) {
- let mobile_bg_asset = document.createElement("div");
-
- mobile_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.mobile_bg}
-
- `;
-
- asset_container.appendChild(mobile_bg_asset);
- }
-
- if (apiCategory.pdp_bg != null) {
- let pdp_bg_asset = document.createElement("div");
-
- pdp_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_PDP_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.pdp_bg}
-
- `;
-
- asset_container.appendChild(pdp_bg_asset);
- }
-
- if (apiCategory.success_modal_bg != null) {
- let success_modal_bg_asset = document.createElement("div");
-
- success_modal_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_SUCCESS_MODAL_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.success_modal_bg}
-
- `;
-
- asset_container.appendChild(success_modal_bg_asset);
- }
-
- if (apiCategory.mobile_banner != null) {
- let mobile_banner_asset = document.createElement("div");
-
- mobile_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.mobile_banner}
-
- `;
-
- asset_container.appendChild(mobile_banner_asset);
- }
-
- if (apiCategory.featured_block != null) {
- let featured_block_asset = document.createElement("div");
-
- featured_block_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_FEATURED_BLOCK")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.featured_block}
-
- `;
-
- asset_container.appendChild(featured_block_asset);
- }
-
- if (apiCategory.hero_banner != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.hero_banner}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.hero_banner_asset && apiCategory.hero_banner_asset.static != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_1")}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.hero_banner_asset && apiCategory.hero_banner_asset.animated != null) {
- let hero_banner_asset = document.createElement("div");
-
- hero_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_2")}
-
- `;
-
- asset_container.appendChild(hero_banner_asset);
- }
-
- if (apiCategory.wide_banner != null) {
- let wide_banner_asset = document.createElement("div");
-
- wide_banner_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_WIDE_BANNER")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.wide_banner}
-
- `;
-
- asset_container.appendChild(wide_banner_asset);
- }
-
- if (apiCategory.hero_logo != null) {
- let hero_logo_asset = document.createElement("div");
-
- hero_logo_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_HERO_LOGO")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.hero_logo}
-
- `;
-
- asset_container.appendChild(hero_logo_asset);
- }
-
- if (apiCategory.category_bg != null) {
- let category_bg_asset = document.createElement("div");
-
- category_bg_asset.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_CATEGORY_BG")}
- ${getTextString("SHOP_CATEGORY_MODAL_ASSETS_ID")}${apiCategory.category_bg}
-
- `;
-
- asset_container.appendChild(category_bg_asset);
- }
- } else if (tab === "reviews" && categoryModalTabCache != "reviews" || bypassCache === true) {
-
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_LOADING")}
-
- `;
-
- fetch(api + REVIEWSAPI + '/' + apiCategory.sku_id, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- }) // Replace with your API URL
- .then(response => response.json())
- .then(data => {
- if (data.message && data.message === "Reviews disabled") {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- let reviewNoneElement = document.createElement("div");
-
- reviewNoneElement.classList.add("review-element-warning");
-
- reviewNoneElement.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_DISABLED")}
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(reviewNoneElement);
-
- } else if (data.message && data.message === "This service is temporarily unavailable, down for maintenance.") {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- let reviewNoneElement = document.createElement("div");
-
- reviewNoneElement.classList.add("review-element-warning");
-
- reviewNoneElement.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_UNAVAILABLE")}
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(reviewNoneElement);
-
- } else if (tab === "reviews" && categoryModalTabCache === "reviews") {
- renderReviews(data);
-
- let hasReviewAlready = false;
-
- data.forEach(review => {
- if (review.users.id === localStorage.discord_user_id) {
- hasReviewAlready = true;
- }
- });
-
- if (localStorage.experiment_2025_05_m === "Treatment 1: Enabled") {
-
- } else if (shop_archives_token && hasReviewAlready === false) {
- let writeReviewContainer = document.createElement("div");
-
- writeReviewContainer.classList.add("shop-category-modal-write-review-container");
- writeReviewContainer.id = 'shop-category-modal-write-review-container';
- writeReviewContainer.innerHTML = `
-
-
- `;
-
- writeReviewContainer.querySelector("[data-post-review-button]").onclick = function(){
- postReview(`${apiCategory.sku_id}`, 0);
- };
-
-
- const stars = writeReviewContainer.querySelectorAll('#star-rating svg');
- let selectedRating = 0;
-
- stars.forEach(star => {
- star.addEventListener('click', () => {
- selectedRating = parseInt(star.getAttribute('data-value'));
- updateStars(selectedRating);
- });
- });
-
- function updateStars(rating) {
- stars.forEach(star => {
- const value = parseInt(star.getAttribute('data-value'));
- star.classList.toggle('filled', value <= rating);
- });
- writeReviewContainer.querySelector("[data-post-review-button]").onclick = function(){
- postReview(`${apiCategory.sku_id}`, selectedRating);
- };
- }
-
- modal.querySelector(".category-modalv2-inner-left").appendChild(writeReviewContainer);
- } else if (shop_archives_token) {
- let writeReviewContainer = document.createElement("div");
-
- writeReviewContainer.classList.add("shop-category-modal-write-review-container");
- writeReviewContainer.id = 'shop-category-modal-write-review-container';
- writeReviewContainer.innerHTML = `
-
-
- `;
-
- writeReviewContainer.querySelector("[data-post-review-button]").onclick = function(){
- postReview(`${apiCategory.sku_id}`, 0);
- };
-
-
- const stars = writeReviewContainer.querySelectorAll('#star-rating svg');
- let selectedRating = 0;
-
- stars.forEach(star => {
- star.addEventListener('click', () => {
- selectedRating = parseInt(star.getAttribute('data-value'));
- updateStars(selectedRating);
- });
- });
-
- function updateStars(rating) {
- stars.forEach(star => {
- const value = parseInt(star.getAttribute('data-value'));
- star.classList.toggle('filled', value <= rating);
- });
- writeReviewContainer.querySelector("[data-post-review-button]").onclick = function(){
- postReview(`${apiCategory.sku_id}`, selectedRating);
- };
- }
-
-
- modal.querySelector(".category-modalv2-inner-left").appendChild(writeReviewContainer);
- } else {
- let writeReviewContainer = document.createElement("div");
-
- writeReviewContainer.classList.add("shop-category-modal-write-review-container");
- writeReviewContainer.id = 'shop-category-modal-write-review-container';
- writeReviewContainer.innerHTML = `
-
-
-
- `;
-
- modal.querySelector(".category-modalv2-inner-left").appendChild(writeReviewContainer);
- }
- }
-
- })
- .catch(error => {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_ERROR")}
-
${error}
-
- `;
- console.error(error);
- });
-
- function renderReviews(datareview) {
- if (localStorage.experiment_2025_05_m === "Treatment 1: Enabled") {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- let reviewNoneElement = document.createElement("div");
-
- reviewNoneElement.classList.add("review-element-warning");
-
- reviewNoneElement.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_UNAVAILABLE")}
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(reviewNoneElement);
- } else if (Array.isArray(datareview) && datareview.length === 0) {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- let reviewNoneElement = document.createElement("div");
-
- reviewNoneElement.classList.add("review-element-notice");
-
- reviewNoneElement.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_NONE")}
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(reviewNoneElement);
- } else {
- const reviewContainer = modal.querySelector("[data-category-modal-inner-content-container]");
-
- if (localStorage.staff_enable_override_review_content === "true") {
- let reviewOverrideWarningElement = document.createElement("div");
-
- reviewOverrideWarningElement.classList.add("review-element-notice");
-
- reviewOverrideWarningElement.innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_OVERRIDE_WARNING")}
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(reviewOverrideWarningElement);
- }
-
- datareview.forEach(review => {
- if (localStorage.reviews_filter_type === "1" || localStorage.discord_user_id === review.users.id || localStorage.reviews_filter_type === "2" && review.review_flag_type != 2) {
- let reviewElement = document.createElement("div");
-
- reviewElement.classList.add("review-element");
-
- if (review.system_type === 1) {
- reviewElement.classList.add("review-element-warning");
- reviewElement.classList.add("review-element-system");
- } else if (review.system_type === 2) {
- reviewElement.classList.add("review-element-notice");
- reviewElement.classList.add("review-element-system");
- }
-
- let reviewTextOutput = review.review_text;
-
- reviewElement.innerHTML = `
-
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.experiment_2025_05_reviews_v2_user_profile === "Treatment 1: Enabled") {
- reviewElement.querySelector("[data-shop-modal-review-name]").classList.add("clickable");
-
- reviewElement.querySelector("[data-shop-modal-review-name]").addEventListener("click", () => {
- fetchUserProfileInfo(review.users.id);
- });
- }
-
- if (review.users.global_name && review.users.global_name != null) {
- reviewElement.querySelector("[data-shop-modal-review-name]").textContent = review.users.global_name;
- } else {
- reviewElement.querySelector("[data-shop-modal-review-name]").textContent = review.users.username;
- }
-
- if (localStorage.experiment_2025_04_reviews_v2_custom_emojis_render === "Treatment 1: Enabled") {
- if (localStorage.staff_enable_override_review_content === "true") {
- reviewElement.querySelector("[data-review-content-text-output]").innerHTML = renderReviewTextWithEmojis(localStorage.staff_raw_review_override_content);
- } else {
- reviewElement.querySelector("[data-review-content-text-output]").innerHTML = renderReviewTextWithEmojis(review.review_text);
- }
- } else {
- if (localStorage.staff_enable_override_review_content === "true") {
- reviewElement.querySelector("[data-review-content-text-output]").textContent = localStorage.staff_raw_review_override_content;
- } else {
- reviewElement.querySelector("[data-review-content-text-output]").textContent = reviewTextOutput;
- }
- }
-
- if (review.users.id === localStorage.discord_user_id || localStorage.admin_level && localStorage.admin_level != "0") {
- let deleteReviewIcon = document.createElement("div");
-
- deleteReviewIcon.title = getTextString("SHOP_CATEGORY_MODAL_REVIEWS_DELETE_HOVER");
-
- deleteReviewIcon.innerHTML = `
-
- `;
-
- reviewElement.querySelector("[data-shop-modal-review-moderation-buttons]").appendChild(deleteReviewIcon);
- }
-
- if (localStorage.experiment_2025_04_reviews_v2_report === "Treatment 1: Enabled" && review.report_type === 0 && review.users.id != localStorage.discord_user_id && localStorage.account_type === "2") {
- let reportReviewIcon = document.createElement("div");
-
- reportReviewIcon.title = getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_HOVER");
-
- reportReviewIcon.innerHTML = `
-
- `;
-
- reportReviewIcon.querySelector("[data-report-review-button]").onclick = function(){
- openReviewReportModal(review.id, review.review_text, review.users.username);
- };
-
- reviewElement.querySelector("[data-shop-modal-review-moderation-buttons]").appendChild(reportReviewIcon);
- } else if (localStorage.experiment_2025_04_reviews_v2_report === "Treatment 1: Enabled" && review.report_type != 0 && localStorage.admin_level != "0" && localStorage.account_type === "2") {
- let reportReviewIcon = document.createElement("div");
-
- reportReviewIcon.title = getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_HOVER");
-
- reportReviewIcon.innerHTML = `
-
- `;
-
- reportReviewIcon.querySelector("[data-report-review-button]").onclick = function(){
- openReviewReportModal(review.id, review.review_text, review.users.username);
- };
-
- reviewElement.querySelector("[data-shop-modal-review-moderation-buttons]").appendChild(reportReviewIcon);
- }
-
- if (review.users.system === true) {
- let moderatorNametag = document.createElement("p");
-
- moderatorNametag.classList.add("shop-modal-review-nametag-moderator");
- moderatorNametag.textContent = `${getTextString("SHOP_CATEGORY_MODAL_NAMETAG_SYSTEM")}`;
- moderatorNametag.title = `${getTextString("SHOP_CATEGORY_MODAL_NAMETAG_SYSTEM_TITLE")}`;
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(moderatorNametag);
- }
-
- if (review.users.primary_guild) {
- let reviewServerTagContainer = document.createElement("div");
-
- reviewServerTagContainer.classList.add("shop-modal-review-server-tag-container");
- reviewServerTagContainer.innerHTML = `
-
- ${review.users.primary_guild.tag}
- `;
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(reviewServerTagContainer);
- }
-
- if (Array.isArray(review.users.badges)) {
- let reviewBadgesContainer = document.createElement("div");
- reviewBadgesContainer.classList.add("shop-modal-review-badges-container");
-
- review.users.badges.forEach(badge => {
- const badgeImg = document.createElement("img");
- badgeImg.src = badge.src;
- badgeImg.alt = badge.name;
- badgeImg.title = badge.name;
- badgeImg.classList.add("review-badge");
-
- if (badge.support) {
- const badgeLink = document.createElement("a");
- badgeLink.href = badge.support;
- badgeLink.target = "_blank";
- badgeLink.rel = "noopener noreferrer";
- badgeLink.appendChild(badgeImg);
- reviewBadgesContainer.appendChild(badgeLink);
- } else {
- reviewBadgesContainer.appendChild(badgeImg);
- }
- });
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(reviewBadgesContainer);
- }
-
-
-
- let starRating = document.createElement("div");
-
- starRating.classList.add("shop-modal-review-star-container");
- starRating.setAttribute('data-shop-modal-review-star-container', '');
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(starRating);
-
-
- const date = new Date(review.created_at);
-
- const day = String(date.getDate()).padStart(2, '0');
- const month = String(date.getMonth() + 1).padStart(2, '0'); // getMonth is 0-indexed
- const year = date.getFullYear();
-
- if (localStorage.reviews_time_type === "uk") {
- const formatted = `${day}/${month}/${year}`;
-
- let createdAtTag = document.createElement("p");
-
- createdAtTag.classList.add("shop-modal-review-time-container");
- createdAtTag.textContent = `${formatted}`;
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(createdAtTag);
- } else {
- const formatted = `${month}/${day}/${year}`;
-
- let createdAtTag = document.createElement("p");
-
- createdAtTag.classList.add("shop-modal-review-time-container");
- createdAtTag.textContent = `${formatted}`;
-
- reviewElement.querySelector("[data-shop-modal-review-name-container]").appendChild(createdAtTag);
- }
-
-
- if (review.rating === 5) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- } else if (review.rating === 4) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- } else if (review.rating === 3) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- } else if (review.rating === 2) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- } else if (review.rating === 1) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- } else if (review.rating === 0) {
- reviewElement.querySelector("[data-shop-modal-review-star-container]").innerHTML = `
-
- `;
- }
- if (document.getElementById("loading-category-reviews")) {
- document.getElementById("loading-category-reviews").remove();
- }
-
- reviewContainer.appendChild(reviewElement);
- }
- });
-
- function openReviewReportModal(reviewID, reviewText, reviewUser) {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
- modal.id = 'modalv2-report-review';
-
- modal.innerHTML = `
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_PREVIEW")}
-
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_SUMMARY")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_1")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_2")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_3")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_4")}
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_4_SUMMARY")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_5")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_DISCLAIMER")}
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_DISCLAIMER1")}
-
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_CANCEL")}
-
-
${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_REPORT")}
-
-
- `;
-
- modal.querySelector("[data-review-report-text-output]").textContent = reviewText;
-
- modal.querySelector("[data-reviews-send-report-button]").addEventListener('click', () => {
- reportReview(document.getElementById("report-review-report-card-inv-imput-review-id").value, document.getElementById("report-review-report-card-inv-imput").value);
- });
-
- if (localStorage.dev === "true") {
- modal.querySelector("[data-dev-only-remove-report-button-container]").innerHTML = `
- ${getTextString("SHOP_CATEGORY_MODAL_REVIEWS_REPORT_REMOVE_REPORT")}
- `;
- modal.querySelector("[data-reviews-remove-report-button]").addEventListener('click', () => {
- reportReview(document.getElementById("report-review-report-card-inv-imput-review-id").value, 0);
- });
- }
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.classList.add('modalv2-back-review-report');
- modal_back.id = 'modalv2-report-review-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- modal.querySelector(".cancel-button").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- }
-
- }
- } else if (tab === "xp_rewards" && categoryModalTabCache != "xp_rewards" || bypassCache2 === true) {
- modal.querySelector("[data-category-modal-inner-content-container]").innerHTML = ``;
-
- if (Array.isArray(claimablesPromotionsCache)) {
- claimablesPromotionsCache.forEach(promo => {
-
- if (promo.already_claimed === false && promo.category_data?.sku_id === apiCategory.sku_id) {
-
- let promoBanner = document.createElement("div");
-
- promoBanner.classList.add("xp-reward-promo-card");
-
- promoBanner.innerHTML = `
-
-
Claim your free ${promo.xp_reward} XP!
-
You have ${promo.xp_reward} XP waiting for you!
-
Learn More about XP
-
Claim ${promo.xp_reward} XP
-
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(promoBanner);
- } else if (promo.category_data?.sku_id === apiCategory.sku_id) {
-
- let promoBanner = document.createElement("div");
-
- promoBanner.classList.add("xp-reward-promo-card");
-
- promoBanner.innerHTML = `
-
-
You claimed ${promo.xp_reward} XP.
-
You already claimed this reward.
-
Learn More about XP
-
- `;
-
- modal.querySelector("[data-category-modal-inner-content-container]").appendChild(promoBanner);
- }
- });
- }
-
- } else {
- console.log("already on that tab")
- }
- }
-
- window.fillCategoryModalContentContainer = fillCategoryModalContentContainer;
-
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `${getTextString("SHOP_CATEGORY_MODAL_SKU_ID")}${apiCategory.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = apiCategory.name;
- modal.querySelector("[data-product-modal-summary]").textContent = apiCategory.summary;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- const top_button_container = document.querySelector("[data-modal-top-product-buttons]");
-
-
- if (localStorage.experiment_2025_02_shop_category_modals === "Treatment 2: Enable category modals w/ data downloads") {
- let downloadItemData = document.createElement("div");
-
- downloadItemData.title = getTextString("SHOP_DOWNLOAD_DATA");
- downloadItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(downloadItemData);
- }
-
- if (localStorage.experiment_2025_03_view_raw_modal === "Treatment 1: Enabled") {
- let rawItemData = document.createElement("div");
-
- rawItemData.title = getTextString("SHOP_VIEW_RAW_DATA");
- rawItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(rawItemData);
-
- modal.querySelector("[data-view-raw-product-card-button]").onclick = function(){
- openRawModal();
- };
-
- async function openRawModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
-
- const unpublishedAt = new Date(apiCategory.unpublished_at);
-
- if (apiCategory.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_NOT_IN_STORE")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("SHOP_CATEGORY_DAYS_LEFT_IN_STORE")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- });
- }
- }
-
-
- const unpublishedAt = new Date(apiCategory.unpublished_at);
-
- if (apiCategory.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- category.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("SHOP_CATEGORY_NOT_IN_STORE")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- category.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("SHOP_CATEGORY_DAYS_LEFT_IN_STORE")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
-
- const cardOutput = category.querySelector("[data-shop-category-card-holder]");
-
- if (localStorage.ext_sty_shop_cards === "2") {
- cardOutput.classList.remove("shop-category-card-holder");
- cardOutput.classList.add("shop-category-card-holder-standard");
- } else {
- cardOutput.classList.add("shop-category-card-holder");
- }
-
- if (cardOutput) {
- for (const product of apiCategory.products) {
- const cardTemplate = document.querySelector("[data-shop-item-card-template]");
- const card = cardTemplate.content.cloneNode(true).children[0];
-
- if (localStorage.ext_sty_shop_cards === "2") {
- card.classList.remove("shop-category-card");
- card.classList.add("shop-category-card-standard");
-
- if (product.styles && product.styles.background_colors != null) {
- function decodePrimaryCard(decimal) {
- const r = (decimal >> 16) & 0xFF; // Extract Red (top 8 bits)
- const g = (decimal >> 8) & 0xFF; // Extract Green (middle 8 bits)
- const b = decimal & 0xFF; // Extract Blue (bottom 8 bits)
- return { r, g, b };
- }
-
- function decodeSecondaryCard(decimal) {
- const r1 = (decimal >> 16) & 0xFF; // Extract Red (top 8 bits)
- const g1 = (decimal >> 8) & 0xFF; // Extract Green (middle 8 bits)
- const b1 = decimal & 0xFF; // Extract Blue (bottom 8 bits)
- return { r1, g1, b1 };
- }
-
- // Example usage:
- const cardPrimaryColorDecimal = product.styles.background_colors[0]; // example (like 0xFFA000)
- const { r, g, b } = decodePrimaryCard(cardPrimaryColorDecimal);
-
- const cardSecondaryColorDecimal = product.styles.background_colors[1]; // example (like 0xFFA000)
- const { r1, g1, b1 } = decodeSecondaryCard(cardSecondaryColorDecimal);
- card.style.backgroundImage = `linear-gradient(rgb(${r}, ${g}, ${b}),rgb(${r1}, ${g1}, ${b1}))`;
- }
-
- } else {
- card.classList.add("shop-category-card");
- }
-
- card.id = product.sku_id;
-
- if (product.type === item_types.NONE) {
- card.classList.add("type_100");
- card.classList.add('hidden')
- } else if (product.type === item_types.AVATAR_DECORATION) {
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- card.classList.add("type_1");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("type_2");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}asset.webm`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- const videoElement = previewHolder.querySelector("[data-user-nameplate-preview-img]");
-
- videoElement.src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- videoElement.play();
- });
- card.addEventListener("mouseleave", () => {
- videoElement.pause();
- });
- }
- });
-
- } else if (product.type === item_types.BUNDLE) {
- card.classList.add("type_1000");
- // Fetch the bundled products for the bundle summary
- const bundledProducts = product.bundled_products || [];
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- card.querySelector("[data-product-card-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (item.type === 0) {
- // Avatar decoration
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("avatar-decoration-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(decoImage);
-
- const bgimg = document.createElement("div");
- bgimg.classList.add("avatar-decoration-bg-image");
-
- card.querySelector("[data-shop-card-preview-holder]").appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("profile-effect-image");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects[0] && matchingEffect.effects[0].src) {
- effectImage.src = matchingEffect.effects[0].src;
- }
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
- card.addEventListener("mouseleave", () => {
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- // Update SKU and summary
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Always display the base variant name
- card.querySelector("[data-product-card-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = card.querySelector("[data-shop-card-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlockTmp = document.querySelector("[data-shop-varcolorblock-template]");
- const variantColorBlock = variantColorBlockTmp.content.cloneNode(true).children[0];
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.id = "shop-card-var";
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- card.querySelector("[data-shop-card-var-title]").textContent = `(${selectedVariant.variant_label})`;
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals != "Treatment 1: Enable modals" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 2: Enable modals w/ data downloads" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 3: Enable modals w/ p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 4: Enable modals w/ p+ on p+ page" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 5: Enable modals w/ data downloads and p+" && localStorage.experiment_2025_02_shop_card_modals != "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
- }
-
- if (selectedVariant.type === 0) {
- card.classList.add("type_2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('avatar-decoration-image');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- const bgimg = document.createElement("div");
- if (isFirstTimeLoadingVariant == true) {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- isFirstTimeLoadingVariant = false;
- } else {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- }
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- card.addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
- card.addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- bgimg.style.backgroundImage = `url()`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- card.classList.add("type_2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- if (isFirstTimeLoadingVariant == true) {
- previewHolder.innerHTML = `
-
- `;
- isFirstTimeLoadingVariant = false;
- } else {
- previewHolder.innerHTML = `
-
- `;
- }
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- card.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- card.classList.add("type_3000");
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- } else {
- card.querySelector("[data-product-card-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- }
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
-
- if (product.sku_id === ORB_PROFILE_BADGE) {
- previewHolder.classList.add('potion-card-preview-holder');
-
- previewHolder.innerHTML = `
-
- `;
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- card.querySelector("#orb-profile-badge-card-video").play();
- });
- card.addEventListener("mouseleave", () => {
- card.querySelector("#orb-profile-badge-card-video").pause();
- card.querySelector("#orb-profile-badge-card-video").currentTime = 0;
- });
- }
- } else if (product.sku_id === NITRO_CREDITS_3_DAYS) {
- previewHolder.classList.add('potion-card-preview-holder');
-
- previewHolder.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- } else {
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
- }
-
- } else if (product.type === 'plus_more') {
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_TITLE")}`;
- card.querySelector("[data-product-card-summary]").textContent = `${getTextString("CARD_TYPE_PLUS_MORE_DESC")}`;
-
- card.querySelector("[data-shop-price-container]").innerHTML = ``;
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- card.querySelector("[data-share-product-card-button]").innerHTML = ``;
-
- const plusMoreQuestionMark = document.createElement("img");
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- plusMoreQuestionMark.classList.add("plus-more-question-mark");
- card.querySelector("[data-shop-card-preview-holder]").appendChild(plusMoreQuestionMark);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.gif`;
- });
- card.addEventListener("mouseleave", () => {
- plusMoreQuestionMark.src = `https://cdn.discordapp.com/assets/server_products/storefront/question-mark.png`;
- });
- }
- } else if (product.items[0].item_type === 'deco') {
- product.items.forEach(item => {
-
- card.classList.add("type_0");
- // Set the innerHTML for the preview holder
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('avatar-decoration-image');
-
- // Set the initial image for the deco card
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = imgElement.src = item.static;
-
- previewHolder.appendChild(imgElement);
-
- const bgimg = document.createElement("div");
- bgimg.id = "shop-card-deco-bg-image";
-
- previewHolder.appendChild(bgimg);
-
- // Set the product details
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = item.animated;
- if (localStorage.discord_avatar != defaultAvatar1 && localStorage.discord_avatar != defaultAvatar2 && localStorage.discord_avatar != defaultAvatar3 && localStorage.discord_avatar != defaultAvatar4 && localStorage.discord_avatar != defaultAvatar5 && localStorage.discord_avatar != defaultAvatar6) {
- bgimg.style.backgroundImage = `url(${localStorage.discord_avatar})`
- }
- });
-
- card.addEventListener("mouseleave", () => {
- imgElement.src = item.static;
- bgimg.style.backgroundImage = `url()`;
- });
- }
-
- });
- } else if (product.items[0].item_type === 'effect') {
- card.classList.add("type_1");
-
- card.querySelector("[data-product-card-sku-id]").textContent = ``;
- card.querySelector("[data-product-card-name]").textContent = product.name;
- card.querySelector("[data-product-card-summary]").textContent = product.summary;
-
- const previewHolder = card.querySelector("[data-shop-card-preview-holder]");
- previewHolder.classList.add('profile-effect-image');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = card.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- card.addEventListener("mouseenter", () => {
- imgElement.src = product.items[0].animated;
- });
-
- card.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = product.items[0].static;
- });
- }
- } else {
- card.classList.add('hidden')
- }
-
-
- const priceTextNitro = card.querySelector("[data-price-nitro]");
- const priceTextStandard = card.querySelector("[data-price-standard]");
-
- const priceContainerNitro = card.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = card.querySelector("[data-price-standard-container]");
-
- const priceContainer = card.querySelector("[data-shop-price-container]");
-
- let priceStandard = "N/A";
- let priceNitro = "N/A";
- let priceOrb = "N/A";
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- if (localStorage.discord_premium_type === "2") {
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- standardPriceOutput = `US$${(priceStandard / 100).toFixed(2)}`;
-
- priceContainerStandard.innerHTML = `
- ${standardPriceOutput}
-
- `;
-
- } else if (priceStandard != "N/A") {
-
- standardPriceOutput = `US$${(priceStandard / 100).toFixed(2)}`;
-
- priceContainerStandard.innerHTML = `
- ${standardPriceOutput}
-
- `;
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
- orb_price.style.bottom = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- priceTextStandard.textContent = `US$${(priceStandard / 100).toFixed(2)}`;
-
- } else if (priceStandard != "N/A") {
-
- priceTextStandard.textContent = `US$${(priceStandard / 100).toFixed(2)}`;
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
- orb_price.style.bottom = `0px`;
-
- priceContainer.appendChild(orb_price);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- }
-
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceNitro = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- if (priceTextNitro) {
- priceTextNitro.textContent = priceNitro !== "N/A" ? `US$${(priceNitro / 100).toFixed(2)} with Nitro` : "null";
- }
- }
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 1: Enabled" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button") {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
-
- ${getTextString("CARD_OPEN_IN_SHOP_V2")}
- ${getTextString("CARD_COPU_SKU_ID")}
-
- `;
- } else {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = `
- ${getTextString("CARD_OPEN_IN_SHOP")}
- `;
- }
-
- if (product.items[0] && product.items[0].item_type && product.items[0].item_type === 'deco' || product.items[0] && product.items[0].item_type && product.items[0].item_type === 'effect' || product.sku_id === "0") {
- card.querySelector("[data-product-card-open-in-shop]").innerHTML = ``;
- }
-
- if (product.premium_type === 2) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 1: Enable modals" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 3: Enable modals w/ p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 4: Enable modals w/ p+ on p+ page" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- if (product.type === item_types.AVATAR_DECORATION || product.type === item_types.PROFILE_EFFECT || product.type === item_types.NAMEPLATE || product.type === item_types.BUNDLE || product.type === item_types.VARIANTS_GROUP || product.type === item_types.EXTERNAL_SKU) {
- card.classList.add('clickable');
-
- card.addEventListener("click", (event) => {
- if (event.target.matches("[data-shop-card-var]") || event.target.matches(".card-button") || event.target.matches(".shareIcon_f4a996")) {
- } else {
- openItemModal();
- addParams({itemSkuId: product.sku_id})
- }
- });
-
- const itemSKUForScroll = params.get("itemSkuId");
-
- if (itemSKUForScroll === product.sku_id && modalIsAlreadyOpen != true) {
- modalIsAlreadyOpen = true;
- setTimeout(() => {
- openItemModal();
- }, 1000);
- }
-
-
- async function openItemModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- if (apiCategory.pdp_bg != null) {
- pdp = apiCategory.pdp_bg
- } else {
- pdp = apiCategory.banner
- }
-
- modal.innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- if (apiCategory.logo != null) {
- modal.querySelector("[data-modalv2-inner-logo]").src = `https://cdn.discordapp.com/app-assets/1096190356233670716/${apiCategory.logo}.png?size=4096`;
- }
-
- const button_container = document.querySelector("[data-modal-buttons]");
- const top_button_container = document.querySelector("[data-modal-top-product-buttons]");
-
-
- let copyDiscordLink = document.createElement("div");
-
- copyDiscordLink.title = getTextString("SHOP_SHARE_DISCORD_LINK");
- copyDiscordLink.innerHTML = `
-
- `;
-
- top_button_container.appendChild(copyDiscordLink);
-
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- let downloadItemData = document.createElement("div");
-
- downloadItemData.title = getTextString("SHOP_DOWNLOAD_DATA");
- downloadItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(downloadItemData);
- }
-
- if (localStorage.experiment_2025_03_view_raw_modal === "Treatment 1: Enabled") {
- let rawItemData = document.createElement("div");
-
- rawItemData.title = getTextString("SHOP_VIEW_RAW_DATA");
- rawItemData.innerHTML = `
-
- `;
-
- top_button_container.appendChild(rawItemData);
-
- modal.querySelector("[data-view-raw-product-card-button]").onclick = function(){
- openRawModal();
- };
-
- async function openRawModal() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
- button_container.innerHTML = `
- ${getTextString("CARD_OPEN_IN_SHOP")}
- `;
-
- if (product.type === item_types.AVATAR_DECORATION) {
-
- modal.classList.add('modal-0');
-
- product.items.forEach(item => {
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
-
- } else {
-
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- const imgElement = document.createElement("img");
- imgElement.id = "shop-card-deco-image";
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
-
- previewHolder.appendChild(imgElement);
-
- // Hover effect: Change the image src on mouse enter and leave
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- }
-
- });
- } else if (product.type === item_types.PROFILE_EFFECT) {
- modal.classList.add('modal-1');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(product.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = product.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (product.items && product.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = product.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (matchingEffect) {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- const imgElement = document.createElement("img");
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
-
- previewHolderLeft.appendChild(imgElement);
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- } else {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- }
- } else if (product.type === item_types.NAMEPLATE) {
- card.classList.add("modal-2");
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('nameplate-modal-preview');
-
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- if (localStorage.discord_displayname && localStorage.discord_displayname != '') {
- previewName = localStorage.discord_displayname;
- } else {
- previewName = 'Default User'
- }
-
- if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning" && product.category_sku_id === discord_categories.NAMEPLATE) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_1")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- } else if (localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 1: Nameplate Test Warning" || localStorage.experiment_2025_03_early_nameplate_warning === "Treatment 2: Nameplate & Nameplate Test Warning") {
- if (product.category_sku_id === discord_categories.NAMEPLATE_TEST) {
- let nameplateWarning = document.createElement("div");
-
- nameplateWarning.classList.add('nameplate-modal-early-warning-container');
- nameplateWarning.innerHTML = `
- ${getTextString("SHOP_NAMEPLATE_WARNING_NOTICE_2")}
- `;
-
- modal.querySelector(".modalv2-inner-left").appendChild(nameplateWarning);
- }
- }
-
- previewHolder.innerHTML = `
-
-
-
-
-
- `;
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- product.items.forEach(item => {
- const nameplatePreview = previewHolder.querySelector("[data-user-nameplate-preview]");
- const paletteName = item.palette;
- const asset = `https://cdn.discordapp.com/assets/collectibles/${item.asset}asset.webm`;
- const bgcolor = nameplate_palettes[paletteName].darkBackground;
-
- const videoElement = previewHolder.querySelector("[data-user-nameplate-preview-img]");
-
- videoElement.src = asset;
-
- nameplatePreview.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
- // nameplatePreview.style.boxShadow = `0 0 0 1px #a10606`;
-
- const nullUserNameRandomWidth = previewHolder.querySelectorAll("[data-null-user-random-name]");
-
- nullUserNameRandomWidth.forEach(UserName => {
- const randomWidth = Math.floor(Math.random() * (180 - 80 + 1)) + 80;
- UserName.style.width = randomWidth + `px`;
- });
-
- const nullUserAvatar = previewHolder.querySelectorAll("[data-nameplate-user-random-avatar]");
-
- nullUserAvatar.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- videoElement.play();
- }
-
-
-
- const videoElementLeft = previewHolderLeft.querySelector("[data-user-nameplate-preview-img-left]");
- const nameplatePreviewLeft = previewHolderLeft.querySelector("[data-user-nameplate-preview-left]");
- previewHolderLeft.classList.add("modal-left-nameplate-preview");
-
- videoElementLeft.src = asset;
-
- nameplatePreviewLeft.style.backgroundImage = `linear-gradient(90deg, #00000000 -30%, ${bgcolor} 200%)`;
-
- const nullUserAvatarLeft = previewHolderLeft.querySelectorAll("[data-nameplate-user-random-avatar-left]");
-
- nullUserAvatarLeft.forEach(UserAvatar => {
- UserAvatar.style.backgroundImage = `url(${localStorage.discord_avatar})`;
- });
-
- if (localStorage.reduced_motion != "true") {
- videoElementLeft.addEventListener("mouseenter", () => {
- videoElementLeft.play();
- });
-
- videoElementLeft.addEventListener("mouseleave", () => {
- videoElementLeft.pause();
- });
- }
- });
-
- } else if (product.type === item_types.BUNDLE) {
- modal.classList.add('modal-1000');
-
- const bundledProducts = product.bundled_products || [];
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- // Generate the bundle summary from the names of the bundled products
- const type0Product = bundledProducts.find(item => item.type === 0);
- const type1Product = bundledProducts.find(item => item.type === 1);
-
- let bundleSummary = `${getTextString("CARD_TYPE_BUNDLE_TITLE")}`;
- if (type0Product) {
- bundleSummary += `${type0Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_DECO")}`;
- }
- if (type1Product) {
- bundleSummary += `${type1Product.name}${getTextString("CARD_TYPE_BUNDLE_TITLE_EFFECT")}`;
- }
-
- // Set the summary text
- modal.querySelector("[data-product-modal-summary]").textContent = bundleSummary;
-
- // Set the basic card details
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
-
- // Handle each item in the bundle
- product.items.forEach(item => {
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (item.type === 0) {
- decosrc = item.asset
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- renderProfile(effectUrl)
- }
- }
- })();
- }
-
- function renderProfile(effectUrl) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
-
-
- } else {
- if (item.type === 0) {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.classList.add("modal-avatar-decoration-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- } else if (item.type === 1) {
- // Profile effect
- (async () => {
- // Fetch profile effects if not cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find the matching effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === item.id);
-
- if (matchingEffect) {
- const effectImage = document.createElement("img");
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- effectImage.alt = "Profile Effect";
- effectImage.classList.add("modal-profile-effect-img");
- modal.querySelector("[data-modal-preview-holder]").appendChild(effectImage);
-
- // Hover effect for profile effect
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- effectImage.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- effectImage.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- effectImage.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- });
- } else if (product.type === item_types.VARIANTS_GROUP) {
- modal.querySelector("[data-shop-modal-var-container-container]").classList.add('show');
- // Update SKU and summary
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- // Always display the base variant name
- modal.querySelector("[data-product-modal-name]").textContent = product.variants[0]?.base_variant_name || "Product";
-
- // Render variant color blocks as interactive divs
- const variantContainer = modal.querySelector("[data-shop-modal-var-container]");
- variantContainer.innerHTML = ""; // Clear existing variant blocks
- let currentSelectedVariant = null; // Track selected variant
-
- product.variants.forEach((variant, index) => {
- // Create variant color block
- const variantColorBlock = document.createElement("div");
- variantColorBlock.classList.add("shop-card-var");
- variantColorBlock.style.backgroundColor = `${variant.variant_value}`;
-
- // Add click event listener to switch variants
- variantColorBlock.addEventListener("click", () => {
- if (currentSelectedVariant) {
- currentSelectedVariant.classList.remove("shop-card-var-selected");
- }
- variantColorBlock.classList.add("shop-card-var-selected");
- currentSelectedVariant = variantColorBlock;
- applyVariant(variant);
- });
-
- // Append the color block to the container
- variantContainer.appendChild(variantColorBlock);
-
- // Set the first variant as the default selected
- if (index === 0) {
- currentSelectedVariant = variantColorBlock;
- variantColorBlock.classList.add("shop-card-var-selected");
- }
- });
-
- let isFirstTimeLoadingVariant = true;
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- const previewHolderLeft = modal.querySelector("[data-modal-left-preview-holder]");
-
- // Function to apply the selected variant
- function applyVariant(selectedVariant) {
- modal.querySelector("[data-shop-modal-var-title]").textContent = `(${selectedVariant.variant_label})`;
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${selectedVariant.sku_id}`;
- modal.querySelector("[data-share-product-card-button]").onclick = function(){
- copyEmoji(`https://canary.discord.com/shop#itemSkuId=${selectedVariant.sku_id}`);
- };
- if (localStorage.experiment_2025_02_shop_card_modals === "Treatment 2: Enable modals w/ data downloads" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 5: Enable modals w/ data downloads and p+" || localStorage.experiment_2025_02_shop_card_modals === "Treatment 6: Enable modals w/ data downloads and p+ on p+ page") {
- modal.querySelector("[data-download-product-card-button]").onclick = function(){
- window.open(`https://item.yapper.shop/sku/${selectedVariant.sku_id}/data.zip`);
- };
- }
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
-
- if (selectedVariant.type === 0) {
- selectedVariant.items?.forEach(item => {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- previewHolderLeft.classList.add('modal-left-avatar-decoration-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-deco-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- imgElement.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
-
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- if (!discordProfileEffectsCache) {
- await setDiscordProfileEffectCache();
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
- `;
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- }
- }
-
- previewHolderLeft.classList.add('modal-left-profile-effect-img');
-
- previewHolderLeft.innerHTML = `
-
- `;
-
- const imgElement = previewHolderLeft.querySelector("[data-left-preview-effect-var]");
-
- if (localStorage.reduced_motion != "true") {
- imgElement.addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- imgElement.addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- imgElement.addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- })();
- }
-
-
- } else {
- if (selectedVariant.type === 0) {
- modal.classList.add("modal-2000-0");
- previewHolder.innerHTML = ""; // Clear previous decorations
- previewHolder.classList.add('modal-avatar-decoration-img');
-
- // Add the avatar decoration based on the selected variant
- selectedVariant.items?.forEach(item => {
- const decoImage = document.createElement("img");
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- decoImage.alt = "Avatar Decoration";
- decoImage.id = "shop-card-deco-image";
- previewHolder.appendChild(decoImage);
-
- // Hover effect for decoration image
- if (localStorage.reduced_motion !== "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=true`;
- });
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- decoImage.src = `https://cdn.discordapp.com/avatar-decoration-presets/${item.asset}.png?size=4096&passthrough=false`;
- });
- }
- });
- } else if (selectedVariant.type === 1) {
- modal.classList.add("modal-2000-1");
- (async () => {
- // Ensure the item ID is accessible here
- let itemId = undefined;
- if (Array.isArray(selectedVariant.items)) {
- // If items is an array, find the item with type 1 and get its id
- const item = selectedVariant.items.find(item => item.type === 1);
- if (item) {
- itemId = item.id;
- }
- } else if (selectedVariant.items && selectedVariant.items.type === 1) {
- // If items is an object and has type 1, get its id
- itemId = selectedVariant.items.id;
- }
-
-
- // Fetch profile effects API only if not already cached
- if (!discordProfileEffectsCache) {
- const response = await fetch(api + PROFILE_EFFECTS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- });
- const effectsData = await response.json();
- discordProfileEffectsCache = effectsData.profile_effect_configs;
- }
-
- // Find matching profile effect
- const matchingEffect = discordProfileEffectsCache.find(effect => effect.id === itemId);
-
- if (matchingEffect) {
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
- previewHolder.classList.add('modal-profile-effect-img');
-
- previewHolder.innerHTML = `
-
- `;
-
- // Hover effect: change to the first effect URL (use 'src' from the 'effects' array)
- const imgElement = previewHolder.querySelector("img");
-
- if (localStorage.reduced_motion != "true") {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- if (matchingEffect.effects && matchingEffect.effects.length > 0) {
- const effectUrl = matchingEffect.effects[0]?.src;
- imgElement.src = effectUrl || matchingEffect.thumbnailPreviewSrc;
- }
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- } else {
- document.getElementById('modalv2-inner-right').addEventListener("mouseenter", () => {
- imgElement.src = matchingEffect.reducedMotionSrc;
- });
-
- document.getElementById('modalv2-inner-right').addEventListener("mouseleave", () => {
- // Revert back to the original thumbnailPreviewSrc when hover ends
- imgElement.src = matchingEffect.thumbnailPreviewSrc;
- });
- }
- }
- })();
- }
- }
- }
-
- // Apply the default variant (first one) initially
- if (product.variants.length > 0) {
- applyVariant(product.variants[0]);
- }
- } else if (product.type === item_types.EXTERNAL_SKU) {
- modal.classList.add('modal-3000');
-
- modal.querySelector("[data-product-modal-sku-id]").textContent = `SKU ID: ${product.sku_id}`;
- modal.querySelector("[data-product-modal-name]").textContent = product.name;
- modal.querySelector("[data-product-modal-summary]").textContent = product.summary;
-
- const previewHolder = modal.querySelector("[data-modal-preview-holder]");
-
- if (product.sku_id === ORB_PROFILE_BADGE) {
- previewHolder.classList.add('modal-preview-profile-container');
- previewHolder.innerHTML = `
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
-
-
-
- `;
-
- document.getElementById("modal-username-preview").textContent = localStorage.discord_username.toLowerCase();
- } else if (product.sku_id === NITRO_CREDITS_3_DAYS) {
- previewHolder.classList.add('modal-preview-profile-container');
-
- previewHolder.innerHTML = `
-
-
-
Nitro
-
-
-
Custom emojis anywhere
-
-
-
-
-
-
-
Colour app themes and more!
-
-
- `;
- } else {
- previewHolder.innerHTML = `
- ${getTextString("CARD_TYPE_EXTERNAL_SKU_ERROR")}
- `;
- }
-
- }
-
-
- const priceTextNitro = modal.querySelector("[data-price-nitro]");
- const priceTextStandard = modal.querySelector("[data-price-standard]");
-
- const priceContainerNitro = modal.querySelector("[data-price-nitro-container]");
- const priceContainerStandard = modal.querySelector("[data-price-standard-container]");
-
- const priceContainer = modal.querySelector("[data-shop-price-container]");
-
- let priceStandard = "N/A";
- let priceNitro = "N/A";
- let priceOrb = "N/A";
-
- if (localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- if (localStorage.discord_premium_type === "2") {
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `20px`;
-
- priceContainer.appendChild(orb_price);
-
- } else if (priceStandard != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
-
- priceContainer.appendChild(orb_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.right = `20px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- } else if (priceStandard != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.left = `23px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.right = `20px`;
-
- priceContainer.appendChild(orb_price);
-
- } else if (priceStandard != "N/A") {
-
- let nitro_price = document.createElement("div");
-
- nitro_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
- `;
- nitro_price.style.position = `absolute`;
- nitro_price.style.left = `0px`;
-
- priceContainer.appendChild(nitro_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_price = document.createElement("div");
-
- orb_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_price.style.position = `absolute`;
- orb_price.style.left = `23px`;
-
- priceContainer.appendChild(orb_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- if (price.currency === "discord_orb") {
- priceOrb = price.amount;
- }
- });
-
- if (priceStandard != "N/A" && priceOrb != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.right = `20px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- } else if (priceStandard != "N/A") {
-
- let standard_price = document.createElement("div");
-
- standard_price.innerHTML = `
- US$${(priceStandard / 100).toFixed(2)}
-
- `;
- standard_price.style.position = `absolute`;
- standard_price.style.left = `0px`;
- standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(standard_price);
-
- } else if (priceOrb != "N/A") {
-
- let orb_standard_price = document.createElement("div");
-
- orb_standard_price.innerHTML = `
- ${priceOrb}
-
- `;
- orb_standard_price.style.position = `absolute`;
- orb_standard_price.style.left = `23px`;
- orb_standard_price.style.marginTop = `30px`;
-
- priceContainer.appendChild(orb_standard_price);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_ORB_EXCLUSIVE_TAG")}
-
- `;
-
- }
- }
- }
-
- } else {
- if (product.prices && product.prices["0"] && product.prices["0"].country_prices && product.prices["0"].country_prices.prices) {
- product.prices["0"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceStandard = price.amount;
- }
- });
- }
-
- if (product.prices && product.prices["4"] && product.prices["4"].country_prices && product.prices["4"].country_prices.prices) {
- product.prices["4"].country_prices.prices.forEach(price => {
- if (price.currency === "usd") {
- priceNitro = price.amount;
- }
- });
- }
-
- if (priceTextStandard) {
- priceTextStandard.textContent = priceStandard !== "N/A" ? `US$${(priceStandard / 100).toFixed(2)}` : "null";
- }
-
- if (priceTextNitro) {
- priceTextNitro.textContent = priceNitro !== "N/A" ? `US$${(priceNitro / 100).toFixed(2)} with Nitro` : "null";
- }
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_UNPUBLISHED_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- if (product.premium_type === 2) {
- modal.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && product.type != 3000) {
-
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen") {
- let newLogInWithDiscordDismissible = document.createElement("div");
-
- newLogInWithDiscordDismissible.innerHTML = `
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_TITLE")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_1")}
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_2")}
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_LOG_IN")}
-
${getTextString("DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_NO_THANKS")}
-
-
- `;
-
- newLogInWithDiscordDismissible.classList.add('newLogInWithDiscordDismissible');
-
- newLogInWithDiscordDismissible.id = `newLogInWithDiscordDismissible`;
-
- modal.appendChild(newLogInWithDiscordDismissible);
- }
- }
-
-
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- removeParams('itemSkuId');
- modalIsAlreadyOpen = false;
- }
- });
-
- document.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
- }
-
- if (localStorage.experiment_2025_03_copy_sku_card === "Treatment 2: w/ share button" || localStorage.experiment_2025_03_copy_sku_card === "Treatment 3: only share button") {
- card.querySelector("[data-share-product-card-button]").innerHTML = `
-
- `;
- }
-
-
- function newItemCheck() {
-
- if (N > g) {
- } else {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_NEW_TAG")}
-
- `;
- }
- }
-
- if (m.includes(product.sku_id)) {
- newItemCheck();
- }
-
- function newColorItemCheck() {
-
- if (N > newColorsExpireDate) {
- } else {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_NEW_COLORS_TAG")}
-
- `;
- }
- }
-
- if (params.get("page") === "leaks") {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_LEAKED_TAG")}
-
- `;
- }
-
- if (newColorsSKUIDS.includes(product.sku_id) && discord_categories.ANIME_V3 === apiCategory.sku_id) {
- newColorItemCheck();
- }
-
- function popularItemCheck() {
- card.classList.add('popular-item');
- }
-
- if (I.includes(product.sku_id)) {
- popularItemCheck();
- }
-
-
- const unpublishedAt = new Date(product.unpublished_at);
-
- if (product.unpublished_at && !isNaN(unpublishedAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_UNPUBLISHED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${days}${getTextString("CARD_UNPUBLISHED_COUNTDOWN_TAG")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- const ExpiredAt = new Date(product.expires_at);
-
- if (product.expires_at && !isNaN(ExpiredAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = ExpiredAt - now;
-
- if (timeDiff <= 0) {
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_TAG")}
-
- `;
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- card.querySelector("[data-shop-card-tag-container]").innerHTML = `
-
-
${getTextString("CARD_EXPIRED_COUNTDOWN_TAG")}${days}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_DAYS")}${hours}${getTextString("CARD_EXPIRED_COUNTDOWN_TAG_HOURS")}
-
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- // Append card to output
- cardOutput.append(card);
-
- scrollToSKU(product.sku_id);
- }
- }
-
- categoryOutput.append(category);
-
- scrollToSKU(apiCategory.sku_id);
-
- const nameplates_banner = document.getElementById(discord_categories.NAMEPLATE);
- const arcane_banner = document.getElementById(discord_categories.WARRIOR);
- const dnd_banner = document.getElementById(discord_categories.CHANCE);
- const street_fighter_banner = document.getElementById(discord_categories.BAND);
- const fall_banner = document.getElementById(discord_categories.FALL);
- const palworld_banner = document.getElementById(discord_categories.TIDE);
- const valorant_banner = document.getElementById(discord_categories.SHY);
-
- if (localStorage.disable_client_banner_overrides != "true") {
- if (nameplates_banner) {
- document.getElementById(`${discord_categories.NAMEPLATE}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.NAMEPLATE}-banner-banner-container`).innerHTML = `
-
-
- `;
- }
-
- if (palworld_banner) {
- document.getElementById(`${discord_categories.TIDE}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.TIDE}-banner-banner-container`).innerHTML = `
-
-
-
- `;
- document.getElementById(`${discord_categories.TIDE}-logo-container`).innerHTML = `
-
- `;
- }
-
- if (valorant_banner) {
- document.getElementById(`${discord_categories.SHY}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.SHY}-banner-banner-container`).innerHTML = `
-
-
-
-
- `;
- document.getElementById(`${discord_categories.SHY}-logo-container`).innerHTML = `
-
- `;
- }
-
- if (localStorage.reduced_motion != "true") {
-
- if (arcane_banner) {
- document.getElementById(`${discord_categories.WARRIOR}-banner-banner-container`).innerHTML = `
-
-
- `;
- }
-
- if (dnd_banner) {
- document.getElementById(`${discord_categories.CHANCE}-banner-banner-container`).innerHTML = `
-
-
- `;
- }
-
- if (street_fighter_banner) {
- document.getElementById(`${discord_categories.BAND}-banner-banner-container`).innerHTML = `
-
-
- `;
- }
-
- if (palworld_banner) {
- document.getElementById(`${discord_categories.TIDE}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.TIDE}-banner-banner-container`).innerHTML = `
-
-
-
-
- `;
- document.getElementById(`${discord_categories.TIDE}-logo-container`).innerHTML = `
-
- `;
- }
-
- if (valorant_banner) {
- document.getElementById(`${discord_categories.SHY}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.SHY}-banner-banner-container`).innerHTML = `
-
-
-
-
- `;
- document.getElementById(`${discord_categories.SHY}-logo-container`).innerHTML = `
-
- `;
- }
-
- }
- }
-
- if (fall_banner) {
- document.getElementById(`${discord_categories.FALL}-discord-watermark-container`).innerHTML = ``;
- document.getElementById(`${discord_categories.FALL}-logo-container`).innerHTML = ``;
- }
- }
- }
-
- // Remove loading container
- document.getElementById("shop-category-loading-container").innerHTML = ``;
- }
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
${getTextString("SHOP_NOT_LOAD_ERROR_1")}
-
${getTextString("SHOP_NOT_LOAD_ERROR_2")}
-
${error}
-
${getTextString("SHOP_NOT_LOAD_ERROR_RELOAD")}
-
- `;
- });
-
- }
- }
-
- async function fetchUserProfileInfo(userID) {
- let modal = document.createElement("div");
-
- modal.classList.add('modal-profile');
-
- modal.innerHTML = `
- Loading User Profile...
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- modal_back.style.opacity = '0';
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- fetch(api + `/users/${userID}/profile`, {
- method: "GET",
- headers: {
- "Authorization": localStorage.shop_archives_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- if (data.message) {
- modal.innerHTML = `
-
-
-
-
-
-
-
${data.message}
-
${data.error}
-
-
- `;
- } else {
- modal.innerHTML = `
-
-
-
-
-
-
-
${data.global_name}
-
${data.username}
-
-
- `;
-
- if (data.banner_color) {
- modal.querySelector("[popout-profile-banner-color]").style.backgroundColor = data.banner_color;
- }
-
- if (data.global_name === null) {
- modal.querySelector("[popout-profile-displayname]").textContent = data.username;
- }
-
- modal.querySelector("[popout-profile-username]").textContent = data.username;
- }
- })
- .catch(error => {
- console.error(error);
- modal.innerHTML = `
-
-
-
-
-
-
-
Unknown User
-
unknownuser
-
-
- `;
- });
- }
-
-
- function renderReviewTextWithEmojis(reviewText) {
- // Escape HTML special characters
- const safeText = reviewText
- .replace(/&/g, "&")
- .replace(//g, ">");
-
- // Replace :emoji: with
- const rendered = safeText.replace(/(:[a-zA-Z0-9_]+:)/g, (match) => {
- const emojiUrl = CUSTOM_EMOJIS[match];
- if (emojiUrl) {
- return ` `;
- }
- return match; // Leave as-is if emoji not found
- });
-
- return rendered;
- }
-
-
- function selectReviewReportType(type) {
- if (document.querySelector(".report-card-option-selected")) {
- document.querySelectorAll('.report-card-option-selected').forEach((el) => {
- el.classList.remove("report-card-option-selected");
- });
- }
-
- if (type === 1 || type === 2 || type === 3 || type === 4 || type === 5) {
- document.getElementById("report-review-report-card-option-" + type).classList.add("report-card-option-selected");
- document.getElementById("report-review-report-card-inv-imput").value = type;
- } else {
- console.error(type + " is not a valid review report type")
- }
- }
-
- function reportReview(reviewId, reportType) {
-
- fetch(api + REVIEWSAPI + `/report/${reviewId}`, {
- method: "POST",
- headers: {
- "Content-Type": "application/json",
- "Authorization": shop_archives_token
- },
- body: JSON.stringify({
- reportType: Number(reportType)
- })
- })
- .then(response => response.json())
- .then((data) => {
- if (data.success && data.success === true) {
- const modal = document.getElementById("modalv2-report-review");
- const modal_back = document.getElementById("modalv2-report-review-back");
-
- if (modal && modal_back) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- fillCategoryModalContentContainer('reviews', true);
- }
- if (document.getElementById("review-panel-report-type-id-" + reviewId) && document.getElementById("review-panel-report-type-id-" + reviewId + "-text")) {
- document.getElementById("review-panel-report-type-id-" + reviewId).classList.remove("review-flag-type-2");
- document.getElementById("review-panel-report-type-id-" + reviewId).classList.add("review-flag-type-0");
- document.getElementById("review-panel-report-type-id-" + reviewId + "-text").textContent = "0";
- }
- } else {
- if (document.getElementById("shop-category-modal-report-review-error-output")) {
- document.getElementById("shop-category-modal-report-review-error-output").textContent = data.message;
- }
- }
- })
- .catch(error => {
- console.error(error);
- if (document.getElementById("shop-category-modal-report-review-error-output")) {
- document.getElementById("shop-category-modal-report-review-error-output").textContent = error;
- }
- });
- }
-
-
- const postReview = async (itemId, rating) => {
-
- if (document.getElementById("shop-category-modal-write-review-error-output")) {
- document.getElementById("shop-category-modal-write-review-error-output").textContent = ``;
- }
-
- const accessToken = localStorage.discord_token;
-
- const reviewText = document.getElementById("shop-category-modal-write-review-post-input").value;
-
- if (!accessToken) {
- console.error('Access token is missing!');
- return;
- }
-
- const response = await fetch(api + REVIEWSAPI, {
- method: 'POST',
- headers: {
- 'Content-Type': 'application/json',
- "Authorization": shop_archives_token
- },
- body: JSON.stringify({
- itemId,
- rating,
- reviewText
- })
- });
-
- const result = await response.json();
- if (response.ok) {
- fillCategoryModalContentContainer('reviews', true);
- } else {
- if (document.getElementById("shop-category-modal-write-review-error-output")) {
- document.getElementById("shop-category-modal-write-review-error-output").textContent = `${result.message}`;
- }
- }
-
- };
-
- // Example usage:
- // postReview('item123', 5, 'This is my review text.');
-
- window.postReview = postReview;
-
- function deleteReview(reviewId) {
-
- fetch(api + REVIEWSAPI + `/delete/${reviewId}`, {
- method: "DELETE",
- headers: {
- "Content-Type": "application/json",
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- fillCategoryModalContentContainer('reviews', true);
- })
- .catch(error => {
- console.error(error)
- });
- }
-
-
- function deleteAllStoredUserData() {
- const accessToken = discord_token;
-
- fetch(api + REVIEWSAPI + '/all', {
- method: "DELETE",
- headers: {
- "Content-Type": "application/json",
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- },
- body: JSON.stringify({
- accessToken
- })
- })
- .catch(error => {
- console.error(error)
- });
- }
-
-
- // Function to copy the emoji to clipboard
- function copyEmoji(emoji) {
- navigator.clipboard.writeText(emoji)
- }
-
- // Redirect to Google if emojiCopy is null
- function redirectToLink(link) {
- window.location.href = link;
- }
-
-
- if (params.get("page") != "item_tool" && params.get("page") != "published_listings" && params.get("page") != "orb_converter" && params.get("page") != "year-recap" && params.get("page") != "login") {
- window.onload = fetchData;
- }
-
- const clickable_side_tabs_container = document.getElementById('clickable-side-tabs-container');
- if (clickable_side_tabs_container) { // Check if element exists
- document.getElementById('clickable-side-tabs-container').innerHTML = `
- ${getTextString("DISCORD_DISCLAIMER")}
- ${getTextString("DISCORD_DISCLAIMER")}
-
-
- ${getTextString("FEATURED_TAB_TITLE")}
-
-
-
-
- ${getTextString("SHOP_DM_DEVIDER")}
-
-
- ${getTextString("SHOP_TAB_TITLE")}
-
-
-
-
-
-
-
-
- ${getTextString("POTIONS_TAB_TITLE")}
-
-
- ${getTextString("MISCELLANEOUS_TAB_TITLE")}
-
-
-
-
-
- ${getTextString("PROFILES_PLUS_TAB_TITLE")}
-
-
-
-
-
- ${getTextString("TOOLS_DM_DEVIDER")}
-
-
- `;
-
- if (localStorage.experiment_2025_02_profiles_plus_home === "Treatment 2: Enabled") {
- document.getElementById('old-pplus-tab').innerHTML = ``;
- document.getElementById('new-profiles-plus-tab-container').innerHTML = `
- ${getTextString("PROFILES_PLUS_DM_DEVIDER")}
-
-
- ${getTextString("PROFILES_PLUS_FEATURED_TAB_TITLE")}
-
-
- ${getTextString("PROFILES_PLUS_BROWSE_ALL_TAB_TITLE")}
-
-
- `;
- }
-
- if (localStorage.experiment_2025_02_profiles_plus_home === "Treatment 3: Hide All Profiles Plus Tabs") {
- document.getElementById('old-pplus-tab').innerHTML = ``;
- document.getElementById('new-profiles-plus-tab-container').innerHTML = ``;
- }
-
- if (localStorage.experiment_2025_01_orb_testing === "Treatment 4: Orb Converter") {
- document.getElementById('orb-converter').innerHTML = `
-
- ${getTextString("ORB_CONVERTER_TAB_TITLE")}
-
- `;
- }
-
- if (localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 1: Enabled" || localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 2: Enable v2") {
- document.getElementById('shop-marketing-tab-container').innerHTML = `
-
- ${getTextString("MARKETING_TAB_TITLE")}
-
- `;
- }
-
- if (localStorage.dev === "true") {
- document.getElementById('secret-tools').innerHTML = `
-
- ${getTextString("ITEM_DEBUG_TAB_TITLE")}
-
- `;
- }
- }
-
- if (localStorage.experiment_2024_11_recap === "Treatment 1: Enabled") {
- document.getElementById('recap-2024-tab-loading').innerHTML = `
-
-
- ${getTextString("RECAP_2024_TAB_TITLE")}
-
-
- `;
- document.getElementById('recap-2024-tab').style.backgroundImage = "linear-gradient(90deg, rgba(200, 91, 241, 0.00) 18.75%, #C85BF1 108.26%)";
- } else if (localStorage.experiment_2024_11_recap === "Treatment 2: Nameplate Marketing") {
- document.getElementById('recap-2024-tab-loading').innerHTML = `
-
-
- ${getTextString("RECAP_2024_TAB_TITLE")}
-
-
- `;
- document.getElementById('recap-2024-tab').style.backgroundImage = "linear-gradient(10deg, rgba(0, 0, 0, 0) 40%, rgb(115, 11, 200) 180%), linear-gradient(170deg, rgba(0, 0, 0, 0) 40%, rgb(115, 11, 200) 180%)";
- }
-
- function pageCheck() {
- privateAPICheck()
- if (params.get("page") === "home") {
- document.title = `${getTextString("FEATURED_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "home");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + HOME_PAGE_ALL;
- }
- createHomePageElement()
- document.getElementById("home-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("FEATURED_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "year-recap") {
- document.title = `${getTextString("RECAP_2024_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- createRecap2024Element()
- document.getElementById("recap-2024-tab").classList.add('dm-button-selected');
- localStorage.dismissible_recap_2024 = "Treatment 1: Seen";
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("RECAP_2024_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "shop") {
- document.title = `${getTextString("SHOP_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "shop");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + COLLECTIBLES_VARIANTS;
- }
- createMainShopElement()
- document.getElementById("shop-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("SHOP_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "orbs") {
- document.title = `${getTextString("ORB_SHOP_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_orbs_shop === "Treatment 2: Orb Shop done like default" || localStorage.experiment_2025_02_orbs_shop === "Treatment 3: Default + New tag") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
-
- if (localStorage.experiment_2025_05_orbs_shop_home === "Treatment 1: Enabled") {
- apiUrl.searchParams.append("tab", "orbs-home");
- createHomePageElement()
- } else {
- apiUrl.searchParams.append("tab", "orbs");
- createMainShopElement()
- }
-
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- if (localStorage.experiment_2025_02_orbs_shop === "Treatment 3: Default + New tag") {
- localStorage.dismissible_orbs_shop_new_tag = "Treatment 1: Seen"
- }
- } else {
- apiUrl = api + ORBS_SHOP;
- }
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("ORB_SHOP_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "leaks") {
- document.title = `${getTextString("LEAKS_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "leaks");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + LEAKS;
- }
- createMainShopElement()
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("LEAKS_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "leaks_") {
- document.title = `${getTextString("LEAKS_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "fake-leaks");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + LEAKS;
- }
- createMainShopElement()
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("LEAKS_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "nameplates") {
- document.title = `${getTextString("NAMEPLATES_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "nameplates");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- }
- createMainShopElement()
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("NAMEPLATES_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "consumables") {
- document.title = `${getTextString("POTIONS_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "consumables");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + CONSUMABLES;
- }
- createMainPotionsElement()
- document.getElementById("potions-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("POTIONS_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "miscellaneous") {
- document.title = `${getTextString("MISCELLANEOUS_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "miscellaneous");
- if (localStorage.experiment_2025_04_purchasable_items == "Treatment 1: Enabled") {
- apiUrl.searchParams.append("include-purchasable", "true");
- }
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + MISCELLANEOUS;
- }
- createMainShopElement()
- document.getElementById("miscellaneous-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("MISCELLANEOUS_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "marketing") {
- document.title = `${getTextString("MARKETING_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "marketing");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- }
- createMainShopElement()
- document.getElementById("shop-marketing-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("MARKETING_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "pplus-home") {
- document.title = `${getTextString("PROFILES_PLUS_FEATURED_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "pplus-home");
- if (localStorage.unreleased_profiles_plus == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + HOME_PAGE_PPLUS;
- }
- createHomePageElement()
- document.getElementById("pplus-home-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("PROFILES_PLUS_FEATURED_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "pplus") {
- document.title = `${getTextString("PROFILES_PLUS_BROWSE_ALL_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiUrl = new URL(url);
- apiUrl.searchParams.append("tab", "pplus");
- if (localStorage.unreleased_profiles_plus == "true") {
- apiUrl.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiUrl = api + PROFILES_PLUS;
- }
- if (localStorage.experiment_2024_12_profiles_plus_marketing_variants == "Treatment 1: Paper Beach V2") {
- localStorage.dismissible_paper_beach_v2_marketing = "Treatment 1: Seen";
- } else if (localStorage.experiment_2024_12_profiles_plus_marketing_variants == "Treatment 2: Roblox Doors") {
- localStorage.dismissible_roblox_doors_marketing = "Treatment 1: Seen";
- }
- createMainShopElement()
- document.getElementById("pplus-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("PROFILES_PLUS_BROWSE_ALL_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "published_listings") {
- document.title = `${getTextString("PUBLISHED_LISTINGS_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- createPublishedListingsPageElement()
- document.getElementById("published-listings-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("PUBLISHED_LISTINGS_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "orb_converter") {
- document.title = `${getTextString("ORB_CONVERTER_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- createOrbConverterPageElement()
- document.getElementById("orb-converter-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("ORB_CONVERTER_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "item_tool") {
- document.title = `${getTextString("ITEM_DEBUG_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- createItemToolPageElement()
- document.getElementById("avatar-decorations-debug-tab").classList.add('dm-button-selected');
- document.getElementById("top-bar-container").innerHTML = `
- ${getTextString("ITEM_DEBUG_TAB_PAGE_TITLE")}
-
-
- `;
- } else if (params.get("page") === "login") {
- document.title = `${getTextString("DOCUMENT_TITLE_WEBSITE_NAME")}`;
- if (localStorage.experiment_2025_05_account_creator === "Treatment 1: Enabled") {
- document.body.innerHTML = `
-
-
-
-
${getTextString("ACCOUNT_CREATOR_BASIC_HEADER")}
-
${getTextString("ACCOUNT_CREATOR_BASIC_LOG_IN_DESC")}
-
-
-
-
BETA
-
${getTextString("ACCOUNT_CREATOR_STANDARD_HEADER")}
-
${getTextString("ACCOUNT_CREATOR_STANDARD_LOG_IN_DESC")}
-
-
-
-
-
-
-
-
-
-
- `;
-
- changeACType('1');
-
-
- window.addEventListener('DOMContentLoaded', () => {
- const hash = window.location.hash;
- const match = hash.match(/#token=([^&]+)/);
-
- if (match) {
- async function login() {
- try {
- const token = match[1];
- localStorage.setItem('discord_token', token);
- window.location.hash = '';
- localStorage.dismissible_newLogInWithDiscord = "Treatment 1: Seen";
-
-
- } catch (error) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
- }
-
- login();
- }
- });
- } else {
- document.body.innerHTML = `logging in...`;
- window.addEventListener('DOMContentLoaded', () => {
- const hash = window.location.hash;
- const match = hash.match(/#token=([^&]+)/);
-
- if (match) {
- async function login() {
- try {
- const token = match[1];
- localStorage.setItem('discord_token', token);
- window.location.hash = '';
- localStorage.dismissible_newLogInWithDiscord = "Treatment 1: Seen";
-
- if (!localStorage.discord_profile) {
- const userInfo = await fetch('https://discord.com/api/users/@me', {
- headers: { Authorization: `Bearer ${token}` }
- });
-
- if (!userInfo.ok) {
- // If the response is not ok (e.g., 401 Unauthorized)
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- return;
- }
-
- const user = await userInfo.json();
- localStorage.discord_profile = JSON.stringify(user, undefined, 4);
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${user.id}/${user.avatar}.webp?size=4096`;
- localStorage.discord_username = user.username;
- localStorage.discord_user_id = user.id;
- if (user.global_name != null) {
- localStorage.discord_displayname = user.global_name;
- } else {
- localStorage.discord_displayname = user.username;
- }
- localStorage.discord_banner_color = user.banner_color;
- localStorage.discord_premium_type = user.premium_type;
-
- if (user.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${user.id}/${user.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
-
- console.log('success');
- setParams({ page: 'home', login: 'true' });
- location.reload();
- }
-
- // Optional: additional check (but `localStorage.discord_profile` is a string, so this check won't work unless parsed)
- const parsedProfile = JSON.parse(localStorage.discord_profile);
- if (parsedProfile.code === 0) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
-
- } catch (error) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
- }
-
- login();
-
- } else {
- setParams({page: 'home', login: 'false'});
- location.reload();
- }
- });
- }
- } else if (params.get("page")) {
- setParams({page: 'home',err: '404'});
- document.title = `${getTextString("FEATURED_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- location.reload();
- console.log('b')
- } else {
- setParams({page: 'home'});
- document.title = `${getTextString("FEATURED_TAB_DOCUMENT_TITLE")}${getTextString("DOCUMENT_TITLE_SITE_NAME")}`;
- location.reload();
- console.log('a')
- }
-
-
- if (params.get("login") === "true") {
- copyNotice('logintrue');
- removeParams('login');
- } else if (params.get("login") === "false") {
- copyNotice('loginfalse');
- removeParams('login');
- }
-
- const open_help_modals_buttons_holder = document.getElementById('open-help-modals-buttons-holder-new');
-
- if (localStorage.experiment_2025_02_extra_options != "Treatment 6: Settings like discord" && open_help_modals_buttons_holder) {
- if (localStorage.discord_token) {
- let user_button = document.createElement("div");
-
- user_button.id = 'open-profile-settings-button-1';
- // user_button.setAttribute("onclick","logoutOfDiscord();");
- // user_button.title = `Log Out`;
- user_button.title = getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGGED_IN_AS") + localStorage.discord_displayname;
- user_button.innerHTML = `
-
- `;
-
- open_help_modals_buttons_holder.appendChild(user_button);
- }
-
- let options_button = document.createElement("div");
-
- options_button.id = 'open-options-tools-button-1';
- options_button.setAttribute("onclick","optionsSidebarToggle();");
- options_button.title = `Options`;
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen") {
- options_button.innerHTML = `
-
-
- `;
- } else {
- options_button.innerHTML = `
-
- `;
- }
-
- open_help_modals_buttons_holder.appendChild(options_button);
- }
-
- if (localStorage.dev == "true" && open_help_modals_buttons_holder) {
- let devtools_button = document.createElement("div");
-
- devtools_button.id = 'open-dev-tools-button-1';
- devtools_button.classList.add("top-bar-button");
- devtools_button.setAttribute("onclick","openDevModal();");
- devtools_button.title = `Dev Tools`;
- devtools_button.innerHTML = `
-
- `;
-
- open_help_modals_buttons_holder.appendChild(devtools_button);
- }
-
- if (localStorage.experiment_2025_05_m === "Treatment 1: Enabled" && open_help_modals_buttons_holder) {
- let system_warning_button = document.createElement("div");
-
- system_warning_button.id = 'system-warning-button';
- system_warning_button.classList.add("top-bar-button");
- system_warning_button.setAttribute("onclick","openNewDiscordLikeSettings();");
- system_warning_button.title = `Notice`;
- system_warning_button.innerHTML = `
-
- `;
-
- open_help_modals_buttons_holder.appendChild(system_warning_button);
- }
- }
-
- pageCheck();
-
- async function createAccountWithDiscord(type, expires_at) {
- const errorOutput = document.getElementById("ac-error-container");
-
- errorOutput.innerHTML = ``;
-
- const login = await fetch('https://api.yapper.shop/v2/user-login', {
- method: "POST",
- headers: {
- "Content-Type": "application/json",
- "Authorization": `${localStorage.discord_token}`
- },
- body: JSON.stringify({
- type,
- expires_at
- })
- });
-
- if (!login.ok) {
- const errors = await login.json();
-
- if (errors && errors.message && errors.error) {
- errorOutput.innerHTML = `
-
-
${errors.error}, ${errors.message}
-
- `;
- }
- return
- }
-
- const loginInfo = await login.json();
-
- if (type === "2") {
- localStorage.shop_archives_token = loginInfo.token;
-
- localStorage.discord_profile = JSON.stringify(loginInfo.user, undefined, 4);
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${loginInfo.user.id}/${loginInfo.user.avatar}.webp?size=4096`;
- localStorage.discord_username = loginInfo.user.username;
- localStorage.discord_user_id = loginInfo.user.id;
- if (loginInfo.user.global_name != null) {
- localStorage.discord_displayname = loginInfo.user.global_name;
- } else {
- localStorage.discord_displayname = loginInfo.user.username;
- }
- localStorage.discord_banner_color = loginInfo.user.banner_color;
- localStorage.discord_premium_type = loginInfo.user.premium_type;
-
- if (loginInfo.user.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${loginInfo.user.id}/${loginInfo.user.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
- } else if (type === "1") {
-
- localStorage.discord_profile = JSON.stringify(loginInfo, undefined, 4);
-
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${loginInfo.id}/${loginInfo.avatar}.webp?size=4096`;
- localStorage.discord_username = loginInfo.username;
- localStorage.discord_user_id = loginInfo.id;
- if (loginInfo.global_name != null) {
- localStorage.discord_displayname = loginInfo.global_name;
- } else {
- localStorage.discord_displayname = loginInfo.username;
- }
- localStorage.discord_banner_color = loginInfo.banner_color;
- localStorage.discord_premium_type = loginInfo.premium_type;
-
- if (loginInfo.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${loginInfo.id}/${loginInfo.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
- }
-
- localStorage.account_type = type;
- setParams({ page: 'home', login: 'true' });
- location.reload();
- }
-
- window.createAccountWithDiscord = createAccountWithDiscord;
-
-
- function changeACType(type) {
- if (document.getElementById("ac-tier-card-1") && document.getElementById("ac-tier-card-2")) {
-
- document.getElementById("ac-error-container").innerHTML = ``;
-
- if (type === "1") {
- document.getElementById("ac-tier-card-1").classList.add("selected");
- document.getElementById("ac-tier-card-2").classList.remove("selected");
- document.getElementById("ac-perks-container").innerHTML = `
- ${getTextString("ACCOUNT_CREATOR_BASIC_LOG_IN_TITLE")}
- ${getTextString("ACCOUNT_CREATOR_BASIC_LOG_IN_DESC")}
-
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_1")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_2")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_3")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_4")}
-
-
-
-
- ${getTextString("ACCOUNT_CREATOR_LOGIN_DISCLAIMER1")}
-
- 30 Days (1 month)
-
-
-
- Cancel
- Log In
- `;
- } else if (type === "2") {
- document.getElementById("ac-tier-card-1").classList.remove("selected");
- document.getElementById("ac-tier-card-2").classList.add("selected");
- document.getElementById("ac-perks-container").innerHTML = `
- ${getTextString("ACCOUNT_CREATOR_STANDARD_LOG_IN_TITLE")}
- ${getTextString("ACCOUNT_CREATOR_STANDARD_LOG_IN_DESC")}
-
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_1")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_2")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_3")}
-
-
-
-
${getTextString("ACCOUNT_CREATOR_PERKS_4")}
-
-
-
-
- ${getTextString("ACCOUNT_CREATOR_LOGIN_DISCLAIMER2")}
-
- 30 Days (1 month)
- 60 Days (2 months)
- 90 Days (3 months)
-
-
-
- Cancel
- Log In
-
- `;
-
- if (document.getElementById("ac-login-button") && document.getElementById("ac-log-me-out-after-input")) {
-
- document.getElementById("ac-login-button").addEventListener('click', (a) => {
- createAccountWithDiscord('2', `${document.getElementById("ac-log-me-out-after-input").value}`)
- });
- }
- }
-
- }
- }
-
-
-
- function leaksCheck() {
- if (localStorage.experiment_2025_04_see_you_next_year === "Treatment 1: Enabled") {
- if (localStorage.override_leaks_button === "true") {
- console.log(`Valid Leaks Check: Overridden`);
- document.getElementById('leaks_-tab-loading').innerHTML = `
-
- ${getTextString("LEAKS_TAB_TITLE")}
- ${getTextString("DM_NEW")}
-
- `;
- if (params.get("page") === "leaks_") {
- document.getElementById("leaks_-tab").classList.add('dm-button-selected');
- }
- } else {
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiLeaks = new URL(url);
- apiLeaks.searchParams.append("tab", "fake-leaks");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiLeaks.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiLeaks = api + LEAKS;
- }
- fetch(apiLeaks, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- data.forEach(apiCategory => {
- console.log(`Valid Leaks Check: True`);
- document.getElementById('leaks_-tab-loading').innerHTML = `
-
- ${getTextString("LEAKS_TAB_TITLE")}
- ${getTextString("DM_NEW")}
-
- `;
- if (params.get("page") === "leaks_") {
- document.getElementById("leaks_-tab").classList.add('dm-button-selected');
- }
- });
- })
- .catch(error => {
- console.log(`Valid Leaks Check: False`);
- document.getElementById('leaks-tab-loading').innerHTML = ``;
- });
- }
- } else {
- if (localStorage.override_leaks_button === "true") {
- console.log(`Valid Leaks Check: Overridden`);
- document.getElementById('leaks-tab-loading').innerHTML = `
-
- ${getTextString("LEAKS_TAB_TITLE")}
- ${getTextString("DM_NEW")}
-
- `;
- if (params.get("page") === "leaks") {
- document.getElementById("leaks-tab").classList.add('dm-button-selected');
- }
- } else {
- if (localStorage.experiment_2025_02_fetch_from_vercel_endpoits === "Treatment 1: Enabled") {
- url = api + COLLECTIBLES_SHOP;
- apiLeaks = new URL(url);
- apiLeaks.searchParams.append("tab", "leaks");
- if (localStorage.unreleased_discord_collectibles == "true") {
- apiLeaks.searchParams.append("include-unpublished", "true");
- }
- } else {
- apiLeaks = api + LEAKS;
- }
- fetch(apiLeaks, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- data.forEach(apiCategory => {
- console.log(`Valid Leaks Check: True`);
- document.getElementById('leaks-tab-loading').innerHTML = `
-
- ${getTextString("LEAKS_TAB_TITLE")}
- ${getTextString("DM_NEW")}
-
- `;
- if (params.get("page") === "leaks") {
- document.getElementById("leaks-tab").classList.add('dm-button-selected');
- }
- });
- })
- .catch(error => {
- console.log(`Valid Leaks Check: False`);
- document.getElementById('leaks-tab-loading').innerHTML = ``;
- });
- }
- }
- }
-
-
-
- leaksCheck();
-
-
- if (localStorage.experiment_2025_02_orbs_shop === "Treatment 1: Orb Shop done like Potions" || localStorage.experiment_2025_02_orbs_shop === "Treatment 2: Orb Shop done like default" || localStorage.experiment_2025_02_orbs_shop === "Treatment 3: Default + New tag") {
- if (localStorage.experiment_2025_02_orbs_shop === "Treatment 3: Default + New tag" && localStorage.dismissible_orbs_shop_new_tag != "Treatment 1: Seen") {
- document.getElementById('orbs-shop-tab-loading').innerHTML = `
-
- ${getTextString("ORB_SHOP_TAB_TITLE")}
- ${getTextString("DM_NEW")}
-
- `;
- } else {
- document.getElementById('orbs-shop-tab-loading').innerHTML = `
-
- ${getTextString("ORB_SHOP_TAB_TITLE")}
-
- `;
- }
- if (params.get("page") === "orbs") {
- document.getElementById("orbs-shop-tab").classList.add('dm-button-selected');
- }
- }
-
-
-
- function createHomePageElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ${getTextString("CARD_OPEN_IN_SHOP")}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- if (params.get("err") === "404") {
- document.getElementById("home-page-warning-container").innerHTML = `
-
-
${getTextString("HOME_PAGE_404_ERROR")}
-
- `;
- }
- if (params.get("err") === "403") {
- document.getElementById("home-page-warning-container").innerHTML = `
-
-
${getTextString("HOME_PAGE_403_ERROR")}
-
- `;
- }
- if (localStorage.experiment_2024_11_recap === "Treatment 1: Enabled") {
- if (localStorage.dismissible_recap_2024 != "Treatment 1: Seen") {
- document.getElementById("home-page-dismissible-content-container").innerHTML = `
-
- `;
- }
- }
- }
-
- function dismissibleContentRecap2024() {
- setParams({page: 'year-recap'}); location.reload();
- localStorage.dismissible_recap_2024 = "Treatment 1: Seen";
- }
-
- function createRecap2024Element() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
-
-
-
-
2025 Recap
-
-
Things such as Splash Potions and randomness added to Profile Effects and much more were all nice gifts given to us in 2025!
-
The Shop Archives teams has made this article that covers everything that was added to Discord in 2025!
-
why are you here? this page should only be public from 10/12/2025 to 10/01/2026
-
(remove these notes before the rollout)
-
-
-
-
-
-
Nameplates
-
-
-
-
Make your name stand out with nameplates! These special designs customize how your name appears in your direct messages (DMs), group chats and servers, giving your name that extra fun and flair wherever you go on Discord.
-
-
-
-
-
-
Spring Nitro Promotion
-
-
-
-
During Spring, if you were a first time Nitro subscriber, you can choose 1 of 3 Avatar Decorations of your own to collect and keep with an active Nitro subscription!
-
-
-
-
-
-
Valentine's Nitro Promotion
-
-
-
-
This Valentine's day, up until February 18th, 2025, when you purchase a Nitro gift you would receive the 'Heart-to-Heart' Avatar Decoration of your own to collect and keep!
-
-
-
-
-
-
Emoji Confetti Potions
-
-
-
-
Emoji Confetti turns ordinary messages into extraordinary ones, going beyond standard emoji reactions to create more fun moments and interactions in your conversations. For only US$0.99.
-
-
-
-
-
-
See what items you got during 2025
-
-
This will only display items you currently have, it does not have access to expired/removed items
-
-
- How do I find my collectibles-purchases?
- Open discord.com/app on a browser of your choice and make sure you're signed in.
- Open Dev Tools by pressing CTRL + SHIFT + I (CMD + OPTION + I on mac) on your keyboard.
- At the top of Dev Tools you should see the "Network" tab, if you don't see it click the two right poiting arrows for a dropdown, then click "Network".
- On discord.com open your profile tab in user settings.
- In the "Network" tab press CTRL + F (CMD + F on mac) on your keyboard and search "collectibles-purchases".
- Go to the "Response" tab of the file, copy the contents and paste it below.
-
-
-
-
-
The file you upload will not be stored in any online servers, once the page is refreshed all data is deleted.
-
-
-
-
-
-
-
Profile Effects
-
Avatar Decorations
-
Shop
-
This page will be visible until 10/01/2026
-
-
-
-
- `;
-
-
- function processJsonData(data) {
- try {
- const parsedData = JSON.parse(data);
- console.log("Parsed Data:", parsedData);
-
- const totalItems2024 = parsedData.filter(item => new Date(item.purchased_at).getFullYear() === 2025);
- const totalDecorations = totalItems2024.filter(item => item.type === 0).length;
- const totalEffects = totalItems2024.filter(item => item.type === 1).length;
- const totalNameplates = totalItems2024.filter(item => item.type === 2).length;
- const totalBundles = totalItems2024.filter(item => item.type === 1000).length;
-
- const purchaseTypes = {
- 1: "Items purchased",
- 5: "Items claimed for free",
- 6: "Items claimed from gifts",
- 7: "Items claimed with Nitro",
- 9: "Items claimed free with Staff",
- 10: "Items claimed in Quests",
- 12: "Items claimed with Orbs"
- };
-
- const purchaseTypeCounts = {};
- Object.keys(purchaseTypes).forEach(key => {
- const type = parseInt(key, 10);
- purchaseTypeCounts[type] = totalItems2024.filter(item => item.purchase_type === type).length;
- });
-
- // Generate HTML content with all boxes already included
- const outputDiv = document.getElementById("collectibles-purchases-output-div");
- outputDiv.innerHTML = `
-
-
-
All items you obtained in 2025.
-
-
- ${totalItems2024.map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All Avatar Decorations you obtained in 2025.
-
-
- ${totalItems2024.filter(item => item.type === 0).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All Profile Effects you obtained in 2025.
-
-
- ${totalItems2024.filter(item => item.type === 1).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All Profile Nameplates you obtained in 2025.
-
-
- ${totalItems2024.filter(item => item.type ===2).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All Bundles you obtained in 2025.
-
-
- ${totalItems2024.filter(item => item.type === 1000).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items purchased with real money in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 1).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items claimed with Nitro (Such as DISXCORE items) or when gifting Nitro in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 5).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items claimed from a gift sent by a friend in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 6).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items claimed when purchasing a Nitro Subscription (Such as Gyoiko Sakura) in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 7).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items claimed with Staff Pannel (Or however staff claim their free collectibles) in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 9).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items claimed when completing a Quest in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 10).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
-
-
-
All items purchased with Discord Orbs in 2025.
-
-
- ${totalItems2024.filter(item => item.purchase_type === 12).map(item => `${item.name} (${item.sku_id}) `).join('')}
-
-
-
- `;
-
- // Expandable functionality for each box
- const boxes = document.querySelectorAll('.output-box .box-header');
- boxes.forEach(box => {
- box.addEventListener('click', () => {
- const expandableContent = box.nextElementSibling.nextElementSibling; // Grabbing the expandable content
- if (expandableContent.classList.contains('a2024-output-box-expanded')) {
- expandableContent.classList.remove('a2024-output-box-expanded');
- } else {
- expandableContent.classList.add('a2024-output-box-expanded');
- }
- });
- });
-
- // Log results for debugging
- console.log(`Total items purchased in 2025: ${totalItems2024.length}`);
- console.log(`Total Decorations: ${totalDecorations}`);
- console.log(`Total Effects: ${totalEffects}`);
- console.log(`Total Bundles: ${totalBundles}`);
- Object.entries(purchaseTypeCounts).forEach(([type, count]) => {
- console.log(`${purchaseTypes[type]}: ${count}`);
- });
- } catch (error) {
- console.error("Invalid JSON format:", error.message);
- }
- }
-
- // Handle JSON from textarea
- document.getElementById('load-raw-collectibles-purchases-by-text-button').addEventListener('click', () => {
- const textareaValue = document.getElementById('load-raw-collectibles-purchases-by-text-input').value.trim();
- if (textareaValue) {
- processJsonData(textareaValue);
- } else {
- console.warn("Textarea is empty.");
- }
- });
-
- // Handle JSON file upload
- document.getElementById('load-raw-collectibles-purchases-by-file-input').addEventListener('change', (event) => {
- const file = event.target.files[0];
- if (file) {
- const reader = new FileReader();
- reader.onload = (e) => {
- const fileContent = e.target.result;
- processJsonData(fileContent);
- };
- reader.readAsText(file);
- } else {
- console.warn("No file selected.");
- }
- });
-
- }
-
-
- function createMainShopElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ${getTextString("CARD_OPEN_IN_SHOP")}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
- function createShopCategoryLoadingElement() {
- document.getElementById("shop-category-loading-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
-
- function createMainPotionsElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
- ${getTextString("CARD_OPEN_SUPPORT_ARTICLE")}
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
- function createPotionsCategoryLoadingElement() {
- document.getElementById("shop-category-loading-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
- function createMarketingCategoryLoadingElement() {
- document.getElementById("shop-category-loading-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- `;
- }
-
- function createItemToolPageElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
- `;
-
-
- const customDecorationInput = document.getElementById('customDecorationInput');
- const customDecorationUrlInput = document.getElementById('customDecorationUrlInput');
- const loadCustomDecorationUrlButton = document.getElementById('loadCustomDecorationUrl');
- const customDecorationPreview = document.getElementById('customDecorationPreview');
- const decoDataUrlOutput = document.getElementById('deco-dataUrlOutput');
-
- // Function to handle file upload
- customDecorationInput.addEventListener('change', function(event) {
- const file = event.target.files[0];
- if (file) {
- const reader = new FileReader();
-
- reader.onload = function(e) {
- const dataUrl = e.target.result;
-
- // Display custom decoration preview
- customDecorationPreview.src = dataUrl;
- customDecorationPreview.style.display = 'block';
-
- // Display Data URL
- decoDataUrlOutput.textContent = dataUrl;
- };
-
- reader.readAsDataURL(file);
- }
- });
-
- // Function to handle custom decoration URL input
- loadCustomDecorationUrlButton.addEventListener('click', function() {
- const customDecorationUrl = customDecorationUrlInput.value;
-
- if (customDecorationUrl) {
- const img = new Image();
- img.crossOrigin = 'Anonymous'; // This is needed to avoid CORS issues
-
- img.onload = function() {
- const canvas = document.createElement('canvas');
- canvas.width = img.width;
- canvas.height = img.height;
- const ctx = canvas.getContext('2d');
-
- ctx.drawImage(img, 0, 0);
-
- // Convert custom decoration to Data URL
- const dataUrl = canvas.toDataURL('image/png');
-
- // Display custom decoration preview
- customDecorationPreview.src = dataUrl;
- customDecorationPreview.style.display = 'block';
-
- // Display Data URL
- decoDataUrlOutput.textContent = dataUrl;
- };
-
- img.src = customDecorationUrl;
- }
- });
-
-
-
-
-
-
- const inputs = {
- name: document.getElementById('deco-name-intput-box'),
- description: document.getElementById('deco-desc-intput-box'),
- id: document.getElementById('deco-skuid-input-box'),
- animatedLink: document.getElementById('deco-animated-link-input-box'),
- staticLink: document.getElementById('deco-static-link-input-box'),
- price: document.getElementById('deco-price-input-box'),
- price2: document.getElementById('deco-price2-input-box')
- };
-
- // Define output elements
- const outputs = {
- name: document.getElementById('deco-name-output-text'),
- description: document.getElementById('deco-desc-output-text'),
- id: document.getElementById('deco-skuid-output-text'),
- animatedLink: document.getElementById('deco-animated-link-output-text'),
- staticLink: document.getElementById('deco-static-link-output-text'),
- price: document.getElementById('deco-price-output-text'),
- price2: document.getElementById('deco-price2-output-text')
- };
-
- const decoImagePreview = document.getElementById('customDecorationPreview');
- const decoPreviewCard = document.getElementById('deco-preview-card');
- let DecoStaticLink = '';
- let DecoAnimatedLink = '';
-
- // Add event listeners to update text live
- for (const key in inputs) {
- inputs[key].addEventListener('input', function() {
- outputs[key].textContent = `${inputs[key].value}`;
-
- if (key === 'staticLink') {
- DecoStaticLink = inputs.staticLink.value;
- decoImagePreview.src = DecoStaticLink;
- } else if (key === 'animatedLink') {
- DecoAnimatedLink = inputs.animatedLink.value;
- }
- });
- }
-
- decoPreviewCard.addEventListener('mouseenter', function() {
- if (DecoAnimatedLink) {
- decoImagePreview.src = DecoAnimatedLink;
- }
- });
-
- // Reset image source to static link on mouse leave
- decoPreviewCard.addEventListener('mouseleave', function() {
- if (DecoStaticLink) {
- decoImagePreview.src = DecoStaticLink;
- }
- });
-
- // Load JSON from textarea into inputs
- document.getElementById('deco-load-json-button').addEventListener('click', function() {
- try {
- const jsonData = JSON.parse(document.getElementById('deco-json-input').value);
-
- // Populate the input fields with the JSON data
- inputs.name.value = jsonData.name || "";
- inputs.description.value = jsonData.summary || "";
- inputs.id.value = jsonData.sku_id || "";
- inputs.price.value = jsonData.price || "";
- inputs.price2.value = jsonData.price_nitro || "";
- inputs.staticLink.value = jsonData.items[0].static || "";
- inputs.animatedLink.value = jsonData.items[0].animated || "";
-
- // Trigger input events to update the live preview
- for (const key in inputs) {
- inputs[key].dispatchEvent(new Event('input'));
- }
- } catch (e) {
- alert("Invalid JSON! Please check the format.");
- }
- });
-
- // Copy button functionality
- document.getElementById('custom-deco-copy-button').addEventListener('click', function() {
- // Create JSON string for API use
- const jsonData = {
- name: inputs.name.value,
- summary: inputs.description.value,
- sku_id: inputs.id.value,
- price: inputs.price.value,
- price_nitro: inputs.price2.value,
- unpublished_at: null,
- isNew: "false",
- emojiCopy: null,
- items: [
- {
- item_type: "deco",
- name: inputs.name.value,
- static: inputs.staticLink.value,
- animated: inputs.animatedLink.value,
- summary: inputs.description.value
- }
- ]
- };
-
- // Stringify JSON data with indentation for better formatting
- const jsonString = JSON.stringify(jsonData, null, 4);
-
- // Create a temporary textarea to hold the text
- const tempTextarea = document.createElement('textarea');
- tempTextarea.value = jsonString;
- document.body.appendChild(tempTextarea);
- tempTextarea.select();
- document.execCommand('copy');
- document.body.removeChild(tempTextarea);
- });
-
-
-
-
-
- const customEffectInput = document.getElementById('customEffectInput');
- const customEffectUrlInput = document.getElementById('customEffectUrlInput');
- const loadCustomEffectUrlButton = document.getElementById('loadCustomEffectUrl');
- const customEffectPreview = document.getElementById('customEffectPreview');
- const effectDataUrlOutput = document.getElementById('effect-dataUrlOutput');
-
- // Function to handle file upload
- customEffectInput.addEventListener('change', function(event) {
- const file = event.target.files[0];
- if (file) {
- const reader = new FileReader();
-
- reader.onload = function(e) {
- const dataUrl = e.target.result;
-
- // Display custom Effect preview
- customEffectPreview.src = dataUrl;
- customEffectPreview.style.display = 'block';
-
- // Display Data URL
- effectDataUrlOutput.textContent = dataUrl;
- };
-
- reader.readAsDataURL(file);
- }
- });
-
- // Function to handle custom Effect URL input
- loadCustomEffectUrlButton.addEventListener('click', function() {
- const customEffectUrl = customEffectUrlInput.value;
-
- if (customEffectUrl) {
- const img = new Image();
- img.crossOrigin = 'Anonymous'; // This is needed to avoid CORS issues
-
- img.onload = function() {
- const canvas = document.createElement('canvas');
- canvas.width = img.width;
- canvas.height = img.height;
- const ctx = canvas.getContext('2d');
-
- ctx.drawImage(img, 0, 0);
-
- // Convert custom Effect to Data URL
- const dataUrl = canvas.toDataURL('image/png');
-
- // Display custom Effect preview
- customEffectPreview.src = dataUrl;
- customEffectPreview.style.display = 'block';
-
- // Display Data URL
- effectDataUrlOutput.textContent = dataUrl;
- };
-
- img.src = customEffectUrl;
- }
- });
-
-
-
-
-
-
- const effectinputs = {
- name: document.getElementById('effect-name-intput-box'),
- description: document.getElementById('effect-desc-intput-box'),
- id: document.getElementById('effect-skuid-input-box'),
- animatedLink: document.getElementById('effect-animated-link-input-box'),
- staticLink: document.getElementById('effect-static-link-input-box'),
- price: document.getElementById('effect-price-input-box'),
- price2: document.getElementById('effect-price2-input-box')
- };
-
- // Define output elements
- const effectoutputs = {
- name: document.getElementById('effect-name-output-text'),
- description: document.getElementById('effect-desc-output-text'),
- id: document.getElementById('effect-skuid-output-text'),
- animatedLink: document.getElementById('effect-animated-link-output-text'),
- staticLink: document.getElementById('effect-static-link-output-text'),
- price: document.getElementById('effect-price-output-text'),
- price2: document.getElementById('effect-price2-output-text')
- };
-
- const effectImagePreview = document.getElementById('customEffectPreview');
- const effectPreviewCard = document.getElementById('effect-preview-card');
- let effectStaticLink = '';
- let effectAnimatedLink = '';
-
- // Add event listeners to update text live
- for (const key in effectinputs) {
- effectinputs[key].addEventListener('input', function() {
- effectoutputs[key].textContent = `${effectinputs[key].value}`;
-
- if (key === 'staticLink') {
- effectStaticLink = effectinputs.staticLink.value;
- effectImagePreview.src = effectStaticLink;
- } else if (key === 'animatedLink') {
- effectAnimatedLink = effectinputs.animatedLink.value;
- }
- });
- }
-
- effectPreviewCard.addEventListener('mouseenter', function() {
- if (effectAnimatedLink) {
- effectImagePreview.src = effectAnimatedLink;
- }
- });
-
- // Reset image source to static link on mouse leave
- effectPreviewCard.addEventListener('mouseleave', function() {
- if (effectStaticLink) {
- effectImagePreview.src = effectStaticLink;
- }
- });
-
- // Load JSON from textarea into inputs
- document.getElementById('effect-load-json-button').addEventListener('click', function() {
- try {
- const jsonData = JSON.parse(document.getElementById('effect-json-input').value);
-
- // Populate the input fields with the JSON data
- effectinputs.name.value = jsonData.name || "";
- effectinputs.description.value = jsonData.summary || "";
- effectinputs.id.value = jsonData.sku_id || "";
- effectinputs.price.value = jsonData.price || "";
- effectinputs.price2.value = jsonData.price_nitro || "";
- effectinputs.staticLink.value = jsonData.items[0].static || "";
- effectinputs.animatedLink.value = jsonData.items[0].animated || "";
-
- // Trigger input events to update the live preview
- for (const key in effectinputs) {
- effectinputs[key].dispatchEvent(new Event('input'));
- }
- } catch (e) {
- alert("Invalid JSON! Please check the format.");
- }
- });
-
- // Copy button functionality
- document.getElementById('custom-effect-copy-button').addEventListener('click', function() {
- // Create JSON string for API use
- const jsonData = {
- name: effectinputs.name.value,
- summary: effectinputs.description.value,
- sku_id: effectinputs.id.value,
- price: effectinputs.price.value,
- price_nitro: effectinputs.price2.value,
- unpublished_at: null,
- isNew: "false",
- emojiCopy: null,
- items: [
- {
- item_type: "effect",
- name: effectinputs.name.value,
- static: effectinputs.staticLink.value,
- animated: effectinputs.animatedLink.value,
- summary: effectinputs.description.value
- }
- ]
- };
-
- // Stringify JSON data with indentation for better formatting
- const jsonString = JSON.stringify(jsonData, null, 4);
-
- // Create a temporary textarea to hold the text
- const tempTextarea = document.createElement('textarea');
- tempTextarea.value = jsonString;
- document.body.appendChild(tempTextarea);
- tempTextarea.select();
- document.execCommand('copy');
- document.body.removeChild(tempTextarea);
- });
- }
-
-
-
- function createOrbConverterPageElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
- `;
- }
-
-
-
- function createPublishedListingsPageElement() {
- document.getElementById("everything-housing-container").innerHTML = `
-
-
-
-
Check Published Listing by SKU ID
-
-
-
-
-
-
Check
-
-
-
SKU ID:
-
Name:
-
Summary:
-
Type:
-
Slug:
-
Application ID:
-
Application Name:
-
Standard Price:
-
Nitro Price:
-
-
-
-
-
-
- `;
- if (localStorage.dev === "true") {
- document.getElementById("secret-published-listings-testers").innerHTML = `
-
-
-
Category Items List | Staff Only
-
-
-
-
-
-
Check
-
-
-
SKU ID:
-
Name:
-
Summary:
-
Slug:
-
Application ID:
-
Application Name:
-
-
-
- `;
- }
- }
-
- function checkValidSKUID() {
- const SKUinput = document.getElementById('sku-id-input').value;
-
- document.getElementById('sku-is-valid-or-not-container').innerHTML = ``;
-
- fetch(`https://canary.discord.com/api/v9/store/published-listings/skus/${SKUinput}`)
- .then(response => response.json())
- .then((data) => {
-
- itemType = data.sku.type;
-
- if (data.sku.price != null) {
- priceStandard = data.sku.price.amount;
- priceStandardOutput = `${data.sku.price.currency}$${(priceStandard / 100).toFixed(2)}`;
- } else {
- priceStandard = 'N/A';
- priceStandardOutput = 'N/A';
- }
-
- if (data.sku.price != null) {
- if (data.sku.price.premium != null) {
- priceNitro = data.sku.price.premium["2"].amount;
- priceNitroOutput = `${data.sku.price.currency}$${(priceNitro / 100).toFixed(2)}`;
- } else {
- priceNitroOutput = 'N/A';
- priceNitro = 'N/A';
- }
- } else {
- priceNitro = 'N/A';
- priceNitroOutput = 'N/A';
- }
-
- if (itemType === 2) {
- itemTypeOutput = `Collectible/Category`;
- } else if (itemType === 3) {
- itemTypeOutput = `Consumable`;
- } else if (itemType === 4) {
- itemTypeOutput = `Bundle of Collectibles`;
- }
-
- document.getElementById('sku-check-info-container').innerHTML = `
- SKU ID: ${data.sku.id}
- Name: ${data.sku.name}
- Summary: ${data.summary}
- Type: ${itemTypeOutput} (${itemType})
- Slug: ${data.sku.slug}
- Application ID: ${data.sku.application.id}
- Application Name: ${data.sku.application.name}
- Standard Price: ${priceStandardOutput} (${priceStandard})
- Nitro Price: ${priceNitroOutput} (${priceNitro})
- `;
- })
- .catch(error => {
- if (SKUinput != '') {
- document.getElementById('sku-is-valid-or-not-container').innerHTML = `
-
-
The SKU ID '${SKUinput}' is either invalid or unpublished!
-
- `;
- document.getElementById('sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Type:
- Slug:
- Application ID:
- Application Name:
- Standard Price:
- Nitro Price:
- `;
- } else {
- document.getElementById('sku-is-valid-or-not-container').innerHTML = `
-
-
Please input an SKU ID below!
-
- `;
- document.getElementById('sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Type:
- Slug:
- Application ID:
- Application Name:
- Standard Price:
- Nitro Price:
- `;
- }
- console.error(error);
- });
- }
-
- function categoryCheckValidSKUID() {
- const SKUinput = document.getElementById('category-sku-id-input').value;
-
- document.getElementById('category-sku-is-valid-or-not-container').innerHTML = ``;
-
- fetch(`https://canary.discord.com/api/v9/store/published-listings/skus/${SKUinput}`)
- .then(response => response.json())
- .then((data) => {
-
- if (data.child_skus == null) {
- if (SKUinput != '') {
- document.getElementById('category-sku-is-valid-or-not-container').innerHTML = `
-
-
The SKU ID '${SKUinput}' has no child SKUs or is unpublished!
-
- `;
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Slug:
- Application ID:
- Application Name:
- `;
- } else {
- document.getElementById('category-sku-is-valid-or-not-container').innerHTML = `
-
-
Please input an SKU ID below!
-
- `;
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Slug:
- Application ID:
- Application Name:
- `;
- }
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Slug:
- Application ID:
- Application Name:
- `;
- } else {
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID: ${data.sku.id}
- Name: ${data.sku.name}
- Summary: ${data.summary}
- Slug: ${data.sku.slug}
- Application ID: ${data.sku.application.id}
- Application Name: ${data.sku.application.name}
-
- `;
-
- const childContainer = document.querySelector("[data-category-child-sku-output-container]");
-
- data.child_skus.forEach(item => {
- const childBlock = document.createElement("div");
- childBlock.classList.add('category-child-sku-output')
- itemType = item.type;
-
- fetch(`https://canary.discord.com/api/v9/store/published-listings/skus/${item.id}`)
- .then(response => response.json())
- .then((itemItself) => {
-
- itemType = itemItself.sku.type;
-
- if (itemItself.sku.price != null) {
- priceStandard = itemItself.sku.price.amount;
- priceStandardOutput = `${itemItself.sku.price.currency}$${(priceStandard / 100).toFixed(2)}`;
- } else {
- priceStandard = 'N/A';
- priceStandardOutput = 'N/A';
- }
-
- if (itemItself.sku.price != null) {
- if (itemItself.sku.price.premium != null) {
- priceNitro = itemItself.sku.price.premium["2"].amount;
- priceNitroOutput = `${itemItself.sku.price.currency}$${(priceNitro / 100).toFixed(2)}`;
- } else {
- priceNitroOutput = 'N/A';
- priceNitro = 'N/A';
- }
- } else {
- priceNitro = 'N/A';
- priceNitroOutput = 'N/A';
- }
-
- if (itemType === 2) {
- itemTypeOutput = `Collectible/Category`;
- } else if (itemType === 3) {
- itemTypeOutput = `Consumable`;
- } else if (itemType === 4) {
- itemTypeOutput = `Bundle of Collectibles`;
- }
-
- childBlock.innerHTML = `
- SKU ID: ${itemItself.sku.id}
- Name: ${itemItself.sku.name}
- Summary: ${itemItself.summary}
- Type: ${itemTypeOutput} (${itemType})
- Slug: ${itemItself.sku.slug}
- Application ID: ${itemItself.sku.application.id}
- Application Name: ${itemItself.sku.application.name}
- Standard Price: ${priceStandardOutput} (${priceStandard})
- Nitro Price: ${priceNitroOutput} (${priceNitro})
- `;
- })
- .catch(error => {
- if (item.price != null) {
- priceStandard = item.price.amount;
- priceStandardOutput = `${item.price.currency}$${(priceStandard / 100).toFixed(2)}`;
- } else {
- priceStandard = 'N/A';
- priceStandardOutput = 'N/A';
- }
-
- if (item.price != null) {
- if (item.price.premium != null) {
- priceNitro = item.price.premium["2"].amount;
- priceNitroOutput = `${item.price.currency}$${(priceNitro / 100).toFixed(2)}`;
- } else {
- priceNitroOutput = 'N/A';
- priceNitro = 'N/A';
- }
- } else {
- priceNitro = 'N/A';
- priceNitroOutput = 'N/A';
- }
-
-
- if (itemType === 2) {
- itemTypeOutput = `Collectible/Category`;
- } else if (itemType === 3) {
- itemTypeOutput = `Consumable`;
- } else if (itemType === 4) {
- itemTypeOutput = `Bundle of Collectibles`;
- }
-
- childBlock.innerHTML = `
-
-
-
This item is not Published!
-
-
SKU ID: ${item.id}
-
Name: ${item.name}
-
Summary: ${item.summary}
-
Type: ${itemTypeOutput} (${itemType})
-
Slug: ${item.slug}
-
Standard Price: ${priceStandardOutput} (${priceStandard})
-
Nitro Price: ${priceNitroOutput} (${priceNitro})
-
- `;
- console.error(error);
- });
-
- childContainer.appendChild(childBlock);
- });
- }
- })
- .catch(error => {
- if (SKUinput != '') {
- document.getElementById('category-sku-is-valid-or-not-container').innerHTML = `
-
-
The SKU ID '${SKUinput}' is either invalid or unpublished!
-
- `;
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Slug:
- `;
- } else {
- document.getElementById('category-sku-is-valid-or-not-container').innerHTML = `
-
-
Please input an SKU ID below!
-
- `;
- document.getElementById('category-sku-check-info-container').innerHTML = `
- SKU ID:
- Name:
- Summary:
- Slug:
- `;
- }
- console.error(error);
- });
- }
-
-
- if (localStorage.experiment_2025_02_extra_options === "Treatment 6: Settings like discord") {
- const dm_container = document.querySelector(".dm-list");
- let u_bar = document.createElement("div");
-
- u_bar.classList.add("ubar-profile-and-settings")
- u_bar.innerHTML = `
-
- ${localStorage.discord_displayname ? localStorage.discord_displayname : "Default User"}
- ${localStorage.discord_username ? localStorage.discord_username : "default_user"}
-
- `;
-
- dm_container.appendChild(u_bar);
- }
-
- function openNewDiscordLikeSettings() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv3');
-
- modal.innerHTML = `
-
- `;
-
- document.body.appendChild(modal);
-
- document.getElementById("modalv3-side-tabs-container").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_HEADER_USER_SETTINGS")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_ACCOUNT")}
-
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_HEADER_SITE_SETTINGS")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_APPEARANCE")}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Website made by:
DTACat
-
${app_version2} ${app_version1}
-
- `;
-
- if (localStorage.experiment_2025_04_profile_tab_v2 === "Treatment 1: Enabled") {
- document.getElementById("modalv3-side-tabs-profile-container").innerHTML = `
-
- ${getTextString("MODAL_V3_TAB_TEXT_PROFILE")}
-
- `;
- }
-
- if (localStorage.experiment_2025_04_reviews_v2 === "Treatment 1: Enabled") {
- document.getElementById("modalv3-side-tabs-reviews-container").innerHTML = `
-
- ${getTextString("MODAL_V3_TAB_TEXT_REVIEWS")}
-
- `;
- }
-
- if (localStorage.experiment_2025_04_reviews_v2_warning_system === "Treatment 1: Enabled" && discord_token) {
- document.getElementById("modalv3-side-tabs-warnings-container").innerHTML = `
-
- ${getTextString("MODAL_V3_TAB_TEXT_WARNINGS")}
-
- `;
- }
-
- if (localStorage.experiment_2025_04_accessibility_v2 === "Treatment 1: Enabled") {
- document.getElementById("modalv3-side-tabs-accessibility-container").innerHTML = `
-
- ${getTextString("MODAL_V3_TAB_TEXT_ACCESSIBILITY")}
-
- `;
- }
-
- if (localStorage.experiment_2025_05_xp_system === "Treatment 1: Enabled") {
- document.getElementById("xp-perks-options-modalv3-container").innerHTML = `
-
-
-
${getTextString("MODAL_V3_TAB_HEADER_XP_PERKS")}
-
BETA
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_XP_EVENTS")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_XP_GENERAL")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_XP_INVENTORY")}
-
- `;
- }
-
- if (localStorage.dev === "true") {
- document.getElementById("staff-options-modalv3-container").innerHTML = `
-
-
-
${getTextString("MODAL_V3_TAB_HEADER_STAFF_ONLY")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_EXPERIMENTS")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_DISMISSIBLE_CONTENT")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_API_TEST_FETCH")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_CLAIMABLES_PURCHASE")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_LOCAL_STORAGE")}
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_MISC")}
-
- `;
- }
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- setModalv3InnerContent('account');
-
-
- document.addEventListener("keydown", function (event) {
- if (event.key === "Escape") {
- modal.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- }, 300);
- }
- });
-
- document.querySelector("[data-discord-like-settings-close-button]").addEventListener('click', (event) => {
- modal.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- }, 300);
- });
- }
-
- async function setModalv3InnerContent(tab) {
- if (!document.getElementById("modalv3-right-content-container-inner")) {
- openNewDiscordLikeSettings();
- }
- const tabPageOutput = document.getElementById("modalv3-right-content-container-inner");
-
- if (document.querySelector(".side-tabs-button-selected")) {
- document.querySelectorAll('.side-tabs-button-selected').forEach((el) => {
- el.classList.remove("side-tabs-button-selected");
- });
- }
-
- document.getElementById("modalv3-right-content-container").scrollTo(0,0);
-
- if (localStorage.discord_token) {
- document.getElementById("login-logout-options-modalv3-container").innerHTML = `
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_LOG_OUT")}
-
- `;
- } else if (localStorage.experiment_2025_05_m != "Treatment 1: Enabled") {
- document.getElementById("login-logout-options-modalv3-container").innerHTML = `
-
-
- ${getTextString("MODAL_V3_TAB_TEXT_LOG_IN")}
-
- `;
- }
-
- if (tab === "account") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_ACCOUNT_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_SUMMARY")}
-
-
-
-
-
-
-
-
-
-
-
-
-
Loading...
-
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.experiment_2025_05_account_creator === "Treatment 1: Enabled" && localStorage.discord_token && !localStorage.account_type && document.getElementById("modalv3-account-account-outdated-container")) {
- document.getElementById("modalv3-account-account-outdated-container").innerHTML = `
-
-
Account outdated!
-
You logged in to Shop Archives before the new account system, if you ignore this warning some things may break. Please log in again.
-
- `;
- }
-
- const accountDetails = document.getElementById("modalv3-account-account-details-container");
-
- if (localStorage.experiment_2025_05_m === "Treatment 1: Enabled") {
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_ACCOUNT_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_SUMMARY")}
-
-
-
-
${getTextString("MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_UNAVAILABLE_SUMMARY")}
-
-
- `;
- } else if (localStorage.discord_token && localStorage.account_type != "2") {
- const discordProfile = JSON.parse(localStorage.discord_profile);
- accountDetails.innerHTML = `
-
-
-
-
-
-
-
-
${discordProfile.global_name}
-
Resync Profile
-
-
-
-
-
-
${discordProfile.global_name}
-
-
-
-
${discordProfile.username}
-
-
-
-
- `;
- } else if (localStorage.discord_token && localStorage.account_type === "2") {
-
- if (!atMeUsercache) {
- fetch(api + `/users/@me`, {
- method: "GET",
- headers: {
- "Authorization": localStorage.shop_archives_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- renderAtMeAccountPage(data);
- atMeUsercache = data;
- })
- .catch(error => {
- console.error(error);
- accountDetails.innerHTML = `
- error
- `;
- });
- } else {
- renderAtMeAccountPage(atMeUsercache)
- }
-
- function renderAtMeAccountPage(atMe) {
- if (atMe.message) {
- accountDetails.innerHTML = `
-
-
-
-
-
-
-
-
Error
-
Log In with Discord
-
-
-
-
-
There was an error loading your account details.
-
-
-
Your token may have expired, please log in again.
-
-
-
-
- `;
- } else {
- accountDetails.innerHTML = `
-
-
-
-
-
-
-
-
-
Resync Profile
-
-
-
- `;
-
- if (atMe.banner_color) {
- accountDetails.querySelector("[data-modalv3-banner-color]").style.backgroundColor = atMe.banner_color;
- }
-
- if (atMe.global_name === null) {
- accountDetails.querySelector("[data-modalv3-account-displayname]").textContent = atMe.username;
- } else {
- accountDetails.querySelector("[data-modalv3-account-displayname]").textContent = atMe.global_name;
- }
-
- if (atMe.global_name === null) {
- accountDetails.querySelector("[data-modalv3-account-displayname2]").textContent = atMe.username;
- } else {
- accountDetails.querySelector("[data-modalv3-account-displayname2]").textContent = atMe.global_name;
- }
-
- accountDetails.querySelector("[data-modalv3-account-username2]").textContent = atMe.username;
- }
- }
- } else {
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_ACCOUNT_HEADER")}
-
-
-
-
${getTextString("MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_NOT_LOGGED_IN_SUMMARY")}
-
${getTextString("MODAL_V3_TAB_ACCOUNT_LOGIN_WITH_DISCORD_BUTTON")}
-
-
- `;
- }
- } else if (tab === "profile") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_PROFILE_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_SUMMARY")}
-
-
- `;
-
- document.getElementById("modalv3-profile-editor-preview-container").innerHTML = `
- Preview:
-
-
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
- `;
-
- document.getElementById("modalv3-profile-editor-content-container").innerHTML = `
-
-
-
-
-
-
-
-
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_AVATAR")}
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_REMOVE_AVATAR")}
-
-
-
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_BANNER")}
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_REMOVE_BANNER")}
-
-
-
-
-
-
-
- `;
-
- if (discord_token) {
- document.getElementById("modalv3-profile-tab-sign-in-notice").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_LOGGED_IN_TITLE")}
-
${getTextString("MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_LOGGED_IN_SUMMARY")}
-
- `;
- }
-
- document.getElementById("options-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- const avatarImageInput = document.getElementById("profileAvatarInput");
- const avatarImagePreview = document.getElementById("profileAvatarPreview");
- const removeAvatarImageButton = document.getElementById("removeProfileAvatarButton");
-
- // Load saved image from localStorage on page load
- document.addEventListener("DOMContentLoaded", () => {
- const savedImage = localStorage.getItem("discord_avatar");
- if (savedImage) {
- avatarImagePreview.src = savedImage;
- }
- });
-
- // Handle image upload
- avatarImageInput.addEventListener("change", function () {
- document.getElementById("options-avatar-img-input-option-error").innerHTML = ``;
- const file = this.files[0];
- if (file) {
- const reader = new FileReader();
- reader.onload = function (event) {
- const dataUrl = event.target.result;
- try {
- localStorage.setItem("discord_avatar", dataUrl);
- avatarImagePreview.src = dataUrl;
- } catch(error) {
- document.getElementById("options-avatar-img-input-option-error").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG_SUMMARY")}
-
- `;
- }
- };
- reader.readAsDataURL(file);
- }
- });
-
- // Handle image removal
- removeAvatarImageButton.addEventListener("click", function () {
- setRandomDiscordAvatar()
- avatarImagePreview.src = localStorage.discord_avatar;
- document.getElementById("options-avatar-img-input-option-error").innerHTML = ``;
- });
-
-
- const bannerImageInput = document.getElementById("profileBannerInput");
- const bannerImagePreview = document.getElementById("profileBannerPreview");
- const removeBannerImageButton = document.getElementById("removeProfileBannerButton");
-
-
- if (localStorage.discord_banner === ``) {
- removeBannerImageButton.style.display = 'none';
- }
-
- // Load saved image from localStorage on page load
- document.addEventListener("DOMContentLoaded", () => {
- const savedImage = localStorage.getItem("discord_banner");
- if (savedImage) {
- bannerImagePreview.style.backgroundImage = `url(${savedImage})`;
- }
- });
-
- // Handle image upload
- bannerImageInput.addEventListener("change", function () {
- document.getElementById("options-banner-img-input-option-error").innerHTML = ``;
- removeBannerImageButton.style.display = 'unset';
- const file = this.files[0];
- if (file) {
- const reader = new FileReader();
- reader.onload = function (event) {
- const dataUrl = event.target.result;
- try {
- localStorage.setItem("discord_banner", dataUrl);
- bannerImagePreview.style.backgroundImage = `url(${dataUrl})`;
- } catch(error) {
- document.getElementById("options-banner-img-input-option-error").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG_SUMMARY")}
-
- `;
- }
- };
- reader.readAsDataURL(file);
- }
- });
-
- // Handle image removal
- removeBannerImageButton.addEventListener("click", function () {
- removeBannerImageButton.style.display = 'none';
- localStorage.discord_banner = ``
- bannerImagePreview.style.backgroundImage = '';
- document.getElementById("options-banner-img-input-option-error").innerHTML = ``;
- });
-
- } else if (tab === "warnings") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_WARNINGS_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_WARNINGS_ACCOUNT_WARNINGS_SUMMARY")}
-
-
-
-
- `;
-
- updateAndCacheReviewsWarnings();
- } else if (tab === "reviews") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- if (localStorage.experiment_2025_05_m === "Treatment 1: Enabled") {
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_REVIEWS_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_UNAVAILABLE_SUMMARY")}
-
- `;
- } else if (localStorage.discord_token && shop_archives_token) {
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_REVIEWS_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SUMMARY")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_3_SUMMARY")}
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_2_SUMMARY")}
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_1_SUMMARY")}
-
-
-
- `;
-
- updateReviewsFilterStore();
- } else {
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_REVIEWS_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_DISCORD_ACCOUNT_NOT_LOGGED_IN_SUMMARY")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_3_SUMMARY")}
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_2_SUMMARY")}
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_1_SUMMARY")}
-
-
-
- `;
- }
-
- } else if (tab === "appearance") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_APPEARANCE_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_THEME_SUMMARY")}
-
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_TIME_SUMMARY")}
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_2_SUMMARY")}
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_1_SUMMARY")}
-
-
-
-
-
- `;
-
- updateReviewsTimeFormatStore();
-
- document.getElementById("modalv3-theme-selection-container").innerHTML = `
-
-
-
- `;
-
- if (localStorage.experiment_2025_04_theme_picker_v2_color === "Treatment 1: Enabled") {
- document.getElementById("modal-v3-color-themes-experiment-output").innerHTML = `
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_THEME_COLOR_SUMMARY")}
-
-
-
-
- `;
-
- document.getElementById("modalv3-color-theme-selection-container").innerHTML = `
-
-
-
- `;
- }
-
- if (localStorage.experiment_2025_04_theme_picker_v2_custom === "Treatment 1: Enabled") {
- document.getElementById("modal-v3-custom-themes-experiment-output").innerHTML = `
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_THEME_CUSTOM_SUMMARY")}
-
-
-
-
- `;
-
- document.getElementById("modalv3-custom-theme-selection-container").innerHTML = `
-
- `;
- }
-
- if (localStorage.experiment_2025_04_theme_picker_v2_community === "Treatment 2: As banners") {
- document.getElementById("modal-v3-community-themes-experiment-output").innerHTML = `
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_THEME_COMMUNITY_SUMMARY")}
-
-
-
- `;
- fetchAndRenderCommunityThemesAsBanners();
- }
-
- async function fetchAndRenderCommunityThemesAsBanners() {
- if (!communityThemesCache) {
- await setCommunityThemesCache();
- }
-
- try {
- communityThemesCache.forEach(theme => {
- let themeIcon = document.createElement("div");
-
- themeIcon.classList.add("modalv3-community-theme-banner");
- themeIcon.id = 'theme-community-' + theme.id + '-button'
- themeIcon.style.color = theme.text_color;
- if (theme.banner.src != null) {
- themeIcon.style.backgroundImage = `linear-gradient(-90deg,rgba(0, 0, 0, 0) 30%,${theme.banner.color_primary}), url('${theme.banner.src}')`;
- } else if (theme.banner.color_secondary != null) {
- themeIcon.style.backgroundImage = `linear-gradient(-90deg, ${theme.banner.color_secondary} 30%,${theme.banner.color_primary})`;
- } else {
- themeIcon.style.backgroundColor = theme.banner.color_primary;
- }
-
- themeIcon.innerHTML = `
-
- Apply
-
- `;
-
- document.getElementById("modalv3-community-theme-selection-container").appendChild(themeIcon);
- });
- if (document.getElementById("theme-" + localStorage.sa_theme + "-button")) {
- document.getElementById("theme-" + localStorage.sa_theme + "-button").classList.add('theme-selection-box-selected');
- }
- }
- catch(error) {
- document.getElementById("modalv3-community-theme-selection-container").innerHTML = `There was an error loading community themes`;
- }
- }
-
- if (document.getElementById("theme-" + localStorage.sa_theme + "-button")) {
- document.getElementById("theme-" + localStorage.sa_theme + "-button").classList.add('theme-selection-box-selected');
- }
-
- if (localStorage.experiment_2025_04_extended_styles === "Treatment 1: Enabled" || localStorage.experiment_2025_04_extended_styles === "Treatment 2: Card Styles") {
- document.getElementById("modal-v3-extended-styles-experiment-output").innerHTML = `
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SUMMARY")}
-
-
-
- `;
-
- document.getElementById("modalv3-extended-styles-card-container-category-tabs").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_DARK")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SELECTED")}
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_OTHER")}
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_TRANSPARENT")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SELECTED")}
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_OTHER")}
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_LEGACY")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SELECTED")}
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_OTHER")}
-
-
-
-
-
-
-
- `;
-
- updateExtendedStylesCategoryTab();
- }
-
- if (localStorage.experiment_2025_04_extended_styles === "Treatment 2: Card Styles") {
- document.getElementById("modal-v3-extended-styles-cards-experiment-output").innerHTML = `
-
-
-
-
${getTextString("MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_SHOP_CARDS_SUMMARY")}
-
-
- `;
- }
-
- } else if (tab === "accessibility") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_ACCESSIBILITY_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_ACCESSIBILITY_REDUCED_MOTION_SUMMARY")}
-
${getTextString("MODAL_V3_TAB_ACCESSIBILITY_REDUCED_MOTION_SUMMARY2")}
-
-
-
- `;
-
- } else if (tab === "xp_events") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
-
-
-
-
- ${getTextString("MODAL_V3_TAB_XP_EVENTS_HEADER")}
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_EVENTS_EVENTS_SUMMARY")}
-
Learn More about XP
-
-
-
-
-
-
Loading Events...
-
Events are currently being loaded, please wait...
-
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.dismissible_XPnotice != "Treatment 1: Seen") {
- document.getElementById("modalv3-xp-notice-container").innerHTML = `
-
-
-
${getTextString("MODAL_V3_XP_NOTICE_1")}
-
${getTextString("MODAL_V3_XP_NOTICE_2")}
-
- `;
- }
-
- if (!claimablesPromotionsCache) {
- try {
-
- url = api + CLAIMABLES_PROMOTIONS;
- fetchUrl = new URL(url);
- if (localStorage.staff_unpublished_xp_events == "true") {
- fetchUrl.searchParams.append("include-unpublished", "true");
- }
-
- const userInfo = await fetch(fetchUrl, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- document.getElementById("modalv3-failed-to-load-xp-events-balance").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_EVENTS_ERROR_1")}
-
-
- `;
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
- document.getElementById("modalv3-failed-to-load-xp-events-balance").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_EVENTS_ERROR_1")}
-
${data.error}, ${data.message}
-
-
- `;
- } else {
- claimablesPromotionsCache = data;
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- function fetchXpEvents() {
- document.getElementById("modalv3-xp-events-output").innerHTML = ``;
- document.getElementById("modalv3-xp-events-output2").innerHTML = ``;
- if (Array.isArray(claimablesPromotionsCache) && claimablesPromotionsCache.length != 0) {
- claimablesPromotionsCache.forEach(promo => {
-
- let promoBanner = document.createElement("div");
-
- promoBanner.classList.add("xp-reward-event-card");
-
- if (promo.already_claimed === false) {
-
- if (promo.category_data) {
- promoBanner.innerHTML = `
-
-
-
${promo.name}
-
You have ${promo.xp_reward.toLocaleString()} XP waiting for you!
-
Take me there
-
- `;
- } else {
- promoBanner.innerHTML = `
-
-
-
${promo.name}
-
You have ${promo.xp_reward.toLocaleString()} XP waiting for you!
-
Claim ${promo.xp_reward.toLocaleString()} XP
-
- `;
- }
-
- const expiresAt = new Date(promo.expires_at);
-
- if (promo.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- promoBanner.classList.add("hidden");
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / (1000 * 60));
- const seconds = Math.floor((timeDiff % (1000 * 60)) / 1000);
-
- const date = `ENDS IN ${days}d ${hours}h ${minutes}m ${seconds}s`;
-
- promoBanner.querySelector("[data-xp-event-expires-at]").innerHTML = `
- ${date.replace(" 0d 0h 0m", "").replace(" 0d 0h", "").replace(" 0d", "")}
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- document.getElementById("modalv3-xp-events-output").appendChild(promoBanner);
- } else {
-
- promoBanner.classList.add("claimed");
-
- promoBanner.innerHTML = `
-
-
-
${promo.name}
-
You already claimed this reward for ${promo.xp_reward.toLocaleString()} XP.
-
Claimed
-
- `;
-
- const expiresAt = new Date(promo.expires_at);
-
- if (promo.expires_at && !isNaN(expiresAt.getTime())) {
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = expiresAt - now;
-
- if (timeDiff <= 0) {
- promoBanner.classList.add("hidden");
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / (1000 * 60));
- const seconds = Math.floor((timeDiff % (1000 * 60)) / 1000);
-
- const date = `ENDS IN ${days}d ${hours}h ${minutes}m ${seconds}s`;
-
- promoBanner.querySelector("[data-xp-event-expires-at]").innerHTML = `
- ${date.replace(" 0d 0h 0m", "").replace(" 0d 0h", "").replace(" 0d", "")}
- `;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer();
- }
-
- document.getElementById("modalv3-xp-events-output2").appendChild(promoBanner);
- }
- });
-
- document.getElementById("modalv3-xp-events-output").style.display = 'unset';
- document.getElementById("modalv3-xp-events-output2").style.display = 'unset';
- document.getElementById("modalv3-xp-events-loading").style.display = 'none';
- } else {
- document.getElementById("modalv3-xp-events-output").style.display = 'unset';
- document.getElementById("modalv3-xp-events-loading").style.display = 'none';
-
- document.getElementById("modalv3-xp-events-output").innerHTML = `
-
-
-
All is quiet...
-
There are currently no events happening right now, check back later.
-
-
- `;
- }
- }
-
- window.fetchXpEvents = fetchXpEvents;
-
- fetchXpEvents();
-
- } else if (tab === "xp_general") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
-
-
-
-
- ${getTextString("MODAL_V3_TAB_XP_SHOP_HEADER")}
-
-
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CLAIMABLES_FEATURED_SUMMARY")}
-
-
-
-
-
-
-
-
- `;
-
- if (localStorage.dismissible_XPnotice != "Treatment 1: Seen") {
- document.getElementById("modalv3-xp-notice-container").innerHTML = `
-
-
-
${getTextString("MODAL_V3_XP_NOTICE_1")}
-
${getTextString("MODAL_V3_XP_NOTICE_2")}
-
- `;
- }
-
- if (!atMeUsercache) {
- try {
-
- const userInfo = await fetch('https://api.yapper.shop/v2/users/@me', {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
-
- `;
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
${data.error}, ${data.message}
-
-
- `;
- } else {
- atMeUsercache = data;
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- if (!myClaimablesClaimedCache) {
- try {
-
- const userInfo = await fetch(api + CLAIMABLES_CLAIMED, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
-
- `;
- }
-
- const claimablesClaimed = await userInfo.json();
-
- if (claimablesClaimed.message) {
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
${claimablesClaimed.error}, ${claimablesClaimed.message}
-
-
- `;
- } else {
- myClaimablesClaimedCache = claimablesClaimed;
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- if (!claimablesShopcache) {
-
- url = api + CLAIMABLES_SHOP;
- fetchUrl = new URL(url);
- if (localStorage.staff_unpublished_xp_shop == "true") {
- fetchUrl.searchParams.append("include-unpublished", "true");
- }
-
- fetch(fetchUrl, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message) {
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
${data.error}, ${data.message}
-
-
- `;
- } else {
- claimablesShopcache = data;
- renderXPShop(data);
- }
- })
- .catch(error => {
- console.error(error);
- document.getElementById("modalv3-failed-to-load-xp-shop").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_2")}
-
${error}
-
-
- `;
- });
- } else {
- renderXPShop(claimablesShopcache)
- }
-
- if (!myXPBalancecache) {
- fetch(api + XP_BALANCE, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message) {
- document.getElementById("modalv3-failed-to-load-xp-balance").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_3")}
-
${data.error}, ${data.message}
-
-
- `;
- } else {
- myXPBalancecache = data;
- rendermyXPBalanceShop(data);
- }
- })
- .catch(error => {
- console.error(error);
- document.getElementById("modalv3-failed-to-load-xp-balance").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_ERROR_3")}
-
-
-
- `;
- });
- } else {
- rendermyXPBalanceShop(myXPBalancecache)
- }
-
- function renderXPShop(data) {
- document.getElementById("modalv3-xp-perks-featured-output").innerHTML = ``;
- document.getElementById("modalv3-xp-perks-shop-output").innerHTML = ``;
-
- data.featured.forEach(featured => {
- let featuredCard = document.createElement("div");
-
- featuredCard.classList.add("xp-card-featured");
-
- let itemPrice = `${featured.price.toLocaleString()} XP`;
-
- let alreadyClaimed = false;
-
- let nonoClaim = false;
-
- if (myClaimablesClaimedCache != null) {
- myClaimablesClaimedCache.forEach(claimed => {
- if (claimed.id === featured.id) {
- itemPrice = "Already Claimed"
- alreadyClaimed = true;
- }
- });
- }
-
- featuredCard.innerHTML = `
- ${featured.name}
- ${featured.summary}
-
-
- ${itemPrice}
- `;
-
- const today = new Date();
- const year = today.getFullYear();
- const month = String(today.getMonth() + 1).padStart(2, '0'); // Months are 0-indexed
- const day = String(today.getDate()).padStart(2, '0');
- let formattedDate = `${day}/${month}/${year}`
-
- if (localStorage.reviews_time_type === "us") {
- formattedDate = `${month}/${day}/${year}`
- }
-
- if (featured.id === "2" && atMeUsercache.primary_guild) {
-
- featuredCard.querySelector("[data-possible-review-preview]").innerHTML = `
-
-
-
-
-
-
${atMeUsercache.global_name ? atMeUsercache.global_name : atMeUsercache.username}
-
-
-
${atMeUsercache.primary_guild.tag}
-
-
-
-
-
${formattedDate}
-
-
${featured.preview_text}
-
-
- `;
-
- } else if (featured.id === "2" && !atMeUsercache.primary_guild) {
-
- let featuredCardBlock = document.createElement("div");
-
- featuredCardBlock.classList.add("xp-card-featured-block");
-
- featuredCardBlock.innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_1")}
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_2")}
-
Learn More
-
- `;
-
- featuredCard.appendChild(featuredCardBlock);
-
- nonoClaim = true;
-
- } else if (featured.id === "3") {
-
- featuredCard.querySelector("[data-possible-review-preview]").innerHTML = `
-
-
-
-
-
${atMeUsercache.global_name ? atMeUsercache.global_name : atMeUsercache.username}
-
-
-
-
${formattedDate}
-
-
${featured.preview_text}
-
-
- `;
-
- } else if (featured.id === "5" && atMeUsercache.avatar_decoration_data) {
-
- featuredCard.querySelector("[data-possible-review-preview]").innerHTML = `
-
-
-
-
-
-
${atMeUsercache.global_name ? atMeUsercache.global_name : atMeUsercache.username}
-
-
-
-
${formattedDate}
-
-
${featured.preview_text}
-
-
- `;
- } else if (featured.id === "5" && !atMeUsercache.avatar_decoration_data) {
-
- let featuredCardBlock = document.createElement("div");
-
- featuredCardBlock.classList.add("xp-card-featured-block");
-
- featuredCardBlock.innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_1")}
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_2")}
-
Learn More
-
- `;
-
- featuredCard.appendChild(featuredCardBlock);
-
- nonoClaim = true;
-
- }
-
- if (alreadyClaimed === false && nonoClaim === false) {
- featuredCard.addEventListener('click', () => {
- openClaimablesPurchaseModal(featured.id)
- });
- featuredCard.classList.add("clickable");
- }
-
- document.getElementById("modalv3-xp-perks-featured-output").appendChild(featuredCard);
-
- });
-
- data.shop.forEach(claimable => {
- let shopCard = document.createElement("div");
-
- shopCard.classList.add("xp-card-shop");
-
- let itemPrice = `${claimable.price.toLocaleString()} XP`;
-
- let alreadyClaimed = false;
-
- if (myClaimablesClaimedCache != null) {
- myClaimablesClaimedCache.forEach(claimed => {
- if (claimed.id === claimable.id) {
- itemPrice = "Already Claimed"
- alreadyClaimed = true;
- }
- });
- }
-
- if (itemPrice != "Already Claimed") {
- shopCard.classList.add("clickable");
- }
-
- if (alreadyClaimed === false) {
- shopCard.addEventListener('click', () => {
- openClaimablesPurchaseModal(claimable.id)
- });
- }
-
- shopCard.innerHTML = `
- ${claimable.name}
- ${claimable.summary}
- ${itemPrice}
- `;
-
- document.getElementById("modalv3-xp-perks-shop-output").appendChild(shopCard);
-
- });
-
- document.getElementById("modalv3-xp-perks-featured-output").style.display = `grid`;
- document.getElementById("modalv3-xp-perks-shop-output").style.display = `grid`;
- document.getElementById("modalv3-xp-perks-loading").style.display = `none`;
- }
-
- window.renderXPShop = renderXPShop;
-
- function rendermyXPBalanceShop(data) {
- document.getElementById("modalv3-xp-balance-text").textContent = ` ${data.xp_balance.toLocaleString()} `;
- }
-
- } else if (tab === "xp_inventory") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
-
-
-
-
- ${getTextString("MODAL_V3_TAB_XP_INVENTORY_HEADER")}
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_INVENTORY_CLAIMS_SUMMARY")}
-
-
-
-
-
-
Loading Inventory...
-
Your inventory is currently being loaded, please wait...
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_INVENTORY_REWARDS_SUMMARY")}
-
-
-
-
-
-
- `;
-
- if (localStorage.experiment_2025_05_redeem_gift_codes === "Treatment 1: Enabled") {
- document.getElementById("modalv3-xp-inventory-redeem-gift").innerHTML = `
-
-
-
${getTextString("MODAL_V3_TAB_XP_INVENTORY_REDEEM_SUMMARY")}
-
-
-
- Redeem
-
-
-
-
- `;
-
- document.getElementById("xp-inventory-claim-code-button").addEventListener("click", function () {
- document.getElementById("xp-inventory-claim-code-loading").classList.remove("invalid");
- document.getElementById("xp-inventory-claim-code-loading").textContent = '';
- document.getElementById("xp-inventory-claim-code-button").disabled = true;
- document.getElementById("xp-inventory-claim-code-button").textContent = '...';
- redeemXPGiftCode(document.getElementById("xp-inventory-claim-code-input").value);
- });
- }
-
- if (localStorage.dismissible_XPnotice != "Treatment 1: Seen") {
- document.getElementById("modalv3-xp-notice-container").innerHTML = `
-
-
-
${getTextString("MODAL_V3_XP_NOTICE_1")}
-
${getTextString("MODAL_V3_XP_NOTICE_2")}
-
- `;
- }
-
- if (!myClaimablesClaimedCache) {
- try {
-
- const userInfo = await fetch(api + CLAIMABLES_CLAIMED, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- document.getElementById("modalv3-failed-to-load-xp-inventory").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_INVENTORY_ERROR_1")}
-
-
- `;
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
- document.getElementById("modalv3-failed-to-load-xp-inventory").innerHTML = `
-
-
${getTextString("MODAL_V3_TAB_XP_INVENTORY_ERROR_1")}
-
${data.error}, ${data.message}
-
-
- `;
- } else {
- myClaimablesClaimedCache = data;
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- function fetchXpInventory() {
- document.getElementById("modalv3-xp-inventory-output").innerHTML = ``;
- if (Array.isArray(myClaimablesClaimedCache)) {
-
- myClaimablesClaimedCache.sort((a, b) => new Date(b.claim_date) - new Date(a.claim_date));
-
- myClaimablesClaimedCache.forEach(claimable => {
-
- let formatted = null;
-
- if (localStorage.reviews_time_type === "uk") {
- const date = new Date(claimable.claim_date);
-
- const day = String(date.getDate()).padStart(2, '0');
- const month = String(date.getMonth() + 1).padStart(2, '0'); // getMonth is 0-indexed
- const year = date.getFullYear();
-
- formatted = `${day}/${month}/${year}`;
- } else {
- const date = new Date(claimable.claim_date);
-
- const day = String(date.getDate()).padStart(2, '0');
- const month = String(date.getMonth() + 1).padStart(2, '0'); // getMonth is 0-indexed
- const year = date.getFullYear();
-
- formatted = `${day}/${month}/${year}`;
- }
-
- if (claimable.type === 1) {
-
- let promoBanner = document.createElement("div");
-
- promoBanner.classList.add("xp-inventory-card");
-
- promoBanner.innerHTML = `
-
-
-
${claimable.name}
-
You claimed this item on ${formatted}.
-
-${claimable.price.toLocaleString()} XP
-
- `;
-
- if (claimable.refunded === true) {
- promoBanner.querySelector("[data-xp-inventory-tag-refund-text]").innerHTML = `
- ${getTextString("MODAL_V3_TAB_XP_INVENTORY_TAG_REFUNDED")}
- `;
- promoBanner.querySelector("[data-xp-inventory-price]").classList.remove("remove");
- promoBanner.querySelector("[data-xp-inventory-price]").classList.add("normal");
- }
-
- document.getElementById("modalv3-xp-inventory-output").appendChild(promoBanner);
- } else if (claimable.type === 0) {
-
- let promoBanner = document.createElement("div");
-
- promoBanner.classList.add("xp-inventory-card");
-
- promoBanner.innerHTML = `
-
-
-
${claimable.name}
-
You claimed this reward on ${formatted}.
-
+${claimable.price.toLocaleString()} XP
-
- `;
-
- if (claimable.refunded === true) {
- promoBanner.querySelector("[data-xp-inventory-tag-revoke-text]").innerHTML = `
- ${getTextString("MODAL_V3_TAB_XP_INVENTORY_TAG_REVOKED")}
- `;
- promoBanner.querySelector("[data-xp-inventory-price]").classList.remove("add");
- promoBanner.querySelector("[data-xp-inventory-price]").classList.add("normal");
- }
-
- document.getElementById("modalv3-xp-inventory-output2").appendChild(promoBanner);
- }
- });
-
- document.getElementById("modalv3-xp-inventory-output").style.display = 'grid';
- document.getElementById("modalv3-xp-inventory-output2").style.display = 'grid';
- document.getElementById("modalv3-xp-inventory-loading").style.display = 'none';
- }
- if (!myClaimablesClaimedCache.find(item => item.type === 0)) {
- document.getElementById("modalv3-xp-inventory-output2").innerHTML = `
-
-
-
No Claimed Rewards.
-
You don't have any claimed rewards.
-
-
- `;
- }
- if (!myClaimablesClaimedCache.find(item => item.type === 1)) {
- document.getElementById("modalv3-xp-inventory-output").innerHTML = `
-
-
-
No Claimed Items.
-
You don't have any claimed items.
-
-
- `;
- }
- }
-
- window.fetchXpInventory = fetchXpInventory;
-
- fetchXpInventory();
- } else if (tab === "experiments") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_EXPERIMENTS_HEADER")}
-
-
-
-
${getTextString("MODAL_V3_TAB_EXPERIMENTS_DISABLE_FORCE_ROLLOUT_SUMMARY")}
-
-
-
-
-
-
- `;
-
- if (localStorage.experiment_force_rollout === "false") {
- document.getElementById("experiments-force-rollout-checkbox").checked = true;
- }
-
- experimentsList.forEach(({ title, id, name, treatments, rollout, needs_api_token, not_needed }) => {
- if (not_needed != "true") {
- try {
-
- let hrel = document.createElement("hr");
-
- document.getElementById("modalv3-experiment-output").appendChild(hrel);
-
- let experimentCard = document.createElement("div");
-
- experimentCard.classList.add('modalv3-experiment-container');
- experimentCard.innerHTML = `
- ${title}
- ${id}
- ${getTextString("MODAL_V3_TAB_EXPERIMENTS_ROLLOUT")}${rollout}
-
-
-
- Clear
-
- `;
-
- if (needs_api_token === "true") {
- let apiNotice = document.createElement("p");
-
- apiNotice.classList.add('modalv3-experiment-api-notice');
- apiNotice.textContent = getTextString("MODAL_V3_TAB_EXPERIMENTS_API_WARNING");
-
- experimentCard.appendChild(apiNotice);
- }
-
-
- document.getElementById("modalv3-experiment-output").appendChild(experimentCard);
-
- const treatmentPicker = document.getElementById(`${name}_treatment_container`);
-
- if (!treatmentPicker) return; // Skip if element doesn't exist
-
- populateExperimentOptions(treatmentPicker, treatments);
-
- const storedTreatment = localStorage.getItem(name);
- if (storedTreatment) {
- treatmentPicker.value = storedTreatment;
- }
-
- treatmentPicker.addEventListener("change", () => {
- localStorage.setItem(name, treatmentPicker.value);
- });
-
- } catch (error) {
- console.error(`Error setting up experiment: ${name}`, error);
- }
- }
- });
-
- function populateExperimentOptions(selectElement, treatments) {
- treatments.forEach((treatment) => {
- const optElement = document.createElement("option");
- optElement.value = treatment;
- optElement.textContent = treatment;
- selectElement.appendChild(optElement);
- });
- }
- } else if (tab === "dismissible_content") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_DISMISSIBLE_CONTENT_HEADER")}
-
-
-
- `;
-
- dismissibleContentList.forEach(({ title, id, name, treatments, needs_api_token }) => {
- try {
-
- let hrel = document.createElement("hr");
-
- document.getElementById("modalv3-dismissible-content-output").appendChild(hrel);
-
- let experimentCard = document.createElement("div");
-
- experimentCard.classList.add('modalv3-experiment-container');
- experimentCard.innerHTML = `
- ${title}
- ${id}
-
-
-
-
- `;
-
-
- document.getElementById("modalv3-dismissible-content-output").appendChild(experimentCard);
-
- const treatmentPicker = document.getElementById(`${name}_treatment_container`);
-
- if (!treatmentPicker) return; // Skip if element doesn't exist
-
- populateDismissibleContentOptions(treatmentPicker, treatments);
-
- const storedTreatment = localStorage.getItem(name);
- if (storedTreatment) {
- treatmentPicker.value = storedTreatment;
- }
-
- treatmentPicker.addEventListener("change", () => {
- localStorage.setItem(name, treatmentPicker.value);
- });
-
- } catch (error) {
- console.error(`Error setting up experiment: ${name}`, error);
- }
- });
-
- function populateDismissibleContentOptions(selectElement, treatments) {
- treatments.forEach((treatment) => {
- const optElement = document.createElement("option");
- optElement.value = treatment;
- optElement.textContent = treatment;
- selectElement.appendChild(optElement);
- });
- }
- } else if (tab === "api_test_fetch") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_API_TEST_FETCH_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_API_TESTING_API_STATUS_SUMMARY")}
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_API_TESTING_TEST_FETCH_SUMMARY")}
-
-
-
-
-
-
-
-
-
- v2
-
-
-
-
-
-
- /collectibles-shop
- /profile-effects
- /community
- /status
-
-
-
-
-
-
- tab
- has-leaks
- include-no-sku-items
- include-unpublished
-
-
- Add
-
-
-
-
-
${getTextString("MODAL_V3_TAB_API_TESTING_TEST_FETCH_FETCH")}
-
-
-
-
- `;
-
- fetch(api + APISTATUS, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message && data.message === "Missing Access") {
- document.getElementById("modalv3-api-status-container").innerHTML = `
-
-
Shop
-
-
Missing Access
-
-
-
Discord Auth
-
-
Missing Access
-
-
-
Database
-
-
Missing Access
-
- `;
- } else {
- data.forEach(apistatus => {
- let statuscard = document.createElement("div");
-
- statuscard.classList.add("modalv3-api-status-card");
-
- if (apistatus.status === "Operational") {
- statuscard.innerHTML = `
- ${apistatus.name}
-
- ${apistatus.status}
- `;
- } else if (apistatus.status === "Down") {
- statuscard.innerHTML = `
- ${apistatus.name}
-
- ${apistatus.status}
- `;
- }
-
- document.getElementById("modalv3-api-status-container").appendChild(statuscard);
-
- });
- }
- })
- .catch(error => {
- document.getElementById("modalv3-api-status-container").innerHTML = `
-
-
-
Discord Auth
-
-
Down
-
-
- `;
- });
- } else if (tab === "claimables_purchase") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_CLAIMABLES_PURCHASE_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_CLAIMABLES_PURCHASE_TITLE_SUMMARY")}
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_CLAIMABLES_PURCHASE_OPEN_MODAL_OPEN")}
-
-
-
-
-
${getTextString("MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_TITLE_SUMMARY")}
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_OPEN_MODAL_OPEN")}
-
- `;
- document.getElementById("modalv3-claimable-id-button").addEventListener("click", function () {
- openClaimablesPurchaseModal(document.getElementById("modalv3-claimable-id-test").value);
- });
- document.getElementById("modalv3-claimable-reward-id-button").addEventListener("click", function () {
- openClaimablesRewardClaimModal(document.getElementById("modalv3-claimable-reward-id-test").value);
- });
- } else if (tab === "local_storage") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_LOCAL_STORAGE_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_SUMMARY")}
-
-
-
-
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_ADD")}
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_STORAGE_SESSION_STORAGE_SUMMARY")}
-
-
-
-
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_ADD")}
-
-
-
- `;
-
- modalv3RefreshLocalStorageList()
- modalv3RefreshSessionStorageList()
- } else if (tab === "misc") {
- document.getElementById("modal-v3-tab-" + tab).classList.add("side-tabs-button-selected");
- tabPageOutput.innerHTML = `
- ${getTextString("MODAL_V3_TAB_MISC_HEADER")}
-
-
-
${getTextString("MODAL_V3_TAB_MISC_REVIEW_CONTENT_OVERRIDE_SUMMARY")}
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_MISC_UNPUBLISHED_XP_EVENTS_SUMMARY")}
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_MISC_UNPUBLISHED_XP_SHOP_SUMMARY")}
-
-
-
- `;
-
- if (localStorage.staff_enable_override_review_content === "true") {
- document.getElementById("override-review-text-content-checkbox").checked = true;
- }
- if (localStorage.staff_unpublished_xp_events === "true") {
- document.getElementById("unpublished-xp-events-checkbox").checked = true;
- }
- if (localStorage.staff_unpublished_xp_shop === "true") {
- document.getElementById("unpublished-xp-shop-checkbox").checked = true;
- }
- } else {
- console.error(tab + ' is not a valid tab');
- }
- }
-
- window.setModalv3InnerContent = setModalv3InnerContent;
-
-
- // Misc Staff
-
- function toggleStaffUnpublishedXPEvents() {
- if (localStorage.staff_unpublished_xp_events === "true") {
- localStorage.staff_unpublished_xp_events = "false"
- } else {
- localStorage.staff_unpublished_xp_events = "true"
- }
- }
-
- function toggleStaffUnpublishedXPShop() {
- if (localStorage.staff_unpublished_xp_shop === "true") {
- localStorage.staff_unpublished_xp_shop = "false"
- } else {
- localStorage.staff_unpublished_xp_shop = "true"
- }
- }
-
-
-
-
- async function redeemXPGiftCode(giftCode) {
- if (giftCode.length != 0) {
- try {
-
- const userInfo = await fetch(api + REDEEM_GIFT_CODE + giftCode, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- document.getElementById("xp-inventory-claim-code-loading").classList.add("invalid");
- document.getElementById("xp-inventory-claim-code-loading").textContent = 'Invalid Code';
- document.getElementById("xp-inventory-claim-code-button").disabled = false;
- document.getElementById("xp-inventory-claim-code-button").textContent = 'Redeem';
- }
-
- const data = await userInfo.json();
-
- if (data.message === "Invalid Gift Code.") {
- document.getElementById("xp-inventory-claim-code-loading").classList.add("invalid");
- document.getElementById("xp-inventory-claim-code-loading").textContent = `Invalid Gift Code.`;
- document.getElementById("xp-inventory-claim-code-button").disabled = false;
- document.getElementById("xp-inventory-claim-code-button").textContent = 'Redeem';
- } else if (data.message) {
- document.getElementById("xp-inventory-claim-code-loading").classList.add("invalid");
- document.getElementById("xp-inventory-claim-code-loading").textContent = `${data.error}, ${data.message}`;
- document.getElementById("xp-inventory-claim-code-button").disabled = false;
- document.getElementById("xp-inventory-claim-code-button").textContent = 'Redeem';
- } else {
- if (data.type === 0) {
- openClaimablesRewardClaimModal(data.id, data, giftCode)
- } else if (data.type === 1) {
- openClaimablesPurchaseModal(data.id, data, giftCode)
- }
-
- document.getElementById("xp-inventory-claim-code-loading").textContent = ``;
- document.getElementById("xp-inventory-claim-code-input").value = ``;
- document.getElementById("xp-inventory-claim-code-button").disabled = false;
- document.getElementById("xp-inventory-claim-code-button").textContent = 'Redeem';
- }
-
- } catch (error) {
- console.error(error)
- }
- } else {
- document.getElementById("xp-inventory-claim-code-loading").classList.add("invalid");
- document.getElementById("xp-inventory-claim-code-loading").textContent = `Invalid Gift Code.`;
- document.getElementById("xp-inventory-claim-code-button").disabled = false;
- document.getElementById("xp-inventory-claim-code-button").textContent = 'Redeem';
- }
- }
-
-
-
- async function openClaimablesPurchaseModal(claimableId, existingClaimableData, giftCode) {
-
- let disclaimerString = '';
-
- if (claimableId === "2" || claimableId === 2) {
- disclaimerString = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_2");
- } else if (claimableId === "3" || claimableId === 3) {
- disclaimerString = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_3");
- } else if (claimableId === "4" || claimableId === 4) {
- disclaimerString = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_4");
- } else if (claimableId === "5" || claimableId === 5) {
- disclaimerString = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_5");
- }
-
- if (!claimableId) {
- claimableId = null;
- }
-
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.style.zIndex = '601';
-
- modal.innerHTML = `
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_HEADER")}
-
-
-
-
-
-
-
-
-
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_1")}
-
${disclaimerString}
-
-
-
- `;
-
- if (!myXPBalancecache) {
- try {
-
- const userInfo = await fetch(api + XP_BALANCE, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
-
- }
-
- const xpBalance = await userInfo.json();
-
- if (xpBalance.message) {
-
- } else {
- myXPBalancecache = xpBalance;
- rendermyXPBalanceModal(xpBalance);
- }
-
- } catch (error) {
- console.error(error)
- }
- } else {
- rendermyXPBalanceModal(myXPBalancecache)
- }
-
- function rendermyXPBalanceModal(data) {
- modal.querySelector("[data-claimable-purchase-your-xp]").textContent = `You have ${data.xp_balance.toLocaleString()} XP`;
- }
-
- if (existingClaimableData) {
- renderModalContent(existingClaimableData);
- } else {
- fetch(api + '/claimables/published/' + claimableId, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- } else {
- renderModalContent(data);
- }
- })
- .catch(error => {
- console.error(error);
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- function renderModalContent(data) {
- modal.querySelector("[data-claimable-purchase-modal-name-preview]").textContent = data.name;
- modal.querySelector("[data-claimable-purchase-modal-price-preview]").textContent = data.xp_price.toLocaleString() + ' XP';
- modal.querySelector("[data-claimable-purchase-button]").textContent = `Claim for ${data.xp_price.toLocaleString()} XP`;
- modal.querySelector("[data-claimable-purchase-button]").style.display = 'unset';
-
- if (myXPBalancecache.xp_balance < data.xp_price) {
- modal.querySelector("[data-claimable-purchase-button]").disabled = true;
- modal.querySelector("[data-shop-claim-item-modal-error-output]").textContent = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_NOT_ENOUGH_ERROR");
- }
- modal.querySelector("[data-claimable-purchase-button]").addEventListener('click', () => {
- modal.querySelector("[data-claimable-purchase-button]").disabled = true;
- modal.querySelector("[data-claimable-purchase-button]").textContent = `...`;
- claimPerkWithXP(data.id, modal, modal_back, giftCode)
- });
- }
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- modal_back.style.zIndex = '600';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- modal.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- async function claimPerkWithXP(perkId, modal, modal_back, giftCode) {
- document.getElementById("shop-claim-item-modal-error-output").textContent = '';
-
- if (!giftCode) {
- giftCode = null;
- }
-
- try {
-
- const userInfo = await fetch(api + '/claimables/purchase/' + perkId, {
- method: "POST",
- headers: {
- Authorization: `${shop_archives_token}`,
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify({
- giftCode
- })
- });
-
- if (!userInfo.ok) {
-
- }
-
- const purchase = await userInfo.json();
-
- if (purchase.message) {
- document.getElementById("shop-claim-item-modal-error-output").textContent = purchase.message;
- } else {
- await updateXPBalance();
- await updateClaimablesClaimed();
- await updatePerksShop();
-
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
-
- } catch (error) {
- console.error(error)
- document.getElementById("shop-claim-item-modal-error-output").textContent = error;
- }
- }
-
-
- async function openClaimablesRewardClaimModal(claimableId, existingClaimableData, giftCode) {
-
- if (!claimableId) {
- claimableId = null;
- }
-
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.style.zIndex = '601';
-
- modal.innerHTML = `
-
-
-
-
-
-
... XP
-
${getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_REWARD_MODAL_HEADER")}
-
-
Learn More about XP
-
-
-
- `;
-
- if (existingClaimableData) {
- renderModalContent(existingClaimableData);
- } else {
- fetch(api + '/claimables/published/' + claimableId, {
- method: "GET",
- headers: {
- "Authorization": shop_archives_token
- }
- })
- .then(response => response.json())
- .then(data => {
- if (data.message) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- } else {
- renderModalContent(data)
- }
- })
- .catch(error => {
- console.error(error);
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- function renderModalContent(data) {
- modal.querySelector("[data-claimable-purchase-modal-price-preview]").textContent = getTextString("MODAL_V3_TAB_XP_SHOP_CLAIM_REWARD_MODAL_SUMMARY") + data.xp_reward.toLocaleString() + ' XP';
- modal.querySelector("[data-claimable-purchase-modal-price-preview2]").textContent = data.xp_reward.toLocaleString() + ' XP';
- modal.querySelector("[data-claimable-purchase-button]").textContent = `Claim ${data.xp_reward.toLocaleString()} XP`;
- modal.querySelector("[data-claimable-purchase-button]").style.display = 'unset';
-
- modal.querySelector("[data-claimable-purchase-button]").addEventListener('click', () => {
- modal.querySelector("[data-claimable-purchase-button]").disabled = true;
- modal.querySelector("[data-claimable-purchase-button]").textContent = `...`;
- claimFreeXPReward(data.id, modal, modal_back, giftCode)
- });
- }
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- modal_back.style.zIndex = '600';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- modal.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- window.openClaimablesRewardClaimModal = openClaimablesRewardClaimModal;
-
- async function claimFreeXPReward(perkId, modal, modal_back, giftCode) {
- document.getElementById("shop-claim-item-modal-error-output").textContent = '';
-
- if (!giftCode) {
- giftCode = null;
- }
-
- try {
-
- const userInfo = await fetch(api + '/claim-free-xp-reward/' + perkId, {
- method: "POST",
- headers: {
- Authorization: `${shop_archives_token}`,
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify({
- giftCode
- })
- });
-
- if (!userInfo.ok) {
-
- }
-
- const purchase = await userInfo.json();
-
- if (purchase.message) {
- document.getElementById("shop-claim-item-modal-error-output").textContent = purchase.message;
- } else {
- await updateXPBalance();
- await updateClaimablesClaimed();
- await updatePerksShop();
- await updateClaimablesPromotions();
-
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
-
- } catch (error) {
- console.error(error)
- document.getElementById("shop-claim-item-modal-error-output").textContent = error;
- }
- }
-
-
- async function updateXPBalance() {
- try {
-
- const userInfo = await fetch(api + XP_BALANCE, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
-
- } else {
- myXPBalancecache = data;
- if (document.getElementById("modalv3-xp-balance-text")) {
- document.getElementById("modalv3-xp-balance-text").textContent = data.xp_balance.toLocaleString();
- }
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- async function updatePerksShop() {
- try {
-
- url = api + CLAIMABLES_SHOP;
- fetchUrl = new URL(url);
- if (localStorage.staff_unpublished_xp_shop == "true") {
- fetchUrl.searchParams.append("include-unpublished", "true");
- }
-
- const userInfo = await fetch(fetchUrl, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
-
- } else {
- claimablesShopcache = data;
- try {
- renderXPShop(data);
- } catch (error) {
- }
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- async function updateClaimablesClaimed() {
- try {
-
- const userInfo = await fetch(api + CLAIMABLES_CLAIMED, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
-
- } else {
- myClaimablesClaimedCache = data;
- try {
- fetchXpInventory();
- } catch (error) {
- }
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
- async function updateClaimablesPromotions() {
- try {
-
- url = api + CLAIMABLES_PROMOTIONS;
- fetchUrl = new URL(url);
- if (localStorage.staff_unpublished_xp_events == "true") {
- fetchUrl.searchParams.append("include-unpublished", "true");
- }
-
- const userInfo = await fetch(fetchUrl, {
- headers: { Authorization: `${shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- }
-
- const data = await userInfo.json();
-
- if (data.message) {
-
- } else {
- claimablesPromotionsCache = data;
- try {
- fillCategoryModalContentContainer('xp_rewards', null, true);
- } catch (error) {
- }
- try {
- fetchXpEvents();
- } catch (error) {
- }
- }
-
- } catch (error) {
- console.error(error)
- }
- }
-
-
- function updateExtendedStylesCategoryTab(setFilter) {
- const el1 = document.getElementById("modalv3-extended-styles-category-tab-1");
- const el2 = document.getElementById("modalv3-extended-styles-category-tab-2");
- const el3 = document.getElementById("modalv3-extended-styles-category-tab-3");
-
- if (el1 && el1.classList.contains('selected')) {
- el1.classList.remove('selected');
- } else if (el2 && el2.classList.contains('selected')) {
- el2.classList.remove('selected');
- } else if (el3 && el3.classList.contains('selected')) {
- el3.classList.remove('selected');
- }
-
- if (setFilter) {
- localStorage.ext_sty_category_tab = setFilter;
- document.getElementById("modalv3-extended-styles-category-tab-" + setFilter).classList.add('selected');
- } else {
- document.getElementById("modalv3-extended-styles-category-tab-" + localStorage.ext_sty_category_tab).classList.add('selected');
- }
- }
-
- function updateReviewsFilterStore(setFilter) {
- const el3 = document.getElementById("modalv3-ratio-card-reviews-filter-3");
- const el2 = document.getElementById("modalv3-ratio-card-reviews-filter-2");
- const el1 = document.getElementById("modalv3-ratio-card-reviews-filter-1");
-
- if (el3 && el3.classList.contains('modalv3-content-ratio-card-selected')) {
- el3.classList.remove('modalv3-content-ratio-card-selected');
- } else if (el2 && el2.classList.contains('modalv3-content-ratio-card-selected')) {
- el2.classList.remove('modalv3-content-ratio-card-selected');
- } else if (el1 && el1.classList.contains('modalv3-content-ratio-card-selected')) {
- el1.classList.remove('modalv3-content-ratio-card-selected');
- }
-
- if (setFilter) {
- localStorage.reviews_filter_type = setFilter;
- document.getElementById("modalv3-ratio-card-reviews-filter-" + setFilter).classList.add('modalv3-content-ratio-card-selected');
- } else {
- document.getElementById("modalv3-ratio-card-reviews-filter-" + localStorage.reviews_filter_type).classList.add('modalv3-content-ratio-card-selected');
- }
- }
-
- function updateReviewsTimeFormatStore(setTimeFormat) {
- const el2 = document.getElementById("modalv3-ratio-card-reviews-time-us");
- const el1 = document.getElementById("modalv3-ratio-card-reviews-time-uk");
-
- if (el2 && el2.classList.contains('modalv3-content-ratio-card-selected')) {
- el2.classList.remove('modalv3-content-ratio-card-selected');
- } else if (el1 && el1.classList.contains('modalv3-content-ratio-card-selected')) {
- el1.classList.remove('modalv3-content-ratio-card-selected');
- }
-
- if (setTimeFormat) {
- localStorage.reviews_time_type = setTimeFormat;
- document.getElementById("modalv3-ratio-card-reviews-time-" + setTimeFormat).classList.add('modalv3-content-ratio-card-selected');
- } else {
- document.getElementById("modalv3-ratio-card-reviews-time-" + localStorage.reviews_time_type).classList.add('modalv3-content-ratio-card-selected');
- }
- }
-
- let userReviewsWarnsCache = null;
-
- async function updateAndCacheReviewsWarnings() {
- let warningsRaw = null;
- if (userReviewsWarnsCache === null) {
- warningsRaw = await fetch(api + REVIEWSAPI + "/users/" + localStorage.discord_user_id + "/warns", {
- headers: { Authorization: `${localStorage.discord_token}`, Token: sessionStorage.getItem("api-token") }
- });
-
- const warnings = await warningsRaw.json();
-
- console.log(warnings)
- userReviewsWarnsCache = warnings;
- }
-
- if (document.getElementById("modalv3-warnings-warns-output-container")) {
- if (Array.isArray(userReviewsWarnsCache) && userReviewsWarnsCache.length === 0) {
-
- } else {
- userReviewsWarnsCache.forEach(warn => {
- let warningCard = document.createElement("div");
-
- let formatted = null;
-
- if (localStorage.reviews_time_type === "uk") {
- const date = new Date(warn.created_at);
-
- const day = String(date.getDate()).padStart(2, '0');
- const month = String(date.getMonth() + 1).padStart(2, '0'); // getMonth is 0-indexed
- const year = date.getFullYear();
-
- formatted = `${day}/${month}/${year}`;
- } else {
- const date = new Date(warn.created_at);
-
- const day = String(date.getDate()).padStart(2, '0');
- const month = String(date.getMonth() + 1).padStart(2, '0'); // getMonth is 0-indexed
- const year = date.getFullYear();
-
- formatted = `${day}/${month}/${year}`;
- }
-
-
- warningCard.classList.add('review-element-warning');
- warningCard.style.paddingLeft = '10px';
- warningCard.innerHTML = `
- Warning!
- At: ${formatted}
- Reason: ${warn.message}
- `;
-
- document.getElementById("modalv3-warnings-warns-output-container").appendChild(warningCard);
- })
- }
- }
- }
-
-
- function modalv3RefreshLocalStorageList() {
- const container = document.getElementById('modalv3-localstorage-output');
- container.innerHTML = '';
-
- const keys = Object.keys(localStorage).sort();
-
- if (keys.length === 0) {
- container.innerHTML = 'No items in localStorage.
';
- return;
- }
-
- keys.forEach(key => {
- const value = localStorage.getItem(key);
-
- const div = document.createElement('div');
- div.className = 'modalv3-localstorage-item-card';
-
- div.innerHTML = `
-
-
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_UPDATE")}
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_DELETE")}
- `;
-
- container.appendChild(div);
- });
- }
-
- function modalv3AddLocalStorage() {
- const key = document.getElementById('modalv3-localstorage-add-input-key').value.trim();
- const value = document.getElementById('modalv3-localstorage-add-input-value').value;
-
- if (!key) {
- alert("Key cannot be empty.");
- return;
- }
-
- localStorage.setItem(key, value);
- document.getElementById('modalv3-localstorage-add-input-key').value = '';
- document.getElementById('modalv3-localstorage-add-input-value').value = '';
- modalv3RefreshLocalStorageList();
- }
-
- function modalv3UpdateLocalStorage(key) {
- const newValue = document.getElementById(`value-local-${key}`).value;
- localStorage.setItem(key, newValue);
- modalv3RefreshLocalStorageList();
- }
-
- function modalv3DeleteLocalStorage(key) {
- if (confirm(`Delete key "${key}"?`)) {
- localStorage.removeItem(key);
- modalv3RefreshLocalStorageList();
- }
- }
-
-
- function modalv3RefreshSessionStorageList() {
- const container = document.getElementById('modalv3-sessionstorage-output');
- container.innerHTML = '';
-
- const keys = Object.keys(sessionStorage).sort();
-
- if (keys.length === 0) {
- container.innerHTML = 'No items in sessionStorage.
';
- return;
- }
-
- keys.forEach(key => {
- const value = sessionStorage.getItem(key);
-
- const div = document.createElement('div');
- div.className = 'modalv3-localstorage-item-card';
-
- div.innerHTML = `
-
-
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_UPDATE")}
- ${getTextString("MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_DELETE")}
- `;
-
- container.appendChild(div);
- });
- }
-
- function modalv3AddSessionStorage() {
- const key = document.getElementById('modalv3-sessionstorage-add-input-key').value.trim();
- const value = document.getElementById('modalv3-sessionstorage-add-input-value').value;
-
- if (!key) {
- alert("Key cannot be empty.");
- return;
- }
-
- sessionStorage.setItem(key, value);
- document.getElementById('modalv3-sessionstorage-add-input-key').value = '';
- document.getElementById('modalv3-sessionstorage-add-input-value').value = '';
- modalv3RefreshSessionStorageList();
- }
-
- function modalv3UpdateSessionStorage(key) {
- const newValue = document.getElementById(`value-session-${key}`).value;
- sessionStorage.setItem(key, newValue);
- modalv3RefreshSessionStorageList();
- }
-
- function modalv3DeleteSessionStorage(key) {
- if (confirm(`Delete key "${key}"?`)) {
- sessionStorage.removeItem(key);
- modalv3RefreshSessionStorageList();
- }
- }
-
-
-
- function adminDeleteReview(reviewId) {
-
- const accessToken = discord_token;
-
- fetch(api + REVIEWSAPI, {
- method: "DELETE",
- headers: {
- "Content-Type": "application/json",
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- },
- body: JSON.stringify({
- accessToken,
- reviewId
- })
- })
- .catch(error => {
- console.error(error)
- });
-
- if (document.getElementById(reviewId + "-review-admin-card")) {
- document.getElementById(reviewId + "-review-admin-card").remove();
- }
- }
-
- function modalv3AddTestFetchParam() {
- const key = document.getElementById("modalv3-test-fetch-search-params-key").value;
- const value = document.getElementById('modalv3-test-fetch-search-params-value').value;
-
- const container = document.getElementById('modalv3-test-fetch-params-output');
- const div = document.createElement('div');
- div.className = 'modalv3-api-testfetch-param-card';
- div.innerHTML = `
-
-
- &${key}=${value}
- Delete
- `;
- container.appendChild(div);
-
- document.getElementById('modalv3-test-fetch-search-params-value').value = '';
- }
-
- function fetchAPITestFetch() {
- const baseurl = document.getElementById("modalv3-test-fetch-base-url").value;
- const versionid = document.getElementById("modalv3-test-fetch-version").value;
- const endpoint = document.getElementById("modalv3-test-fetch-endpoint").value;
- const output = document.getElementById("modalv3-test-fetch-output");
-
- url = baseurl + "/" + versionid + endpoint;
- testFetchURL = new URL(url);
-
- const keyInputs = document.querySelectorAll('.test-fetch-param-key');
- const valueInputs = document.querySelectorAll('.test-fetch-param-value');
-
- const params = new URLSearchParams();
- for (let i = 0; i < keyInputs.length; i++) {
- const key = keyInputs[i].value.trim();
- const value = valueInputs[i].value.trim();
- if (key) params.append(key, value);
- }
-
- const finalUrl = `${testFetchURL}?${params.toString()}`;
-
- fetch(finalUrl, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- console.log(data);
- output.textContent = JSON.stringify(data, undefined, 4);
- })
- .catch(error => {
- console.log(`Failed to test fetch: `, error);
- });
- }
-
- function disabledExperimentForceRolloutV2() {
- if (localStorage.experiment_force_rollout === "false") {
- localStorage.experiment_force_rollout = "true"
- } else {
- localStorage.experiment_force_rollout = "false"
- }
- }
-
- function overrideReviewTextContent() {
- if (localStorage.staff_enable_override_review_content === "true") {
- localStorage.staff_enable_override_review_content = "false"
- } else {
- localStorage.staff_enable_override_review_content = "true"
- }
- }
-
- function overrideRawReviewTextContent() {
- localStorage.staff_raw_review_override_content = document.getElementById("modalv3-update-review-content-override").value;
- }
-
- function updateThemeStore(theme, hasButtons, raw) {
- localStorage.sa_theme = theme;
- localStorage.removeItem('community_theme_raw');
- if (hasButtons === "true") {
- try {
- if (document.querySelector(".theme-selection-box-selected")) {
- document.querySelectorAll('.theme-selection-box-selected').forEach((el) => {
- el.classList.remove("theme-selection-box-selected");
- });
- }
- document.body.removeAttribute("class");
- } catch (error) {
- }
- if (document.getElementById("theme-" + theme + "-button")) {
- document.getElementById("theme-" + theme + "-button").classList.add('theme-selection-box-selected');
- }
- }
- document.body.classList.add('theme-' + theme);
- if (raw != null) {
- localStorage.community_theme_raw = raw;
- fetch(raw, {
- method: "GET"
- })
- .then(response => response.text())
- .then((data) => {
-
- document.getElementById("community-theme-import").innerHTML = `${data}`;
-
- })
- .catch(error => {
- console.error(error)
- });
-
- if (document.getElementById("theme-" + theme + "-button")) {
- document.getElementById("theme-" + theme + "-button").classList.add('theme-selection-box-selected');
- }
- } else {
- document.getElementById("community-theme-import").innerHTML = ``;
- }
- }
-
- function updateThemeToCommunity() {
- if (localStorage.community_theme_raw) {
- fetch(localStorage.community_theme_raw, {
- method: "GET"
- })
- .then(response => response.text())
- .then((data) => {
- document.getElementById("community-theme-import").innerHTML = `${data}`;
- })
- .catch(error => {
- console.error(error)
- });
- }
- }
-
- updateThemeToCommunity();
-
- function optionsSidebarToggle() {
- if (document.getElementById('options-sidebar-container').classList.contains('options-sidebar-container-expanded')) {
- document.getElementById('options-sidebar-container').classList.remove("options-sidebar-container-expanded");
- } else {
- document.getElementById('options-sidebar-container').classList.add("options-sidebar-container-expanded");
- document.getElementById('options-sidebar-container').innerHTML = `
- ${getTextString("OPTIONS_SIDEBAR_TITLE")}
-
-
-
-
-
-
${getTextString("OPTIONS_SIDEBAR_CURRENCY_PICKER")}
-
-
-
-
-
-
-
${getTextString("OPTIONS_SIDEBAR_REDUCED_MOTION")}
-
-
-
-
-
${getTextString("OPTIONS_SIDEBAR_REDUCED_MOTION_BANNERS")}
-
-
-
-
-
-
-
-
-
- ${getTextString("OPTIONS_SIDEBAR_DOWNLOADS")}
-
-
-
${getTextString("OPTIONS_SIDEBAR_YAPPER_HELP")}
-
- ${getTextString("OPTIONS_SIDEBAR_YAPPER_DISCORD_SERVER")}
- ${getTextString("OPTIONS_SIDEBAR_YAPPER_GITHUB")}
-
- ${getTextString("APP_VERSION")}${tcbx926n29}
- `;
-
- if (app_version2 === "Stable") {
- let betatester = document.createElement("div");
-
- betatester.innerHTML = `
-
${getTextString("OPTIONS_SIDEBAR_YAPPER_BETA_TESTING")}
- `;
-
- document.getElementById("yapper-article-container").appendChild(betatester);
- }
-
- if (localStorage.experiment_2025_02_extra_options === "Treatment 4: Enabled" || localStorage.experiment_2025_02_extra_options === "Treatment 5: Enabled w/o currency picker" || localStorage.experiment_2025_02_extra_options === "Treatment 6: Settings like discord") {
- document.getElementById("username-picker-container-dev").innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_DESC")}
-
-
-
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_USERNAME")}
-
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_BANNER_COLOR")}
-
-
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_AVATAR")}
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_REMOVE_AVATAR")}
-
-
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_CHANGE_BANNER")}
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_REMOVE_BANNER")}
-
-
-
-
-
-
-
-
-
-
-
${localStorage.discord_displayname}
-
-
-
-
- `;
-
- if (localStorage.experiment_2025_04_discord_sign_in === "Treatment 3: Force Logged In" || localStorage.experiment_2025_04_discord_sign_in === "Treatment 1: Dynamic" && localStorage.getItem('discord_token')) {
- let cantChangeProfileWhenLoggedIn = document.createElement("div");
-
- cantChangeProfileWhenLoggedIn.classList.add('cant-change-profile-when-logged-in-container');
- cantChangeProfileWhenLoggedIn.innerHTML = `
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_1")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_2")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_BUTTON")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_RESYNC")}
-
- `;
-
-
- document.getElementById("profile-change-settings").appendChild(cantChangeProfileWhenLoggedIn);
-
- document.getElementById("discord-integration-options-container").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGGED_IN_AS")}${localStorage.discord_displayname} (${localStorage.discord_username})
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT")}
- `;
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen" && localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1") {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
-
${getTextString("DM_NEW")}
- `;
- } else {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
- `;
- }
- } else if (localStorage.experiment_2025_04_discord_sign_in === "Treatment 1: Dynamic" || localStorage.experiment_2025_04_discord_sign_in === "Treatment 2: Force Logged Out") {
- document.getElementById("discord-integration-options-container").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_SUMMARY")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGIN")}
- `;
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen" && localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1") {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
-
${getTextString("DM_NEW")}
- `;
- } else {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
- `;
- }
- }
-
- if (localStorage.experiment_2025_04_discord_sign_in === "Treatment 6: Force Logged In v2" || localStorage.experiment_2025_04_discord_sign_in === "Treatment 4: Dynamic v2" && localStorage.getItem('discord_token')) {
-
- document.getElementById("options-profile-nono-change-container").innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_1")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_2")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_ERROR_3")}
- `;
-
- document.getElementById("profile-settings-edit").style.display = 'none';
-
- document.getElementById("discord-integration-options-container").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGGED_IN_AS")}${localStorage.discord_displayname} (${localStorage.discord_username})
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_RESYNC")}
- ${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT")}
-
- `;
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen" && localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1") {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
-
${getTextString("DM_NEW")}
- `;
- } else {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
- `;
- }
- } else if (localStorage.experiment_2025_04_discord_sign_in === "Treatment 4: Dynamic v2") {
- document.getElementById("discord-integration-options-container").innerHTML = `
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_SUMMARY")}
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGIN")}
- `;
- if (localStorage.dismissible_newLogInWithDiscord != "Treatment 1: Seen" && localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1") {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
-
${getTextString("DM_NEW")}
- `;
- } else {
- document.getElementById('discord-sign-in-title-container').innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD")}
- `;
- }
- }
-
-
-
- document.getElementById("accessibility-options-container").innerHTML = `
-
${getTextString("OPTIONS_SIDEBAR_ACCESSIBILITY")}
-
-
-
${getTextString("OPTIONS_SIDEBAR_REDUCED_MOTION")}
-
-
- `;
- document.getElementById("old-options-container-dev").innerHTML = ``;
-
- document.getElementById("options-username-preview").textContent = localStorage.discord_username.toLowerCase();
-
- // if (localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker") {
- // document.getElementById("currency-picker-experiment-container").innerHTML = `
- //
- //
${getTextString("OPTIONS_SIDEBAR_NITRO_DISCOUNT")}
- //
- //
- // `;
- //
- //
Currency
- //
- //
- //
- // }
-
-
- const avatarImageInput = document.getElementById("profileAvatarInput");
- const avatarImagePreview = document.getElementById("profileAvatarPreview");
- const removeAvatarImageButton = document.getElementById("removeProfileAvatarButton");
-
- // Load saved image from localStorage on page load
- document.addEventListener("DOMContentLoaded", () => {
- const savedImage = localStorage.getItem("discord_avatar");
- if (savedImage) {
- avatarImagePreview.src = savedImage;
- }
- });
-
- // Handle image upload
- avatarImageInput.addEventListener("change", function () {
- document.getElementById("options-avatar-img-input-option-error").classList.remove('options-img-input-option-error')
- document.getElementById("options-avatar-img-input-option-error").innerHTML = ``;
- const file = this.files[0];
- if (file) {
- const reader = new FileReader();
- reader.onload = function (event) {
- const dataUrl = event.target.result;
- try {
- localStorage.setItem("discord_avatar", dataUrl);
- avatarImagePreview.src = dataUrl;
- } catch(error) {
- document.getElementById("options-avatar-img-input-option-error").classList.add('options-img-input-option-error')
- document.getElementById("options-avatar-img-input-option-error").innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG")}
- `;
- }
- };
- reader.readAsDataURL(file);
- }
- });
-
- // Handle image removal
- removeAvatarImageButton.addEventListener("click", function () {
- setRandomDiscordAvatar()
- avatarImagePreview.src = localStorage.discord_avatar;
- });
-
-
- const bannerImageInput = document.getElementById("profileBannerInput");
- const bannerImagePreview = document.getElementById("profileBannerPreview");
- const removeBannerImageButton = document.getElementById("removeProfileBannerButton");
-
-
- if (localStorage.discord_banner === ``) {
- removeBannerImageButton.style.display = 'none';
- }
-
- // Load saved image from localStorage on page load
- document.addEventListener("DOMContentLoaded", () => {
- const savedImage = localStorage.getItem("discord_banner");
- if (savedImage) {
- bannerImagePreview.style.backgroundImage = `url(${savedImage})`;
- }
- });
-
- // Handle image upload
- bannerImageInput.addEventListener("change", function () {
- document.getElementById("options-banner-img-input-option-error").classList.remove('options-img-input-option-error')
- document.getElementById("options-banner-img-input-option-error").innerHTML = ``;
- removeBannerImageButton.style.display = 'block';
- const file = this.files[0];
- if (file) {
- const reader = new FileReader();
- reader.onload = function (event) {
- const dataUrl = event.target.result;
- try {
- localStorage.setItem("discord_banner", dataUrl);
- bannerImagePreview.style.backgroundImage = `url(${dataUrl})`;
- } catch(error) {
- document.getElementById("options-banner-img-input-option-error").classList.add('options-img-input-option-error')
- document.getElementById("options-banner-img-input-option-error").innerHTML = `
-
${getTextString("OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG")}
- `;
- }
- };
- reader.readAsDataURL(file);
- }
- });
-
- // Handle image removal
- removeBannerImageButton.addEventListener("click", function () {
- removeBannerImageButton.style.display = 'none';
- localStorage.discord_banner = ``
- bannerImagePreview.style.backgroundImage = '';
- });
- }
-
- try {
- const currency_picker_currencies = ["USD", "Discord Orb"];
-
- const currency_picker_currencies_picker = document.getElementById("currency_picker_container");
-
-
- populate_currency_picker();
-
- const storedTreatment = localStorage.getItem("currency");
- if (storedTreatment) {
- currency_picker_currencies_picker.value = storedTreatment;
- }
-
- function populate_currency_picker() {
- currency_picker_currencies.forEach((treatments) => {
- const optElement = document.createElement("option");
- optElement.value = treatments;
- optElement.textContent = treatments;
- currency_picker_currencies_picker.appendChild(optElement);
- });
- }
-
- currency_picker_currencies_picker.addEventListener("change", () => {
- const selectedTreatment = currency_picker_currencies_picker.value;
-
- // Store the selection
- localStorage.setItem("currency", selectedTreatment);
- });
- } catch(error) {
- }
-
- if (localStorage.experiment_2024_12_theme_picker == "Treatment 1: Enabled" || localStorage.experiment_2024_12_theme_picker == "Treatment 2: Enabled with custom css") {
- document.getElementById("theme-picker-container").innerHTML = `
-
${getTextString("OPTIONS_SIDEBAR_APPEARANCE")}
-
${getTextString("OPTIONS_SIDEBAR_APPEARANCE_1")}
-
-
${getTextString("OPTIONS_SIDEBAR_APPEARANCE_2")}
- `;
- if (localStorage.experiment_2024_12_theme_picker == "Treatment 2: Enabled with custom css") {
- const themes_container = document.getElementById("theme-picker-container");
-
- document.getElementById("default-theme-title").style.display = 'unset';
- document.getElementById("custom-theme-title").style.display = 'unset';
-
- let custom_themes = document.createElement("div");
- custom_themes.id = 'theme-selection-box-container';
-
- custom_themes.innerHTML = `
-
-
-
- `;
-
- themes_container.appendChild(custom_themes);
- }
- }
-
- if (localStorage.sa_theme == "dark") {
- try {
- document.getElementById("theme-dark-button").classList.add('theme-selection-box-selected');
- document.body.classList.add('theme-dark');
- } catch (error) {
- }
- } else
- if (localStorage.sa_theme == "midnight") {
- try {
- document.getElementById("theme-midnight-button").classList.add('theme-selection-box-selected');
- document.body.classList.add('theme-midnight');
- } catch (error) {
- }
- } else
- if (localStorage.sa_theme == "light") {
- try {
- document.getElementById("theme-light-button").classList.add('theme-selection-box-selected');
- document.body.classList.add('theme-light');
- } catch (error) {
- }
- } else
- if (localStorage.sa_theme == "neongreen") {
- try {
- document.getElementById("theme-neongreen-button").classList.add('theme-selection-box-selected');
- document.body.classList.add('theme-neongreen');
- } catch (error) {
- }
- } else
- if (localStorage.sa_theme == "neonpurple") {
- try {
- document.getElementById("theme-neonpurple-button").classList.add('theme-selection-box-selected');
- document.body.classList.add('theme-neonpurple');
- } catch (error) {
- }
- }
-
-
- if (localStorage.fetch_collectibles_variants == "true") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.fetch_collectibles_variants == "none") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.reduced_motion == "true") {
- document.getElementById("reduced-motion-box").checked = true;
- }
-
- // if (localStorage.is_nitro_user == "true" && localStorage.experiment_2025_02_extra_options && localStorage.experiment_2025_02_extra_options != "Treatment 5: Enabled w/o currency picker" && localStorage.experiment_2025_02_extra_options != "Treatment -1: Disabled") {
- // document.getElementById("options-has-nitro-box").checked = true;
- // }
-
- if (localStorage.disable_client_banner_overrides == "true") {
- document.getElementById("disable-banner-overrides-box").checked = true;
- }
-
- if (localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 1: Enabled" || localStorage.experiment_2025_04_collectibles_marketing_page === "Treatment 2: Enable v2") {
- const content = document.getElementById('downloadables-output');
- content.innerHTML = `
-
${getTextString("OPTIONS_SIDEBAR_MARKETING_DOWNLOADS_HAVE_MOVED")}
-
- ${getTextString("OPTIONS_SIDEBAR_MARKETING_DOWNLOADS_HAVE_MOVED_BUTTON")}
-
- `;
- } else {
-
- fetch(api + DOWNLOADABLE_DATA, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- // Call the function to display the data
- displayData(data);
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
- // Function to display the data in the HTML
- function displayData(data) {
- const content = document.getElementById('downloadables-output');
- const template = document.getElementById('downloadables-api-template');
-
- data.forEach(item => {
- // Clone the template
- const clone = template.content.cloneNode(true);
-
- // Fill in the name and summary
- clone.querySelector('.name').textContent = item.name;
- clone.querySelector('.summary').textContent = item.summary;
-
- if (item.id === "discord_marketing") {
- // Add buttons for downloadables
- const downloadablesDiv = clone.querySelector('.downloadables');
- item.downloadables.forEach(downloadable => {
- const button = document.createElement('button');
- button.textContent = `${downloadable.id}: ` + downloadable.name;
- button.classList.add('card-button');
- button.addEventListener('click', () => {
- window.open('https://item.yapper.shop/marketing/' + downloadable.id + '/data.zip', '_blank');
- });
- downloadablesDiv.appendChild(button);
- });
- }
-
- if (item.id === "profiles_plus_marketing") {
- // Add buttons for downloadables
- const downloadablesDiv = clone.querySelector('.downloadables');
- item.downloadables.forEach(downloadable => {
- const button = document.createElement('button');
- button.textContent = `${downloadable.id}: ` + downloadable.name;
- button.classList.add('card-button');
- button.addEventListener('click', () => {
- window.open('https://item.yapper.shop/profiles-plus-marketing/' + downloadable.id + '/data.zip', '_blank');
- });
- downloadablesDiv.appendChild(button);
- });
- }
-
- // Append the cloned template to the content
- content.appendChild(clone);
- });
- }
-
- }
- if (localStorage.experiment_2025_03_extra_options_dismissible_content === "Treatment 1: V1") {
- localStorage.dismissible_newProfileSettings = "Treatment 1: Seen"
- if (document.getElementById("newProfileSettingsDismissible")) {
- document.getElementById("newProfileSettingsDismissible").remove();
- }
- }
- if (localStorage.experiment_2025_04_discord_sign_in_dismissible === "Treatment 1: V1" && localStorage.staff_dont_dismiss_discord_login != "true") {
- localStorage.dismissible_newLogInWithDiscord = "Treatment 1: Seen"
- if (document.getElementById("open-options-tools-button-1")) {
- document.getElementById("open-options-tools-button-1").innerHTML = `
-
- `;
- }
- if (document.getElementById("newLogInWithDiscordDismissible")) {
- document.getElementById("newLogInWithDiscordDismissible").remove();
- }
- }
- }
- }
-
-
- function loginToDiscord() {
- const discordUrl = `https://discord.com/api/oauth2/authorize?client_id=${discord_app_ids.SHOP_ARCHIVES}&redirect_uri=${encodeURIComponent(api + LOGIN_CALLBACK)}&response_type=code&scope=identify`;
- window.location.href = discordUrl;
- }
-
- function logoutOfDiscord() {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_1")}
-
-
${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_2")}
-
- ${getTextString("OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_3")}
-
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- modal.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
-
- function actuallyLogOutOfDiscord() {
- localStorage.removeItem('discord_token');
- localStorage.removeItem('discord_profile');
- sessionStorage.removeItem('discord_profile');
- localStorage.removeItem('discord_avatar');
- localStorage.removeItem('discord_username');
- localStorage.removeItem('discord_user_id');
- localStorage.removeItem('discord_displayname');
- localStorage.removeItem('discord_banner_color');
- localStorage.removeItem('discord_banner');
- localStorage.removeItem('discord_premium_type');
- localStorage.removeItem('admin_level');
- localStorage.removeItem('account_type');
- localStorage.removeItem('shop_archives_token');
- localStorage.dev = "false";
- localStorage.reviews_filter_type = "2";
- location.reload();
- }
-
- function closeLoginDismissibleCoachtip() {
- if (document.getElementById('newLogInWithDiscordDismissible')) {
- localStorage.dismissible_newLogInWithDiscord = "Treatment 1: Seen";
- document.getElementById('newLogInWithDiscordDismissible').remove();
- }
- }
-
- function closenew100FreeXPDismissibleCoachtip() {
- if (document.getElementById('new100FreeXPDismissible')) {
- localStorage.dismissible_new100FreeXP = "Treatment 1: Seen";
- document.getElementById('new100FreeXPDismissible').remove();
- }
- }
-
- function closeXPnoticeDismissibleCoachtip() {
- if (document.getElementById('XPnotice')) {
- localStorage.dismissible_XPnotice = "Treatment 1: Seen";
- document.getElementById('XPnotice').remove();
- }
- }
-
- async function updateDiscordProfilePlaceholder() {
- await updateDiscordProfile(localStorage.discord_token);
- optionsSidebarToggle();
- optionsSidebarToggle();
- if (apiUrl) {
- fetchData(pageCheck());
- }
- }
-
- window.updateDiscordProfilePlaceholder = updateDiscordProfilePlaceholder;
-
- async function updateDiscordProfileModalv3() {
- await updateDiscordProfile(localStorage.discord_token);
- setModalv3InnerContent('account');
- if (apiUrl) {
- fetchData(pageCheck());
- }
- }
-
- window.updateDiscordProfileModalv3 = updateDiscordProfileModalv3;
-
- async function updateDiscordProfile(token) {
- if (localStorage.account_type === "2") {
- try {
- const userInfo = await fetch('https://api.yapper.shop/v2/users/@me', {
- method: "POST",
- headers: { Authorization: `${localStorage.shop_archives_token}` }
- });
-
- if (!userInfo.ok) {
- // If the response is not ok (e.g., 401 Unauthorized)
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- return;
- }
-
- const user = await userInfo.json();
- localStorage.discord_profile = JSON.stringify(user, undefined, 4);
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${user.id}/${user.avatar}.webp?size=4096`;
- localStorage.discord_username = user.username;
- if (user.global_name != null) {
- localStorage.discord_displayname = user.global_name;
- } else {
- localStorage.discord_displayname = user.username;
- }
- localStorage.discord_banner_color = user.banner_color;
- localStorage.discord_premium_type = user.premium_type;
-
- if (user.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${user.id}/${user.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
-
- const atMe = await fetch('https://api.yapper.shop/v2/users/@me', {
- headers: { Authorization: `${localStorage.shop_archives_token}` }
- });
-
- const atMe2 = await atMe.json();
-
- atMeUsercache = atMe2;
-
- console.log('success');
-
- // Optional: additional check (but `localStorage.discord_profile` is a string, so this check won't work unless parsed)
- const parsedProfile = JSON.parse(localStorage.discord_profile);
- if (parsedProfile.code === 0) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
-
- } catch (error) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
- } else {
- try {
- const userInfo = await fetch('https://discord.com/api/users/@me', {
- headers: { Authorization: `Bearer ${token}` }
- });
-
- if (!userInfo.ok) {
- // If the response is not ok (e.g., 401 Unauthorized)
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- return;
- }
-
- const user = await userInfo.json();
- localStorage.discord_profile = JSON.stringify(user, undefined, 4);
- localStorage.discord_avatar = `https://cdn.discordapp.com/avatars/${user.id}/${user.avatar}.webp?size=4096`;
- localStorage.discord_username = user.username;
- if (user.global_name != null) {
- localStorage.discord_displayname = user.global_name;
- } else {
- localStorage.discord_displayname = user.username;
- }
- localStorage.discord_banner_color = user.banner_color;
- localStorage.discord_premium_type = user.premium_type;
-
- if (user.banner != null) {
- localStorage.discord_banner = `https://cdn.discordapp.com/banners/${user.id}/${user.banner}.png?size=4096`;
- } else {
- localStorage.removeItem('discord_banner');
- }
-
- console.log('success');
-
- // Optional: additional check (but `localStorage.discord_profile` is a string, so this check won't work unless parsed)
- const parsedProfile = JSON.parse(localStorage.discord_profile);
- if (parsedProfile.code === 0) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
-
- } catch (error) {
- setParams({ page: 'home', login: 'false' });
- actuallyLogOutOfDiscord();
- }
- }
- }
-
- function changeUsernameFromInput() {
- const input = document.getElementById('profile-username-text-input')
-
- localStorage.discord_username = input.value;
- localStorage.discord_displayname = input.value;
-
- const displayname = document.getElementById('options-preview-profile-displayname')
-
- displayname.textContent = input.value;
-
-
- const usernamename = document.getElementById('options-username-preview')
-
- usernamename.textContent = input.value.toLowerCase();
- }
-
- function changeBannerColorFromInput() {
- const input = document.getElementById('profile-banner-color-input')
-
- localStorage.discord_banner_color = input.value;
-
- const banner = document.getElementById('options-preview-profile-banner-color')
-
- banner.style.backgroundColor = input.value;
- }
-
- function changeAvatarFromInput() {
- const input = document.getElementById('profile-avatar-text-input')
-
- localStorage.discord_avatar = input.value;
- }
-
-
- if (localStorage.experiment_2025_03_extra_options_dismissible_content === "Treatment 1: V1") {
-
- if (localStorage.dismissible_newProfileSettings != "Treatment 1: Seen") {
- let newProfileSettingsDismissible = document.createElement("div");
-
- newProfileSettingsDismissible.onclick = function() {
- optionsSidebarToggle();
- localStorage.dismissible_newProfileSettings = "Treatment 1: Seen"
- newProfileSettingsDismissible.remove();
- };
-
- newProfileSettingsDismissible.classList.add('newProfileSettingsDismissible');
-
- newProfileSettingsDismissible.id = `newProfileSettingsDismissible`;
-
- document.body.appendChild(newProfileSettingsDismissible);
- }
- }
-
- if (localStorage.experiment_2024_12_profiles_plus_marketing_variants === "Treatment 1: Paper Beach V2") {
-
- if (localStorage.dismissible_paper_beach_v2_marketing != "Treatment 1: Seen") {
- const profiles_plus_tab = document.getElementById("pplus-tab");
- if (profiles_plus_tab) {
- profiles_plus_tab.innerHTML = `
-
-
${getTextString("PROFILES_PLUS_BROWSE_ALL_TAB_TITLE")}
-
${getTextString("DM_NEW")}
-
-
-
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_PAPER_BEACH_V2_TITLE")}
- `;
- profiles_plus_tab.classList.add('paper_beach_v2_marketing_tab');
-
- profiles_plus_tab.addEventListener("mouseenter", () => {
- if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/12.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- } else if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/8.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- } else if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/2.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- }
- });
- }
- }
- }
-
-
- if (localStorage.experiment_2024_12_profiles_plus_marketing_variants === "Treatment 2: Roblox Doors") {
-
- if (localStorage.dismissible_roblox_doors_marketing != "Treatment 1: Seen") {
- const profiles_plus_tab = document.getElementById("pplus-tab");
- if (profiles_plus_tab) {
- profiles_plus_tab.innerHTML = `
-
-
${getTextString("PROFILES_PLUS_BROWSE_ALL_TAB_TITLE")}
-
${getTextString("DM_NEW")}
-
-
-
-
-
-
-
${getTextString("DISMISSIBLE_CONTENT_ROBLOX_DOORS_TITLE")}
- `;
- profiles_plus_tab.classList.add('roblox_doors_marketing_tab');
-
- profiles_plus_tab.addEventListener("mouseenter", () => {
- if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/12.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- } else if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/8.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- } else if (document.getElementById("dm-tab-preview-avatar-decoration").src == "https://cdn.yapper.shop/custom-collectibles/paper-beach/avatar-decorations/2.png") {
- document.getElementById("dm-tab-preview-avatar-decoration-container").innerHTML = `
-
- `;
- }
- });
- }
- }
- }
-
-
-
-
-
- function themeDarkChecked() {
- clearCurrentTheme()
- localStorage.sa_theme = "dark"
- document.body.classList.add('theme-dark');
- document.getElementById("theme-dark-button").classList.add('theme-selection-box-selected');
- }
-
- function themeMidnightChecked() {
- clearCurrentTheme()
- localStorage.sa_theme = "midnight"
- document.body.classList.add('theme-midnight');
- document.getElementById("theme-midnight-button").classList.add('theme-selection-box-selected');
- }
-
- function themeLightChecked() {
- clearCurrentTheme()
- localStorage.sa_theme = "light"
- document.body.classList.add('theme-light');
- document.getElementById("theme-light-button").classList.add('theme-selection-box-selected');
- }
-
- function themeNeonGreenChecked() {
- clearCurrentTheme()
- localStorage.sa_theme = "neongreen"
- document.body.classList.add('theme-neongreen');
- document.getElementById("theme-neongreen-button").classList.add('theme-selection-box-selected');
- }
-
- function themeNeonPurpleChecked() {
- clearCurrentTheme()
- localStorage.sa_theme = "neonpurple"
- document.body.classList.add('theme-neonpurple');
- document.getElementById("theme-neonpurple-button").classList.add('theme-selection-box-selected');
- }
-
- function clearCurrentTheme() {
- try {
- document.getElementById("theme-dark-button").classList.remove('theme-selection-box-selected');
- document.body.classList.remove('theme-dark');
- document.getElementById("theme-midnight-button").classList.remove('theme-selection-box-selected');
- document.body.classList.remove('theme-midnight');
- document.getElementById("theme-light-button").classList.remove('theme-selection-box-selected');
- document.body.classList.remove('theme-light');
- document.getElementById("theme-neongreen-button").classList.remove('theme-selection-box-selected');
- document.body.classList.remove('theme-neongreen');
- document.getElementById("theme-neonpurple-button").classList.remove('theme-selection-box-selected');
- document.body.classList.remove('theme-neonpurple');
- } catch (error) {
- }
- }
-
- function disabledExperimentForceRollout() {
- if (!localStorage.experiment_force_rollout) {
- localStorage.experiment_force_rollout = "true"
- } else if (localStorage.experiment_force_rollout != "true") {
- localStorage.experiment_force_rollout = "true"
- } else {
- localStorage.experiment_force_rollout = "false"
- }
- }
-
- function inShopIsChecked() {
- if (localStorage.fetch_collectibles_variants != "true") {
- localStorage.fetch_collectibles_variants = "true"
- }
- else {
- localStorage.fetch_collectibles_variants = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData(pageCheck());
- }
- }
-
- function reducedMotionChecked() {
- if (!localStorage.reduced_motion) {
- localStorage.reduced_motion = "true"
- } else if (localStorage.reduced_motion != "true") {
- localStorage.reduced_motion = "true"
- } else {
- localStorage.reduced_motion = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData(pageCheck());
- }
- }
-
- function optionsHasNitroChecked() {
- if (localStorage.is_nitro_user != "true") {
- localStorage.is_nitro_user = "true"
- } else {
- localStorage.is_nitro_user = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData(pageCheck());
- }
- }
-
- function disableBannerOverridesChecked() {
- if (localStorage.disable_client_banner_overrides != "true") {
- localStorage.disable_client_banner_overrides = "true"
- }
- else {
- localStorage.disable_client_banner_overrides = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData(pageCheck());
- }
- }
-
- function noBundlesInShopIsChecked() {
- if (localStorage.shop_have_no_bundles != "true") {
- localStorage.shop_have_no_bundles = "true"
- }
- else {
- localStorage.shop_have_no_bundles = "false"
- }
- if (typeof fetchData === 'function') {
- pageCheck();
- }
- }
-
- function openMobileModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = `
-
-
-
-
Looks like you're on mobile
-
Would you like to use the mobile client?
-
Yes
-
No
-
-
-
- `;
- }
-
- function openOptionsModal() {
- const options_modal = document.getElementById('modal-housing');
- options_modal.innerHTML = `
-
-
-
-
Options
-
-
-
-
Shop: Hide removed items
-
This will hide all categories that are not currently in the shop
-
-
-
-
Shop: Hide bundles
-
This will hide all bundles in the shop page
-
-
-
-
-
Close
-
-
-
- `;
-
- if (localStorage.fetch_collectibles_variants == "true") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.fetch_collectibles_variants == "none") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.items_in_shop != "true") {
- if (localStorage.items_in_shop != "none") {
- document.getElementById("is-in-shop-box-option").style.display = 'none';
- }
- }
-
-
- if (localStorage.shop_have_no_bundles == "true") {
- document.getElementById("no-bundles-in-shop-box").checked = true;
- }
- }
-
- function openDownloadsModal() {
- const downloads_modal = document.getElementById('modal-housing');
- downloads_modal.innerHTML = `
-
-
-
-
Manual Downloads
-
Experimental
-
-
-
- `;
-
- // Fetch the data from the API
- fetch(DOWNLOADABLE_DATA, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- // Call the function to display the data
- displayData(data);
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
- // Function to display the data in the HTML
- function displayData(data) {
- const content = document.getElementById('downloadables-output');
- const template = document.getElementById('downloadables-api-template');
-
- data.forEach(item => {
- // Clone the template
- const clone = template.content.cloneNode(true);
-
- // Fill in the name and summary
- clone.querySelector('.name').textContent = item.name;
- clone.querySelector('.summary').textContent = item.summary;
-
- // Add buttons for downloadables
- const downloadablesDiv = clone.querySelector('.downloadables');
- item.downloadables.forEach(downloadable => {
- const button = document.createElement('button');
- button.textContent = downloadable.name;
- button.classList.add('card-button');
- button.addEventListener('click', () => {
- window.open(downloadable.url, '_blank');
- });
- downloadablesDiv.appendChild(button);
- });
-
- // Append the cloned template to the content
- content.appendChild(clone);
- });
- }
-
- }
-
- function scrollToSKUOverrride(type) {
- if (type === "card") {
- const sku_id = document.getElementById("scroll-to-sku-id-override-input").value;
- document.getElementById("scroll-to-sku-id-override-button").disabled = true;
- document.getElementById("scroll-to-sku-id-override-button").style.backgroundColor = 'var(--button-danger-background)';
- setTimeout(() => {
- try {
- document.getElementById(sku_id).scrollIntoView({ behavior: "smooth" });
- }
- catch(error) {
- scrollToSKU(sku_id)
- }
- }, 10);
- document.getElementById(sku_id).classList.add("highlighted")
-
- let highlightedGlint = document.createElement("div");
-
- highlightedGlint.classList.add('shop-category-card-highlighted-glint');
-
- document.getElementById(sku_id).appendChild(highlightedGlint);
- setTimeout(() => {
- highlightedGlint.remove();
- document.getElementById(sku_id).classList.remove("highlighted");
- document.getElementById("scroll-to-sku-id-override-button").disabled = false;
- document.getElementById("scroll-to-sku-id-override-button").style.backgroundColor = '';
- }, 3000);
- } else if (type === "category") {
- const sku_id = document.getElementById("scroll-to-category-sku-id-override-input").value;
- document.getElementById("scroll-to-category-sku-id-override-button").disabled = true;
- document.getElementById("scroll-to-category-sku-id-override-button").style.backgroundColor = 'var(--button-danger-background)';
- setTimeout(() => {
- try {
- document.getElementById(sku_id).scrollIntoView({ behavior: "smooth" });
- }
- catch(error) {
- scrollToSKU(sku_id)
- }
- }, 10);
- document.getElementById(sku_id).classList.add("highlighted")
-
- let highlightedGlint = document.createElement("div");
-
- highlightedGlint.classList.add('shop-category-highlighted-glint');
-
- document.getElementById(sku_id).appendChild(highlightedGlint);
- setTimeout(() => {
- highlightedGlint.remove();
- document.getElementById(sku_id).classList.remove("highlighted");
- document.getElementById("scroll-to-category-sku-id-override-button").disabled = false;
- document.getElementById("scroll-to-category-sku-id-override-button").style.backgroundColor = '';
- }, 3000);
- }
- }
-
-
- let dev_topbar_container = document.createElement("div");
-
- dev_topbar_container.classList.add('dev-topbar-container');
- dev_topbar_container.id = 'dev-topbar-container';
-
- document.body.appendChild(dev_topbar_container);
-
- function openDevModal() {
- if (localStorage.dev == "true") {
-
-
- if (document.getElementById('dev-topbar-container').classList.contains('dev-topbar-container-expanded')) {
- document.getElementById('dev-topbar-container').classList.remove("dev-topbar-container-expanded");
- } else {
- document.getElementById('dev-topbar-container').classList.add("dev-topbar-container-expanded");
- document.getElementById('dev-topbar-container').innerHTML = `
-
${getTextString("OPTIONS_DEV_TITLE")}
-
-
-
${getTextString("OPTIONS_EXTRA_STAFF_NOTES")}
-
${getTextString("OPTIONS_EXTRA_STAFF_NOTES_2")}
-
${getTextString("OPTIONS_EXTRA_STAFF_NOTES_1")}
-
-
-
- ${getTextString("OPTIONS_DEV_OPEN_STAFF_DISCORD_SERVER")}
-
-
-
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST")}
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST_1")}
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST_2")}
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST_3")}
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST_4")}
-
${getTextString("OPTIONS_EXTRA_STAFF_TODO_LIST_5")}
-
-
-
-
-
${getTextString("OPTIONS_DEV_UNPUBLISHED_COLLECTIBLES")}
-
-
-
-
${getTextString("OPTIONS_DEV_UNPUBLISHED_PPLUS_ITEMS")}
-
-
-
-
${getTextString("OPTIONS_DEV_NO_SEEN_DISCORD_LOG_IN_OPTIONS_OPEN")}
-
-
-
-
-
- ${getTextString("OPTIONS_DEV_DISABLE_CLIENT_REWORK")}
- ${getTextString("OPTIONS_DEV_OPEN_NAMEPLATES_PAGE")}
-
-
-
-
${getTextString("OPTIONS_DEV_HIGHLIGHT_SKU_ID")}
-
-
-
- ${getTextString("OPTIONS_DEV_HIGHLIGHT_SKU_CARD")}
-
-
-
-
${getTextString("OPTIONS_DEV_HIGHLIGHT_CAT_SKU_ID")}
-
-
-
- ${getTextString("OPTIONS_DEV_HIGHLIGHT_SKU_CAT")}
-
- ${getTextString("APP_VERSION")}${tcbx926n29}
- `;
-
- if (localStorage.unreleased_discord_collectibles == "true") {
- document.getElementById("unpublished-collectibles-box").checked = true;
- }
-
- if (localStorage.unreleased_profiles_plus == "true") {
- document.getElementById("unpublished-pplus-items-box").checked = true;
- }
-
- if (localStorage.staff_dont_dismiss_discord_login == "true") {
- document.getElementById("dont-dismiss-discord-login-box").checked = true;
- }
- }
- } else {
- console.error('403 (Forbidden)')
- }
- }
-
- function disableClientRework() {
- localStorage.full_client_rework = "false"
- location.reload();
- }
-
- function setPageToNameplatePage() {
- setParams({page: 'nameplates'});
- location.reload();
- }
-
- function unreleasedDiscordCollectiblesToggle() {
- if (!localStorage.unreleased_discord_collectibles) {
- localStorage.unreleased_discord_collectibles = "true"
- } else if (localStorage.unreleased_discord_collectibles === "none") {
- localStorage.unreleased_discord_collectibles = "true"
- } else {
- localStorage.unreleased_discord_collectibles = "none"
- }
- fetchData(pageCheck());
- }
-
- function unreleasedPPlusItemsToggle() {
- if (!localStorage.staff_dont_dismiss_discord_login) {
- localStorage.staff_dont_dismiss_discord_login = "true"
- } else if (localStorage.unreleased_profiles_plus === "none") {
- localStorage.unreleased_profiles_plus = "true"
- } else {
- localStorage.unreleased_profiles_plus = "none"
- }
- fetchData(pageCheck());
- }
-
- function dontSetDiscordLoginDismissibleToSeenToggle() {
- if (!localStorage.staff_dont_dismiss_discord_login) {
- localStorage.staff_dont_dismiss_discord_login = "true"
- } else if (localStorage.staff_dont_dismiss_discord_login === "none") {
- localStorage.staff_dont_dismiss_discord_login = "true"
- } else {
- localStorage.staff_dont_dismiss_discord_login = "none"
- }
- }
-
- function testFetchAPI(fetcherName) {
- const endpoint = testFetchAPIList.find(api => api.name === fetcherName);
-
- const { rollout } = endpoint;
- const treatmentPicker = document.getElementById(`${fetcherName}_treatment_container`);
-
- if (fetcherName === "testfetch_testfetchnew") {
- url = api + "/" + "collectibles-shop";
- testFetchURL = new URL(url);
- testFetchURL.searchParams.append("tab", treatmentPicker.value);
- } else if (fetcherName === "testfetch_testfetcheffects") {
- url = api + "/" + "profile-effects";
- testFetchURL = new URL(url);
- testFetchURL.searchParams.append("tab", treatmentPicker.value);
- } else {
- url = api + "/" + treatmentPicker.value;
- testFetchURL = new URL(url);
- }
- testFetchURL.searchParams.append("is-test-fetch", "true");
- if (document.getElementById("test-fetch-include-no-sku-items-box").checked === true) {
- testFetchURL.searchParams.append("include-no-sku-items", "true");
- }
- if (document.getElementById("test-fetch-unpublished-collectibles-box").checked === true) {
- testFetchURL.searchParams.append("include-unpublished", "true");
- }
-
- fetch(testFetchURL, {
- method: "GET",
- headers: {
- "Password": api_password,
- "Authorization": discord_token,
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then((data) => {
- console.log(data);
- })
- .catch(error => {
- console.log(`Failed to test fetch: `, error);
- });
- }
-
- function openOldDevModal() {
- if (localStorage.dev == "true") {
- document.getElementById('modal-housing').innerHTML = `
-
-
-
-
${getTextString("OPTIONS_DEV_TITLE")}
-
${getTextString("OPTIONS_DEV_DESC")}
-
${getTextString("OPTIONS_DEV_CLOSE")}
-
${getTextString("OPTIONS_DEV_SAFE_MODE")}
-
-
-
Modals
-
-
-
Lost
-
modal no longer supported on client
-
Open
-
-
-
-
-
-
-
-
-
Local Storage Overrides
-
Refresh the page for changes to take effect
-
Delete All
-
-
-
Save
-
-
-
-
-
-
${getTextString("APP_VERSION")}${tcbx926n29}
-
-
-
${getTextString("OPTIONS_DEV_CLOSE")}
-
${getTextString("OPTIONS_DEV_SAFE_MODE")}
-
-
-
- `;
-
- displayLocalStorage();
- } else {
- console.error('403 (Forbidden)')
- }
- }
-
- function colorButtonsPerRollout() {
-
- if (localStorage.experiment_theme_picker == "two" || localStorage.experiment_theme_picker == "two_autorollout") {
- document.getElementById("2024-12_theme_picker-2").classList.add('newish-experiment-button-selected');
- }
-
- if (localStorage.experiment_theme_picker == "true" || localStorage.experiment_theme_picker == "true_autorollout") {
- document.getElementById("2024-12_theme_picker-1").classList.add('newish-experiment-button-selected');
- }
-
- if (localStorage.experiment_theme_picker == "false" || localStorage.experiment_theme_picker == "false_autorollout") {
- document.getElementById("2024-12_theme_picker-00").classList.add('newish-experiment-button-selected');
- }
-
-
- if (localStorage.profiles_plus_marketing_variants == "variant_1" || localStorage.profiles_plus_marketing_variants == "variant_1_autorollout") {
- document.getElementById("2024-12_profiles_plus_marketing_variants-1").classList.add('newish-experiment-button-selected');
- }
-
- if (localStorage.profiles_plus_marketing_variants == "false" || localStorage.profiles_plus_marketing_variants == "false_autorollout") {
- document.getElementById("2024-12_profiles_plus_marketing_variants-00").classList.add('newish-experiment-button-selected');
- }
-
-
-
- if (localStorage.collectibles_variants == "true" || localStorage.collectibles_variants == "true_autorollout") {
- document.getElementById("2024-11_collectibles_variants-1").classList.add('newish-experiment-button-selected');
- }
-
- if (localStorage.collectibles_variants == "false" || localStorage.collectibles_variants == "false_autorollout") {
- document.getElementById("2024-11_collectibles_variants-00").classList.add('newish-experiment-button-selected');
- }
-
-
-
-
- if (localStorage.recap_items_2024 == "true" || localStorage.recap_items_2024 == "true_autorollout") {
- document.getElementById("2024-11_recap-1").classList.add('newish-experiment-button-selected');
- }
-
- if (localStorage.recap_items_2024 == "false" || localStorage.recap_items_2024 == "false_autorollout") {
- document.getElementById("2024-11_recap-00").classList.add('newish-experiment-button-selected');
- }
- }
-
-
-
-
- function closeDevModal() {
- const dev_modal = document.getElementById('modal-housing');
- dev_modal.innerHTML = ``;
- }
-
- function closeMobileModal() {
- const mobile_modal = document.getElementById('modal-housing');
- mobile_modal.innerHTML = ``;
- }
-
- function closeLostModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = ``;
- }
-
-
-
-
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
-
-
- function turnOffDevMode() {
- localStorage.dev = "false"
- location.reload();
- }
-
- function dev() {
- localStorage.dev = "true"
- location.reload();
- }
-
-
-
-
- function themePicker2() {
- localStorage.experiment_theme_picker = "two"
- document.getElementById("2024-12_theme_picker-2").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-00").classList.remove('newish-experiment-button-selected');
- }
-
- function themePicker1() {
- localStorage.experiment_theme_picker = "true"
- document.getElementById("2024-12_theme_picker-2").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-00").classList.remove('newish-experiment-button-selected');
- }
-
- function themePicker00() {
- localStorage.experiment_theme_picker = "false"
- document.getElementById("2024-12_theme_picker-2").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-00").classList.add('newish-experiment-button-selected');
- }
-
- function themePicker0() {
- localStorage.experiment_theme_picker = "pleasesetautorollout"
- document.getElementById("2024-12_theme_picker-2").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_theme_picker-00").classList.remove('newish-experiment-button-selected');
- fetchExperimentRolloutData();
- }
-
-
- function profilesPlusMarketingVariants1() {
- localStorage.profiles_plus_marketing_variants = "variant_1"
- document.getElementById("2024-12_profiles_plus_marketing_variants-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-12_profiles_plus_marketing_variants-00").classList.remove('newish-experiment-button-selected');
- }
-
- function profilesPlusMarketingVariants00() {
- localStorage.profiles_plus_marketing_variants = "false"
- document.getElementById("2024-12_profiles_plus_marketing_variants-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_profiles_plus_marketing_variants-00").classList.add('newish-experiment-button-selected');
- }
-
- function profilesPlusMarketingVariants0() {
- localStorage.profiles_plus_marketing_variants = "pleasesetautorollout"
- document.getElementById("2024-12_profiles_plus_marketing_variants-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_profiles_plus_marketing_variants-00").classList.remove('newish-experiment-button-selected');
- fetchExperimentRolloutData();
- }
-
-
- function collectiblesVariants1() {
- localStorage.collectibles_variants = "true"
- document.getElementById("2024-11_collectibles_variants-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-11_collectibles_variants-00").classList.remove('newish-experiment-button-selected');
- }
-
- function collectiblesVariants00() {
- localStorage.collectibles_variants = "false"
- document.getElementById("2024-11_collectibles_variants-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_collectibles_variants-00").classList.add('newish-experiment-button-selected');
- }
-
- function collectiblesVariants0() {
- localStorage.collectibles_variants = "pleasesetautorollout"
- document.getElementById("2024-11_collectibles_variants-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_collectibles_variants-00").classList.remove('newish-experiment-button-selected');
- fetchExperimentRolloutData();
- }
-
-
-
- function recap2024Items1() {
- localStorage.recap_items_2024 = "true"
- document.getElementById("2024-11_recap-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-11_recap-00").classList.remove('newish-experiment-button-selected');
- }
-
- function recap2024Items00() {
- localStorage.recap_items_2024 = "false"
- document.getElementById("2024-11_recap-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_recap-00").classList.add('newish-experiment-button-selected');
- }
-
- function recap2024Items0() {
- localStorage.recap_items_2024 = "pleasesetautorollout"
- document.getElementById("2024-11_recap-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_recap-00").classList.remove('newish-experiment-button-selected');
- fetchExperimentRolloutData();
- }
-
-
-
-
- function disableClientReworkTrue() {
- localStorage.full_client_rework = "false"
- document.getElementById("2024-12_disable_client_rework-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_disable_client_rework-00").classList.add('newish-experiment-button-selected');
- location.reload();
- }
-
- function disableClientReworkFalse() {
- localStorage.full_client_rework = "true"
- document.getElementById("2024-12_disable_client_rework-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-12_disable_client_rework-00").classList.remove('newish-experiment-button-selected');
- location.reload();
- }
-
-
-
-
- function forceAllApiToFectchPrivateApiFalse() {
- localStorage.force_all_api_to_fectch_private_api = "none"
- document.getElementById("2024-12_force_all_api_to_fectch_private_api-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-12_force_all_api_to_fectch_private_api-2").classList.add('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
- function forceAllApiToFectchPrivateApiTrue() {
- localStorage.force_all_api_to_fectch_private_api = "true"
- document.getElementById("2024-12_force_all_api_to_fectch_private_api-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-12_force_all_api_to_fectch_private_api-2").classList.remove('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
-
-
-
- function overrideLeaksButtonHide() {
- localStorage.override_leaks_button = "none"
- document.getElementById("2024-11_override_leaks_button-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_override_leaks_button-2").classList.add('newish-experiment-button-selected');
- leaksCheck();
- }
-
- function overrideLeaksButtonShow() {
- localStorage.override_leaks_button = "true"
- document.getElementById("2024-11_override_leaks_button-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-11_override_leaks_button-2").classList.remove('newish-experiment-button-selected');
- leaksCheck();
- }
-
-
-
- function unreleasedDiscordCollectiblesFalse() {
- localStorage.unreleased_discord_collectibles = "none"
- document.getElementById("2024-11_unreleased_discord_collectibles-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-11_unreleased_discord_collectibles-2").classList.add('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
- function unreleasedDiscordCollectiblesTrue() {
- localStorage.unreleased_discord_collectibles = "true"
- document.getElementById("2024-11_unreleased_discord_collectibles-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-11_unreleased_discord_collectibles-2").classList.remove('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
-
-
-
- function unreleasedProfilesPlusItemsFalse() {
- localStorage.unreleased_profiles_plus = "none"
- document.getElementById("2024-09_profiles_plus-1").classList.remove('newish-experiment-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.add('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
- function unreleasedProfilesPlusItemsTrue() {
- localStorage.unreleased_profiles_plus = "true"
- document.getElementById("2024-09_profiles_plus-1").classList.add('newish-experiment-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.remove('newish-experiment-button-selected');
- fetchData(pageCheck());
- }
-
-
-
-
- function saveToLocalStorage() {
- // Get the values from the inputs
- const key = document.getElementById('keyInput').value;
- const value = document.getElementById('valueInput').value;
-
- // Save to local storage
- localStorage.setItem(key, value);
-
- // Refresh the display
- displayLocalStorage();
- }
-
- function displayLocalStorage() {
- // Get the container element
- const storageItems = document.getElementById('storageItems');
-
- // Clear the container
- storageItems.innerHTML = '';
-
- // Iterate over all items in local storage
- for (let i = 0; i < localStorage.length; i++) {
- const key = localStorage.key(i);
- const value = localStorage.getItem(key);
-
- // Create a container for each item
- const itemDiv = document.createElement('div');
-
- // Create editable input fields for key and value
- const keyInput = document.createElement('input');
- keyInput.type = 'text';
- keyInput.value = key;
- keyInput.disabled = true; // Disable key editing
- keyInput.className = 'dev-local-storage-input-2';
-
- const valueInput = document.createElement('input');
- valueInput.type = 'text';
- valueInput.value = value;
- valueInput.className = 'dev-local-storage-input-3';
-
- // Save button for each item
- const saveButton = document.createElement('button');
- saveButton.textContent = 'Update';
- saveButton.className = 'refresh-button';
- saveButton.onclick = function() {
- localStorage.setItem(key, valueInput.value);
- };
-
- // Delete button for each item
- const deleteButton = document.createElement('button');
- deleteButton.textContent = 'Delete';
- deleteButton.className = 'refresh-button';
- deleteButton.onclick = function() {
- localStorage.removeItem(key);
- displayLocalStorage(); // Refresh the display
- };
-
- // Append elements to the item div
- itemDiv.appendChild(deleteButton);
- itemDiv.appendChild(keyInput);
- itemDiv.appendChild(valueInput);
- itemDiv.appendChild(saveButton);
-
- // Append the item div to the container
- storageItems.appendChild(itemDiv);
- }
- }
-
-
- function triggerCrash() {
- if (localStorage.crash_count == null) {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "1") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_1")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "2") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_2")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "3") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_3")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "4") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_4")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "5") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_5")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "6") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_6")}
-
- `;
- crashCountIncrease()
- } else if (localStorage.crash_count == "7") {
- if (localStorage.dev == "true") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_EASTER_EGG_DEV")}
-
- `;
- } else {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_EASTER_EGG_7")}
-
- `;
- }
- crashCountIncrease()
- } else if (localStorage.crash_count == "8") {
- document.body.innerHTML = `
-
-
${getTextString("CRASH_UH_OH")}
-
${getTextString("CRASH_REFRESH")}
-
${getTextString("CRASH_SUPPORT")}
-
- `;
- }
- }
-
- window.addEventListener('error', (event) => {
- if (event.message.includes("is not defined")) {
- triggerCrash();
- }
- });
-
- function crashCountIncrease() {
- // Retrieve the counter from localStorage or initialize it to 0
- let crashCount = parseInt(localStorage.getItem('crash_count')) || 0;
-
- // Increment the counter
- crashCount++;
-
- // Store the updated counter back to localStorage
- localStorage.setItem('crash_count', crashCount);
- }
-
- function heartBeat() {
- fetch(api + HEARTBEAT_DATA, {
- method: "GET",
- headers: {
- "Token": api_token
- }
- })
- .then(response => response.json())
- .then(data => {
- console.log('sending heartbeat');
-
- if (isFirstHeartbeat === true && localStorage.ongoing_discord_event_version != data.ongoing_discord_events[0].version) {
-
- }
-
- if (app_version2 === "Dev") {
- if (app_version1 != data.latest_version_dev) {
- console.log(`${getTextString("HEARTBEAT_UPDATE_READY")}`)
-
- let update_button = document.createElement("div");
-
- update_button.style.position = 'absolute';
- update_button.style.marginLeft = '70px';
- update_button.style.marginTop = '-5px';
- update_button.innerHTML = `
-
- ${getTextString("HEARTBEAT_UPDATE_READY")}
-
- `;
-
-
- document.body.appendChild(update_button);
- }
- } else if (app_version2 === "Stable") {
- if (app_version1 != data.latest_version_stable) {
- console.log(`${getTextString("HEARTBEAT_UPDATE_READY")}`)
-
- let update_button = document.createElement("div");
-
- update_button.style.position = 'absolute';
- update_button.style.marginLeft = '70px';
- update_button.style.marginTop = '-5px';
- update_button.innerHTML = `
-
- ${getTextString("HEARTBEAT_UPDATE_READY")}
-
- `;
-
-
- document.body.appendChild(update_button);
- }
- }
- isFirstHeartbeat = false;
- })
- .catch(error => console.error('Error fetching data:', error));
- }
-
- let isFirstHeartbeat = true;
-
- if (localStorage.experiment_2025_03_heartbeat === "Treatment 1: Fetch once on startup") {
- heartBeat();
- } else if (localStorage.experiment_2025_03_heartbeat === "Treatment 2: Fetch every 60 seconds") {
- heartBeat();
- setInterval(heartBeat, 60000);
- }
-
- function copyNotice(type) {
- if (type === "copylink") {
- string = getTextString("SHOP_LINK_COPY_SUCCESS");
- } else if (type === "copysku") {
- string = getTextString("SHOP_SKU_ID_COPY_SUCCESS");
- } else if (type === "copyemoji") {
- string = getTextString("SHOP_EMOJI_COPY_SUCCESS");
- } else if (type === "logintrue") {
- string = getTextString("SHOP_DISCORD_LOGIN_SUCCESS");
- } else if (type === "loginfalse") {
- string = getTextString("SHOP_DISCORD_LOGIN_FAIL");
- } else {
- string = getTextString("SHOP_LINK_COPY_FAIL");
- console.warn('Invalid copyNotice')
- }
-
- let copyNotice = document.createElement("div");
-
- copyNotice.classList.add('copy-notice-container');
- copyNotice.innerHTML = `
-
${string}
- `;
-
- document.body.appendChild(copyNotice);
- setTimeout(() => {
- copyNotice.remove();
- }, 5000);
- }
-
- function scrollToSKU(sku_id, noscroll) {
- const itemSKUForScroll = params.get("itemSkuId");
- const justScrollSKU = params.get("scrollTo");
-
- if (itemSKUForScroll === sku_id) {
- setTimeout(() => {
- try {
- if (noscroll != "true") {
- document.getElementById(itemSKUForScroll).scrollIntoView({ behavior: "smooth" });
- }
- document.getElementById(sku_id).classList.add("highlighted")
-
- let highlightedGlint = document.createElement("div");
-
- highlightedGlint.classList.add('shop-category-highlighted-glint');
-
- document.getElementById(sku_id).appendChild(highlightedGlint);
- setTimeout(() => {
- highlightedGlint.remove();
- }, 3000);
- }
- catch(error) {
- scrollToSKU(sku_id)
- }
- }, 10);
- } else if (justScrollSKU === sku_id) {
- setTimeout(() => {
- try {
- if (noscroll != "true") {
- document.getElementById(justScrollSKU).scrollIntoView({ behavior: "smooth" });
- }
- document.getElementById(sku_id).classList.add("highlighted")
-
- let highlightedGlint = document.createElement("div");
-
- highlightedGlint.classList.add('shop-category-highlighted-glint');
-
- document.getElementById(sku_id).appendChild(highlightedGlint);
- setTimeout(() => {
- highlightedGlint.remove();
- removeParams('scrollTo');
- }, 3000);
- }
- catch(error) {
- scrollToSKU(sku_id)
- }
- }, 10);
- }
- }
-
- function openInDiscordShop(sku_id, type, from, unpublished_data, category_sku_id) {
- if (params.get("page") === "shop" && from === "card" && unpublished_data != "null" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_UNPUBLISHED_WARNING"));
- } else if (params.get("page") === "orbs" && from === "card" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_MISCELLANEOUS_WARNING"));
- } else if (params.get("page") === "leaks" && from === "card" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_UNRELEASED_WARNING"));
- } else if (params.get("page") === "miscellaneous" && from === "card" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_MISCELLANEOUS_WARNING"));
- } else if (category_sku_id === discord_categories.NAMEPLATE && from === "card" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_ROLLING_OUT_WARNING"));
- } else if (params.get("page") === "nameplates" && category_sku_id === discord_categories.NAMEPLATE_TEST && from === "card" && localStorage.dismissible_open_in_shop_notice != "Treatment 1: Seen") {
- createModal(getTextString("SHOP_MISCELLANEOUS_WARNING"));
- } else {
- location.href='https://discord.com/shop#itemSkuId=' + sku_id;
- }
-
- function createModal(string) {
- let modal = document.createElement("div");
-
- modal.classList.add('modalv2');
-
- modal.innerHTML = `
-
- `;
-
- document.body.appendChild(modal);
-
- setTimeout(() => {
- modal.classList.add('show');
- }, 1);
-
- let modal_back = document.createElement("div");
-
- modal_back.classList.add('modalv2-back');
- modal_back.id = 'modalv2-back';
-
- document.body.appendChild(modal_back);
-
- setTimeout(() => {
- modal_back.classList.add('show');
- }, 1);
-
-
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- }
- });
-
- modal.querySelector("[data-close-product-card-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
-
- modal.querySelector("[data-go-back-button]").addEventListener('click', () => {
- modal.classList.remove('show');
- modal_back.classList.remove('show');
- setTimeout(() => {
- modal.remove();
- modal_back.remove();
- }, 300);
- });
- }
- }
-
- function openAndDismiss(sku_id) {
- localStorage.dismissible_open_in_shop_notice = "Treatment 1: Seen";
- location.href='https://discord.com/shop#itemSkuId=' + sku_id;
- }
-
-
-
-
- function getTextString(variableName) {
- return window[variableName] || variableName; // Uses the variable if it exists, otherwise keeps ${TEXT}
- }
- // getTextString("")
- // ${getTextString("")}
-}
\ No newline at end of file
diff --git a/assets/2.js b/assets/2.js
deleted file mode 100644
index d0c6596..0000000
--- a/assets/2.js
+++ /dev/null
@@ -1,895 +0,0 @@
-
-let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/collectibles';
-
-// Function to clear the shop data
-function clearShopData() {
- const output = document.querySelector("[data-shop-output]");
- output.innerHTML = ''; // Clears the content of the shop category
- document.getElementById("shop-category-loading").classList.remove('hidden');
-}
-
-// Function to fetch and display shop data
-function fetchData() {
- document.getElementById("shop-category-loading").classList.remove('hidden');
- if (localStorage.items_in_shop_yes == "true") {
- apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/collectibles-in-shop';
- } else {
- apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/collectibles';
- }
-
- // Clear the previous data
- clearShopData();
-
- // Fetch new data
- fetch(apiUrl)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const template = document.querySelector("[data-shop-category-template]");
- const output = document.querySelector("[data-shop-output]");
-
- const category = template.content.cloneNode(true).children[0];
-
- const banner = category.querySelector("[data-shop-category-banner]");
- banner.id = user.sku_id;
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image]").classList.add('shop-logo-sway');
- }
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "UNOBTAINABLE";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / 1000);
-
- timerElement.textContent = `${days} DAYS LEFT IN SHOP`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
-
- if (localStorage.item_data_downloads == "two") {
- // Function to create a card
- function createCard(item, sku, price, priceNitro, emojiCopy, popular = false, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- if (localStorage.standard_cards == "true") {
- card.classList.add('shop-category-card-standard');
- } else {
- card.classList.add('shop-category-card');
- }
-
- card.id = sku;
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- if (localStorage.top_selling_item == "true") {
- if (popular == "true") {
- card.classList.add('shop-category-card-top-selling');
- }
- }
-
- if (localStorage.top_selling_item == "none") {
- if (popular == "true") {
- card.classList.add('shop-category-card-top-selling');
- }
- }
-
- if (localStorage.top_selling_item == "two") {
- card.classList.add('shop-category-card-top-selling');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
-
NEW
-
MOST POPULAR
- `;
-
- } else {
- card.innerHTML = `
-
-
-
-
NEW
-
MOST POPULAR
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- card.addEventListener('click', () => openModal(item, sku, price, priceNitro, emojiCopy));
-
- return card;
- }
- } else {
- // Function to create a card
- function createCard(item, sku, price, priceNitro, emojiCopy, popular = false, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- if (localStorage.standard_cards == "true") {
- card.classList.add('shop-category-card-standard');
- } else {
- card.classList.add('shop-category-card');
- }
-
- card.id = sku;
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- if (localStorage.top_selling_item == "true") {
- if (popular == "true") {
- card.classList.add('shop-category-card-top-selling');
- }
- }
-
- if (localStorage.top_selling_item == "none") {
- if (popular == "true") {
- card.classList.add('shop-category-card-top-selling');
- }
- }
-
- if (localStorage.top_selling_item == "two") {
- card.classList.add('shop-category-card-top-selling');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- Open In Shop
-
-
NEW
-
MOST POPULAR
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- Open In Shop
-
-
NEW
-
MOST POPULAR
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- card.addEventListener('click', () => openModal(item, sku, price, priceNitro, emojiCopy));
-
- return card;
- }
- }
-
-
- if (localStorage.item_data_downloads == "true") {
- // Function to open the modal
- function openModal(item, sku, price, priceNitro, emojiCopy) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
-
-
- const modalContent = `
-
-
-
SKU ID: ${sku}
-
${item.name}
-
${description}
-
-
-
-
Please note that not all collectibles have downloadable data, this button will most likely send you to a 404 page
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
- }
-
- if (localStorage.item_data_downloads == "two") {
- // Function to open the modal
- function openModal(item, sku, price, priceNitro, emojiCopy) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
-
-
- const modalContent = `
-
-
-
SKU ID: ${sku}
-
${item.name}
-
${description}
-
-
-
-
Please note that not all collectibles have downloadable data, this button will most likely send you to a 404 page
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
- }
-
- if (localStorage.item_data_downloads == "false") {
- // Function to open the modal
- function openModal(item, sku, price, priceNitro, emojiCopy) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
-
-
- const modalContent = `
-
-
-
SKU ID: ${sku}
-
${item.name}
-
${description}
-
-
-
- Open In Shop
- ${emojiCopy ? 'Copy P+ Emoji' : 'Request to P+'}
-
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
- }
-
- if (localStorage.item_data_downloads != "true") {
- if (localStorage.item_data_downloads != "false") {
- if (localStorage.item_data_downloads != "two") {
- // Function to open the modal
- function openModal(item, sku, price, priceNitro, emojiCopy) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
-
-
- const modalContent = `
-
-
-
SKU ID: ${sku}
-
${item.name}
-
${description}
-
-
-
- Open In Shop
- ${emojiCopy ? 'Copy P+ Emoji' : 'Request to P+'}
-
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
- }
- }
- }
-
-
- // Function to get image type based on item properties
- function getImageType(item) {
- // Check if the item has a type field and return appropriate ID
- if (item.item_type === 'deco') {
- return 'avatar-decoration'; // Change this to match your needs
- } else if (item.item_type === 'effect') {
- return 'profile-effect'; // Change this to match your needs
- } else if (item.bundled_products) {
- return 'bundle'; // For bundles
- }
- return 'unknown-type'; // Fallback for undefined types
- }
-
-
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const sku = product.sku_id || ""; // Get credits from the product
- const price = product.price || "";
- const priceNitro = product.price_nitro || "";
- const emojiCopy = product.emojiCopy || ""; // Get emojiCopy from the product
- const popular = product.popular || "";
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- cardHolder.appendChild(createCard(product, sku, price, priceNitro, emojiCopy, popular, true, isNew));
- } else {
- // Handle individual items
- product.items.forEach(item => {
- cardHolder.appendChild(createCard(item, sku, price, priceNitro, emojiCopy, popular, false, isNew));
- });
- }
- });
-
- // Append the category to the output section
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
-
- const kawaii_mode_banner = document.getElementById('1306330663213072494');
- if (kawaii_mode_banner) { // Check if element exists
- document.getElementById('1306330663213072494').innerHTML = `
-
-
- `;
- }
- const arcane_banner = document.getElementById('1303490165284802580');
- if (arcane_banner) { // Check if element exists
- document.getElementById('1303490165284802580').innerHTML = `
-
-
-
- `;
- }
- const dnd_banner = document.getElementById('1293373563494993952');
- if (dnd_banner) { // Check if element exists
- document.getElementById('1293373563494993952').innerHTML = `
-
-
-
-
The ultimate adventurer\u2019s pack.
-
- `;
- }
- const street_fighter_banner = document.getElementById('1285465421339693076');
- if (street_fighter_banner) { // Check if element exists
- document.getElementById('1285465421339693076').innerHTML = `
-
-
-
-
Hit the streets with Street Fighter.
-
- `;
- }
- const palworld_banner = document.getElementById('1252404112650407998');
- if (palworld_banner) { // Check if element exists
- document.getElementById('1252404112650407998').innerHTML = `
-
-
-
-
-
-
-
-
-
New island, new Pals, new adventures!
-
- `;
- }
- const valorant_banner = document.getElementById('1220513972189663413');
- if (valorant_banner) { // Check if element exists
- document.getElementById('1220513972189663413').innerHTML = `
-
-
-
-
-
-
-
-
- `;
- }
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-}
-
-// Function to copy the emoji to clipboard
-function copyEmoji(emoji) {
- navigator.clipboard.writeText(emoji).then(() => {
- alert('Emoji copied to clipboard!');
- }).catch(err => {
- console.error('Failed to copy emoji:', err);
- });
-}
-
-// Redirect to Google if emojiCopy is null
-function redirectToGoogle() {
- window.location.href = 'https://discord.gg/Mcwh7hGcWb';
-}
-
-// Initial data fetch when the page loads
-window.onload = fetchData;
\ No newline at end of file
diff --git a/assets/23.js b/assets/23.js
deleted file mode 100644
index 5d34fe1..0000000
--- a/assets/23.js
+++ /dev/null
@@ -1,682 +0,0 @@
-DISCORD_DISCLAIMER = "Discord is a registered trademark of Discord Inc. Shop Archives is not affiliated with, endorsed or sponsored by Discord Inc.";
-DOCUMENT_TITLE_SITE_NAME = " | Shop Archives";
-DOCUMENT_TITLE_WEBSITE_NAME = "Shop Archives";
-SHOP_DM_DEVIDER = "Shop";
-PROFILES_PLUS_DM_DEVIDER = "Profiles Plus";
-TOOLS_DM_DEVIDER = "Tools";
-DM_NEW = "NEW";
-OPTIONS_SIDEBAR_TITLE = "Options";
-OPTIONS_SIDEBAR_DOWNLOADS = "Downloads";
-OPTIONS_SIDEBAR_ACCESSIBILITY = "Accessibility";
-OPTIONS_SIDEBAR_APPEARANCE = "Appearance";
-OPTIONS_SIDEBAR_DISMISSIBLE_CONTENT = "Dismissible Content";
-OPTIONS_SIDEBAR_APPEARANCE_1 = "Default";
-OPTIONS_SIDEBAR_APPEARANCE_2 = "Custom";
-OPTIONS_SIDEBAR_APPEARANCE_THEME_1 = "Dark";
-OPTIONS_SIDEBAR_APPEARANCE_THEME_2 = "Midnight";
-OPTIONS_SIDEBAR_APPEARANCE_THEME_3 = "Light";
-OPTIONS_SIDEBAR_CURRENCY_PICKER = "Currency";
-OPTIONS_SIDEBAR_CURRENCY_PICKER_MORE = "Other currencies coming soon!";
-OPTIONS_SIDEBAR_REDUCED_MOTION = "Reduced Motion";
-OPTIONS_SIDEBAR_MARKETING_DOWNLOADS_HAVE_MOVED = "Marketing Downloads have moved.";
-OPTIONS_SIDEBAR_MARKETING_DOWNLOADS_HAVE_MOVED_BUTTON = "Take me there";
-OPTIONS_SIDEBAR_REDUCED_MOTION_BANNERS = "Disable Banner Overrides";
-OPTIONS_SIDEBAR_NITRO_DISCOUNT = "Display Nitro Discount";
-OPTIONS_SIDEBAR_NO_FORCE_ROLLOUT = "Disable Force Rollouts";
-OPTIONS_SIDEBAR_EXPERIMENTS_API_PASSWORD = "You may need to add your user password or discord auth token to the valid password list in the api backend.";
-OPTIONS_SIDEBAR_EXPERIMENTS_TEST_FETCH_API = "Fetch is output in console.";
-OPTIONS_SIDEBAR_DISCORD_HELP = "Discord Help Articles";
-OPTIONS_SIDEBAR_YAPPER_HELP = "Shop Archives";
-OPTIONS_SIDEBAR_DISCORD_HELP_SHOP = "Shop";
-OPTIONS_SIDEBAR_DISCORD_HELP_AVATAR_DECORATIONS = "Avatar Decorations";
-OPTIONS_SIDEBAR_DISCORD_HELP_PROFILE_EFFECTS = "Profile Effects";
-OPTIONS_SIDEBAR_DISCORD_HELP_HD_STREAMING_POTION = "HD Splash Potion";
-OPTIONS_SIDEBAR_DISCORD_HELP_HD_CONFETTI_POTION = "Confetti Potion";
-OPTIONS_SIDEBAR_YAPPER_DISCORD_SERVER = "Discord Server";
-OPTIONS_SIDEBAR_YAPPER_GITHUB = "Github";
-OPTIONS_SIDEBAR_YAPPER_BETA_TESTING = "Beta Testing";
-OPTIONS_EXTRA_STAFF_NOTES = "Staff Notes";
-OPTIONS_EXTRA_STAFF_NOTES_1 = "All api passwords will be reset at least once a month, new api passwords will be sent in the shop archives staff discord server.";
-OPTIONS_EXTRA_STAFF_NOTES_2 = "Either log in with Discord or use api password to access server side staff features.";
-OPTIONS_EXTRA_STAFF_TODO_LIST = "Staff TO-DO List";
-OPTIONS_EXTRA_STAFF_TODO_LIST_1 = "1. Finish the god damn strings (done)";
-OPTIONS_EXTRA_STAFF_TODO_LIST_2 = "2. Add custom theme support";
-OPTIONS_EXTRA_STAFF_TODO_LIST_3 = "3. Update options system again";
-OPTIONS_EXTRA_STAFF_TODO_LIST_4 = "4. Add discord integration for profile (done)";
-OPTIONS_EXTRA_STAFF_TODO_LIST_5 = "5. Update/Fix Profiles Plus";
-OPTIONS_EXTRA_PROFILE = "Profile";
-OPTIONS_EXTRA_PROFILE_DESC = "Your Profile will be seen around the website.";
-OPTIONS_EXTRA_PROFILE_DISCORD = "Discord Settings";
-OPTIONS_EXTRA_PROFILE_DISCORD_SUMMARY = "Log in with Discord to keep your profile up to date on Shop Archives!";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGIN = "Log in with Discord";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGGED_IN_AS = "Logged in as: ";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT = "Log Out";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_1 = "Holup!";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_2 = "Make sure to deauthorise the Shop Archives App in Discord if you fully want to remove Shop Archives from your Discord account.";
-OPTIONS_EXTRA_PROFILE_DISCORD_LOGOUT_3 = "Log Out";
-OPTIONS_EXTRA_PROFILE_CHANGE_USERNAME = "Username";
-OPTIONS_EXTRA_PROFILE_CHANGE_BANNER_COLOR = "Banner Color";
-OPTIONS_EXTRA_PROFILE_CHANGE_AVATAR = "Upload Avatar";
-OPTIONS_EXTRA_PROFILE_REMOVE_AVATAR = "Remove Avatar";
-OPTIONS_EXTRA_PROFILE_CHANGE_BANNER = "Upload Banner";
-OPTIONS_EXTRA_PROFILE_REMOVE_BANNER = "Remove Banner";
-OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG = "File too large!";
-OPTIONS_EXTRA_PROFILE_FILE_TOO_BIG_SUMMARY = "The file you uploaded is too large.";
-OPTIONS_EXTRA_PROFILE_ERROR_1 = "Cannot edit profile when logged in.";
-OPTIONS_EXTRA_PROFILE_ERROR_2 = "Your profile is synced with your Discord profile.";
-OPTIONS_EXTRA_PROFILE_ERROR_3 = "Preview:";
-OPTIONS_EXTRA_PROFILE_ERROR_BUTTON = "Log Out";
-OPTIONS_EXTRA_PROFILE_RESYNC = "Resync Profiles";
-OPTIONS_DEV_TITLE = "Dev Tools";
-OPTIONS_DEV_DESC = "Greetings Shop Archives Staff and/or Dataminer! This model has everything only available for developers, only use this if you know what you're doing. Don't break anything :)";
-OPTIONS_DEV_CLOSE = "Close";
-OPTIONS_DEV_SAFE_MODE = "Safe Mode";
-OPTIONS_DEV_UNPUBLISHED_COLLECTIBLES = "Shop: Include Unpublished Collectibles";
-OPTIONS_DEV_UNPUBLISHED_PPLUS_ITEMS = "PPlus: Include Unpublished Items";
-OPTIONS_DEV_NO_SEEN_DISCORD_LOG_IN_OPTIONS_OPEN = "Don't set login dismiss when opening options";
-OPTIONS_DEV_DISABLE_CLIENT_REWORK = "Go back to old client";
-OPTIONS_DEV_OPEN_NAMEPLATES_PAGE = "Open Nameplates page";
-OPTIONS_DEV_OPEN_STAFF_DISCORD_SERVER = "Open Discord Server";
-OPTIONS_DEV_HIGHLIGHT_SKU_CARD = "Higlight Card";
-OPTIONS_DEV_HIGHLIGHT_SKU_ID = "Higlight SKU ID";
-OPTIONS_DEV_HIGHLIGHT_SKU_CAT = "Higlight Category";
-OPTIONS_DEV_HIGHLIGHT_CAT_SKU_ID = "Higlight SKU ID";
-HOME_PAGE_404_ERROR = "Error: 404 Not Found";
-HOME_PAGE_403_ERROR = "Error: 404 Not Found";
-FEATURED_TAB_TITLE = "Featured";
-FEATURED_TAB_PAGE_TITLE = "Featured";
-FEATURED_TAB_DOCUMENT_TITLE = "Featured";
-RECAP_2024_TAB_TITLE = "2025 Recap";
-RECAP_2024_TAB_PAGE_TITLE = "2025 Recap";
-RECAP_2024_TAB_DOCUMENT_TITLE = "2025 Recap";
-SHOP_TAB_TITLE = "Shop All";
-SHOP_TAB_PAGE_TITLE = "Shop > Shop All";
-SHOP_TAB_DOCUMENT_TITLE = "Shop All";
-ORB_SHOP_TAB_TITLE = "Orbs Exclusives";
-ORB_SHOP_TAB_PAGE_TITLE = "Shop > Orbs Exclusives";
-ORB_SHOP_TAB_DOCUMENT_TITLE = "Orbs Exclusives";
-LEAKS_TAB_TITLE = "Leaks";
-LEAKS_TAB_PAGE_TITLE = "Shop > Leaks";
-LEAKS_TAB_DOCUMENT_TITLE = "Leaks";
-NAMEPLATES_TAB_PAGE_TITLE = "Shop > Nameplates";
-NAMEPLATES_TAB_DOCUMENT_TITLE = "Nameplates";
-POTIONS_TAB_TITLE = "Potions";
-POTIONS_TAB_PAGE_TITLE = "Shop > Potions";
-POTIONS_TAB_DOCUMENT_TITLE = "Potions";
-MISCELLANEOUS_TAB_TITLE = "Miscellaneous";
-MISCELLANEOUS_TAB_PAGE_TITLE = "Shop > Miscellaneous";
-MISCELLANEOUS_TAB_DOCUMENT_TITLE = "Miscellaneous";
-MARKETING_TAB_TITLE = "Marketing";
-MARKETING_TAB_PAGE_TITLE = "Shop > Marketing";
-MARKETING_TAB_DOCUMENT_TITLE = "Marketing";
-PROFILES_PLUS_TAB_TITLE = "Profiles Plus";
-PROFILES_PLUS_TAB_PAGE_TITLE = "Profiles Plus";
-PROFILES_PLUS_TAB_DOCUMENT_TITLE = "Profiles Plus";
-PROFILES_PLUS_FEATURED_TAB_TITLE = "Featured";
-PROFILES_PLUS_FEATURED_TAB_PAGE_TITLE = "Profiles Plus > Featured";
-PROFILES_PLUS_FEATURED_TAB_DOCUMENT_TITLE = "Featured";
-PROFILES_PLUS_BROWSE_ALL_TAB_TITLE = "Browse All";
-PROFILES_PLUS_BROWSE_ALL_TAB_PAGE_TITLE = "Profiles Plus > Browse All";
-PROFILES_PLUS_BROWSE_ALL_TAB_DOCUMENT_TITLE = "Browse All";
-PUBLISHED_LISTINGS_TAB_TITLE = "Published Listings";
-PUBLISHED_LISTINGS_TAB_PAGE_TITLE = "Tools > Published Listings";
-PUBLISHED_LISTINGS_TAB_DOCUMENT_TITLE = "Published Listings";
-ORB_CONVERTER_TAB_TITLE = "Orb Converter";
-ORB_CONVERTER_TAB_PAGE_TITLE = "Tools > Orb Converter";
-ORB_CONVERTER_TAB_DOCUMENT_TITLE = "Orb Converter";
-ITEM_DEBUG_TAB_TITLE = "api v1 Item Tool";
-ITEM_DEBUG_TAB_PAGE_TITLE = "Tools > api v1 Item Tool";
-ITEM_DEBUG_TAB_DOCUMENT_TITLE = "api v1 Item Tool";
-
-ITEM_SEARCH_INPUT_PLACEHOLDER = "Search Name or SKU ID";
-
-
-
-
-QUICK_INFO_PAGE_TITLE = "Quick Info";
-SHOP_NOT_LOAD_ERROR_1 = "Well, this is awkward.";
-SHOP_NOT_LOAD_ERROR_2 = "Hmmm, we weren’t able to load the shop. Check back later.";
-SHOP_NOT_LOAD_ERROR_3 = "Quick Info failed to load.";
-SHOP_NO_LEAKS_ERROR_1 = "Sorry, no leaks.";
-SHOP_NO_LEAKS_ERROR_2 = "The reason this page did not load is most likely because there are no leaks at the moment, please try again later.";
-SHOP_NOT_LOAD_ERROR = "Error: ";
-SHOP_NOT_LOAD_ERROR_RELOAD = "Reload";
-SHOP_CATEGORY_SHOP_THE_COLLECTION_1 = "Shop the ";
-SHOP_CATEGORY_SHOP_THE_COLLECTION_2 = " Collection";
-SHOP_CATEGORY_BROWSE_THE_COLLECTION_1 = "Browse the ";
-SHOP_CATEGORY_BROWSE_THE_COLLECTION_2 = " Collection";
-SHOP_CATEGORY_NOT_IN_STORE = "NOT IN STORE";
-SHOP_CATEGORY_DAYS_LEFT_IN_STORE = " DAYS LEFT IS SHOP";
-SHOP_CATEGORY_MODAL_ITEM_COUNT = "Number of items in category: ";
-SHOP_CATEGORY_MODAL_ASSETS = "Assets";
-SHOP_CATEGORY_MODAL_ASSETS_SHOW = "Assets:";
-SHOP_CATEGORY_MODAL_ASSETS_ID = "ID: ";
-SHOP_CATEGORY_MODAL_ASSETS_BANNER = "Banner (banner):";
-SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_1 = "Banner Asset Static (banner_asset.static):";
-SHOP_CATEGORY_MODAL_ASSETS_BANNER_ASSET_2 = "Banner Asset Animated (banner_asset.animated):";
-SHOP_CATEGORY_MODAL_ASSETS_LOGO = "Logo (logo):";
-SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BG = "Mobile Background (mobile_bg):";
-SHOP_CATEGORY_MODAL_ASSETS_PDP_BG = "Product Detail Page Background (pdp_bg):";
-SHOP_CATEGORY_MODAL_ASSETS_SUCCESS_MODAL_BG = "Success Modal Background (success_modal_bg):";
-SHOP_CATEGORY_MODAL_ASSETS_MOBILE_BANNER = "Mobile Banner (mobile_banner):";
-SHOP_CATEGORY_MODAL_ASSETS_FEATURED_BLOCK = "Featured Block (featured_block):";
-SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER = "Hero Banner (hero_banner):";
-SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_1 = "Hero Banner Asset Static (hero_banner_asset.static):";
-SHOP_CATEGORY_MODAL_ASSETS_HERO_BANNER_ASSET_2 = "Hero Banner Asset Animated (hero_banner_asset.animated):";
-SHOP_CATEGORY_MODAL_ASSETS_WIDE_BANNER = "Wide Banner (wide_banner):";
-SHOP_CATEGORY_MODAL_ASSETS_HERO_LOGO = "Hero Logo (hero_logo):";
-SHOP_CATEGORY_MODAL_ASSETS_CATEGORY_BG = "Category Background (category_bg):";
-SHOP_CATEGORY_MODAL_ASSETS_CONDENSED_BANNER_LEFT = "Condensed Banner Left (condensed_banner_left):";
-SHOP_CATEGORY_MODAL_ASSETS_CONDENSED_BANNER_RIGHT = "Condensed Banner Right (condensed_banner_right):";
-SHOP_CATEGORY_MODAL_SKU_ID = "SKU ID: ";
-FAILED_TO_LOAD_ITEM_CARD_ERROR = "Failed to load item";
-CARD_REQUEST_PPLUS_EMOJI_TITLE = "Request item in our Discord server";
-CARD_REQUEST_PPLUS_EMOJI = "Request to P+";
-CARD_REQUEST_PPLUS_EMOJI_v2 = "Request";
-CARD_COPY_PPLUS_EMOJI_TITLE = "Copy P+ emoji to clipboard";
-CARD_COPY_PPLUS_EMOJI = "Copy P+ Emoji";
-CARD_COPY_PPLUS_EMOJI_V2 = "Copy Emoji";
-CARD_PPLUS_ERROR_TITLE = "There was an error fetching emojiCopy";
-CARD_PPLUS_ERROR = "Error";
-CARD_FAILED_TO_LOAD_ITEM_ERROR = "Failed To Load Item";
-CARD_DOWNLOAD_MARKETING_DATA = "Download Marketing Data";
-CARD_MARKETING_GO_TO_CATEGORY = "Go to category";
-CARD_MARKETING_SHOP_TAB_PREVIEW = "Shop";
-CARD_MARKETING_SHOP_TAB_PREVIEW_TEXT = "Shop tab preview:";
-CARD_MARKETING_SHOP_TAB_PREVIEW_TITLE = "Shop tab preview";
-CARD_OPEN_IN_SHOP = "Open In Shop";
-CARD_OPEN_IN_SHOP_V2 = "Open";
-CARD_OPEN_IN_SHOP_TITLE = "Open this item in the Discord Shop";
-CARD_COPU_SKU_ID = "Copy SKU";
-CARD_COPU_SKU_ID_TITLE = "Copy this items SKU ID";
-CARD_OPEN_SUPPORT_ARTICLE = "Open Support Article";
-CARD_OPEN_SUPPORT_ARTICLE_TITLE = "Open this Potion's support article";
-CARD_TYPE_PLUS_MORE_TITLE = "Plus More...";
-CARD_TYPE_PLUS_MORE_DESC = "There are more items in this category that are coming soon.";
-CARD_TYPE_EXTERNAL_SKU_ERROR = "item type 3000 (EXTERNAL_SKU) is not yet defined on the client, please make sure you're up to date";
-CARD_TYPE_NAMEPLATE_ERROR = "item type 2 (NAMEPLATE) is not yet defined on the client, please make sure you're up to date";
-CARD_TYPE_NAMEPLATE_PPLUS_ERROR = "item type 2 (NAMEPLATE) is not yet made for profiles plus, please make sure you're up to date";
-CARD_TYPE_BUNDLE_TITLE = "Bundle Includes: ";
-CARD_TYPE_BUNDLE_TITLE_DECO = " Decoration & ";
-CARD_TYPE_BUNDLE_TITLE_EFFECT = " Profile Effect";
-CARD_NEW_TAG = "NEW";
-CARD_NEW_COLORS_TAG = "NEW COLORS";
-CARD_ORB_EXCLUSIVE_TAG = "ORBS EXCLUSIVES";
-CARD_UNPUBLISHED_TAG = "OFF SALE";
-CARD_LEAKED_TAG = "NEW LEAKS";
-CARD_UNPUBLISHED_COUNTDOWN_TAG = " DAYS LEFT IN SHOP";
-CARD_EXPIRED_TAG = "EXPIRED";
-CARD_EXPIRED_COUNTDOWN_TAG = "EXPIRES IN ";
-CARD_EXPIRED_COUNTDOWN_TAG_DAYS = "D ";
-CARD_EXPIRED_COUNTDOWN_TAG_HOURS = "H";
-CARD_LEFT_TO_REQUEST_COUNTDOWN_TAG = " DAYS LEFT TO REQUEST";
-CARD_PUBLISHING_TAG = "PUBLISHING...";
-CARD_PUBLISHING_COUNTDOWN_TAG_DAYS = "D ";
-CARD_PUBLISHING_COUNTDOWN_TAG_HOURS = "H";
-CARD_PPLUS_MADE_BY = "Made By: ";
-CARD_SHOP_MARKETING_ID = "Version ID: ";
-SHOP_REVIEWS_TITLE = "Reviews (Beta):";
-SHOP_REVIEWS_LOADING = "Loading Reviews...";
-SHOP_REVIEWS_NONE_TITLE = "No reviews yet.";
-SHOP_REVIEWS_NONE_DESC = "This item has no reviews";
-SHOP_REVIEWS_NONE_BE_THE_FIRST = "Be the first to review this item!";
-SHOP_REVIEWS_NO_ACCESS_TITLE = "Missing Access";
-SHOP_REVIEWS_NO_ACCESS_DESC = "You do not have permission to see the reviews of this item!";
-SHOP_REVIEWS_ERROR_TITLE = "Error";
-SHOP_REVIEWS_ERROR_DESC = "Check console for more details";
-SHOP_REVIEWS_NAMETAG_MODERATOR = "MODERATOR";
-SHOP_REVIEWS_NAMETAG_SPECIAL = "ILL PUT SOMETHING HERE LATER";
-SHOP_SHARE_DISCORD_LINK = "Copy Discord Link";
-SHOP_DOWNLOAD_DATA = "Download Data";
-SHOP_VIEW_RAW_DATA = "View Raw";
-SHOP_LINK_COPY_SUCCESS = "Link Copied";
-SHOP_SKU_ID_COPY_SUCCESS = "SKU ID Copied";
-SHOP_EMOJI_COPY_SUCCESS = "Emoji Copied";
-SHOP_DISCORD_LOGIN_SUCCESS = "Successfully logged in";
-SHOP_DISCORD_LOGIN_FAIL = "Failed to Log In";
-SHOP_LINK_COPY_FAIL = "Failed to Copy";
-SHOP_NAMEPLATE_WARNING_NOTICE_1 = "Nameplates are currently in a rollout, very few people can see them in the Discord shop.";
-SHOP_NAMEPLATE_WARNING_NOTICE_2 = "Nameplates from this category can no longer be purchased.";
-SHOP_UNPUBLISHED_WARNING = "This item has an unpublished date and might not show up in the Discord shop.";
-SHOP_UNRELEASED_WARNING = "This item has not released yet and will not show up in the Discord shop unless you know what you're doing.";
-SHOP_MISCELLANEOUS_WARNING = "This is a miscellaneous item and will not show up in the Discord shop unless you know what you're doing.";
-SHOP_ROLLING_OUT_WARNING = "This item is part of a rollout and will not show up in the Discord shop unless you have the rollout.";
-SHOP_MODAL_UNPUBLISHED_WARNING_CONTINUE = "Continue";
-SHOP_MODAL_UNPUBLISHED_WARNING_CONTINUE2 = "Continue and don't show again";
-SHOP_MODAL_UNPUBLISHED_WARNING_GO_BACK = "Go Back";
-CRASH_UH_OH = "Uh Oh! Looks like the app has crashed.";
-CRASH_REFRESH = "We have no idea what you did but you did something bad, refresh and don't do it again.";
-CRASH_SUPPORT = "If this keeps happening, contact support.";
-CRASH_EASTER_EGG_1 = "If this keeps happening, contact support or DON'T DO IT AGAIN!";
-CRASH_EASTER_EGG_2 = "I'm Serious, stop crashing my app.";
-CRASH_EASTER_EGG_3 = "You just don't know when to quit do you?";
-CRASH_EASTER_EGG_4 = "Do you want something from me?";
-CRASH_EASTER_EGG_5 = "What do you achieve by crashing my app so much? Honestly...";
-CRASH_EASTER_EGG_6 = "Crash my app one more time and I'll make you regret it...";
-CRASH_EASTER_EGG_7 = "I know exactly what you did.";
-CRASH_EASTER_EGG_DEV = "Oh! You're a developer..? I'm so sorry, you're just testing stuff.. Well, go about your day.";
-HEARTBEAT_UPDATE_READY = "Update Ready!";
-LOREM_IPSUM_LONG = "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.";
-LOREM_IPSUM = "Lorem ipsum";
-APP_VERSION = "App Version: ";
-
-
-
-
-// Account Creator
-
-ACCOUNT_CREATOR_BASIC_HEADER = "Basic";
-ACCOUNT_CREATOR_STANDARD_HEADER = "Standard";
-
-ACCOUNT_CREATOR_BASIC_LOG_IN_TITLE = "Basic Log In";
-ACCOUNT_CREATOR_BASIC_LOG_IN_DESC = "Keep things simple.";
-
-ACCOUNT_CREATOR_STANDARD_LOG_IN_TITLE = "Standard Log In";
-ACCOUNT_CREATOR_STANDARD_LOG_IN_DESC = "Full time Shop Archives user.";
-
-ACCOUNT_CREATOR_PERKS_1 = "Preview your Discord profile across the website.";
-ACCOUNT_CREATOR_PERKS_2 = "Write reviews for categories.";
-ACCOUNT_CREATOR_PERKS_3 = "More user settings.";
-ACCOUNT_CREATOR_PERKS_4 = "Beta Program (Early access to new features).";
-
-ACCOUNT_CREATOR_LOGIN_DISCLAIMER1 = "Discord will log you out automatically.";
-ACCOUNT_CREATOR_LOGIN_DISCLAIMER2 = "Log me out after";
-
-ACCOUNT_CREATOR_DISCLAIMER = "By clicking 'Log In', you agree to the Shop Archives ";
-ACCOUNT_CREATOR_DISCLAIMER_PRIVACY_POLICY = "Privacy Policy.";
-
-
-// Cateogry Modal
-
-SHOP_CATEGORY_MODAL_ASSETS_TAB = "Assets";
-SHOP_CATEGORY_MODAL_REVIEWS_TAB = "Reviews";
-SHOP_CATEGORY_MODAL_REVIEWS_BETA_TAB = "BETA";
-SHOP_CATEGORY_MODAL_REWARDS_TAB = "XP Rewards";
-SHOP_CATEGORY_MODAL_REWARDS_NEW_TAB = "NEW";
-
-SHOP_CATEGORY_MODAL_REVIEWS_LOADING = "Loading Reviews...";
-SHOP_CATEGORY_MODAL_REVIEWS_NONE = "No Reviews yet.";
-SHOP_CATEGORY_MODAL_REVIEWS_DISABLED = "Reviews have been disabled for this category.";
-SHOP_CATEGORY_MODAL_REVIEWS_UNAVAILABLE = "Reviews have been temporarily disabled (Down for maintenance).";
-
-SHOP_CATEGORY_MODAL_REVIEWS_ERROR = "There was an error loading reviews";
-
-SHOP_CATEGORY_MODAL_REVIEWS_WRITE = "Write a review for ";
-SHOP_CATEGORY_MODAL_REVIEWS_EDIT = "Edit your review for ";
-SHOP_CATEGORY_MODAL_REVIEWS_LOGIN = "You must have a Standard account to write reviews...";
-
-SHOP_CATEGORY_MODAL_REVIEWS_DISCLAIMER = "By making a review, you agree to the Shop Archives ";
-SHOP_CATEGORY_MODAL_REVIEWS_DISCLAIMER_PRIVACY_POLICY = "Privacy Policy.";
-
-SHOP_CATEGORY_MODAL_NAMETAG_MODERATOR = "ADMIN";
-SHOP_CATEGORY_MODAL_NAMETAG_SYSTEM = "SYSTEM";
-
-SHOP_CATEGORY_MODAL_NAMETAG_SYSTEM_TITLE = "Official Shop Archives Message";
-
-SHOP_CATEGORY_MODAL_REVIEWS_WARNING = "Do NOT ask questions about nameplates in your review, your review will be deleted and you will be banned from posting reviews! Please report any reviews that break this rule.";
-SHOP_CATEGORY_MODAL_REVIEWS_OVERRIDE_WARNING = "All review text has been overridden locally";
-
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_HEADER = "Report Review";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_SUMMARY = "Please select the option that best describes the problem.";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_PREVIEW = "You are reporting the following review:";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_1 = "Inappropriate or Sexual content";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_2 = "Abuse or Harassment";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_3 = "Bypassing Language Filter";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_4 = "Spam, Advertisements or Begging";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_4_SUMMARY = "If multiple reviews contain the same or similar content, please do not report all of them.";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_5 = "Other";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_DISCLAIMER = "By submitting this report you agree that it is truthful and not a duplicate report.";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_DISCLAIMER1 = "False reports can get you banned from making future reviews.";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_REPORT = "Report";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_REMOVE_REPORT = "Remove Report";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_CANCEL = "Cancel";
-
-SHOP_CATEGORY_MODAL_REVIEWS_DELETE_HOVER = "Delete Review";
-SHOP_CATEGORY_MODAL_REVIEWS_REPORT_HOVER = "Report Review";
-
-
-SHOP_CATEGORY_MODAL_REVIEWS_PPLUS_WARNING = "You cannot review Profiles Plus categories";
-
-// Themes
-
-THEME_PICKER_V2_LIGHT = "Light";
-THEME_PICKER_V2_DARK = "Dark";
-THEME_PICKER_V2_MIDNIGHT = "Midnight";
-
-THEME_PICKER_V2_BLUE = "Blue";
-THEME_PICKER_V2_RED = "Red";
-THEME_PICKER_V2_GREEN = "Green";
-
-THEME_PICKER_V2_CUSTOM = "Edit Custon CSS";
-
-
-// Modal v3
-
-// Headers
-
-MODAL_V3_TAB_HEADER_USER_SETTINGS = "USER SETTINGS";
-MODAL_V3_TAB_HEADER_SITE_SETTINGS = "APP SETTINGS";
-MODAL_V3_TAB_HEADER_XP_PERKS = "XP PERKS";
-MODAL_V3_TAB_HEADER_STAFF_ONLY = "DEVELOPER ONLY";
-
-// Tabs
-
-MODAL_V3_TAB_TEXT_ACCOUNT = "Account";
-MODAL_V3_TAB_TEXT_PROFILE = "Profile";
-MODAL_V3_TAB_TEXT_REVIEWS = "Reviews";
-MODAL_V3_TAB_TEXT_WARNINGS = "Warnings";
-
-MODAL_V3_TAB_TEXT_APPEARANCE = "Appearance";
-MODAL_V3_TAB_TEXT_ACCESSIBILITY = "Accessibility";
-
-MODAL_V3_TAB_TEXT_XP_EVENTS = "Events";
-MODAL_V3_TAB_TEXT_XP_GENERAL = "Shop";
-MODAL_V3_TAB_TEXT_XP_INVENTORY = "Inventory";
-
-MODAL_V3_TAB_TEXT_EXPERIMENTS = "Experiments";
-MODAL_V3_TAB_TEXT_DISMISSIBLE_CONTENT = "Dismissible Content";
-MODAL_V3_TAB_TEXT_API_TEST_FETCH = "API Testing";
-MODAL_V3_TAB_TEXT_CLAIMABLES_PURCHASE = "Claimables Purchase Test";
-MODAL_V3_TAB_TEXT_REVIEWS_DATABASE = "Reviews Panel";
-MODAL_V3_TAB_TEXT_LOCAL_STORAGE = "Local Storage";
-MODAL_V3_TAB_TEXT_MISC = "Miscellaneous";
-
-MODAL_V3_TAB_TEXT_LOG_IN = "Log In with Discord";
-MODAL_V3_TAB_TEXT_LOG_OUT = "Log Out";
-
-// Pages
-
-// Account
-
-MODAL_V3_TAB_ACCOUNT_HEADER = "Account";
-
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_HEADER = "Discord Account";
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_SUMMARY = "The Discord account linked to Shop Archives.";
-
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_NOT_LOGGED_IN_HEADER = "You are curently not logged in.";
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_NOT_LOGGED_IN_SUMMARY = "Log in with Discord to view your account details.";
-
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_UNAVAILABLE_HEADER = "Account Settings Temporarily Unavailable";
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_UNAVAILABLE_SUMMARY = "We are currently updating the account system, please use the new Profile tab if you want to change your profile.";
-
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_DISPLAY_NAME = "Display Name";
-MODAL_V3_TAB_ACCOUNT_DISCORD_ACCOUNT_USERNAME = "Username";
-
-MODAL_V3_TAB_ACCOUNT_LOGIN_WITH_DISCORD_BUTTON = "Log In with Discord";
-
-// Profile
-
-MODAL_V3_TAB_PROFILE_HEADER = "Profile";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_HEADER = "Edit Profile";
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_SUMMARY = "Your Profile will be seen around the website (only visible to you).";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_LOGGED_IN_TITLE = "You are logged in!";
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_LOGGED_IN_SUMMARY = "You will need to resync profiles if you want to revert back to your Discord profile.";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_CHANGE_DISPLAY_NAME_HEADER = "Display Name / Username";
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_CHANGE_DISPLAY_NAME_PLACEHOLDER = "Please Enter A Display Name";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_CHANGE_AVATAR_HEADER = "Change Avatar";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_CHANGE_BANNER_HEADER = "Change Banner";
-
-MODAL_V3_TAB_PROFILE_DISCORD_PROFILE_CHANGE_BANNER_COLOR_HEADER = "Banner Color";
-
-// Warning
-
-MODAL_V3_TAB_WARNINGS_HEADER = "Warnings";
-
-MODAL_V3_TAB_WARNINGS_ACCOUNT_WARNINGS_HEADER = "Review Warnings";
-MODAL_V3_TAB_WARNINGS_ACCOUNT_WARNINGS_SUMMARY = "You will receive warnings if you break our community guidelines.";
-
-// Reviews
-
-MODAL_V3_TAB_REVIEWS_HEADER = "Reviews";
-
-MODAL_V3_TAB_REVIEWS_DISCORD_ACCOUNT_NOT_LOGGED_IN_SUMMARY = "Filters what reviews are shown. You must have a Standard account to change your review settings.";
-
-MODAL_V3_TAB_REVIEWS_UNAVAILABLE_HEADER = "Reviews Settings Temporarily Unavailable";
-MODAL_V3_TAB_REVIEWS_UNAVAILABLE_SUMMARY = "We are currently updating the reviews system.";
-
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_HEADER = "Filter";
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SUMMARY = "Filters what reviews are shown.";
-
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_3 = "Disable Reviews";
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_3_SUMMARY = "Hide all reviews";
-
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_2 = "Filter Bad Language";
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_2_SUMMARY = "Hide reviews with profane or vulgar language";
-
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_1 = "No Filter";
-MODAL_V3_TAB_REVIEWS_REVIEWS_FILTER_SETTINGS_1_SUMMARY = "Show all reviews";
-
-// Appearance
-
-MODAL_V3_TAB_APPEARANCE_HEADER = "Appearance";
-
-MODAL_V3_TAB_APPEARANCE_THEME_HEADER = "Theme";
-MODAL_V3_TAB_APPEARANCE_THEME_SUMMARY = "Adjust the color of the interface for better visibility.";
-
-MODAL_V3_TAB_APPEARANCE_THEME_COLOR_HEADER = "Color Themes";
-MODAL_V3_TAB_APPEARANCE_THEME_COLOR_SUMMARY = "Adjust the color of the interface for better visibility.";
-
-MODAL_V3_TAB_APPEARANCE_THEME_CUSTOM_HEADER = "Custom Themes";
-MODAL_V3_TAB_APPEARANCE_THEME_CUSTOM_SUMMARY = "Your very own custom CSS.";
-
-MODAL_V3_TAB_APPEARANCE_THEME_COMMUNITY_HEADER = "Community Made Themes";
-MODAL_V3_TAB_APPEARANCE_THEME_COMMUNITY_SUMMARY = "Theme custom made by the community.";
-
-
-MODAL_V3_TAB_APPEARANCE_TIME_HEADER = "Time Format";
-MODAL_V3_TAB_APPEARANCE_TIME_SUMMARY = "Change how the date is displayed around the website.";
-
-MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_2 = "US";
-MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_2_SUMMARY = "MM/DD/YYYY";
-
-MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_1 = "UK";
-MODAL_V3_TAB_APPEARANCE_TIME_SETTINGS_1_SUMMARY = "DD/MM/YYYY";
-
-
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_HEADER = "Category Tab Style";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SUMMARY = "Style the tabs on category modals.";
-
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_DARK = "Connected";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_TRANSPARENT = "Transparent";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_LEGACY = "Legacy";
-
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_SELECTED = "Selected Tab";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_CATEGORY_TABS_OTHER = "Other Tab";
-
-
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_SHOP_CARDS_HEADER = "Shop Card Style";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_SHOP_CARDS_SUMMARY = "Style the cards in the shop.";
-
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_SHOP_CARDS_TALL = "Tall";
-MODAL_V3_TAB_APPEARANCE_EXTENDED_STYLES_SHOP_CARDS_STANDARD = "Standard";
-
-// Accessibility
-
-MODAL_V3_TAB_ACCESSIBILITY_HEADER = "Accessibility";
-
-MODAL_V3_TAB_ACCESSIBILITY_REDUCED_MOTION_HEADER = "Reduced Motion";
-MODAL_V3_TAB_ACCESSIBILITY_REDUCED_MOTION_SUMMARY = "Reduce the amount and intensity of animations,";
-MODAL_V3_TAB_ACCESSIBILITY_REDUCED_MOTION_SUMMARY2 = " hover effects and other moving effects across Shop Archives.";
-
-// XP Events
-
-MODAL_V3_XP_NOTICE_1 = "Notice!";
-MODAL_V3_XP_NOTICE_2 = "XP is a Shop Archives only feature, spending / receiving XP will not change anything on the Discord app.";
-
-MODAL_V3_TAB_XP_EVENTS_HEADER = "Events";
-
-MODAL_V3_TAB_XP_EVENTS_ERROR_1 = "There was an error loading XP Events!";
-
-MODAL_V3_TAB_XP_EVENTS_EVENTS_HEADER = "Active Events";
-MODAL_V3_TAB_XP_EVENTS_EVENTS_SUMMARY = "Events can let you earn free XP, keep an eye out for new events!";
-
-// XP Shop
-
-MODAL_V3_TAB_XP_SHOP_HEADER = "XP Shop";
-
-MODAL_V3_TAB_XP_SHOP_XP_LEVEL_HEADER = "Your XP";
-
-MODAL_V3_TAB_XP_SHOP_CLAIMABLES_FEATURED = "Featured Perks";
-MODAL_V3_TAB_XP_SHOP_CLAIMABLES_FEATURED_SUMMARY = "Top picks from us we think you might like.";
-
-MODAL_V3_TAB_XP_SHOP_CLAIMABLES_ADDITIONAL = "Additional Perks";
-
-MODAL_V3_TAB_XP_SHOP_ERROR_1 = "There was an error!";
-MODAL_V3_TAB_XP_SHOP_ERROR_2 = "There was an error loading XP Perks!";
-MODAL_V3_TAB_XP_SHOP_ERROR_3 = "There was an error loading your XP balance!";
-
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_HEADER = "Claim Perk";
-
-MODAL_V3_TAB_XP_SHOP_CLAIM_REWARD_MODAL_HEADER = "Congratulations!";
-MODAL_V3_TAB_XP_SHOP_CLAIM_REWARD_MODAL_SUMMARY = "You can claim your ";
-
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_NOT_ENOUGH_ERROR = "You don't have enough XP to claim this item.";
-
-MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_1 = "Cannot Claim Perk.";
-MODAL_V3_TAB_XP_SHOP_CANT_CLAIM_2 = "You do not meet the requirements to claim this perk.";
-
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_1 = "Claiming this item means you have a limited licence to use this item on Shop Archives. This item is non-refundable.";
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_2 = "Once you've claimed this item, your Discord server tag will be applied to all your existing and future reviews. Note that if you don't have a Discord server tag applied on your profile, this item is useless.";
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_3 = "Review colors will not actually be animated. Once you've claimed this item, you'll be able to pick a color before sending your review.";
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_4 = "Once you've claimed this item, you'll be able to write reviews with up to 200 characters.";
-MODAL_V3_TAB_XP_SHOP_CLAIM_MODAL_5 = "Once you've claimed this item, your Discord avatar decoration will be applied to all your existing and future reviews. Note that if you don't have a Discord avatar decoration applied on your profile, this item is useless.";
-
-// XP Inventory
-
-MODAL_V3_TAB_XP_INVENTORY_HEADER = "Inventory";
-
-MODAL_V3_TAB_XP_INVENTORY_ERROR_1 = "There was an error loading your XP Inventory!";
-
-MODAL_V3_TAB_XP_INVENTORY_REDEEM_HEADER = "Redeem Code";
-MODAL_V3_TAB_XP_INVENTORY_REDEEM_SUMMARY = "Received a gift or event code? Enter it below:";
-
-MODAL_V3_TAB_XP_INVENTORY_REDEEM_PLACEHOLDER = "XXXX-XXXXX-XXXXX-XXXXX";
-
-MODAL_V3_TAB_XP_INVENTORY_CLAIMS_HEADER = "Claimed Items";
-MODAL_V3_TAB_XP_INVENTORY_CLAIMS_SUMMARY = "Your history of all the items you have claimed with XP.";
-
-MODAL_V3_TAB_XP_INVENTORY_REWARDS_HEADER = "Claimed Rewards";
-MODAL_V3_TAB_XP_INVENTORY_REWARDS_SUMMARY = "Your history of all the rewards you have claimed for XP.";
-
-MODAL_V3_TAB_XP_INVENTORY_TAG_REFUNDED = "REFUNDED";
-MODAL_V3_TAB_XP_INVENTORY_TAG_REFUNDED_TITLE = "This item has been refunded.";
-MODAL_V3_TAB_XP_INVENTORY_TAG_REVOKED = "REVOKED";
-MODAL_V3_TAB_XP_INVENTORY_TAG_REVOKED_TITLE = "This reward has been removed from your account.";
-
-// Experiments
-
-MODAL_V3_TAB_EXPERIMENTS_HEADER = "Experiments";
-
-MODAL_V3_TAB_EXPERIMENTS_DISABLE_FORCE_ROLLOUT_HEADER = "Disable Force Rollouts";
-MODAL_V3_TAB_EXPERIMENTS_DISABLE_FORCE_ROLLOUT_SUMMARY = "Disables the client from forcing the default experiment treatment.";
-
-MODAL_V3_TAB_EXPERIMENTS_ROLLOUT = "Rollout: ";
-MODAL_V3_TAB_EXPERIMENTS_API_WARNING = "This experiment requires api/database changes, without them it may not work as intended.";
-MODAL_V3_TAB_EXPERIMENTS_API_WARNING2 = "You are not logged in as staff, some experiments may not work as intended.";
-
-// Dismissible Content
-
-MODAL_V3_TAB_DISMISSIBLE_CONTENT_HEADER = "Dismissible Content";
-
-// API Test Fetch
-
-MODAL_V3_TAB_API_TEST_FETCH_HEADER = "API Testing";
-
-MODAL_V3_TAB_API_TESTING_API_STATUS_HEADER = "API Status";
-MODAL_V3_TAB_API_TESTING_API_STATUS_SUMMARY = "Status of Shop Archives API and Database";
-
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_HEADER = "Test Fetch";
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_SUMMARY = "Test the API to make sure it's returning the correct data.";
-
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_BASE_URL = "Base URL";
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_API_VERSION = "API Version";
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_ENDPOINT = "Endpoint";
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_PARAMS = "Fetch Params";
-
-MODAL_V3_TAB_API_TESTING_TEST_FETCH_FETCH = "Fetch";
-
-MODAL_V3_TAB_API_TESTING_DATABASE_HEADER = "Database";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_HEADER = "Reviews";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_SUMMARY = "Reviews database";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REFRESH_BUTTON = "Refresh";
-
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO = "Review Info";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO_ID = "ID: ";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO_RATING = "Star Rating: ";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO_REVIEW = "Text: ";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO_FLAG = "Flag: ";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_REVIEW_INFO_DATE = "Date Created: ";
-
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_ITEM_INFO = "Item Info";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_USER_INFO = "User Info";
-
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_ADMIN_INFO = "Admin";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_ADMIN_INFO_SUMMARY = "You will need to add your user id to the admin list in the api backend (refresh list after deleting a review).";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_ADMIN_DELETE_REVIEW = "Delete Review";
-MODAL_V3_TAB_API_TESTING_DATABASE_REVIEWS_ADMIN_BAN_USER = "Ban User";
-
-// Claimables Test
-
-MODAL_V3_TAB_CLAIMABLES_PURCHASE_HEADER = "Claimables Purchase Test";
-
-MODAL_V3_TAB_CLAIMABLES_PURCHASE_TITLE_HEADER = "Open Claimables Modal Test";
-MODAL_V3_TAB_CLAIMABLES_PURCHASE_TITLE_SUMMARY = "Open Claim Claimable Modal";
-
-MODAL_V3_TAB_CLAIMABLES_PURCHASE_OPEN_MODAL_TITLE = "Claimable ID";
-MODAL_V3_TAB_CLAIMABLES_PURCHASE_OPEN_MODAL_OPEN = "Open";
-
-MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_TITLE_HEADER = "Open Rewards Modal Test";
-MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_TITLE_SUMMARY = "Open Claim Reward Modal";
-
-MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_OPEN_MODAL_TITLE = "Claimable ID";
-MODAL_V3_TAB_CLAIMABLES_REWARD_CLAIM_OPEN_MODAL_OPEN = "Open";
-
-
-// Local Storage
-
-MODAL_V3_TAB_LOCAL_STORAGE_HEADER = "Storage";
-
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_HEADER = "Local Storage";
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_SUMMARY = "Edit the websites local storage.";
-
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_KEY_PLACEHOLDER = "Key";
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_VALUE_PLACEHOLDER = "Value";
-
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_ADD = "Add";
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_UPDATE = "Update";
-MODAL_V3_TAB_STORAGE_LOCAL_STORAGE_DELETE = "Delete";
-
-MODAL_V3_TAB_STORAGE_SESSION_STORAGE_HEADER = "Session Storage";
-MODAL_V3_TAB_STORAGE_SESSION_STORAGE_SUMMARY = "Edit the websites session storage.";
-
-// Misc
-
-MODAL_V3_TAB_MISC_HEADER = "Miscellaneous";
-
-MODAL_V3_TAB_MISC_REVIEW_CONTENT_OVERRIDE_HEADER = "Override Review Content";
-MODAL_V3_TAB_MISC_REVIEW_CONTENT_OVERRIDE_SUMMARY = "Override the review text for all review";
-
-MODAL_V3_TAB_MISC_UNPUBLISHED_XP_EVENTS_HEADER = "Unpublished XP Events";
-MODAL_V3_TAB_MISC_UNPUBLISHED_XP_EVENTS_SUMMARY = "If you have already loaded XP events you must reload for this to take effect";
-
-MODAL_V3_TAB_MISC_UNPUBLISHED_XP_SHOP_HEADER = "Unpublished XP Shop";
-MODAL_V3_TAB_MISC_UNPUBLISHED_XP_SHOP_SUMMARY = "If you have already loaded the XP shop you must reload for this to take effect";
-
-
-// Dismissible Content
-
-DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_TITLE = "NEW! Log in with Discord";
-DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_1 = "Want this to be your Discord profile?";
-DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_SUMMARY_2 = "Log in with Discord to keep your profile up to date on Shop Archives!";
-DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_LOG_IN = "Log in with Discord";
-DISMISSIBLE_CONTENT_NEW_DISCORD_SIGN_IN_MODAL_NO_THANKS = "No Thanks";
-
-DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_TITLE = "NEW! Claim 100 XP for free";
-DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_SUMMARY_1 = "New users get to claim 100 XP for free, don't forget to claim yours.";
-DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_TAKE_ME_THERE = "Take me there";
-DISMISSIBLE_CONTENT_NEW_CLAIM_100_XP_MODAL_LATER = "Later";
\ No newline at end of file
diff --git a/assets/3.js b/assets/3.js
deleted file mode 100644
index 5c8018f..0000000
--- a/assets/3.js
+++ /dev/null
@@ -1,387 +0,0 @@
-
-let apiUrl = 'https://raw.githubusercontent.com/Yappering/api/main/v1/profiles-plus';
-
-const unreleased_profiles_plus_token = localStorage.getItem('token');
-
-if (localStorage.unreleased_profiles_plus == "true") {
- apiUrl = 'https://raw.githubusercontent.com/Yappering/private-api/refs/heads/main/v2/profiles-plus-u';
-}
-
-const apiUrlWithToken = `${apiUrl}?token=${unreleased_profiles_plus_token}`;
-
-const template = document.querySelector("[data-shop-category-template]");
-const output = document.querySelector("[data-shop-output]");
-
-fetch(apiUrlWithToken)
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const category = template.content.cloneNode(true).children[0];
-
- if (localStorage.epic_pplus_balls == "true") {
- if (user.category_bg != null) {
- const marketing_bg = category.querySelector("[data-shop-category-marketing-bg]");
- marketing_bg.src = user.category_bg;
- }
- }
-
- const banner = category.querySelector("[data-shop-category-banner]");
- banner.id = user.sku_id;
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image]").classList.add('shop-logo-sway');
- }
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "Expired";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- const hours = Math.floor((timeDiff % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
- const minutes = Math.floor((timeDiff % (1000 * 60 * 60)) / (1000 * 60));
- const seconds = Math.floor((timeDiff % (1000 * 60)) / 1000);
-
- timerElement.textContent = `${days} DAYS LEFT TO REQUEST`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
- // Function to create a card
- function createCard(item, credits, pplus_id, emojiCopy, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- card.classList.add('shop-category-card');
-
- card.id = pplus_id;
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- if (localStorage.epic_pplus_balls == "true") {
- card.classList.add('shop-category-card-transparent');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- ${emojiCopy ? 'Copy P+ Emoji' : 'Request to P+'}
-
-
NEW
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- ${emojiCopy ? 'Copy P+ Emoji' : 'Request to P+'}
-
-
NEW
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- card.addEventListener('click', () => openModal(item, credits, emojiCopy));
-
- return card;
- }
-
- // Function to open the modal
- function openModal(item, credits, emojiCopy) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
- const modalContent = `
-
-
-
Made By: ${credits}
-
${item.name}
-
${description}
-
-
- ${emojiCopy ? 'Copy P+ Emoji' : 'Request to P+'}
-
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
-
- // Function to get image type based on item properties
- function getImageType(item) {
- // Check if the item has a type field and return appropriate ID
- if (item.item_type === 'deco') {
- return 'avatar-decoration'; // Change this to match your needs
- } else if (item.item_type === 'effect') {
- return 'profile-effect'; // Change this to match your needs
- } else if (item.bundled_products) {
- return 'bundle'; // For bundles
- }
- return 'unknown-type'; // Fallback for undefined types
- }
-
- // Sort and display the products: Bundle, Decoration, Effect
- const bundleProducts = [];
- const decorationProducts = [];
- const effectProducts = [];
-
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const credits = product.credits || ""; // Get credits from the product
- const pplus_id = product.pplus_id || "";
- const emojiCopy = product.emojiCopy || ""; // Get emojiCopy from the product
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- // Add bundle card with bundled items
- bundleProducts.push({ product, credits, pplus_id, emojiCopy, isNew });
- } else {
- // Handle individual items
- product.items.forEach(item => {
- if (item.item_type === 'deco') {
- decorationProducts.push({ item, credits, pplus_id, emojiCopy, isNew });
- } else if (item.item_type === 'effect') {
- effectProducts.push({ item, credits, pplus_id, emojiCopy, isNew });
- }
- });
- }
- });
-
- // Append Bundle, Decoration, and Effect cards in that order
- bundleProducts.forEach(({ product, credits, pplus_id, emojiCopy, isNew }) => cardHolder.appendChild(createCard(product, credits, pplus_id, emojiCopy, true, isNew)));
- decorationProducts.forEach(({ item, credits, pplus_id, emojiCopy, isNew }) => cardHolder.appendChild(createCard(item, credits, pplus_id, emojiCopy, false, isNew)));
- effectProducts.forEach(({ item, credits, pplus_id, emojiCopy, isNew }) => cardHolder.appendChild(createCard(item, credits, pplus_id, emojiCopy, false, isNew)));
-
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
-
- if (localStorage.epic_pplus_balls == "true") {
- const paper_beach2 = document.getElementById('profiles-plus-8');
- if (paper_beach2) { // Check if element exists
- document.getElementById('profiles-plus-8').innerHTML = `
-
-
-
-
- `;
- }
-
- const windowkill2 = document.getElementById('profiles-plus-4');
- if (windowkill2) { // Check if element exists
- document.getElementById('profiles-plus-4').innerHTML = `
-
-
-
-
- `;
- }
-
- const paper_beach = document.getElementById('profiles-plus-3');
- if (paper_beach) { // Check if element exists
- document.getElementById('profiles-plus-3').innerHTML = `
-
-
-
-
- `;
- }
-
- const bopl_battle = document.getElementById('profiles-plus-2');
- if (bopl_battle) { // Check if element exists
- document.getElementById('profiles-plus-2').innerHTML = `
-
-
-
-
- `;
- }
- }
-
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-pplus").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
-
-// Function to copy emojiCopy to clipboard
-function copyEmoji(emojiCopy) {
- if (emojiCopy) {
- navigator.clipboard.writeText(emojiCopy).then(() => {
- console.log('emoji yes');
- }).catch(err => {
- console.error('Failed to copy emoji:', err);
- });
- } else {
- console.error('Failed to copy emoji:', err);
- }
-}
-
-// Function to redirect to Google
-function redirectToGoogle() {
- window.location.href = 'https://discord.gg/Mcwh7hGcWb';
-}
-
-
-function reFetchProfilesPlus() {
- localStorage.unreleased_profiles_plus = "false"
- location.reload();
-}
\ No newline at end of file
diff --git a/assets/4.js b/assets/4.js
deleted file mode 100644
index f7574a9..0000000
--- a/assets/4.js
+++ /dev/null
@@ -1,776 +0,0 @@
-if (localStorage.full_client_rework != "true") {
- const open_help_modals_buttons_holder = document.getElementById('open-help-modals-buttons-holder');
- open_help_modals_buttons_holder.innerHTML = `
-
-
-
-
- `;
-
- function openLostModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = `
-
-
-
-
Help
- Old user interface:
- Old UI
-
- Discord Server:
- Discord
-
- Github:
- Github
-
- Trella on Youtube:
- Youtube
-
- DTACat on Youtube:
- Youtube
-
- Close
-
- App Version: Dev 142
-
-
-
- `;
- }
-
- function openMobileModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = `
-
-
-
-
Looks like you're on mobile
-
Would you like to use the mobile client?
-
Yes
-
No
-
-
-
- `;
- }
-
- if(/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)){
- openMobileModal()
- }
-
- function openOptionsModal() {
- const options_modal = document.getElementById('modal-housing');
- options_modal.innerHTML = `
-
-
-
-
Options
-
-
-
-
Shop: Hide removed items
-
This will hide all categories that are not currently in the shop
-
-
-
-
Shop: Hide bundles
-
This will hide all bundles in the shop page
-
-
-
-
-
Close
-
-
-
- `;
-
- if (localStorage.items_in_shop_yes == "true") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.items_in_shop_yes == "none") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.items_in_shop != "true") {
- if (localStorage.items_in_shop != "none") {
- document.getElementById("is-in-shop-box-option").style.display = 'none';
- }
- }
-
-
- if (localStorage.shop_have_no_bundles == "true") {
- document.getElementById("no-bundles-in-shop-box").checked = true;
- }
- }
-
- function inShopIsChecked() {
- if (localStorage.items_in_shop_yes != "true") {
- localStorage.items_in_shop_yes = "true"
- }
- else {
- localStorage.items_in_shop_yes = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData();
- }
- }
-
- function noBundlesInShopIsChecked() {
- if (localStorage.shop_have_no_bundles != "true") {
- localStorage.shop_have_no_bundles = "true"
- }
- else {
- localStorage.shop_have_no_bundles = "false"
- }
- if (typeof fetchData === 'function') {
- pageCheck();
- }
- }
-
- function openDownloadsModal() {
- const downloads_modal = document.getElementById('modal-housing');
- downloads_modal.innerHTML = `
-
-
-
-
Manual Downloads
-
Experimental
-
-
-
- `;
-
- // Fetch the data from the API
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/downloadable-data')
- .then(response => response.json())
- .then(data => {
- // Call the function to display the data
- displayData(data);
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
- // Function to display the data in the HTML
- function displayData(data) {
- const content = document.getElementById('downloadables-output');
- const template = document.getElementById('downloadables-api-template');
-
- data.forEach(item => {
- // Clone the template
- const clone = template.content.cloneNode(true);
-
- // Fill in the name and summary
- clone.querySelector('.name').textContent = item.name;
- clone.querySelector('.summary').textContent = item.summary;
-
- // Add buttons for downloadables
- const downloadablesDiv = clone.querySelector('.downloadables');
- item.downloadables.forEach(downloadable => {
- const button = document.createElement('button');
- button.textContent = downloadable.name;
- button.classList.add('card-button');
- button.addEventListener('click', () => {
- window.open(downloadable.url, '_blank');
- });
- downloadablesDiv.appendChild(button);
- });
-
- // Append the cloned template to the content
- content.appendChild(clone);
- });
- }
-
- }
-
-
- function openDevModal() {
- if (localStorage.dev == "true") {
- const dev_modal = document.getElementById('modal-housing');
- dev_modal.innerHTML = `
-
-
-
-
Dev Options
-
Close
-
Safe Mode
-
-
-
Experiments
-
Test out new features
-
-
-
-
-
Client Rework
-
2024-11_full_client_rework
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Epic Profiles Plus Category Changes
-
2024-11_epic_profiles_plus_category_changes
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Top Selling Item Tag
-
2024-11_top_selling_item_tag
-
Override 2
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Item Data Downloads
-
2024-11_item_data_downloads
-
Override 2
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
-
-
-
-
-
Debug
-
Overrides
-
-
-
Unreleased Profiles Plus Items
-
2024-09_profiles_plus
-
Override 1
-
No Override
-
-
-
Show 404 Button
-
2024-09_not_found
-
Override 1
-
No Override
-
-
-
-
-
-
Local Storage Overrides
-
Refresh the page for changes to take effect
-
Save
-
-
-
Save
-
-
-
-
Close
-
Safe Mode
-
-
-
- `;
-
-
-
-
- if (localStorage.full_client_rework == "true") {
- document.getElementById("2024-11_full_client_rework-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.full_client_rework != "true") {
- if (localStorage.full_client_rework != "false") {
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
- }
-
- if (localStorage.full_client_rework == "false") {
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
- if (localStorage.epic_pplus_balls == "true") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.epic_pplus_balls != "true") {
- if (localStorage.epic_pplus_balls != "false") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
- }
-
- if (localStorage.epic_pplus_balls == "false") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.add('refresh-button-selected');
- }
-
-
-
- if (localStorage.top_selling_item != "true") {
- if (localStorage.top_selling_item != "false") {
- if (localStorage.top_selling_item != "two") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
- }
- }
-
- if (localStorage.top_selling_item == "two") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.top_selling_item == "true") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.top_selling_item == "false") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.add('refresh-button-selected');
- }
-
-
-
- if (localStorage.item_data_downloads != "true") {
- if (localStorage.item_data_downloads != "false") {
- if (localStorage.item_data_downloads != "two") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
- }
- }
-
- if (localStorage.item_data_downloads == "two") {
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.item_data_downloads == "true") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.item_data_downloads == "false") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
- if (localStorage.not_found_found == "true") {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
- document.getElementById("2024-09_not_found-1").classList.add('refresh-button-selected');
- }
-
- if (localStorage.not_found_found != "true") {
- document.getElementById("2024-09_not_found-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.add('refresh-button-selected');
- }
-
-
- if (localStorage.unreleased_profiles_plus == "true") {
- document.getElementById("2024-09_profiles_plus-1").classList.add('refresh-button-selected');
- }
-
- if (localStorage.unreleased_profiles_plus != "true") {
- document.getElementById("2024-09_profiles_plus-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.add('refresh-button-selected');
- }
-
- displayLocalStorage();
- }else {
- console.error('403 (Forbidden)')
- }
- }
-
-
- function closeDevModal() {
- const dev_modal = document.getElementById('modal-housing');
- dev_modal.innerHTML = ``;
- }
-
- function closeMobileModal() {
- const mobile_modal = document.getElementById('modal-housing');
- mobile_modal.innerHTML = ``;
- }
-
- function closeLostModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = ``;
- }
-
-
-
- if (localStorage.dev == "true") {
- const dev_tool_button = document.querySelector("#open-dev-tools-button");
- dev_tool_button.style.display = 'block';
- }
-
-
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
-
-
- function turnOffDevMode() {
- localStorage.dev = "false"
- location.reload();
- }
-
- function dev() {
- localStorage.dev = "true"
- location.reload();
- }
-
-
-
-
- function fullClientRework0() {
- localStorage.full_client_rework = "none"
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- function fullClientRework1() {
- localStorage.full_client_rework = "true"
- document.getElementById("2024-11_full_client_rework-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- function fullClientRework00() {
- localStorage.full_client_rework = "false"
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.add('refresh-button-selected');
- }
-
-
-
- function epicProfilesPlusCategoryChanges0() {
- localStorage.epic_pplus_balls = "none"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- function epicProfilesPlusCategoryChanges1() {
- localStorage.epic_pplus_balls = "true"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- function epicProfilesPlusCategoryChanges00() {
- localStorage.epic_pplus_balls = "false"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.add('refresh-button-selected');
- }
-
-
-
- function topSellingItemTag2() {
- localStorage.top_selling_item = "two"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag1() {
- localStorage.top_selling_item = "true"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag0() {
- localStorage.top_selling_item = "none"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag00() {
- localStorage.top_selling_item = "false"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.add('refresh-button-selected');
- }
-
-
-
-
- function itemDataDownloads2() {
- localStorage.item_data_downloads = "two"
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads1() {
- localStorage.item_data_downloads = "true"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads0() {
- localStorage.item_data_downloads = "none"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads00() {
- localStorage.item_data_downloads = "false"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
- function itemDataDownloads2() {
- localStorage.item_data_downloads = "two"
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads1() {
- localStorage.item_data_downloads = "true"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads0() {
- localStorage.item_data_downloads = "none"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads00() {
- localStorage.item_data_downloads = "false"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
-
- function secret404ButtonHide() {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.add('hidden');
- }
- }
- localStorage.not_found_found = "none"
- console.log('hide 404 button')
- document.getElementById("2024-09_not_found-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.add('refresh-button-selected');
- }
-
- function secret404ButtonShow() {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
- localStorage.not_found_found = "true"
- console.log('show 404 button')
- document.getElementById("2024-09_not_found-1").classList.add('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.remove('refresh-button-selected');
- }
-
-
-
- function unreleasedProfilesPlusItemsFalse() {
- localStorage.unreleased_profiles_plus = "none"
- console.log('hide Unreleased Profiles Plus Items')
- document.getElementById("2024-09_profiles_plus-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.add('refresh-button-selected');
- }
-
- function unreleasedProfilesPlusItemsTrue() {
- localStorage.unreleased_profiles_plus = "true"
- console.log('show Unreleased Profiles Plus Items')
- document.getElementById("2024-09_profiles_plus-1").classList.add('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.remove('refresh-button-selected');
- }
-
-
-
-
- function saveToLocalStorage() {
- // Get the values from the inputs
- const key = document.getElementById('keyInput').value;
- const value = document.getElementById('valueInput').value;
-
- // Save to local storage
- localStorage.setItem(key, value);
-
- // Refresh the display
- displayLocalStorage();
- }
-
- function displayLocalStorage() {
- // Get the container element
- const storageItems = document.getElementById('storageItems');
-
- // Clear the container
- storageItems.innerHTML = '';
-
- // Iterate over all items in local storage
- for (let i = 0; i < localStorage.length; i++) {
- const key = localStorage.key(i);
- const value = localStorage.getItem(key);
-
- // Create a container for each item
- const itemDiv = document.createElement('div');
-
- // Create editable input fields for key and value
- const keyInput = document.createElement('input');
- keyInput.type = 'text';
- keyInput.value = key;
- keyInput.disabled = true; // Disable key editing
- keyInput.className = 'dev-local-storage-input-2';
-
- const valueInput = document.createElement('input');
- valueInput.type = 'text';
- valueInput.value = value;
- valueInput.className = 'dev-local-storage-input-3';
-
- // Save button for each item
- const saveButton = document.createElement('button');
- saveButton.textContent = 'Update';
- saveButton.className = 'refresh-button';
- saveButton.onclick = function() {
- localStorage.setItem(key, valueInput.value);
- };
-
- // Delete button for each item
- const deleteButton = document.createElement('button');
- deleteButton.textContent = 'Delete';
- deleteButton.className = 'refresh-button';
- deleteButton.onclick = function() {
- localStorage.removeItem(key);
- displayLocalStorage(); // Refresh the display
- };
-
- // Append elements to the item div
- itemDiv.appendChild(deleteButton);
- itemDiv.appendChild(keyInput);
- itemDiv.appendChild(valueInput);
- itemDiv.appendChild(saveButton);
-
- // Append the item div to the container
- storageItems.appendChild(itemDiv);
- }
- }
-}
\ No newline at end of file
diff --git a/assets/5.png b/assets/5.png
deleted file mode 100644
index 0b390b2..0000000
Binary files a/assets/5.png and /dev/null differ
diff --git a/assets/6.js b/assets/6.js
deleted file mode 100644
index f7574a9..0000000
--- a/assets/6.js
+++ /dev/null
@@ -1,776 +0,0 @@
-if (localStorage.full_client_rework != "true") {
- const open_help_modals_buttons_holder = document.getElementById('open-help-modals-buttons-holder');
- open_help_modals_buttons_holder.innerHTML = `
-
-
-
-
- `;
-
- function openLostModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = `
-
-
-
-
Help
- Old user interface:
- Old UI
-
- Discord Server:
- Discord
-
- Github:
- Github
-
- Trella on Youtube:
- Youtube
-
- DTACat on Youtube:
- Youtube
-
- Close
-
- App Version: Dev 142
-
-
-
- `;
- }
-
- function openMobileModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = `
-
-
-
-
Looks like you're on mobile
-
Would you like to use the mobile client?
-
Yes
-
No
-
-
-
- `;
- }
-
- if(/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)){
- openMobileModal()
- }
-
- function openOptionsModal() {
- const options_modal = document.getElementById('modal-housing');
- options_modal.innerHTML = `
-
-
-
-
Options
-
-
-
-
Shop: Hide removed items
-
This will hide all categories that are not currently in the shop
-
-
-
-
Shop: Hide bundles
-
This will hide all bundles in the shop page
-
-
-
-
-
Close
-
-
-
- `;
-
- if (localStorage.items_in_shop_yes == "true") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.items_in_shop_yes == "none") {
- document.getElementById("is-in-shop-box").checked = true;
- }
-
- if (localStorage.items_in_shop != "true") {
- if (localStorage.items_in_shop != "none") {
- document.getElementById("is-in-shop-box-option").style.display = 'none';
- }
- }
-
-
- if (localStorage.shop_have_no_bundles == "true") {
- document.getElementById("no-bundles-in-shop-box").checked = true;
- }
- }
-
- function inShopIsChecked() {
- if (localStorage.items_in_shop_yes != "true") {
- localStorage.items_in_shop_yes = "true"
- }
- else {
- localStorage.items_in_shop_yes = "false"
- }
- if (typeof fetchData === 'function') {
- fetchData();
- }
- }
-
- function noBundlesInShopIsChecked() {
- if (localStorage.shop_have_no_bundles != "true") {
- localStorage.shop_have_no_bundles = "true"
- }
- else {
- localStorage.shop_have_no_bundles = "false"
- }
- if (typeof fetchData === 'function') {
- pageCheck();
- }
- }
-
- function openDownloadsModal() {
- const downloads_modal = document.getElementById('modal-housing');
- downloads_modal.innerHTML = `
-
-
-
-
Manual Downloads
-
Experimental
-
-
-
- `;
-
- // Fetch the data from the API
- fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/downloadable-data')
- .then(response => response.json())
- .then(data => {
- // Call the function to display the data
- displayData(data);
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
- // Function to display the data in the HTML
- function displayData(data) {
- const content = document.getElementById('downloadables-output');
- const template = document.getElementById('downloadables-api-template');
-
- data.forEach(item => {
- // Clone the template
- const clone = template.content.cloneNode(true);
-
- // Fill in the name and summary
- clone.querySelector('.name').textContent = item.name;
- clone.querySelector('.summary').textContent = item.summary;
-
- // Add buttons for downloadables
- const downloadablesDiv = clone.querySelector('.downloadables');
- item.downloadables.forEach(downloadable => {
- const button = document.createElement('button');
- button.textContent = downloadable.name;
- button.classList.add('card-button');
- button.addEventListener('click', () => {
- window.open(downloadable.url, '_blank');
- });
- downloadablesDiv.appendChild(button);
- });
-
- // Append the cloned template to the content
- content.appendChild(clone);
- });
- }
-
- }
-
-
- function openDevModal() {
- if (localStorage.dev == "true") {
- const dev_modal = document.getElementById('modal-housing');
- dev_modal.innerHTML = `
-
-
-
-
Dev Options
-
Close
-
Safe Mode
-
-
-
Experiments
-
Test out new features
-
-
-
-
-
Client Rework
-
2024-11_full_client_rework
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Epic Profiles Plus Category Changes
-
2024-11_epic_profiles_plus_category_changes
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Top Selling Item Tag
-
2024-11_top_selling_item_tag
-
Override 2
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
Item Data Downloads
-
2024-11_item_data_downloads
-
Override 2
-
Override 1
-
No Override
-
Override -1
-
-
-
-
-
-
-
-
-
-
Debug
-
Overrides
-
-
-
Unreleased Profiles Plus Items
-
2024-09_profiles_plus
-
Override 1
-
No Override
-
-
-
Show 404 Button
-
2024-09_not_found
-
Override 1
-
No Override
-
-
-
-
-
-
Local Storage Overrides
-
Refresh the page for changes to take effect
-
Save
-
-
-
Save
-
-
-
-
Close
-
Safe Mode
-
-
-
- `;
-
-
-
-
- if (localStorage.full_client_rework == "true") {
- document.getElementById("2024-11_full_client_rework-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.full_client_rework != "true") {
- if (localStorage.full_client_rework != "false") {
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
- }
-
- if (localStorage.full_client_rework == "false") {
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
- if (localStorage.epic_pplus_balls == "true") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.epic_pplus_balls != "true") {
- if (localStorage.epic_pplus_balls != "false") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
- }
-
- if (localStorage.epic_pplus_balls == "false") {
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.add('refresh-button-selected');
- }
-
-
-
- if (localStorage.top_selling_item != "true") {
- if (localStorage.top_selling_item != "false") {
- if (localStorage.top_selling_item != "two") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
- }
- }
-
- if (localStorage.top_selling_item == "two") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.top_selling_item == "true") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.top_selling_item == "false") {
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.add('refresh-button-selected');
- }
-
-
-
- if (localStorage.item_data_downloads != "true") {
- if (localStorage.item_data_downloads != "false") {
- if (localStorage.item_data_downloads != "two") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
- }
- }
-
- if (localStorage.item_data_downloads == "two") {
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.item_data_downloads == "true") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- if (localStorage.item_data_downloads == "false") {
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
- if (localStorage.not_found_found == "true") {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
- document.getElementById("2024-09_not_found-1").classList.add('refresh-button-selected');
- }
-
- if (localStorage.not_found_found != "true") {
- document.getElementById("2024-09_not_found-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.add('refresh-button-selected');
- }
-
-
- if (localStorage.unreleased_profiles_plus == "true") {
- document.getElementById("2024-09_profiles_plus-1").classList.add('refresh-button-selected');
- }
-
- if (localStorage.unreleased_profiles_plus != "true") {
- document.getElementById("2024-09_profiles_plus-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.add('refresh-button-selected');
- }
-
- displayLocalStorage();
- }else {
- console.error('403 (Forbidden)')
- }
- }
-
-
- function closeDevModal() {
- const dev_modal = document.getElementById('modal-housing');
- dev_modal.innerHTML = ``;
- }
-
- function closeMobileModal() {
- const mobile_modal = document.getElementById('modal-housing');
- mobile_modal.innerHTML = ``;
- }
-
- function closeLostModal() {
- const lost_modal = document.getElementById('modal-housing');
- lost_modal.innerHTML = ``;
- }
-
-
-
- if (localStorage.dev == "true") {
- const dev_tool_button = document.querySelector("#open-dev-tools-button");
- dev_tool_button.style.display = 'block';
- }
-
-
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
-
-
- function turnOffDevMode() {
- localStorage.dev = "false"
- location.reload();
- }
-
- function dev() {
- localStorage.dev = "true"
- location.reload();
- }
-
-
-
-
- function fullClientRework0() {
- localStorage.full_client_rework = "none"
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- function fullClientRework1() {
- localStorage.full_client_rework = "true"
- document.getElementById("2024-11_full_client_rework-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.remove('refresh-button-selected');
- }
-
- function fullClientRework00() {
- localStorage.full_client_rework = "false"
- document.getElementById("2024-11_full_client_rework-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_full_client_rework-00").classList.add('refresh-button-selected');
- }
-
-
-
- function epicProfilesPlusCategoryChanges0() {
- localStorage.epic_pplus_balls = "none"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- function epicProfilesPlusCategoryChanges1() {
- localStorage.epic_pplus_balls = "true"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.remove('refresh-button-selected');
- }
-
- function epicProfilesPlusCategoryChanges00() {
- localStorage.epic_pplus_balls = "false"
- document.getElementById("2024-11_epic_profiles_plus_category_changes-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_epic_profiles_plus_category_changes-00").classList.add('refresh-button-selected');
- }
-
-
-
- function topSellingItemTag2() {
- localStorage.top_selling_item = "two"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag1() {
- localStorage.top_selling_item = "true"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag0() {
- localStorage.top_selling_item = "none"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.remove('refresh-button-selected');
- }
-
- function topSellingItemTag00() {
- localStorage.top_selling_item = "false"
- document.getElementById("2024-11_top_selling_item_tag-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_top_selling_item_tag-00").classList.add('refresh-button-selected');
- }
-
-
-
-
- function itemDataDownloads2() {
- localStorage.item_data_downloads = "two"
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads1() {
- localStorage.item_data_downloads = "true"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads0() {
- localStorage.item_data_downloads = "none"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads00() {
- localStorage.item_data_downloads = "false"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
- function itemDataDownloads2() {
- localStorage.item_data_downloads = "two"
- document.getElementById("2024-11_item_data_downloads-2").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads1() {
- localStorage.item_data_downloads = "true"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads0() {
- localStorage.item_data_downloads = "none"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.add('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.remove('refresh-button-selected');
- }
-
- function itemDataDownloads00() {
- localStorage.item_data_downloads = "false"
- document.getElementById("2024-11_item_data_downloads-2").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-0").classList.remove('refresh-button-selected');
- document.getElementById("2024-11_item_data_downloads-00").classList.add('refresh-button-selected');
- }
-
-
-
-
-
-
- function secret404ButtonHide() {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.add('hidden');
- }
- }
- localStorage.not_found_found = "none"
- console.log('hide 404 button')
- document.getElementById("2024-09_not_found-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.add('refresh-button-selected');
- }
-
- function secret404ButtonShow() {
- const fourohfour = document.getElementById("404-mains-button");
- if (fourohfour) { // Check if element exists
- if (localStorage.not_found_found == "true") {
- document.getElementById("404-mains-button").classList.remove('hidden');
- }
- }
- localStorage.not_found_found = "true"
- console.log('show 404 button')
- document.getElementById("2024-09_not_found-1").classList.add('refresh-button-selected');
- document.getElementById("2024-09_not_found-2").classList.remove('refresh-button-selected');
- }
-
-
-
- function unreleasedProfilesPlusItemsFalse() {
- localStorage.unreleased_profiles_plus = "none"
- console.log('hide Unreleased Profiles Plus Items')
- document.getElementById("2024-09_profiles_plus-1").classList.remove('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.add('refresh-button-selected');
- }
-
- function unreleasedProfilesPlusItemsTrue() {
- localStorage.unreleased_profiles_plus = "true"
- console.log('show Unreleased Profiles Plus Items')
- document.getElementById("2024-09_profiles_plus-1").classList.add('refresh-button-selected');
- document.getElementById("2024-09_profiles_plus-2").classList.remove('refresh-button-selected');
- }
-
-
-
-
- function saveToLocalStorage() {
- // Get the values from the inputs
- const key = document.getElementById('keyInput').value;
- const value = document.getElementById('valueInput').value;
-
- // Save to local storage
- localStorage.setItem(key, value);
-
- // Refresh the display
- displayLocalStorage();
- }
-
- function displayLocalStorage() {
- // Get the container element
- const storageItems = document.getElementById('storageItems');
-
- // Clear the container
- storageItems.innerHTML = '';
-
- // Iterate over all items in local storage
- for (let i = 0; i < localStorage.length; i++) {
- const key = localStorage.key(i);
- const value = localStorage.getItem(key);
-
- // Create a container for each item
- const itemDiv = document.createElement('div');
-
- // Create editable input fields for key and value
- const keyInput = document.createElement('input');
- keyInput.type = 'text';
- keyInput.value = key;
- keyInput.disabled = true; // Disable key editing
- keyInput.className = 'dev-local-storage-input-2';
-
- const valueInput = document.createElement('input');
- valueInput.type = 'text';
- valueInput.value = value;
- valueInput.className = 'dev-local-storage-input-3';
-
- // Save button for each item
- const saveButton = document.createElement('button');
- saveButton.textContent = 'Update';
- saveButton.className = 'refresh-button';
- saveButton.onclick = function() {
- localStorage.setItem(key, valueInput.value);
- };
-
- // Delete button for each item
- const deleteButton = document.createElement('button');
- deleteButton.textContent = 'Delete';
- deleteButton.className = 'refresh-button';
- deleteButton.onclick = function() {
- localStorage.removeItem(key);
- displayLocalStorage(); // Refresh the display
- };
-
- // Append elements to the item div
- itemDiv.appendChild(deleteButton);
- itemDiv.appendChild(keyInput);
- itemDiv.appendChild(valueInput);
- itemDiv.appendChild(saveButton);
-
- // Append the item div to the container
- storageItems.appendChild(itemDiv);
- }
- }
-}
\ No newline at end of file
diff --git a/assets/7.css b/assets/7.css
deleted file mode 100644
index 35cf9a8..0000000
--- a/assets/7.css
+++ /dev/null
@@ -1,745 +0,0 @@
-body {
- background-color: #313338;
- color: white;
- transition: background-color 0.4s ease-in-out;
-
- font-family: 'gg sans', sans-serif;
- font-family: 'gg sans Normal', sans-serif;
- font-family: 'gg sans Medium', sans-serif;
- font-family: 'gg sans SemiBold', sans-serif;
-}
-
-.gg-sans {
- font-family: 'gg sans', sans-serif;
- font-family: 'gg sans Normal', sans-serif;
- font-family: 'gg sans Medium', sans-serif;
- font-family: 'gg sans SemiBold', sans-serif;
-}
-
-.abcgintonord {
- font-family: "Abcgintonord 800",sans-serif
-}
-
-.housing {
- position: fixed;
- display: flex;
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
-}
-
-.server-list {
- left: auto;
- width: 70px;
- height: 100%;
- background-color: #1E1F22;
- position: fixed;
-}
-
-.dm-list {
- left: auto;
- width: 250px;
- height: 100%;
- margin-left: 70px;
- background-color: #2B2D31;
- position: fixed;
-}
-
-.sidebar {
- height: 100%;
- width: fit-content;
-}
-
-.top-bar {
- height: 50px;
- width: 100%;
- position: fixed;
- background-color: #2B2D31;
- margin-left: 70px;
- box-shadow: 0 0 0 2px #1E1F22;
- z-index: 5;
-}
-
-.home-housing {
- width: 100%;
- height: 100%;
- margin-left: auto;
- background-color: #615DED;
- margin-top: 50px;
-}
-
-.shop-housing {
- width: 100%;
- height: 100%;
- margin-left: auto;
- background-color: #404248;
- margin-top: 50px;
- overflow: auto;
-}
-
-.blog-housing {
- width: 100%;
- height: 100%;
- margin-left: auto;
- background-color: #404248;
- margin-top: 50px;
-}
-
-.modal-housing {
- background-color: #0000006e;
- position: fixed;
- display: flex;
- align-items: center;
- justify-content: center;
- top: 0;
- left: 0;
- height: 100vh;
- width: 100vw;
- animation: modal-popup-anim1 1s;
-}
-@keyframes modal-popup-anim1 {
- 0% {background-color: #00000000;}
- 100% {background-color: #0000006e;}
-}
-
-.modal {
- background-color: #313338;
- border-radius: 10px;
- text-align: center;
- width: 800px;
- height: 500px;
- animation: modal-popup-anim 0.6s;
-}
-
-@keyframes modal-popup-anim {
- 0% {scale: 0;}
- 20% {scale: 0;}
- 100% {scale: 1;}
-}
-
-.modal-lost-found {
- display: none;
-}
-
-.modal-innder {
- text-align: center;
- position: fixed;
- top: 50%;
- left: 50%;
- -webkit-transform: translate(-50%, -50%);
- transform: translate(-50%, -50%);
- width: 700px;
- height: 500px;
-}
-
-.server-avatar {
- margin-top: 10px;
-}
-
-.server-icon {
- display: flex;
- width: 50px;
- height: 50px;
- margin-left: auto;
- margin-right: auto;
- border-radius: 25px;
- border: none;
- cursor: pointer;
- background-color: #2B2D31;
- transition: border-radius 0.4s ease-in-out;
-}
-
-.server-icon-selected {
- border-radius: 10px;
-}
-
-.server-icon:hover {
- border-radius: 10px;
-}
-
-.server-pill {
- left: auto;
- width: 5px;
- height: 50px;
- background-color: white;
- margin-top: -50px;
- border-radius: 100px;
-}
-
-.unread-pill {
- left: auto;
- width: 10px;
- height: 10px;
- background-color: white;
- margin-top: -30px;
- border-radius: 100px;
- margin-left: -5px;
-}
-
-.server-home {
- background-image: url();
- background-size: 100%;
-}
-
-.dm-button {
- display: flex;
- width: 230px;
- height: 50px;
- margin-left: auto;
- margin-right: auto;
- margin-top: 5px;
- border-radius: 5px;
- border: none;
- cursor: pointer;
- background-color: #2B2D31;
- color: #B1B5BB;
- transition: background-color 0.1s, color 0.1s ease-in-out;
-}
-
-.dm-button:hover {
- background-color: #404248;
- color: white;
-}
-
-.dm-button-fetching {
- background-color: #404248;
- color: white;
-}
-
-.dm-button-text-fetching {
- height: 15px;
- margin-left: 10px;
- margin-top: 16px;
- border-radius: 9999px;
- background-color: #B1B5BB;
- animation: dm-button-text-fetching-anim 2s infinite;
-}
-
-.dm-button-text-fetching-var-1 {
- width: 100px;
-}
-.dm-button-text-fetching-var-2 {
- width: 120px;
-}
-.dm-button-text-fetching-var-3 {
- width: 80px;
-}
-
-.dm-button-tag-fetching {
- height: 15px;
- width: 40px;
- margin-left: auto;
- margin-right: 10px;
- margin-top: 16px;
- border-radius: 9999px;
- background-color: #B1B5BB;
- animation: dm-button-text-fetching-anim 2s infinite;
-}
-
-@keyframes dm-button-text-fetching-anim {
- 0% {background-color: #B1B5BB;}
- 50% {background-color: #676d75;}
- 100% {background-color: #B1B5BB;}
-}
-
-.dm-button-text {
- margin-left: 10px;
- margin-top: 13px;
- font-weight: 600;
- font-size: large;
-}
-
-.dm-new-icon {
- margin-top: 15px;
- margin-left: auto;
- margin-right: 10px;
- background-color: #E2373E;
- border-radius: 999px;
- width: 50px;
- font-size: medium;
- font-weight: 600;
- color: white;
-}
-
-.dm-button-selected {
- background-color: #404248;
- color: white;
-}
-
-.divider {
- background-color: #B1B5BB;
- display: flex;
- width: 230px;
- height: 5px;
- margin-left: auto;
- margin-right: auto;
- border-radius: 5px;
-}
-
-.dm-divider {
- color: #B1B5BB;
- display: flex;
- width: 200px;
- margin-left: auto;
- margin-right: auto;
- border-radius: 5px;
- margin-top: 20px;
- font-size: small;
-}
-
-.center-text {
- text-align: center;
-}
-
-.refresh-button {
- background-color: rgb(89, 102, 243);
- color: white;
- height: 30px;
- width: 100px;
- border: none;
- border-radius: 5px;
- cursor: pointer;
- transition: background-color 0.2s ease-in-out;
-}
-
-.refresh-button:hover {
- background-color: rgb(71, 81, 192);
-}
-
-.blog-message-bar {
- position: absolute;
- bottom: 5px;
- color: #676d75;
- background-color: #313338;
- margin-left: 20px;
- border-radius: 10px;
- width: 100%;
-}
-
-.blog-failed {
- background-color: #E2373E;
-}
-
-.shop-category-loading {
- width: 100%;
- height: auto;
- scale: 0.9;
- margin-left: auto;
- margin-right: auto;
- margin-bottom: 40px;
-}
-.shop-category-banner-loading {
- display: block;
- margin-left: auto;
- margin-right: auto;
- width: 100%;
- height: 289px;
- background-color: #313338;
- scale: 0.9;
- margin-left: auto;
- margin-right: auto;
- object-fit: cover;
- border-radius: 20px;
- box-shadow: 0 0 0 5px #2B2D31;
- animation: shop-fetching-anim 4s infinite;
-}
-.shop-category-card-loading {
- display: inline-block;
- height: 432px;
- width: 310px;
- background-color: #313338;
- border-radius: 20px;
- margin-bottom: 4px;
- box-shadow: 0 0 0 2px #2B2D31;
- margin-left: 2px;
- margin-right: 2px;
- animation: shop-fetching-anim 4s infinite;
-}
-.shop-category-card-holder-loading {
- display: block;
- text-align: center;
-}
-
-@keyframes shop-fetching-anim {
- 0% {background-color: #2B2D31;}
- 50% {background-color: #1E1F22;}
- 100% {background-color: #2B2D31;}
-}
-
-.shop-category-banner {
- display: flex;
- position: relative;
- margin-left: auto;
- margin-right: auto;
- width: 1280px;
- height: 289px;
- background-color: #313338;
- scale: 0.9;
- object-fit: cover;
- border-radius: 32px;
- justify-content: center;
- align-items: center;
- overflow: hidden;
- outline: 2px solid rgba(16, 17, 19, 0.4);
- outline-offset: -2px;
-}
-
-.shop-category-banner-img {
- width: 100%;
- height: 100%;
- object-fit: cover;
-}
-
-.shop-category-logo-holder {
- position: absolute;
- top: 50%;
- left: 50%;
- transform: translate(-50%, -50%);
- z-index: 1;
-}
-
-.shop-category-banner-logo {
- width: auto;
- max-width: 530px;
- /* height: 80px; */
- max-height: 160px;
-}
-
-
-
-.shop-category-text-holder {
- position: absolute;
- z-index: 1; /* Ensure the text is above the banner */
- margin-top: 180px; /* Space between the logo and the text */
- text-align: center;
-}
-
-
-
-
-
-
-/* General Card Styling */
-.shop-category-card {
- background-color: #111214;
- border-radius: 15px;
- color: white;
- font-family: 'gg sans', sans-serif;
- box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
- transition: transform 0.5s, box-shadow 0.2s;
- display: flex;
- flex-direction: column;
- height: 440px; /* Fixed height for the entire card */
- overflow: hidden; /* Prevents content from overflowing */
- position: relative; /* Allows positioning of the card bottom */
- border: 2px solid #1E1F22;
-}
-
-/* Card Hover Effect */
-.shop-category-card:hover {
- transform: translateY(-5px);
- box-shadow: 0 8px 12px rgba(0, 0, 0, 0.2);
-}
-
-/* Bundle Items Styling */
-.bundle-items {
- display: flex;
- gap: 15px;
- margin-top: 15px;
- flex: 1; /* Allows bundle-items to take up available space */
-}
-
-/* Individual Bundled Item */
-.bundled-item {
- display: flex;
- align-items: center;
- gap: 10px;
-}
-
-
-.bundled-item:has([class="effect"]) img {
- width: 100px; /* Adjust width as needed */
- height: 150px; /* Adjust height as needed */
- object-fit: cover;
- object-position: top;
- background-image: url('https://raw.githubusercontent.com/DTACat/Collectibles/main/Images/352db5d6852138aabc88.png');
- background-size: cover; /* Ensures the background image covers the whole element */
- background-position: top; /* Centers the background image */
- background-repeat: no-repeat; /* Prevents the background image from repeating */
- border-radius: 10px;
- pointer-events: none;
-}
-
-.bundled-item:has([class="effect"]) {
- margin-top: -160px;
- margin-left: -200px;
- transform: rotate(-10deg);
- scale: 1.5;
- pointer-events: none;
-}
-
-.bundled-item:has([class="deco"]) img {
- width: 100px; /* Adjust width as needed */
- height: 100px; /* Adjust height as needed */
- object-fit: cover;
- background-image: url('https://raw.githubusercontent.com/DTACat/Collectibles/main/Images/ff84fa219ab7e996ec26.png');
- background-size: 80%; /* Ensures the background image covers the whole element */
- background-position: center; /* Centers the background image */
- background-repeat: no-repeat; /* Prevents the background image from repeating */
- border-radius: 10px;
- pointer-events: none;
-}
-
-.bundled-item:has([class="deco"]) {
- margin-top: -160px;
- margin-left: 145px;
- transform: rotate(10deg);
- scale: 1.5;
- z-index: 1;
- pointer-events: none;
-}
-
-/* Bundle Card Description */
-.bundle-description {
- margin-top: 10px;
- font-size: 14px;
- color: #b1b5bb;
-}
-
-/* Card Title */
-.shop-category-card h3 {
- font-size: 20px;
- margin-bottom: 10px;
- color: #ffffff;
-}
-
-/* Card Summary */
-.shop-category-card p {
- font-size: 16px;
- color: #b1b5bb;
-}
-
-/* Card Bottom Container */
-.card-bottom {
- background-color: #1E1F22;
- border-radius: 0 0 8px 8px;
- padding: 15px;
- position: absolute;
- bottom: 0;
- left: 0;
- right: 0;
- height: 150px; /* Fixed height for the card bottom */
- box-sizing: border-box; /* Includes padding in height calculation */
- backdrop-filter: blur(50px);
-}
-
-/* Item Name */
-.card-bottom h3 {
- margin: 0;
- font-size: 18px;
- color: #ffffff;
-}
-
-/* Item Description */
-.card-bottom p {
- margin: 5px 0 0;
- font-size: 14px;
- color: #b1b5bb;
-}
-
-/* Deco Card Image */
-.deco-card img {
- background-image: url('https://raw.githubusercontent.com/DTACat/Collectibles/main/Images/6d8f0708e196aaad2550.png');
- background-size: 80%; /* Ensures the background image covers the whole element */
- background-position: center; /* Centers the background image */
- background-repeat: no-repeat; /* Prevents the background image from repeating */
- scale: 0.75;
- border-radius: 15px;
-}
-
-/* Effect Card Image */
-.effect-card img {
- border-radius: 15px;
-}
-
-.effect-card {
- background-image: url('https://raw.githubusercontent.com/DTACat/Collectibles/main/Images/352db5d6852138aabc88.png');
- background-size: cover; /* Ensures the background image covers the whole element */
- background-position: top; /* Centers the background image */
- background-repeat: no-repeat; /* Prevents the background image from repeating */
-}
-
-.effect-card .card-bottom {
- background-color: #1e1f22b7;
-}
-
-/* Container Holding Cards */
-.shop-category-card-holder {
- display: grid;
- grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
- gap: 20px;
- justify-content: center; /* Center the grid horizontally */
- max-width: 1200px; /* Limit the width of the card holder */
- margin: 0 auto; /* Center the card holder container */
- padding: 20px 0; /* Add some space between the banner and cards */
- padding-left: 20px;
- padding-right: 20px;
-}
-
-/* Adjustments for smaller screens */
-@media (max-width: 768px) {
- .shop-category-card-holder {
- grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
- }
-}
-
-
-
-
-.shop-category-card {
- position: relative;
- overflow: hidden;
-}
-
-.card-bottom {
- transition: opacity 0.3s ease; /* Smooth fade transition */
-}
-
-.card-bottom p {
- margin: 0;
- transition: opacity 0.3s ease; /* Smooth fade transition */
-}
-
-.card-button-container {
- position: absolute;
- bottom: 10px; /* Adjust based on your design */
- left: 50%;
- transform: translateX(-50%) translateY(20px); /* Start off-screen */
- opacity: 0; /* Initially hidden */
- transition: opacity 0.5s ease, transform 0.5s ease; /* Smooth fade and slide transition */
- text-align: center; /* Center buttons horizontally */
- width: 90%;
-}
-
-.card-button {
- display: block;
- margin: 5px 0; /* Space between buttons */
- padding: 10px 20px;
- background-color: #615DED; /* Adjust based on your design */
- color: #fff;
- border: none;
- border-radius: 4px;
- cursor: pointer;
- width: 100%;
- transition: background-color 0.2s ease;
- z-index: 5;
-}
-
-.card-button:hover {
- background-color: #464FBF;
-}
-
-.card-button-disabled {
- background-color: #464FBF;
- cursor: not-allowed;
-}
-
-.shop-category-card:hover .card-button-container {
- opacity: 1; /* Fade in */
- transform: translateX(-50%) translateY(0); /* Slide up to final position */
-}
-
-.shop-category-card:hover .shop-card-summary {
- opacity: 0; /* Fade out description */
-}
-
-
-.shop-price-container {
- position: absolute;
- bottom: 10px; /* Adjust based on your design */
- width: 90%;
- opacity: 1; /* Fade in */
- transition: opacity 0.5s ease;
-}
-
-.shop-category-card:hover .shop-price-container {
- opacity: 0; /* Fade out description */
-}
-
-
-
-
-
-
-
-
-
-
-.shop-expiry-timer-timer {
- text-align: center;
- position: absolute;
- right: 20px;
- top: 0px;
- background-color: white;
- border-radius: 999px;
- width: fit-content;
- padding-left: 5px;
- padding-right: 5px;
- font-size: medium;
- font-weight: 600;
- color: black;
- pointer-events: none;
-}
-
-.new-item-tag {
- text-align: center;
- position: absolute;
- top: 15px;
- right: 15px;
- background-color: white;
- border-radius: 999px;
- width: auto;
- padding-left: 5px;
- padding-right: 5px;
- font-size: medium;
- font-weight: 600;
- color: black;
- z-index: 5;
- pointer-events: none;
-}
-
-.shop-logo-sway {
- animation: shop-banner-logo-rotate 10s infinite !important;
-}
-
-@keyframes shop-banner-logo-rotate {
- 0% {rotate: -3deg;}
- 50% {rotate: 3deg;}
- 100% {rotate: -3deg;}
-}
-
-/* width */
-::-webkit-scrollbar {
- width: 5px;
-}
-
-/* Track */
-::-webkit-scrollbar-track {
- background: none;
-}
-
-/* Handle */
-::-webkit-scrollbar-thumb {
- background: #1E1F22;
- border-radius: 10px;
-}
-
-/* Handle on hover */
-::-webkit-scrollbar-thumb:hover {
- background: #1E1F22;
-}
-
-.hidden {
- display: none;
-}
\ No newline at end of file
diff --git a/assets/8.js b/assets/8.js
deleted file mode 100644
index b0670fc..0000000
--- a/assets/8.js
+++ /dev/null
@@ -1,67 +0,0 @@
-const servers = document.querySelector("[data-servers-template]");
-const serversList = document.querySelector("[data-servers]");
-
-fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/servers')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const card = servers.content.cloneNode(true).children[0];
- const serversButton = card; // Corrected the selection of the button element
-
- serversButton.classList.add(user.class);
-
- if (user.titleText) {
- serversButton.title = user.titleText;
- }
-
- const userImage = card.querySelector("[data-server-icon]");
- userImage.src = user.image;
- userImage.alt = user.title;
-
- // Set the button's click event to redirect to the URL stored in the API
- serversButton.onclick = function() {
- window.location.href = user.url;
- };
-
- serversList.append(card);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
-
-
-const messageTemplate = document.querySelector("[data-blog-message-template]");
-const messageOutput = document.querySelector("[data-blog-messages-output]");
-
-fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/news')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const message = messageTemplate.content.cloneNode(true).children[0];
-
- const newstitle = message.querySelector("[data-news-title]");
- newstitle.textContent = user.title;
-
- const messageTime = message.querySelector("[data-blog-message-time]");
- messageTime.textContent = user.message_time;
-
- if (user.isNew === "true") {
- message.querySelector(".new-item-tag-1").style.display = 'block';
- }
-
- const messageContentOne = message.querySelector("[data-blog-message-content-1]");
- messageContentOne.textContent = user.message_content_1;
-
- const messageContentTwo = message.querySelector("[data-blog-message-content-2]");
- messageContentTwo.textContent = user.message_content_2;
-
- const messageContentThree = message.querySelector("[data-blog-message-content-3]");
- messageContentThree.textContent = user.message_content_3;
-
- messageOutput.append(message);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- });
\ No newline at end of file
diff --git a/assets/9.js b/assets/9.js
deleted file mode 100644
index d41faae..0000000
--- a/assets/9.js
+++ /dev/null
@@ -1,291 +0,0 @@
-const template = document.querySelector("[data-shop-category-template]");
-const output = document.querySelector("[data-shop-output]");
-
-fetch('https://raw.githubusercontent.com/Yappering/api/main/v1/miscellaneous')
- .then(response => response.json())
- .then(data => {
- data.forEach(user => {
- const category = template.content.cloneNode(true).children[0];
-
- const bannerImage = category.querySelector("[data-shop-category-banner-image]");
- bannerImage.src = user.banner;
- bannerImage.alt = user.name;
-
- const logoImage = category.querySelector("[data-shop-category-logo-image]");
- logoImage.src = user.logo;
- logoImage.alt = user.name;
-
- const summary = category.querySelector("[data-shop-category-desc]");
- summary.textContent = user.summary;
-
- if (user.summary_black === "true") {
- category.querySelector(".shop-category-text-holder").style.color = 'black';
- }
-
- // Handling the logo sway effect
- if (user.logo_sway === "true") {
- category.querySelector("[data-shop-category-logo-image]").classList.add('shop-logo-sway');
- }
-
- // Handle expiry timer
- const expiryTimer = category.querySelector(".shop-expiry-timer");
- const timerElement = category.querySelector("#shop-expiry-timer");
- const unpublishedAt = new Date(user.unpublished_at);
-
- if (user.unpublished_at && !isNaN(unpublishedAt.getTime())) {
- expiryTimer.style.display = 'block';
-
- function updateTimer() {
- const now = new Date();
- const timeDiff = unpublishedAt - now;
-
- if (timeDiff <= 0) {
- timerElement.textContent = "UNOBTAINABLE";
- clearInterval(timerInterval);
- } else {
- const days = Math.floor(timeDiff / (1000 * 60 * 60 * 24));
- timerElement.textContent = `${days} DAYS LEFT IN SHOP`;
- }
- }
-
- const timerInterval = setInterval(updateTimer, 1000);
- updateTimer(); // Initial call to display the timer immediately
- } else {
- expiryTimer.style.display = 'none';
- }
-
- const cardHolder = category.querySelector(".shop-category-card-holder");
-
- // Function to create a card
- function createCard(item, sku, price, priceNitro, isBundle = false, isNew = false) {
- const card = document.createElement('div');
- card.classList.add('shop-category-card');
-
- // Determine card class based on item type
- if (item.item_type === 'deco') {
- card.classList.add('deco-card');
- } else if (item.item_type === 'effect') {
- card.classList.add('effect-card');
- } else if (isBundle) {
- card.classList.add('bundle-card');
- }
-
- // Card content based on item type
- if (isBundle && item.bundled_products) {
- const bundleDescription = `Bundle Includes: ${item.bundled_products.filter(product => product.item_type === 'deco').map(deco => deco.name).join(', ')} Decoration & ${item.bundled_products.filter(product => product.item_type === 'effect').map(effect => effect.name).join(', ')} Profile Effect`;
-
- card.innerHTML = `
-
- ${item.bundled_products.map(bundledItem => `
-
-
-
- `).join('')}
-
-
-
- Unable to confirm item availability
-
-
NEW
- `;
-
- } else {
- card.innerHTML = `
-
-
-
- Unable to confirm item availability
-
-
NEW
- `;
- }
-
- // Add hover effect for the entire card to animate images
- card.addEventListener('mouseenter', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated')) {
- img.dataset.originalSrc = img.src; // Save original src
- img.src = img.getAttribute('data-animated'); // Switch to animated src
- }
- });
- });
-
- card.addEventListener('mouseleave', function () {
- const imgs = card.querySelectorAll('img');
- imgs.forEach(img => {
- if (img.hasAttribute('data-animated') && img.dataset.originalSrc) {
- img.src = img.dataset.originalSrc; // Restore original src
- }
- });
- });
-
- card.addEventListener('click', () => openModal(item, sku, price, priceNitro));
-
- return card;
- }
-
-
- // Function to open the modal
- function openModal(item, sku, price, priceNitro) {
- let description = item.summary; // Default description for non-bundle items
-
- // If the item is a bundle, construct the description
- if (item.bundled_products && Array.isArray(item.bundled_products)) {
- let decoName = '', effectName = '';
-
- // Loop through bundled products to find decoration and effect names
- item.bundled_products.forEach(bundledItem => {
- if (bundledItem.item_type === 'deco') {
- decoName = bundledItem.name;
- } else if (bundledItem.item_type === 'effect') {
- effectName = bundledItem.name;
- }
- });
-
- // Create bundle description if both decoration and effect exist
- if (decoName && effectName) {
- description = `Bundle Includes: ${decoName} Decoration & ${effectName} Profile Effect`;
- }
- }
-
- const modalContent = `
-
-
-
SKU ID: ${sku}
-
${item.name}
-
${description}
-
-
${price}
-
${priceNitro}
-
-
-
- Unable to confirm item availability
-
-
-
-
- ${item.bundled_products && Array.isArray(item.bundled_products) ?
- item.bundled_products.map(bundledItem => `
-
-
-
- `).join('') :
- `
-
-
`
- }
-
-
- `;
-
- const modal = document.createElement('div');
- modal.classList.add('shop-item-info-modal');
-
- // Append modal content
- modal.innerHTML = modalContent;
-
- // Add show class for animation
- setTimeout(() => {
- modal.classList.add('show');
- }, 10); // Slight delay to trigger the animation
-
- // Close modal when clicked outside the modal content
- modal.addEventListener('click', (event) => {
- if (event.target === modal) {
- modal.classList.remove('show'); // Start close animation
- modal.addEventListener('transitionend', () => modal.remove()); // Remove after animation
- }
- });
-
- // Add hover effect for animated images
- const modalRight = modal.querySelector('.modal-right');
- modalRight.addEventListener('mouseenter', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const animatedSrc = img.getAttribute('data-animated');
- if (animatedSrc) {
- img.src = animatedSrc; // Change to animated image
- }
- });
- });
-
- modalRight.addEventListener('mouseleave', () => {
- modalRight.querySelectorAll('img').forEach(img => {
- const staticSrc = img.getAttribute('data-static');
- if (staticSrc) {
- img.src = staticSrc; // Revert to static image
- }
- });
- });
-
- document.body.appendChild(modal);
- }
-
- // Function to get image type based on item properties
- function getImageType(item) {
- // Check if the item has a type field and return appropriate ID
- if (item.item_type === 'deco') {
- return 'avatar-decoration'; // Change this to match your needs
- } else if (item.item_type === 'effect') {
- return 'profile-effect'; // Change this to match your needs
- } else if (item.bundled_products) {
- return 'bundle'; // For bundles
- }
- return 'unknown-type'; // Fallback for undefined types
- }
-
-
-
-
- // Display the products in the order they appear in the API
- user.products.forEach(product => {
- const isNew = product.isNew === "true";
- const sku = product.sku_id || ""; // Get SKU from the product
- const price = product.price || "";
- const priceNitro = product.price_nitro || "";
-
- // Check if the product is a bundle
- if (product.bundled_products) {
- cardHolder.appendChild(createCard(product, sku, price, priceNitro, true, isNew));
- } else {
- // Handle individual items
- product.items.forEach(item => {
- cardHolder.appendChild(createCard(item, sku, price, priceNitro, false, isNew));
- });
- }
- });
-
- document.getElementById("shop-category-loading").classList.add('hidden');
- output.append(category);
- });
- })
- .catch(error => {
- console.error('Error fetching the API:', error);
- document.getElementById("failed-to-load-shop").classList.remove('hidden');
- document.getElementById("shop-category-loading").classList.add('hidden');
- });
diff --git a/blog/1/index.html b/blog/1/index.html
deleted file mode 100644
index a8e1f7f..0000000
--- a/blog/1/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/2/index.html b/blog/2/index.html
deleted file mode 100644
index 027cc66..0000000
--- a/blog/2/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/2024-recap/index.html b/blog/2024-recap/index.html
deleted file mode 100644
index 6c16f40..0000000
--- a/blog/2024-recap/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/3/index.html b/blog/3/index.html
deleted file mode 100644
index 1a50dd0..0000000
--- a/blog/3/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/4/index.html b/blog/4/index.html
deleted file mode 100644
index ef13def..0000000
--- a/blog/4/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/5/index.html b/blog/5/index.html
deleted file mode 100644
index ec6427b..0000000
--- a/blog/5/index.html
+++ /dev/null
@@ -1,9 +0,0 @@
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/blog/index.html b/blog/index.html
deleted file mode 100644
index 9d5925b..0000000
--- a/blog/index.html
+++ /dev/null
@@ -1,93 +0,0 @@
-
-
-
-
-
-
Blog | Shop Archives
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/configs.js b/configs.js
new file mode 100644
index 0000000..a9eb147
--- /dev/null
+++ b/configs.js
@@ -0,0 +1,421 @@
+
+const endpoints = {
+ MAIN: "https://api.yapper.shop/",
+ VERSION: "v3",
+ VERIFY_ORIGIN: "/heartbeat",
+ SERVER_EXPERIMENTS: "/experiments",
+ USER: "/users/@me",
+
+ STABLE_LOGIN_CALLBACK: "/callback",
+ DEV_LOGIN_CALLBACK: "/dev/callback",
+ BETA_LOGIN_CALLBACK: "/beta/callback",
+
+ USER_LOGIN: "/user-login",
+
+
+ DISCORD_PROFILE_EFFECTS: "/discord-profile-effects",
+ DISCORD_LEAKED_CATEGORIES: "/discord-leaked-categories",
+ DISCORD_COLLECTIBLES_HOME: "/discord-collectibles-home",
+ DISCORD_COLLECTIBLES_CATEGORIES: "/discord-collectibles-categories",
+ DISCORD_ORBS_CATEGORIES: "/discord-orbs-categories",
+ DISCORD_POTIONS: "/discord-consumables",
+ DISCORD_MISCELLANEOUS_CATEGORIES: "/discord-miscellaneous-categories",
+ CATEGORY_MODAL_INFO: "/category/",
+ CATEGORY_MODAL_REVIEW: "/review",
+ CATEGORY_MODAL_REVIEW_DELETE: "/reviews/"
+};
+
+const redneredAPI = endpoints.MAIN + endpoints.VERSION;
+
+const item_types = {
+ NONE: 100,
+ AVATAR_DECORATION: 0,
+ PROFILE_EFFECT: 1,
+ NAMEPLATE: 2,
+ BUNDLE: 1e3,
+ VARIANTS_GROUP: 2e3,
+ EXTERNAL_SKU: 3e3
+};
+
+const category_types = {
+ HERO: 0,
+ FEATURED: 1,
+ FEED: 2,
+ WIDE_BANNER: 3
+};
+
+const discord_categories = {
+ FANTASY: "1144003461608906824",
+ ANIME: "1144302037593497701",
+ BREAKFAST: "1144054000099012659",
+ DISXCORE: "1144058340327047249",
+ FALL: "1157406994873991284",
+ HALLOWEEN: "1157410718711304313",
+ WINTER: "1174459301239197856",
+ MONSTERS: "1179493515038818325",
+ CYBERPUNK: "1197342727608746044",
+ LUNAR_NEW_YEAR: "1202069709281828935",
+ ELEMENTS: "1207046915880124426",
+ ANIME_V2: "1212565175790473246",
+ SPECIAL_EVENTS: "1217175518781243583",
+ SPECIAL_EVENTS_2: "1309309974266118144",
+ SPRINGTOONS: "1217622942175727736",
+ SHY: "1220513972189663413",
+ LOFI_VIBES: "1228243842684162121",
+ GALAXY: "1232029045928099922",
+ FEELIN_RETRO: "1237649643073044491",
+ PIRATES: "1237653589896200272",
+ ARCADE: "1245086656973901894",
+ TIDE: "1252404112650407998",
+ DARK_FANTASY: "1256321669388308595",
+ ROBERT: "1262491137386614805",
+ STORM: "1265375293397270650",
+ DOJO: "1266520267946201099",
+ THE_VAULT: "1277733175191277721",
+ AUTUMN_EQUINOX: "1282816432056569866",
+ BAND: "1285465421339693076",
+ SPOOKY_NIGHT: "1287835634089594972",
+ CHANCE: "1293373563494993952",
+ MYTHICAL_CREATURES: "1298033986811068497",
+ WARRIOR: "1303490165284802580",
+ KAWAII_MODE: "1306330663213072494",
+ LOFI_GIRL: "1309668861943218229",
+ WINTER_WONDERLAND: "1314020997204283476",
+ FANTASY_V2: "1324454241254903829",
+ STEAMPUNK: "1326333074241486859",
+ PROGRESS: "1333278032999485461",
+ RADIATE: "1336483992429658112",
+ VALENTINES: "1333866045521395723",
+ ORB: "1332505418219655258",
+ ANIME_V3: "1341506445249609728",
+ INSOMNIA: "1343751621364027462",
+ NAMEPLATE_TEST: "1344802365307621427",
+ AESPA: "1346499610977243196",
+ NAMEPLATE: "1349849614353829990",
+ HOLIDAYS: "1349486948942745691",
+ SHENANIGANS: "1352407446500675708",
+ CHIBI_CAFE: "1354894010849820852",
+ GGEZ: "1357589632723849316",
+ HELLO: "1365410896222097539",
+ COZY_VALLEY: "1369434230962262128",
+ RC_TEST: "1370467303782617118",
+ LEAF: "1373015260595884082",
+ NAMEPLATE_V2: "1377377712200744990",
+ SPELL: "1379220459316445257"
+};
+
+const category_client_overrides = [
+ {
+ sku_id: discord_categories.FANTASY,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.ANIME,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.BREAKFAST,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.DISXCORE,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.FALL,
+ banner_verification: "1157407583993339935",
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.HALLOWEEN,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.WINTER,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.MONSTERS,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.CYBERPUNK,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.LUNAR_NEW_YEAR,
+ banner_verification: "1202069953306689626",
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.ELEMENTS,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.ANIME_V2,
+ addLogo: !0,
+ addAttributionLogo: !0,
+ showDarkBannerText: !0
+ },
+ {
+ sku_id: discord_categories.SPRINGTOONS,
+ addLogo: !0,
+ addAttributionLogo: !0,
+ showDarkBannerText: !0
+ },
+ {
+ sku_id: discord_categories.SHY,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.LOFI_VIBES,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.GALAXY,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.FEELIN_RETRO,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.PIRATES,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.ARCADE,
+ addLogo: !0
+ },
+ {
+ sku_id: discord_categories.TIDE,
+ addLogo: !0,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.DARK_FANTASY,
+ addAttributionLogo: !0
+ },
+ {
+ sku_id: discord_categories.ROBERT,
+ showDarkBannerText: !0
+ },
+ {
+ sku_id: discord_categories.DOJO,
+ showDarkBannerText: !0
+ },
+ {
+ sku_id: discord_categories.BAND,
+ animatedBanner: "https://cdn.discordapp.com/assets/content/7e328a07e057745faad2366c9ebdf03e2bd69d22dfe8d41c81a10d29a8de7cf7.png"
+ },
+ {
+ sku_id: discord_categories.WARRIOR,
+ animatedBanner: "https://cdn.discordapp.com/assets/content/db9fb34f490b777a6e9712b129f9e23ad930595d2df73ca85d2b54f247806e01.png"
+ },
+ {
+ sku_id: discord_categories.KAWAII_MODE,
+ showDarkBannerText: !0,
+ heroBanner: {
+ darker: !0,
+ gradientLeft: "linear-gradient(284deg, rgba(228, 23, 180, 0.00) 29.64%, rgba(228, 23, 180, 0.30) 68.69%)",
+ gradientRight: "linear-gradient(76deg, rgba(228, 23, 180, 0.00) 29.64%, rgba(228, 23, 180, 0.30) 68.69%)",
+ animationSource: "https://cdn.discordapp.com/assets/collectibles/drops/kawaii_mode/hero_banner.webm"
+ },
+ animatedBanner: "https://cdn.discordapp.com/assets/collectibles/drops/kawaii_mode/banner_animated.webm"
+ },
+ {
+ sku_id: discord_categories.LOFI_GIRL,
+ heroBanner: {
+ animationSource: "https://cdn.discordapp.com/assets/collectibles/drops/lofi_girl/hero_banner.webm"
+ },
+ animatedBanner: "https://cdn.discordapp.com/assets/collectibles/drops/lofi_girl/banner_animated.webm"
+ },
+ {
+ sku_id: discord_categories.NAMEPLATE,
+ animatedBanner: "https://cdn.discordapp.com/assets/content/6f72be1e45f627e6b43894ca7dcda02c2851a3120a643a85c5132e87af6b50c4.webm"
+ }
+];
+
+const nameplate_palettes = {
+ crimson: {
+ "darkBackground": "#900007",
+ "lightBackground": "#E7040F"
+ },
+ berry: {
+ "darkBackground": "#893A99",
+ "lightBackground": "#B11FCF"
+ },
+ sky: {
+ "darkBackground": "#0080B7",
+ "lightBackground": "#56CCFF"
+ },
+ teal: {
+ "darkBackground": "#086460",
+ "lightBackground": "#7DEED7"
+ },
+ forest: {
+ "darkBackground": "#2D5401",
+ "lightBackground": "#6AA624"
+ },
+ bubble_gum: {
+ "darkBackground": "#DC3E97",
+ "lightBackground": "#F957B3"
+ },
+ violet: {
+ "darkBackground": "#730BC8",
+ "lightBackground": "#972FED"
+ },
+ cobalt: {
+ "darkBackground": "#0131C2",
+ "lightBackground": "#4278FF"
+ },
+ clover: {
+ "darkBackground": "#047B20",
+ "lightBackground": "#63CD5A"
+ }
+};
+
+const experiments = [
+ {
+ title: `Published Items Category`,
+ codename: `published_items_category`,
+ release_config: {
+ year: `2025`,
+ month: `06`
+ },
+ treatments: [
+ {
+ title: `Not Eligible`
+ },
+ {
+ title: `Show Published Items Category In Misc Tab`
+ }
+ ]
+ },
+ {
+ title: `Advanced Theme Picker`,
+ codename: `advanced_theme_picker`,
+ release_config: {
+ year: `2025`,
+ month: `06`
+ },
+ treatments: [
+ {
+ title: `Not Eligible`
+ },
+ {
+ title: `Enabled`
+ }
+ ]
+ },
+ {
+ title: `XP System`,
+ codename: `xp_system`,
+ release_config: {
+ year: `2025`,
+ month: `05`
+ },
+ treatments: [
+ {
+ title: `Not Eligible`
+ },
+ {
+ title: `Enabled`
+ }
+ ]
+ }
+];
+
+const external_skus = {
+ ORB_PROFILE_BADGE: "1342211853484429445",
+ NITRO_CREDITS_3_DAYS: "1333912750274904064"
+};
+
+const defaultThemes = [
+ {
+ name: "Dark",
+ codename: "dark",
+ summary: "Easy on the eyes.",
+ color: "#2B2D31",
+ src: ""
+ },
+ {
+ name: "Midnight",
+ codename: "midnight",
+ summary: "Perfect for late-night browsing.",
+ color: "#000000",
+ src: ""
+ }
+];
+
+const reviews_system_types = [
+ {
+ id: 1,
+ codename: "info"
+ },
+ {
+ id: 2,
+ codename: "critical"
+ },
+ {
+ id: 3,
+ codename: "warning"
+ },
+ {
+ id: 4,
+ codename: "positive"
+ }
+];
+
+const settings = {
+ "non_us_timezone": 0,
+ "profile_effect_tweaks_fix": 0,
+ "dev": 0,
+ "staff_force_leaks_dummy": 0,
+ "staff_force_viewable_reviews_tab": 0,
+ "staff_simulate_ban_type_1": 0,
+ "staff_simulate_ban_type_2": 0,
+ "staff_simulate_guidelines_block": 0
+};
+
+const leaks_dummy_data = {
+ version: 0,
+ categories: [
+ {
+ "sku_id": "0",
+ "name": "Leaks Dummy Category",
+ "summary": null,
+ "store_listing_id": null,
+ "banner": null,
+ "unpublished_at": null,
+ "styles": null,
+ "logo": null,
+ "hero_ranking": null,
+ "mobile_bg": null,
+ "pdp_bg": null,
+ "success_modal_bg": null,
+ "mobile_banner": null,
+ "featured_block": null,
+ "hero_banner": null,
+ "wide_banner": null,
+ "hero_logo": null,
+ "products": []
+ }
+ ]
+};
diff --git a/home/index.html b/home/index.html
deleted file mode 100644
index 292bb30..0000000
--- a/home/index.html
+++ /dev/null
@@ -1,249 +0,0 @@
-
-
-
-
-
-
Home | Shop Archives
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
What's new on Discord
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
What's new for Profiles Plus
-
-
-
-
-
-
-
-
-
Popular Picks
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/index.html b/index.html
index c5e944d..c8e6d16 100644
--- a/index.html
+++ b/index.html
@@ -1,76 +1,299 @@
-
-
-
Loading... | Shop Archives
-
-
-
-
-
-
-
-
-
-
-
-