@comicrelief/component-library 7.0.2 → 7.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -42,8 +42,7 @@ function getAnimationSettings(originXA, originXB) {
42
42
  y: Math.random() - 0.2
43
43
  }
44
44
  };
45
- } // TODO: Refactor this into an atom
46
-
45
+ }
47
46
 
48
47
  function Confetti(_ref) {
49
48
  var trigger = _ref.trigger,
@@ -0,0 +1,15 @@
1
+ # Confetti
2
+
3
+ ```js
4
+ import React, { useState } from 'react';
5
+ import Confetti from './Confetti';
6
+
7
+ const [isConfetti, setIsConfetti] = useState(false);
8
+
9
+ const handleConfettiTrigger = () => setIsConfetti(!isConfetti);
10
+
11
+ <>
12
+ <Confetti trigger={isConfetti} />
13
+ <button type="button" onClick={handleConfettiTrigger}>trigger confetti</button>
14
+ </>
15
+ ```
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = TriggerConfetti;
9
+
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
11
+
12
+ var _react = _interopRequireWildcard(require("react"));
13
+
14
+ var _Confetti = _interopRequireDefault(require("./Confetti"));
15
+
16
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
17
+
18
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
19
+
20
+ function TriggerConfetti() {
21
+ var _useState = (0, _react.useState)(false),
22
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
23
+ isConfetti = _useState2[0],
24
+ setIsConfetti = _useState2[1];
25
+
26
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Confetti.default, {
27
+ trigger: isConfetti
28
+ }), /*#__PURE__*/_react.default.createElement("button", {
29
+ type: "button",
30
+ onClick: function onClick() {
31
+ return setIsConfetti(!isConfetti);
32
+ }
33
+ }, "trigger confetti"));
34
+ }
@@ -28,7 +28,8 @@ var EmailSignUpForm = function EmailSignUpForm() {
28
28
  resolver: (0, _yup.yupResolver)(validationSchema)
29
29
  });
30
30
  var handleSubmit = formMethods.handleSubmit,
31
- trigger = formMethods.trigger;
31
+ trigger = formMethods.trigger,
32
+ setError = formMethods.setError;
32
33
 
33
34
  function handleSubscribe(_x) {
34
35
  return _handleSubscribe.apply(this, arguments);
@@ -50,6 +51,10 @@ var EmailSignUpForm = function EmailSignUpForm() {
50
51
  if (valid) {
51
52
  // eslint-disable-next-line no-console
52
53
  console.log(data);
54
+ } else {
55
+ setError('formError', {
56
+ message: 'Error'
57
+ });
53
58
  }
54
59
 
55
60
  case 4:
@@ -33,7 +33,7 @@ var _EmailSignUpConfig = require("./_EmailSignUpConfig");
33
33
 
34
34
  var _ErrorText = _interopRequireDefault(require("../../Atoms/ErrorText/ErrorText"));
35
35
 
36
- var _Confetti = _interopRequireDefault(require("./_Confetti"));
36
+ var _Confetti = _interopRequireDefault(require("../../Atoms/Confetti/Confetti"));
37
37
 
38
38
  var _excluded = ["title", "topCopy", "successCopy", "privacyCopy", "backgroundColour", "buttonColour", "formContext", "columnLayout"];
39
39
 
@@ -94,9 +94,7 @@ var EmailSignUp = function EmailSignUp(_ref) {
94
94
  loading: isSubmitting,
95
95
  loadingText: "Submitting...",
96
96
  "data-test": "subscribe-button"
97
- }, /*#__PURE__*/_react.default.createElement(_Text.default, null, "Subscribe")))), isSubmitted && !isSubmitSuccessful && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, Object.values(errors).map(function (error) {
98
- return /*#__PURE__*/_react.default.createElement(_ErrorText.default, null, error.message);
99
- })), /*#__PURE__*/_react.default.createElement(_EmailSignUp.PrivacyCopyWrapper, null, /*#__PURE__*/_react.default.createElement(_Text.default, null, privacyCopy)));
97
+ }, /*#__PURE__*/_react.default.createElement(_Text.default, null, "Subscribe")))), isSubmitted && !isSubmitSuccessful && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, errors.formError !== undefined && /*#__PURE__*/_react.default.createElement(_ErrorText.default, null, errors.formError.message)), /*#__PURE__*/_react.default.createElement(_EmailSignUp.PrivacyCopyWrapper, null, /*#__PURE__*/_react.default.createElement(_Text.default, null, privacyCopy)));
100
98
  };
