footer.js 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. const html = require('choo/html');
  2. const Component = require('choo/component');
  3. const version = require('../../package.json').version;
  4. const { browserName } = require('../utils');
  5. class Footer extends Component {
  6. constructor(name, state) {
  7. super(name);
  8. this.state = state;
  9. }
  10. update() {
  11. return false;
  12. }
  13. createElement() {
  14. const translate = this.state.translate;
  15. const browser = browserName();
  16. const feedbackUrl = `https://qsurvey.mozilla.com/s3/txp-firefox-send?ver=${version}&browser=${browser}`;
  17. return html`
  18. <footer
  19. class="flex flex-col md:flex-row items-start w-full flex-none self-start p-6 font-medium text-xs text-grey-dark md:items-center justify-between bg-grey-lightest"
  20. >
  21. <a
  22. class="mozilla-logo pb-10 md:pb-0 m-2"
  23. href="https://www.mozilla.org/"
  24. >
  25. Mozilla
  26. </a>
  27. <ul
  28. class="list-reset flex flex-col md:flex-row items-start md:items-center md:justify-end"
  29. >
  30. <li class="m-2">
  31. <a href="https://www.mozilla.org/about/legal">
  32. ${translate('footerLinkLegal')}
  33. </a>
  34. </li>
  35. <li class="m-2">
  36. <a href="/legal"> ${translate('footerLinkTerms')} </a>
  37. </li>
  38. <li class="m-2">
  39. <a href="https://www.mozilla.org/privacy/websites/#cookies">
  40. ${translate('footerLinkCookies')}
  41. </a>
  42. </li>
  43. <li class="m-2">
  44. <a href="https://www.mozilla.org/about/legal/report-infringement/">
  45. ${translate('reportIPInfringement')}
  46. </a>
  47. </li>
  48. <li class="m-2">
  49. <a href="https://github.com/mozilla/send">GitHub </a>
  50. </li>
  51. <li class="m-2">
  52. <a
  53. href="${feedbackUrl}"
  54. rel="noreferrer noopener"
  55. class="feedback-link"
  56. alt="Feedback"
  57. target="_blank"
  58. >
  59. ${translate('siteFeedback')}
  60. </a>
  61. </li>
  62. </ul>
  63. </footer>
  64. `;
  65. }
  66. }
  67. module.exports = Footer;