From 4f0e9312ec671a5bc20d80b0b8f34c60cab27ff5 Mon Sep 17 00:00:00 2001 From: D3SOX Date: Tue, 7 May 2024 10:04:53 +0200 Subject: [PATCH] feat(betterActivities): allow showing all activities below each other --- src/plugins/betterActivities/index.tsx | 154 ++++++++++++++++--------- 1 file changed, 97 insertions(+), 57 deletions(-) diff --git a/src/plugins/betterActivities/index.tsx b/src/plugins/betterActivities/index.tsx index f6b35ebff..1c7699813 100644 --- a/src/plugins/betterActivities/index.tsx +++ b/src/plugins/betterActivities/index.tsx @@ -64,6 +64,21 @@ const settings = definePluginSettings({ default: true, restartNeeded: false, }, + allActivitiesStyle: { + type: OptionType.SELECT, + description: "Style for showing all activities", + options: [ + { + default: true, + label: "Carousel", + value: "carousel", + }, + { + label: "List", + value: "list", + }, + ] + } }); const cl = classNameFactory("vc-bactivities-"); @@ -364,69 +379,94 @@ export default definePlugin({ if (!activities.length) return null; - return ( -
- + if (settings.store.allActivitiesStyle === "carousel") { + return ( +
+ +
+ {({ + onMouseEnter, + onMouseLeave + }) => { + return { + const index = activities.indexOf(currentActivity!); + if (index - 1 >= 0) + setCurrentActivity(activities[index - 1]); + }} + > + + ; + }} + +
+ {activities.map((activity, index) => ( +
setCurrentActivity(activity)} + className={`dot ${currentActivity === activity ? "selected" : ""}`}/> + ))} +
+ + {({ + onMouseEnter, + onMouseLeave + }) => { + return { + const index = activities.indexOf(currentActivity!); + if (index + 1 < activities.length) + setCurrentActivity(activities[index + 1]); + }} + > + = activities.length - 1} + direction="right"/> + ; + }} +
+
+ ); + } else { + return (
- {({ onMouseEnter, onMouseLeave }) => { - return { - const index = activities.indexOf(currentActivity!); - if (index - 1 >= 0) - setCurrentActivity(activities[index - 1]); - }} - > - - ; - }} - -
- {activities.map((activity, index) => ( -
setCurrentActivity(activity)} - className={`dot ${currentActivity === activity ? "selected" : ""}`} - /> - ))} -
- - {({ onMouseEnter, onMouseLeave }) => { - return { - const index = activities.indexOf(currentActivity!); - if (index + 1 < activities.length) - setCurrentActivity(activities[index + 1]); - }} - > - = activities.length - 1} - direction="right" - /> - ; - }} + {activities.map((activity, index) => ( + + ))}
-
- ); + ); + } }, patches: [