From b82f1f465874f54bf97182de668e1c08190f814a Mon Sep 17 00:00:00 2001 From: Sergio Eduardo Castro Ceballos <72516762+SergioCasCeb@users.noreply.github.com> Date: Mon, 4 Nov 2024 03:58:48 +0100 Subject: [PATCH 1/2] Updating the adopters value automatically --- src/components/CommunitySection/index.js | 133 +++++++++++------------ 1 file changed, 63 insertions(+), 70 deletions(-) diff --git a/src/components/CommunitySection/index.js b/src/components/CommunitySection/index.js index c3e8d06..c7f36e9 100644 --- a/src/components/CommunitySection/index.js +++ b/src/components/CommunitySection/index.js @@ -1,16 +1,69 @@ -import React, { useRef, useEffect } from 'react'; +import React, { useRef, useEffect, useState } from 'react'; import { useColorMode } from '@docusaurus/theme-common'; import clsx from 'clsx'; import styles from './styles.module.scss'; -import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { faDiscord } from '@fortawesome/free-brands-svg-icons'; -import { faCloudUpload } from '@fortawesome/free-solid-svg-icons' +import { faCloudUpload } from '@fortawesome/free-solid-svg-icons'; export default function CommunitySection() { const statsContainerRef = useRef(null); const adoptersListRef = useRef(null); + const [adopterCount, setAdopterCount] = useState(0); // New state for adopter count const { colorMode } = useColorMode(); + useEffect(() => { + /** Function to load adopters list and update count **/ + async function loadAdopters() { + const adoptersList = adoptersListRef.current; + + // Clear existing adopters + while (adoptersList.lastElementChild) { + adoptersList.removeChild(adoptersList.lastElementChild); + } + + // Load new adopters list based on color mode + try { + await eclipseFdnAdopters.getList({ + project_id: "iot.thingweb", + selector: ".scroller", + ul_classes: "adopters", + logo_white: colorMode === 'dark' ? true : false, + }); + } catch (error) { + console.error('Error loading adopters list', error); + } + + const adoptersContainer = document.querySelector('.adopters-container'); + const config = { childList: true }; + + /** + * Check for changes in the adopters list container to update the adopter count + * as well as duplicating the adopters list for the scroller effect + */ + const observer = new MutationObserver(() => { + const adopters = document.querySelector('.adopters'); + const adoptersList = Array.from(document.querySelectorAll('.adopters li')); + + setAdopterCount(adoptersList.length); // Update the adopter count + + adoptersList.forEach(adopter => { + const duplicatedAdopter = adopter.cloneNode(true); + duplicatedAdopter.setAttribute('aria-hidden', 'true'); + adopters.appendChild(duplicatedAdopter); + }); + + observer.disconnect(); + }) + + if (adoptersContainer) { + observer.observe(adoptersContainer, config); + } + } + + loadAdopters(); // Call function to load adopters on color mode change + }, [colorMode]); + useEffect(() => { /** Stats counter animation **/ const statsContainer = statsContainerRef.current; @@ -33,22 +86,23 @@ export default function CommunitySection() { let count = target.dataset.count; if (count === 'true') { - target.dataset.count = 'false' + target.dataset.count = 'false'; let startValue = 0; let endValue = parseInt(target.getAttribute('data-val')); let duration = Math.floor(interval / endValue); let counter = setInterval(() => { - startValue++; target.textContent = startValue; if (startValue === endValue) { - if (endValue >= 30) { target.textContent = endValue + "+"; } clearInterval(counter); } + + startValue++; + }, duration); } } @@ -59,66 +113,7 @@ export default function CommunitySection() { startCounter.observe(item); }); } - - /** Adopter scroller */ - const adoptersList = adoptersListRef.current; - - - if (colorMode === 'dark') { - while (adoptersList.lastElementChild) { - adoptersList.removeChild(adoptersList.lastElementChild); - } - try { - eclipseFdnAdopters.getList({ - project_id: "iot.thingweb", - selector: ".scroller", - ul_classes: "adopters", - logo_white: true, - }); - } - catch (error) { - console.error('Error loading adopters list', error); - } - } - else { - while (adoptersList.lastElementChild) { - adoptersList.removeChild(adoptersList.lastElementChild); - } - try { - eclipseFdnAdopters.getList({ - project_id: "iot.thingweb", - selector: ".scroller", - ul_classes: "adopters", - logo_white: false, - }); - } - catch (error) { - console.error('Error loading adopters list', error); - } - } - - const adoptersContainer = document.querySelector('.adopters-container'); - const config = { childList: true }; - - const observer = new MutationObserver(() => { - const adopters = document.querySelector('.adopters'); - const adoptersList = Array.from(document.querySelectorAll('.adopters li')); - - - adoptersList.forEach(adopter => { - const duplicatedAdopter = adopter.cloneNode(true); - duplicatedAdopter.setAttribute('aria-hidden', 'true'); - adopters.appendChild(duplicatedAdopter); - }); - - observer.disconnect(); - }) - - if (adoptersContainer) { - observer.observe(adoptersContainer, config); - } - }, [colorMode]); - + }, [adopterCount]); // Run this effect when adopter count updates return (
@@ -137,7 +132,7 @@ export default function CommunitySection() {
-

0

+

0

Adopters

@@ -162,8 +157,6 @@ export default function CommunitySection() { - -
); -} +} \ No newline at end of file From 2d10a86a3e0addb1862d5c1573ceaa6301b8b60e Mon Sep 17 00:00:00 2001 From: Sergio Eduardo Castro Ceballos <72516762+SergioCasCeb@users.noreply.github.com> Date: Mon, 4 Nov 2024 04:17:24 +0100 Subject: [PATCH 2/2] fix the animation from stopping the value from updating --- src/components/CommunitySection/index.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/components/CommunitySection/index.js b/src/components/CommunitySection/index.js index c7f36e9..93dba76 100644 --- a/src/components/CommunitySection/index.js +++ b/src/components/CommunitySection/index.js @@ -70,6 +70,11 @@ export default function CommunitySection() { if (statsContainer) { const statsItems = document.querySelectorAll('#stats-number'); + //Making sure the animation will run again when the adopter count updates + statsItems.forEach(item => { + item.dataset.count = 'true'; + }); + let interval = 2000; const appearOptions = { threshold: 0,