diff --git a/frontend/pages/events/[id]/about.vue b/frontend/pages/events/[id]/about.vue index cb8ecb67a..893473709 100644 --- a/frontend/pages/events/[id]/about.vue +++ b/frontend/pages/events/[id]/about.vue @@ -67,10 +67,7 @@ :event="event" /> { textExpanded.value = !textExpanded.value; }; -const currentWidth = ref(window.innerWidth); -let resizeTimeout: ReturnType | null = null; +const windowWidth = ref(window.innerWidth); + const shareButtonLabel = ref(""); function updateShareBtnLabel() { - if (currentWidth.value < Breakpoint.SMALL) { + windowWidth.value = window.innerWidth; + if (windowWidth.value < Breakpoint.SMALL) { shareButtonLabel.value = "components.btn-action.share"; } else { shareButtonLabel.value = "components._global.share-group"; @@ -115,28 +113,16 @@ function updateShareBtnLabel() { } onMounted(() => { - window.addEventListener("resize", handleResize); + window.addEventListener("resize", updateShareBtnLabel); updateShareBtnLabel(); }); -const isUnderLargeBP = ref(false); - -const checkUnderLargeBP = () => { - isUnderLargeBP.value = window.innerWidth < 1024; -}; - -const handleResize = () => { - checkUnderLargeBP(); - - if (resizeTimeout) { - clearTimeout(resizeTimeout); - } - resizeTimeout = setTimeout(updateShareBtnLabel, 100); -}; +onUpdated(() => { + updateShareBtnLabel(); +}); -onMounted(() => { - window.addEventListener("resize", handleResize); - handleResize(); // initial check +onUnmounted(() => { + window.removeEventListener("resize", updateShareBtnLabel); }); const modalIsOpen = ref(false); diff --git a/frontend/pages/organizations/[id]/about.vue b/frontend/pages/organizations/[id]/about.vue index 5a4426633..0a875f3c4 100644 --- a/frontend/pages/organizations/[id]/about.vue +++ b/frontend/pages/organizations/[id]/about.vue @@ -124,30 +124,31 @@ const expandReduceText = () => { textExpanded.value = !textExpanded.value; }; -const currentWidth = ref(window.innerWidth); -let resizeTimeout: ReturnType | null = null; +const windowWidth = ref(window.innerWidth); const shareButtonLabel = ref(""); function updateShareBtnLabel() { - if (currentWidth.value < Breakpoint.SMALL) { + windowWidth.value = window.innerWidth; + if (windowWidth.value < Breakpoint.SMALL) { shareButtonLabel.value = "components.btn-action.share"; } else { shareButtonLabel.value = "components._global.share-organization"; } } -const handleResize = () => { - if (resizeTimeout) { - clearTimeout(resizeTimeout); - } - resizeTimeout = setTimeout(updateShareBtnLabel, 100); -}; - onMounted(() => { - window.addEventListener("resize", handleResize); + window.addEventListener("resize", updateShareBtnLabel); + updateShareBtnLabel(); +}); + +onUpdated(() => { updateShareBtnLabel(); }); +onUnmounted(() => { + window.removeEventListener("resize", updateShareBtnLabel); +}); + // TODO: for testing purpose, should be removed. // const upVotes = ref(123); // const downVotes = ref(123); diff --git a/frontend/pages/organizations/[id]/groups/[id]/about.vue b/frontend/pages/organizations/[id]/groups/[id]/about.vue index 52e1296b3..28f6ad770 100644 --- a/frontend/pages/organizations/[id]/groups/[id]/about.vue +++ b/frontend/pages/organizations/[id]/groups/[id]/about.vue @@ -101,30 +101,31 @@ const expandReduceText = () => { textExpanded.value = !textExpanded.value; }; -const currentWidth = ref(window.innerWidth); -let resizeTimeout: ReturnType | null = null; +const windowWidth = ref(window.innerWidth); const shareButtonLabel = ref(""); function updateShareBtnLabel() { - if (currentWidth.value < Breakpoint.SMALL) { + windowWidth.value = window.innerWidth; + if (windowWidth.value < Breakpoint.SMALL) { shareButtonLabel.value = "components.btn-action.share"; } else { shareButtonLabel.value = "components._global.share-group"; } } -const handleResize = () => { - if (resizeTimeout) { - clearTimeout(resizeTimeout); - } - resizeTimeout = setTimeout(updateShareBtnLabel, 100); -}; - onMounted(() => { - window.addEventListener("resize", handleResize); + window.addEventListener("resize", updateShareBtnLabel); + updateShareBtnLabel(); +}); + +onUpdated(() => { updateShareBtnLabel(); }); +onUnmounted(() => { + window.removeEventListener("resize", updateShareBtnLabel); +}); + const modalIsOpen = ref(false); function openModal() {