101
99
 
102
100
  exports.EmailSignUp = EmailSignUp;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@comicrelief/component-library",
3
3
  "author": "Comic Relief Engineering Team",
4
- "version": "7.0.2",
4
+ "version": "7.1.0",
5
5
  "main": "dist/index.js",
6
6
  "license": "ISC",
7
7
  "jest": {
@@ -30,7 +30,7 @@ function getAnimationSettings(originXA, originXB) {
30
30
  }
31
31
  };
32
32
  }
33
- // TODO: Refactor this into an atom
33
+
34
34
  export default function Confetti({ trigger, duration }) {
35
35
  const refAnimationInstance = useRef(null);
36
36
  const [intervalId, setIntervalId] = useState();
@@ -0,0 +1,15 @@
1
+ # Confetti
2
+
3
+ ```js
4
+ import React, { useState } from 'react';
5
+ import Confetti from './Confetti';
6
+
7
+ const [isConfetti, setIsConfetti] = useState(false);
8
+
9
+ const handleConfettiTrigger = () => setIsConfetti(!isConfetti);
10
+
11
+ <>
12
+ <Confetti trigger={isConfetti} />
13
+ <button type="button" onClick={handleConfettiTrigger}>trigger confetti</button>
14
+ </>
15
+ ```
@@ -0,0 +1,15 @@
1
+ import React, { useState } from 'react';
2
+ import Confetti from './Confetti';
3
+
4
+ export default function TriggerConfetti() {
5
+ const [isConfetti, setIsConfetti] = useState(false);
6
+
7
+ return (
8
+
9
+ <>
10
+ <Confetti trigger={isConfetti} />
11
+ <button type="button" onClick={() => setIsConfetti(!isConfetti)}>trigger confetti</button>
12
+ </>
13
+
14
+ );
15
+ }
@@ -14,7 +14,7 @@ const EmailSignUpForm = () => {
14
14
  mode: 'onBlur',
15
15
  resolver: yupResolver(validationSchema)
16
16
  });
17
- const { handleSubmit, trigger } = formMethods;
17
+ const { handleSubmit, trigger, setError } = formMethods;
18
18
 
19
19
  async function handleSubscribe(data) {
20
20
  const valid = await trigger([
@@ -25,6 +25,8 @@ const EmailSignUpForm = () => {
25
25
  if (valid) {
26
26
  // eslint-disable-next-line no-console
27
27
  console.log(data);
28
+ } else {
29
+ setError('formError', { message: 'Error' });
28
30
  }
29
31
  }
30
32
  const title = 'Stay in the know!';
@@ -15,7 +15,7 @@ import ButtonWithStates from '../../Atoms/ButtonWithStates/ButtonWithStates';
15
15
  import Text from '../../Atoms/Text/Text';
16
16
  import { buildEsuValidationSchema, ESU_FIELDS } from './_EmailSignUpConfig';
17
17
  import ErrorText from '../../Atoms/ErrorText/ErrorText';
18
- import Confetti from './_Confetti';
18
+ import Confetti from '../../Atoms/Confetti/Confetti';
19
19
 
20
20
  const EmailSignUp = ({
21
21
  title,
@@ -100,14 +100,11 @@ const EmailSignUp = ({
100
100
  )}
101
101
  {isSubmitted && !isSubmitSuccessful && (
102
102
  <>
103
- {/*
104
- Field errors will prevent submission,
105
- so theoretically this should just be a single error set in the submission callback
106
- with with RHF's `setError` method, but will neatly display multiple errors.
107
- */}
108
- {Object.values(errors).map(error => (
109
- <ErrorText>{error.message}</ErrorText>
110
- ))}
103
+ {/* This error can be set as part of the submit callback using RHF's `setError` function.
104
+ e.g. setError('formError', { message: 'Some error message'}) */}
105
+ {errors.formError !== undefined && (
106
+ <ErrorText>{errors.formError.message}</ErrorText>
107
+ )}
111
108
  </>
112
109
  )}
113
110