diff options
| author | Armand Philippot <git@armandphilippot.com> | 2022-02-23 18:11:37 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-02-23 18:11:37 +0100 | 
| commit | 84903c1e5182124b1bb618b7d8754cb70d0a6647 (patch) | |
| tree | b9202449b4eb17d2ecd93ce53fef76b0eee81f15 /src/components/Form | |
| parent | c9b16994cd697b15ccb66be6879a119cf7bde7f7 (diff) | |
feat: improve Ackee tracking (#11)
* build(deps): add use-ackee hook package
* chore: create a context provider for Ackee
The provider allows users to change the 'detailed' settings.
* chore: add a select menu to choose which info to share with Ackee
* chore: add a tooltip for askee settings
* chore: replace default select styles with custom styles
* chore: register user choice in localstorage
* chore: replace Matomo with Ackee in legal notice
Diffstat (limited to 'src/components/Form')
| -rw-r--r-- | src/components/Form/Label/Label.module.scss | 22 | ||||
| -rw-r--r-- | src/components/Form/Label/Label.tsx | 24 | ||||
| -rw-r--r-- | src/components/Form/Select/Select.module.scss | 23 | ||||
| -rw-r--r-- | src/components/Form/Select/Select.tsx | 56 | ||||
| -rw-r--r-- | src/components/Form/index.tsx | 4 | 
5 files changed, 128 insertions, 1 deletions
| diff --git a/src/components/Form/Label/Label.module.scss b/src/components/Form/Label/Label.module.scss new file mode 100644 index 0000000..c527b16 --- /dev/null +++ b/src/components/Form/Label/Label.module.scss @@ -0,0 +1,22 @@ +@use "@styles/abstracts/functions" as fun; + +.regular { +  display: block; +  color: var(--color-primary-darker); +  font-size: var(--font-size-sm); +  font-variant: small-caps; +  font-weight: 600; +} + +.settings { +  --icon-size: #{fun.convert-px(25)}; +  --toggle-width: #{fun.convert-px(45)}; +  --toggle-height: calc(var(--toggle-width) / 2); + +  display: inline-flex; +  align-items: center; +} + +.required { +  color: var(--color-secondary); +} diff --git a/src/components/Form/Label/Label.tsx b/src/components/Form/Label/Label.tsx new file mode 100644 index 0000000..baedff0 --- /dev/null +++ b/src/components/Form/Label/Label.tsx @@ -0,0 +1,24 @@ +import styles from './Label.module.scss'; + +type LabelKind = 'regular' | 'settings'; + +const Label = ({ +  body, +  htmlFor, +  required = false, +  kind = 'regular', +}: { +  body: string; +  htmlFor: string; +  required?: boolean; +  kind?: LabelKind; +}) => { +  return ( +    <label htmlFor={htmlFor} className={styles[kind]}> +      {body} +      {required && <span className={styles.required}> *</span>} +    </label> +  ); +}; + +export default Label; diff --git a/src/components/Form/Select/Select.module.scss b/src/components/Form/Select/Select.module.scss new file mode 100644 index 0000000..d4a40eb --- /dev/null +++ b/src/components/Form/Select/Select.module.scss @@ -0,0 +1,23 @@ +@use "@styles/abstracts/functions" as fun; + +.wrapper { +  padding: fun.convert-px(3) var(--spacing-xs); +  background: var(--color-bg-tertiary); +  border: fun.convert-px(2) solid var(--color-border); +  box-shadow: fun.convert-px(3) fun.convert-px(3) 0 0 var(--color-shadow); +  cursor: pointer; +  transition: all 0.3s ease-in-out 0s; + +  &:hover { +    box-shadow: fun.convert-px(4) fun.convert-px(4) 0 fun.convert-px(1) +      var(--color-shadow); +    transform: translate(#{fun.convert-px(-2)}, #{fun.convert-px(-2)}); +  } + +  &:focus { +    background: var(--color-bg); +    border-color: var(--color-primary); +    box-shadow: 0 0 0 0 var(--color-shadow); +    transform: translate(#{fun.convert-px(3)}, #{fun.convert-px(3)}); +  } +} diff --git a/src/components/Form/Select/Select.tsx b/src/components/Form/Select/Select.tsx new file mode 100644 index 0000000..feab991 --- /dev/null +++ b/src/components/Form/Select/Select.tsx @@ -0,0 +1,56 @@ +import { ChangeEvent, ReactElement, SetStateAction } from 'react'; +import styles from './Select.module.scss'; + +type SelectOptions = { +  id: string; +  name: string; +  value: string; +}; + +const Select = ({ +  options, +  id, +  name, +  value, +  setValue, +  required = false, +  label, +}: { +  options: SelectOptions[]; +  id: string; +  name: string; +  value: string; +  setValue: (value: SetStateAction<string>) => void; +  required?: boolean; +  label?: ReactElement; +}) => { +  const getOptions = () => { +    return options.map((option) => ( +      <option key={option.id} value={option.value}> +        {option.name} +      </option> +    )); +  }; + +  const handleChange = (event: ChangeEvent<HTMLSelectElement>) => { +    setValue(event.target.value); +  }; + +  return ( +    <> +      {label} +      <select +        name={name} +        id={id} +        value={value} +        onChange={handleChange} +        required={required} +        className={styles.wrapper} +      > +        {getOptions()} +      </select> +    </> +  ); +}; + +export default Select; diff --git a/src/components/Form/index.tsx b/src/components/Form/index.tsx index 0908e9b..cbe1ec4 100644 --- a/src/components/Form/index.tsx +++ b/src/components/Form/index.tsx @@ -1,7 +1,9 @@  import Form from './Form';  import FormItem from './FormItem/FormItem';  import Input from './Input/Input'; +import Label from './Label/Label'; +import Select from './Select/Select';  import TextArea from './TextArea/TextArea';  import Toggle from './Toggle/Toggle'; -export { Form, FormItem, Input, TextArea, Toggle }; +export { Form, FormItem, Input, Label, Select, TextArea, Toggle }; | 
