From 28ac1597c9476648b6b5d3a7c337a712a3594625 Mon Sep 17 00:00:00 2001 From: Walidoux Date: Thu, 4 May 2023 16:13:24 +0100 Subject: [PATCH] feat(components): implement LangDropdown --- .../layout/LangDropdown/LangDropdown.tsx | 51 +++++++++++++++++++ src/components/layout/LangDropdown/index.ts | 1 + 2 files changed, 52 insertions(+) create mode 100644 src/components/layout/LangDropdown/LangDropdown.tsx create mode 100644 src/components/layout/LangDropdown/index.ts diff --git a/src/components/layout/LangDropdown/LangDropdown.tsx b/src/components/layout/LangDropdown/LangDropdown.tsx new file mode 100644 index 0000000..42bd84d --- /dev/null +++ b/src/components/layout/LangDropdown/LangDropdown.tsx @@ -0,0 +1,51 @@ +import type { Component } from 'solid-js' +import { createSignal, For } from 'solid-js' +import { Motion } from '@motionone/solid' + +import { useLocalStorage } from '../../../hooks/useLocalStorage' +import { AnimateView, Flag } from '../../design' +import { OutSideEventHandler } from '../OutSideEventHandler' +import { Animation, SUPPORTED_LANGS } from '../../../config' + +export const LangDropdown: Component = () => { + const { lang, setLang } = useLocalStorage() + + let ref: HTMLDivElement | undefined + const [active, setActive] = createSignal(false) + + return ( + { + return setActive(false) + }}> +
{ + return setActive(!active()) + }}> + Selected Lang: +
+ + + + {(lang, index) => { + return ( + { + setActive(false) + return setLang(lang.domain) + }}> + + + ) + }} + + +
+ ) +} diff --git a/src/components/layout/LangDropdown/index.ts b/src/components/layout/LangDropdown/index.ts new file mode 100644 index 0000000..17427cd --- /dev/null +++ b/src/components/layout/LangDropdown/index.ts @@ -0,0 +1 @@ +export * from './LangDropdown'