@ukhomeoffice/cop-react-form-renderer 5.28.0 → 5.29.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.
- package/dist/components/CollectionSummary/BannerStrip.js +59 -0
- package/dist/components/CollectionSummary/BannerStrip.scss +47 -0
- package/dist/components/CollectionSummary/BannerStrip.test.js +111 -0
- package/dist/components/CollectionSummary/CollectionSummary.js +182 -0
- package/dist/components/CollectionSummary/CollectionSummary.scss +21 -0
- package/dist/components/CollectionSummary/CollectionSummary.test.js +121 -0
- package/dist/components/CollectionSummary/Confirmation.js +58 -0
- package/dist/components/CollectionSummary/Confirmation.scss +14 -0
- package/dist/components/CollectionSummary/Confirmation.test.js +102 -0
- package/dist/components/CollectionSummary/SummaryCard.js +274 -0
- package/dist/components/CollectionSummary/SummaryCard.scss +244 -0
- package/dist/components/CollectionSummary/SummaryCard.test.js +1164 -0
- package/dist/components/CollectionSummary/index.js +10 -0
- package/dist/components/FormComponent/FormComponent.js +19 -3
- package/dist/components/FormPage/FormPage.js +10 -3
- package/dist/components/FormRenderer/FormRenderer.js +1 -0
- package/dist/components/FormRenderer/onPageAction.js +5 -14
- package/dist/components/FormRenderer/onPageAction.test.js +3 -6
- package/dist/models/ComponentTypes.js +2 -0
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +1 -1
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +4 -21
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +32 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +68 -0
- package/dist/utils/CollectionPage/getQuickEditPage.js +74 -0
- package/dist/utils/CollectionPage/getQuickEditPage.test.js +109 -0
- package/dist/utils/CollectionPage/index.js +4 -0
- package/dist/utils/CollectionPage/removeCollectionPageEntry.js +36 -0
- package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +61 -0
- package/package.json +2 -2
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
|
+
var _react = require("@testing-library/react");
|
|
5
|
+
var _Confirmation = _interopRequireWildcard(require("./Confirmation"));
|
|
6
|
+
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); }
|
|
7
|
+
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; }
|
|
8
|
+
// Global imports.
|
|
9
|
+
|
|
10
|
+
// Local imports.
|
|
11
|
+
|
|
12
|
+
/* eslint-disable no-plusplus */
|
|
13
|
+
|
|
14
|
+
describe('components.CollectionSummary.Confirmation', function () {
|
|
15
|
+
var onConfirmCalls = 0;
|
|
16
|
+
var ON_CONFIRM = function ON_CONFIRM() {
|
|
17
|
+
onConfirmCalls += 1;
|
|
18
|
+
};
|
|
19
|
+
var onCancelCalls = 0;
|
|
20
|
+
var ON_CANCEL = function ON_CANCEL() {
|
|
21
|
+
onCancelCalls += 1;
|
|
22
|
+
};
|
|
23
|
+
beforeEach(function () {
|
|
24
|
+
onConfirmCalls = 0;
|
|
25
|
+
onCancelCalls = 0;
|
|
26
|
+
});
|
|
27
|
+
var ID = 'testId';
|
|
28
|
+
var MESSAGE = 'Confirmation message';
|
|
29
|
+
var LABEL = 'Confirmation label';
|
|
30
|
+
var checkSetup = function checkSetup(container) {
|
|
31
|
+
var withChildren = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
32
|
+
var childIndex = 0;
|
|
33
|
+
var confirmation = container.children[0];
|
|
34
|
+
expect(confirmation.classList).toContain(_Confirmation.DEFAULT_CLASS);
|
|
35
|
+
var heading = confirmation.children[childIndex++];
|
|
36
|
+
expect(heading.tagName).toEqual('H2');
|
|
37
|
+
var children = withChildren ? confirmation.children[childIndex++] : null;
|
|
38
|
+
var confirmButton = confirmation.children[childIndex++];
|
|
39
|
+
expect(confirmButton.tagName).toEqual('BUTTON');
|
|
40
|
+
var cancelButton = confirmation.children[childIndex++];
|
|
41
|
+
expect(cancelButton.tagName).toEqual('BUTTON');
|
|
42
|
+
return {
|
|
43
|
+
heading: heading,
|
|
44
|
+
confirmButton: confirmButton,
|
|
45
|
+
cancelButton: cancelButton,
|
|
46
|
+
children: children
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
it('should render correctly', function () {
|
|
50
|
+
var _render = (0, _react.render)( /*#__PURE__*/React.createElement(_Confirmation.default, {
|
|
51
|
+
id: ID,
|
|
52
|
+
message: MESSAGE,
|
|
53
|
+
confirmLabel: LABEL,
|
|
54
|
+
onConfirm: ON_CONFIRM,
|
|
55
|
+
onCancel: ON_CANCEL
|
|
56
|
+
})),
|
|
57
|
+
container = _render.container;
|
|
58
|
+
var _checkSetup = checkSetup(container),
|
|
59
|
+
heading = _checkSetup.heading,
|
|
60
|
+
confirmButton = _checkSetup.confirmButton,
|
|
61
|
+
cancelButton = _checkSetup.cancelButton;
|
|
62
|
+
expect(heading.textContent).toEqual(MESSAGE);
|
|
63
|
+
expect(confirmButton.textContent).toEqual(LABEL);
|
|
64
|
+
_react.fireEvent.click(confirmButton, {});
|
|
65
|
+
expect(onConfirmCalls).toEqual(1);
|
|
66
|
+
_react.fireEvent.click(cancelButton, {});
|
|
67
|
+
expect(onCancelCalls).toEqual(1);
|
|
68
|
+
});
|
|
69
|
+
it('should use the default message if one is not provided', function () {
|
|
70
|
+
var _render2 = (0, _react.render)( /*#__PURE__*/React.createElement(_Confirmation.default, {
|
|
71
|
+
id: ID,
|
|
72
|
+
confirmLabel: LABEL,
|
|
73
|
+
onConfirm: ON_CONFIRM,
|
|
74
|
+
onCancel: ON_CANCEL
|
|
75
|
+
})),
|
|
76
|
+
container = _render2.container;
|
|
77
|
+
var _checkSetup2 = checkSetup(container),
|
|
78
|
+
heading = _checkSetup2.heading;
|
|
79
|
+
expect(heading.textContent).toEqual(_Confirmation.DEFAULT_MESSAGE);
|
|
80
|
+
});
|
|
81
|
+
it('should use the default label if one is not provided', function () {
|
|
82
|
+
var _render3 = (0, _react.render)( /*#__PURE__*/React.createElement(_Confirmation.default, {
|
|
83
|
+
id: ID,
|
|
84
|
+
onConfirm: ON_CONFIRM,
|
|
85
|
+
onCancel: ON_CANCEL
|
|
86
|
+
})),
|
|
87
|
+
container = _render3.container;
|
|
88
|
+
var confirmButton = checkSetup(container).confirmButton;
|
|
89
|
+
expect(confirmButton.textContent).toEqual(_Confirmation.DEFAULT_CONFIRM_LABEL);
|
|
90
|
+
});
|
|
91
|
+
it('should render children correctly', function () {
|
|
92
|
+
var _render4 = (0, _react.render)( /*#__PURE__*/React.createElement(_Confirmation.default, {
|
|
93
|
+
id: ID,
|
|
94
|
+
onConfirm: ON_CONFIRM,
|
|
95
|
+
onCancel: ON_CANCEL
|
|
96
|
+
}, /*#__PURE__*/React.createElement("p", null, "A child"))),
|
|
97
|
+
container = _render4.container;
|
|
98
|
+
var child = checkSetup(container, true).children;
|
|
99
|
+
expect(child.tagName).toEqual('P');
|
|
100
|
+
expect(child.textContent).toEqual('A child');
|
|
101
|
+
});
|
|
102
|
+
});
|
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = exports.DEFAULT_TITLE = exports.DEFAULT_EDIT_LABEL = exports.DEFAULT_DUPLICATE_BUTTON_LABEL = exports.DEFAULT_DELETE_BUTTON_LABEL = exports.DEFAULT_CLASS = exports.DEFAULT_CHANGE_BUTTON_LABEL = void 0;
|
|
8
|
+
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _getQuickEditPage = _interopRequireDefault(require("../../utils/CollectionPage/getQuickEditPage"));
|
|
12
|
+
var _utils = _interopRequireDefault(require("../../utils"));
|
|
13
|
+
var _hooks = require("../../hooks");
|
|
14
|
+
var _FormPage = _interopRequireDefault(require("../FormPage"));
|
|
15
|
+
var _FormComponent = _interopRequireDefault(require("../FormComponent"));
|
|
16
|
+
var _BannerStrip = _interopRequireDefault(require("./BannerStrip"));
|
|
17
|
+
require("./SummaryCard.scss");
|
|
18
|
+
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); }
|
|
19
|
+
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; }
|
|
20
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
|
+
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
22
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
23
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
24
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
25
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
26
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
27
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
28
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
29
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
30
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
31
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
32
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
33
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
34
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } // Global imports.
|
|
35
|
+
// Local imports.
|
|
36
|
+
// Styles.
|
|
37
|
+
var DEFAULT_CLASS = 'hods-form-summary-card';
|
|
38
|
+
exports.DEFAULT_CLASS = DEFAULT_CLASS;
|
|
39
|
+
var DEFAULT_TITLE = 'Item';
|
|
40
|
+
exports.DEFAULT_TITLE = DEFAULT_TITLE;
|
|
41
|
+
var DEFAULT_CHANGE_BUTTON_LABEL = 'Change';
|
|
42
|
+
exports.DEFAULT_CHANGE_BUTTON_LABEL = DEFAULT_CHANGE_BUTTON_LABEL;
|
|
43
|
+
var DEFAULT_DELETE_BUTTON_LABEL = 'Delete';
|
|
44
|
+
exports.DEFAULT_DELETE_BUTTON_LABEL = DEFAULT_DELETE_BUTTON_LABEL;
|
|
45
|
+
var DEFAULT_EDIT_LABEL = 'Quick Edit';
|
|
46
|
+
exports.DEFAULT_EDIT_LABEL = DEFAULT_EDIT_LABEL;
|
|
47
|
+
var DEFAULT_DUPLICATE_BUTTON_LABEL = 'Duplicate';
|
|
48
|
+
exports.DEFAULT_DUPLICATE_BUTTON_LABEL = DEFAULT_DUPLICATE_BUTTON_LABEL;
|
|
49
|
+
var SummaryCard = function SummaryCard(_ref) {
|
|
50
|
+
var _config$changeAction2, _config$duplicateActi, _config$deleteAction, _masterPage$childPage;
|
|
51
|
+
var id = _ref.id,
|
|
52
|
+
entryData = _ref.entryData,
|
|
53
|
+
config = _ref.config,
|
|
54
|
+
classModifiers = _ref.classModifiers,
|
|
55
|
+
onChange = _ref.onChange,
|
|
56
|
+
onDelete = _ref.onDelete,
|
|
57
|
+
onDuplicate = _ref.onDuplicate,
|
|
58
|
+
pages = _ref.pages,
|
|
59
|
+
onQuickEdit = _ref.onQuickEdit,
|
|
60
|
+
parentCollectionName = _ref.parentCollectionName,
|
|
61
|
+
formData = _ref.formData,
|
|
62
|
+
masterPage = _ref.masterPage,
|
|
63
|
+
hideDetails = _ref.hideDetails;
|
|
64
|
+
var classes = _copReactComponents.Utils.classBuilder(DEFAULT_CLASS, classModifiers, '');
|
|
65
|
+
var _useState = (0, _react.useState)(false),
|
|
66
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
67
|
+
quickEdit = _useState2[0],
|
|
68
|
+
setQuickEdit = _useState2[1];
|
|
69
|
+
var quickEditPage = (0, _react.useMemo)(function () {
|
|
70
|
+
return (0, _getQuickEditPage.default)(config.quickEdit, pages, entryData);
|
|
71
|
+
}, [pages, config, entryData]);
|
|
72
|
+
var _useValidation = (0, _hooks.useValidation)(),
|
|
73
|
+
validate = _useValidation.validate,
|
|
74
|
+
addErrors = _useValidation.addErrors;
|
|
75
|
+
var _useHooks = (0, _hooks.useHooks)(),
|
|
76
|
+
hooks = _useHooks.hooks;
|
|
77
|
+
var _onAction = /*#__PURE__*/function () {
|
|
78
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(action, patch) {
|
|
79
|
+
var errors, hookErrors, allErrors, allData;
|
|
80
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
81
|
+
while (1) switch (_context.prev = _context.next) {
|
|
82
|
+
case 0:
|
|
83
|
+
if (action.type === 'cancel') {
|
|
84
|
+
setQuickEdit(function (prevState) {
|
|
85
|
+
return !prevState;
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
if (!(action.type === 'save' && typeof onQuickEdit === 'function' && Object.keys(patch).length)) {
|
|
89
|
+
_context.next = 10;
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
// Local validation
|
|
93
|
+
errors = validate.page(quickEditPage);
|
|
94
|
+
if (!errors.length) {
|
|
95
|
+
_context.next = 5;
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
return _context.abrupt("return");
|
|
99
|
+
case 5:
|
|
100
|
+
_context.next = 7;
|
|
101
|
+
return hooks.onSubmit('quickEdit', patch, function () {}, function (e) {
|
|
102
|
+
hookErrors = e;
|
|
103
|
+
});
|
|
104
|
+
case 7:
|
|
105
|
+
if (hookErrors) {
|
|
106
|
+
addErrors(hookErrors);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Save data assuming no errors
|
|
110
|
+
allErrors = errors.concat(hookErrors);
|
|
111
|
+
if (allErrors.length === 0 || allErrors.length === 1 && allErrors[0] === undefined) {
|
|
112
|
+
allData = _utils.default.CollectionPage.getData(parentCollectionName, formData);
|
|
113
|
+
allData[entryData.index] = _objectSpread(_objectSpread({}, allData === null || allData === void 0 ? void 0 : allData[entryData.index]), patch);
|
|
114
|
+
onQuickEdit({
|
|
115
|
+
target: {
|
|
116
|
+
name: parentCollectionName,
|
|
117
|
+
value: allData
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
setQuickEdit(function (prevState) {
|
|
121
|
+
return !prevState;
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
case 10:
|
|
125
|
+
case "end":
|
|
126
|
+
return _context.stop();
|
|
127
|
+
}
|
|
128
|
+
}, _callee);
|
|
129
|
+
}));
|
|
130
|
+
return function onAction(_x, _x2) {
|
|
131
|
+
return _ref2.apply(this, arguments);
|
|
132
|
+
};
|
|
133
|
+
}();
|
|
134
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
135
|
+
className: classes(),
|
|
136
|
+
id: id
|
|
137
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
138
|
+
className: classes('header')
|
|
139
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
140
|
+
className: classes('header-content')
|
|
141
|
+
}, config.banners && /*#__PURE__*/_react.default.createElement(_BannerStrip.default, {
|
|
142
|
+
id: "BannerStrip".concat(entryData.id),
|
|
143
|
+
banners: config.banners,
|
|
144
|
+
formData: entryData
|
|
145
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
146
|
+
id: "".concat(id, ".titleText"),
|
|
147
|
+
className: classes('header-content-title')
|
|
148
|
+
}, _copReactComponents.Utils.interpolateString(config.title || DEFAULT_TITLE, entryData)), config.details && /*#__PURE__*/_react.default.createElement("div", {
|
|
149
|
+
id: "".concat(id, ".titleDetail"),
|
|
150
|
+
className: classes('header-content-detail')
|
|
151
|
+
}, _copReactComponents.Utils.interpolateString(config.details, entryData))), /*#__PURE__*/_react.default.createElement("div", {
|
|
152
|
+
className: classes('header-actions')
|
|
153
|
+
}, config.quickEdit && /*#__PURE__*/_react.default.createElement(_copReactComponents.Button, {
|
|
154
|
+
id: "".concat(id, ".quickEditButton"),
|
|
155
|
+
onClick: function onClick() {
|
|
156
|
+
return setQuickEdit(function (prevState) {
|
|
157
|
+
return !prevState;
|
|
158
|
+
});
|
|
159
|
+
},
|
|
160
|
+
classModifiers: "primary",
|
|
161
|
+
disabled: quickEdit
|
|
162
|
+
}, DEFAULT_EDIT_LABEL), config.changeAction && typeof onChange === 'function' && /*#__PURE__*/_react.default.createElement(_copReactComponents.Button, {
|
|
163
|
+
id: "".concat(id, ".changeButton"),
|
|
164
|
+
onClick: function onClick() {
|
|
165
|
+
var _config$changeAction;
|
|
166
|
+
return onChange((_config$changeAction = config.changeAction) === null || _config$changeAction === void 0 ? void 0 : _config$changeAction.page, entryData.id);
|
|
167
|
+
},
|
|
168
|
+
classModifiers: "secondary"
|
|
169
|
+
}, ((_config$changeAction2 = config.changeAction) === null || _config$changeAction2 === void 0 ? void 0 : _config$changeAction2.label) || DEFAULT_CHANGE_BUTTON_LABEL), config.duplicateAction && typeof onDuplicate === 'function' && /*#__PURE__*/_react.default.createElement(_copReactComponents.Button, {
|
|
170
|
+
id: "".concat(id, ".duplicateButton"),
|
|
171
|
+
onClick: function onClick() {
|
|
172
|
+
return onDuplicate(entryData);
|
|
173
|
+
},
|
|
174
|
+
classModifiers: "secondary"
|
|
175
|
+
}, ((_config$duplicateActi = config.duplicateAction) === null || _config$duplicateActi === void 0 ? void 0 : _config$duplicateActi.label) || DEFAULT_DUPLICATE_BUTTON_LABEL), config.deleteAction && typeof onDelete === 'function' && /*#__PURE__*/_react.default.createElement(_copReactComponents.Button, {
|
|
176
|
+
id: "".concat(id, ".deleteButton"),
|
|
177
|
+
onClick: function onClick() {
|
|
178
|
+
return onDelete(entryData);
|
|
179
|
+
},
|
|
180
|
+
classModifiers: "secondary"
|
|
181
|
+
}, ((_config$deleteAction = config.deleteAction) === null || _config$deleteAction === void 0 ? void 0 : _config$deleteAction.label) || DEFAULT_DELETE_BUTTON_LABEL))), quickEdit && /*#__PURE__*/_react.default.createElement(_FormPage.default, {
|
|
182
|
+
page: quickEditPage,
|
|
183
|
+
onAction: function onAction(action, patch) {
|
|
184
|
+
return _onAction(action, patch);
|
|
185
|
+
},
|
|
186
|
+
className: classes('editpage')
|
|
187
|
+
}), /*#__PURE__*/_react.default.createElement("div", {
|
|
188
|
+
className: classes('body')
|
|
189
|
+
}, !hideDetails && /*#__PURE__*/_react.default.createElement(_copReactComponents.Details, {
|
|
190
|
+
summary: "Full details",
|
|
191
|
+
className: "details"
|
|
192
|
+
}, masterPage === null || masterPage === void 0 || (_masterPage$childPage = masterPage.childPages) === null || _masterPage$childPage === void 0 ? void 0 : _masterPage$childPage.map(function (childPage) {
|
|
193
|
+
var _childPage$summaryLay;
|
|
194
|
+
var allPageComponents = _utils.default.Component.elevateNested(childPage === null || childPage === void 0 ? void 0 : childPage.components, entryData);
|
|
195
|
+
return (_childPage$summaryLay = childPage.summaryLayout) === null || _childPage$summaryLay === void 0 ? void 0 : _childPage$summaryLay.sections.map(function (section) {
|
|
196
|
+
var _section$fields;
|
|
197
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
198
|
+
key: section.title,
|
|
199
|
+
className: classes('section')
|
|
200
|
+
}, /*#__PURE__*/_react.default.createElement("h3", {
|
|
201
|
+
className: classes('section-title')
|
|
202
|
+
}, section.title), /*#__PURE__*/_react.default.createElement("div", {
|
|
203
|
+
className: classes('section-content', "columns-".concat(section.columns))
|
|
204
|
+
}, (_section$fields = section.fields) === null || _section$fields === void 0 ? void 0 : _section$fields.map(function (fieldId) {
|
|
205
|
+
var component = allPageComponents.find(function (comp) {
|
|
206
|
+
return comp.fieldId === fieldId;
|
|
207
|
+
});
|
|
208
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
209
|
+
key: fieldId,
|
|
210
|
+
className: classes('field')
|
|
211
|
+
}, /*#__PURE__*/_react.default.createElement(_FormComponent.default, {
|
|
212
|
+
component: _objectSpread(_objectSpread({}, component), {}, {
|
|
213
|
+
hint: ''
|
|
214
|
+
}),
|
|
215
|
+
value: entryData[component === null || component === void 0 ? void 0 : component.fieldId],
|
|
216
|
+
formData: entryData,
|
|
217
|
+
wrap: true,
|
|
218
|
+
readonly: true
|
|
219
|
+
}));
|
|
220
|
+
})));
|
|
221
|
+
});
|
|
222
|
+
}))));
|
|
223
|
+
};
|
|
224
|
+
SummaryCard.propTypes = {
|
|
225
|
+
id: _propTypes.default.string.isRequired,
|
|
226
|
+
entryData: _propTypes.default.shape({
|
|
227
|
+
id: _propTypes.default.string.isRequired,
|
|
228
|
+
index: _propTypes.default.number.isRequired
|
|
229
|
+
}).isRequired,
|
|
230
|
+
config: _propTypes.default.shape({
|
|
231
|
+
banners: _propTypes.default.arrayOf(_propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.shape({})])),
|
|
232
|
+
title: _propTypes.default.string,
|
|
233
|
+
details: _propTypes.default.string,
|
|
234
|
+
changeAction: _propTypes.default.shape({
|
|
235
|
+
label: _propTypes.default.string,
|
|
236
|
+
page: _propTypes.default.string.isRequired
|
|
237
|
+
}),
|
|
238
|
+
deleteAction: _propTypes.default.shape({
|
|
239
|
+
label: _propTypes.default.string
|
|
240
|
+
}),
|
|
241
|
+
duplicateAction: _propTypes.default.shape({
|
|
242
|
+
label: _propTypes.default.string
|
|
243
|
+
}),
|
|
244
|
+
quickEdit: _propTypes.default.shape({
|
|
245
|
+
components: _propTypes.default.arrayOf(_propTypes.default.shape({
|
|
246
|
+
use: _propTypes.default.string
|
|
247
|
+
}))
|
|
248
|
+
})
|
|
249
|
+
}).isRequired,
|
|
250
|
+
masterPage: _propTypes.default.shape({
|
|
251
|
+
childPages: _propTypes.default.arrayOf(_propTypes.default.shape({
|
|
252
|
+
components: _propTypes.default.arrayOf({})
|
|
253
|
+
})).isRequired
|
|
254
|
+
}).isRequired,
|
|
255
|
+
classModifiers: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.arrayOf(_propTypes.default.string)]),
|
|
256
|
+
onChange: _propTypes.default.func,
|
|
257
|
+
onDelete: _propTypes.default.func,
|
|
258
|
+
onDuplicate: _propTypes.default.func,
|
|
259
|
+
onQuickEdit: _propTypes.default.func,
|
|
260
|
+
pages: _propTypes.default.arrayOf(_propTypes.default.shape({})).isRequired,
|
|
261
|
+
parentCollectionName: _propTypes.default.string.isRequired,
|
|
262
|
+
formData: _propTypes.default.shape({}).isRequired,
|
|
263
|
+
hideDetails: _propTypes.default.bool
|
|
264
|
+
};
|
|
265
|
+
SummaryCard.defaultProps = {
|
|
266
|
+
classModifiers: null,
|
|
267
|
+
onChange: null,
|
|
268
|
+
onDelete: null,
|
|
269
|
+
onDuplicate: null,
|
|
270
|
+
onQuickEdit: null,
|
|
271
|
+
hideDetails: false
|
|
272
|
+
};
|
|
273
|
+
var _default = SummaryCard;
|
|
274
|
+
exports.default = _default;
|
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
$govuk-font-family: 'Roboto', arial, sans-serif;
|
|
2
|
+
|
|
3
|
+
@import "node_modules/govuk-frontend/govuk/_base";
|
|
4
|
+
|
|
5
|
+
.govuk-grid-column-two-thirds:has(.hods-form-summary-card) {
|
|
6
|
+
width: 100% !important;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.govuk-form-group:has(.hods-form-summary-card) {
|
|
10
|
+
.govuk-form-group:last-of-type {
|
|
11
|
+
margin-left: govuk-spacing(3);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.hods-form-summary-card {
|
|
16
|
+
box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
|
|
17
|
+
border: 1px solid #E5E4E2;
|
|
18
|
+
margin: 1rem 0;
|
|
19
|
+
padding: 0.75rem;
|
|
20
|
+
display: block;
|
|
21
|
+
|
|
22
|
+
&__header {
|
|
23
|
+
width: auto;
|
|
24
|
+
display: flex;
|
|
25
|
+
flex-direction: row;
|
|
26
|
+
color: #0b0c0c;
|
|
27
|
+
padding: govuk-spacing(3) govuk-spacing(4) 0;
|
|
28
|
+
|
|
29
|
+
&-content,
|
|
30
|
+
&-actions {
|
|
31
|
+
display: block;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
&-content {
|
|
35
|
+
width: 65%;
|
|
36
|
+
@include govuk-font($size: 24, $weight: bold);
|
|
37
|
+
|
|
38
|
+
&-title,
|
|
39
|
+
&-detail {
|
|
40
|
+
display: inline-block;
|
|
41
|
+
margin-bottom: govuk-spacing(1);
|
|
42
|
+
margin-right: govuk-spacing(2);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
&-detail {
|
|
46
|
+
font-weight: normal;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&-actions {
|
|
51
|
+
width: 35%;
|
|
52
|
+
|
|
53
|
+
.hods-button--primary {
|
|
54
|
+
@extend .hods-button--primary;
|
|
55
|
+
margin-right: govuk-spacing(2);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.hods-button--secondary {
|
|
59
|
+
@extend .hods-button--secondary;
|
|
60
|
+
margin-right: govuk-spacing(2);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
&__editpage {
|
|
66
|
+
margin: 0 govuk-spacing(4)
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
&__body {
|
|
70
|
+
display: block;
|
|
71
|
+
padding: 0 0 0 govuk-spacing(4);
|
|
72
|
+
margin-top: govuk-spacing(1);
|
|
73
|
+
|
|
74
|
+
.hods-details__summary {
|
|
75
|
+
text-decoration: underline;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
.details.hods-details {
|
|
79
|
+
margin-bottom: 0;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
&__section {
|
|
84
|
+
border-bottom: 2px solid #A9A9A9;
|
|
85
|
+
|
|
86
|
+
&-title {
|
|
87
|
+
font-weight: bold;
|
|
88
|
+
margin: govuk-spacing(2) 0 govuk-spacing(6) 0;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
&-content {
|
|
92
|
+
display: flex;
|
|
93
|
+
flex-wrap: wrap;
|
|
94
|
+
gap: govuk-spacing(2);
|
|
95
|
+
|
|
96
|
+
.hods-form-summary-card__field {
|
|
97
|
+
box-sizing: border-box;
|
|
98
|
+
margin-bottom: govuk-spacing(4);
|
|
99
|
+
|
|
100
|
+
.govuk-label,
|
|
101
|
+
.govuk-fieldset__legend {
|
|
102
|
+
font-weight: bold;
|
|
103
|
+
margin-bottom: govuk-spacing(1) !important;
|
|
104
|
+
|
|
105
|
+
&::after {
|
|
106
|
+
content: " :";
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
div.govuk-form-group div:has(img){
|
|
111
|
+
display: flex;
|
|
112
|
+
flex-wrap: wrap;
|
|
113
|
+
|
|
114
|
+
.hods-readonly.hods-readonly--success {
|
|
115
|
+
font-size: 0;
|
|
116
|
+
line-height: 0;
|
|
117
|
+
|
|
118
|
+
.cop-upload-preview__thumb {
|
|
119
|
+
display: inline-block;
|
|
120
|
+
margin-right: govuk-spacing(1);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
&--columns-1,
|
|
128
|
+
&--columns-2,
|
|
129
|
+
&--columns-3 {
|
|
130
|
+
position: relative;
|
|
131
|
+
margin-bottom: govuk-spacing(1);
|
|
132
|
+
|
|
133
|
+
&::before {
|
|
134
|
+
content: "";
|
|
135
|
+
position: absolute;
|
|
136
|
+
top: 0;
|
|
137
|
+
width: 2px;
|
|
138
|
+
height: 100%;
|
|
139
|
+
background-color: #A9A9A9;
|
|
140
|
+
left: 0;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
&--columns-2 {
|
|
145
|
+
&::after {
|
|
146
|
+
content: "";
|
|
147
|
+
position: absolute;
|
|
148
|
+
top: 0;
|
|
149
|
+
width: 2px;
|
|
150
|
+
height: 100%;
|
|
151
|
+
background-color: #A9A9A9;
|
|
152
|
+
left: 50%;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
.hods-form-summary-card__field {
|
|
156
|
+
flex: 0 0 calc(50% - 10px);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
&--columns-3 {
|
|
161
|
+
&::after {
|
|
162
|
+
content: "";
|
|
163
|
+
position: absolute;
|
|
164
|
+
top: 0;
|
|
165
|
+
left: 33.333%;
|
|
166
|
+
width: 2px;
|
|
167
|
+
height: 100%;
|
|
168
|
+
background-color: #A9A9A9;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
.hods-form-summary-card__field {
|
|
172
|
+
flex: 0 0 calc(33.333% - 10px);
|
|
173
|
+
|
|
174
|
+
&:nth-child(2)::after {
|
|
175
|
+
content: "";
|
|
176
|
+
position: absolute;
|
|
177
|
+
top: 0;
|
|
178
|
+
right: 33.333%;
|
|
179
|
+
width: 2px;
|
|
180
|
+
height: 100%;
|
|
181
|
+
background-color: #A9A9A9;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
@media (max-width: 640px) {
|
|
190
|
+
.hods-form-summary-card {
|
|
191
|
+
&__header {
|
|
192
|
+
flex-direction: column;
|
|
193
|
+
|
|
194
|
+
&-content {
|
|
195
|
+
width: 100%;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
&-actions {
|
|
199
|
+
width: 100%;
|
|
200
|
+
margin-top: govuk-spacing(2);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
&__section {
|
|
205
|
+
&-content {
|
|
206
|
+
display: block;
|
|
207
|
+
|
|
208
|
+
.hods-form-summary-card__field {
|
|
209
|
+
width: 100%;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
.hods-form-summary-card__field:nth-child(2)::after {
|
|
213
|
+
display: none;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
&--columns-2,
|
|
217
|
+
&--columns-3 {
|
|
218
|
+
position: relative;
|
|
219
|
+
margin-bottom: govuk-spacing(1);
|
|
220
|
+
|
|
221
|
+
&::before {
|
|
222
|
+
content: '';
|
|
223
|
+
position: absolute;
|
|
224
|
+
top: 0;
|
|
225
|
+
width: 2px;
|
|
226
|
+
height: 100%;
|
|
227
|
+
background-color: #A9A9A9;
|
|
228
|
+
left: 0;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
&::after {
|
|
232
|
+
display: none;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
&--columns-3 {
|
|
237
|
+
.hods-form-summary-card__field:nth-child(2)::after {
|
|
238
|
+
content: none;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|