aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/Footer/Footer.tsx
blob: 15a4660102873abf4b1cbce4a9efa5e53c369bf9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import { ButtonLink } from '@components/Buttons';
import Copyright from '@components/Copyright/Copyright';
import FooterNav from '@components/FooterNav/FooterNav';
import { ArrowIcon } from '@components/Icons';
import { t } from '@lingui/macro';
import { useEffect, useState } from 'react';
import styles from './Footer.module.scss';

const Footer = () => {
  const [backToTopClasses, setBackToTopClasses] = useState(
    `${styles['back-to-top']} ${styles['back-to-top--hidden']}`
  );

  const handleScroll = () => {
    const currentScrollY = window.scrollY;

    if (currentScrollY > 300) {
      setBackToTopClasses(
        `${styles['back-to-top']} ${styles['back-to-top--visible']}`
      );
    } else {
      setBackToTopClasses(
        `${styles['back-to-top']} ${styles['back-to-top--hidden']}`
      );
    }
  };

  useEffect(() => {
    window.addEventListener('scroll', handleScroll);
    return () => window.removeEventListener('scroll', handleScroll);
  }, []);

  return (
    <footer className={styles.wrapper}>
      <Copyright />
      <FooterNav />
      <div className={backToTopClasses}>
        <ButtonLink target="#top" position="center">
          <span className="screen-reader-text">{t`Back to top`}</span>
          <ArrowIcon direction="top" />
        </ButtonLink>
      </div>
    </footer>
  );
};

export default Footer;
Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
import { ComponentMeta, ComponentStory } from '@storybook/react';
import ImageWidget from './image-widget';

/**
 * ImageWidget - Storybook Meta
 */
export default {
  title: 'Organisms/Widgets/Image',
  component: ImageWidget,
  args: {
    alignment: 'left',
  },
  argTypes: {
    alignment: {
      control: {
        type: 'select',
      },
      description: 'The content alignment.',
      options: ['left', 'center', 'right'],
      table: {
        category: 'Options',
        defaultValue: { summary: 'left' },
      },
      type: {
        name: 'string',
        required: false,
      },
    },
    className: {
      control: {
        type: 'text',
      },
      description: 'Set additional classnames to the widget wrapper.',
      table: {
        category: 'Styles',
      },
      type: {
        name: 'string',
        required: false,
      },
    },
    description: {
      control: {
        type: 'text',
      },
      description: 'Add a caption image.',
      table: {
        category: 'Options',
      },
      type: {
        name: 'string',
        required: false,
      },
    },
    expanded: {
      control: {
        type: 'boolean',
      },
      description: 'The state of the widget.',
      type: {
        name: 'boolean',
        required: true,
      },
    },
    image: {
      description: 'An image object.',
      type: {
        name: 'object',
        required: true,
        value: {},
      },
    },
    imageClassName: {
      control: {
        type: 'text',
      },
      description: 'Set additional classnames to the image wrapper.',
      table: {
        category: 'Styles',
      },
      type: {
        name: 'string',
        required: false,
      },
    },
    level: {
      control: {
        type: 'number',
        min: 1,
        max: 6,
      },
      description: 'The widget title level (hn).',
      type: {
        name: 'number',
        required: true,
      },
    },
    title: {
      control: {
        type: 'text',
      },
      description: 'The widget title.',
      type: {
        name: 'string',
        required: true,
      },
    },
    url: {
      control: {
        type: 'text',
      },
      description: 'Add a link to the image.',
      table: {
        category: 'Options',
      },
      type: {
        name: 'string',
        required: false,
      },
    },
  },
} as ComponentMeta<typeof ImageWidget>;

const Template: ComponentStory<typeof ImageWidget> = (args) => (
  <ImageWidget {...args} />
);

const image = {
  alt: 'Et perferendis quaerat',
  height: 480,
  src: 'http://placeimg.com/640/480/nature',
  width: 640,
};

/**
 * ImageWidget Stories - Align left
 */
export const AlignLeft = Template.bind({});
AlignLeft.args = {
  alignment: 'left',
  expanded: true,
  image,
  level: 2,
  title: 'Quo et totam',
};

/**
 * ImageWidget Stories - Align center
 */
export const AlignCenter = Template.bind({});
AlignCenter.args = {
  alignment: 'center',
  expanded: true,
  image,
  level: 2,
  title: 'Quo et totam',
};

/**
 * ImageWidget Stories - Align right
 */
export const AlignRight = Template.bind({});
AlignRight.args = {
  alignment: 'right',
  expanded: true,
  image,
  level: 2,
  title: 'Quo et totam',
};

/**
 * ImageWidget Stories - With description
 */
export const WithDescription = Template.bind({});
WithDescription.args = {
  description: 'Sint enim harum',
  expanded: true,
  image,
  level: 2,
  title: 'Quo et totam',
};