@civicactions/cmsds-open-data-components 3.0.0-alpha.2 → 3.0.0-alpha.21
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/README.md +20 -0
- package/dist/main.css +160 -42
- package/dist/main.css.map +1 -1
- package/dist/main.js +2763 -1928
- package/dist/main.js.map +1 -1
- package/dist/types.d.ts +174 -136
- package/dist/types.d.ts.map +1 -1
- package/package.json +12 -9
- package/lib/assets/frequencyMap.js +0 -22
- package/lib/assets/icons/close.js +0 -33
- package/lib/assets/icons/close.jsx +0 -24
- package/lib/assets/icons/copy.js +0 -33
- package/lib/assets/icons/copy.jsx +0 -23
- package/lib/assets/icons/download.js +0 -33
- package/lib/assets/icons/download.jsx +0 -23
- package/lib/assets/icons/settings.js +0 -34
- package/lib/assets/icons/settings.jsx +0 -24
- package/lib/assets/images/CMSGovLogo-O.png +0 -0
- package/lib/assets/images/CMSgov@2x-white-O.png +0 -0
- package/lib/assets/metadataMapping.js +0 -161
- package/lib/assets/metadataMapping.jsx +0 -110
- package/lib/commands/index.js +0 -7
- package/lib/commands/templates/footer.js +0 -61
- package/lib/commands/templates/header.js +0 -84
- package/lib/commands/templates/page_not_found.js +0 -14
- package/lib/components/ApiDocumentation/index.js +0 -24
- package/lib/components/Breadcrumb/index.js +0 -47
- package/lib/components/DataTableDensity/datatabledensity.test.js +0 -30
- package/lib/components/DataTableDensity/index.js +0 -47
- package/lib/components/DataTableRowChanger/datatablerowchanger.test.js +0 -49
- package/lib/components/DataTableRowChanger/index.js +0 -46
- package/lib/components/DatasetAdditionalInformation/index.js +0 -59
- package/lib/components/DatasetDownloads/datasetdownloads.test.js +0 -30
- package/lib/components/DatasetDownloads/index.js +0 -34
- package/lib/components/DatasetSearchFacets/dataset_search_facets.test.js +0 -103
- package/lib/components/DatasetSearchFacets/index.js +0 -104
- package/lib/components/DatasetSearchListItem/datasetsearchlistitem.test.js +0 -44
- package/lib/components/DatasetSearchListItem/index.js +0 -86
- package/lib/components/DatasetTags/datasettags.test.js +0 -40
- package/lib/components/DatasetTags/index.js +0 -38
- package/lib/components/Hero/index.js +0 -92
- package/lib/components/ManageColumns/index.js +0 -36
- package/lib/components/NavBar/index.js +0 -55
- package/lib/components/NavLink/index.js +0 -60
- package/lib/components/NavLink/navlink.test.js +0 -35
- package/lib/components/Pagination/index.js +0 -263
- package/lib/components/Pagination/pagination.test.js +0 -541
- package/lib/components/ResourceConditionField/ResourceConditionalField.test.js +0 -20
- package/lib/components/ResourceConditionField/index.js +0 -246
- package/lib/components/ResourceFilter/index.js +0 -174
- package/lib/components/ResourceFilter/resourcefilter.test.js +0 -440
- package/lib/components/ResourceFooter/index.js +0 -34
- package/lib/components/ResourceHeader/index.js +0 -149
- package/lib/components/ResourceInformation/index.js +0 -37
- package/lib/components/ResourcePreview/index.js +0 -139
- package/lib/components/SearchModal/index.js +0 -116
- package/lib/components/SubMenu/index.js +0 -86
- package/lib/components/TransformedDate/index.js +0 -34
- package/lib/components/useAddLoginLink/index.js +0 -44
- package/lib/components/useScrollToTop/index.js +0 -22
- package/lib/index.js +0 -247
- package/lib/templates/APIPage/index.js +0 -30
- package/lib/templates/Dataset/DatasetBody.js +0 -189
- package/lib/templates/Dataset/index.js +0 -83
- package/lib/templates/DatasetSearch/datasetsearch.test.js +0 -122
- package/lib/templates/DatasetSearch/index.js +0 -356
- package/lib/templates/DrupalPage/index.js +0 -37
- package/lib/templates/FilteredResource/FilteredResourceBody.js +0 -160
- package/lib/templates/FilteredResource/QueryBuilder.js +0 -235
- package/lib/templates/FilteredResource/QueryRow.js +0 -175
- package/lib/templates/FilteredResource/QueryTitle.js +0 -89
- package/lib/templates/FilteredResource/functions.js +0 -142
- package/lib/templates/FilteredResource/index.js +0 -95
- package/lib/templates/Footer/footer.test.js +0 -48
- package/lib/templates/Footer/index.js +0 -366
- package/lib/templates/PageNotFound/index.js +0 -25
- package/lib/templates/header/index.js +0 -112
- package/lib/templates/mobile_header/index.js +0 -199
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
var _react = _interopRequireDefault(require("react"));
|
|
6
|
-
|
|
7
|
-
var _react2 = require("@testing-library/react");
|
|
8
|
-
|
|
9
|
-
require("@testing-library/jest-dom/extend-expect");
|
|
10
|
-
|
|
11
|
-
var _index = _interopRequireDefault(require("./index"));
|
|
12
|
-
|
|
13
|
-
describe('<DatasetTags />', function () {
|
|
14
|
-
test('Renders a download URL link and title', function () {
|
|
15
|
-
var tagList = [{
|
|
16
|
-
data: 'Tag 1',
|
|
17
|
-
identifier: '1'
|
|
18
|
-
}, {
|
|
19
|
-
data: 'Tag 2',
|
|
20
|
-
identifier: '2'
|
|
21
|
-
}, {
|
|
22
|
-
data: 'Tag 3',
|
|
23
|
-
identifier: '3'
|
|
24
|
-
}];
|
|
25
|
-
(0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
26
|
-
keywords: tagList
|
|
27
|
-
}));
|
|
28
|
-
expect(_react2.screen.getByRole('heading', {
|
|
29
|
-
name: 'Tags'
|
|
30
|
-
})).toBeTruthy();
|
|
31
|
-
tagList.forEach(function (tag) {
|
|
32
|
-
expect(_react2.screen.getByRole('link', {
|
|
33
|
-
name: tag.data
|
|
34
|
-
})).toBeTruthy();
|
|
35
|
-
expect(_react2.screen.getByRole('link', {
|
|
36
|
-
name: tag.data
|
|
37
|
-
})).toHaveAttribute('href', "/search?keyword=".concat(tag.data));
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
});
|
|
@@ -1,38 +0,0 @@
|
|
|
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"] = void 0;
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireDefault(require("react"));
|
|
11
|
-
|
|
12
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
13
|
-
|
|
14
|
-
var _reactRouterDom = require("react-router-dom");
|
|
15
|
-
|
|
16
|
-
var DatasetTags = function DatasetTags(_ref) {
|
|
17
|
-
var keywords = _ref.keywords;
|
|
18
|
-
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
19
|
-
className: "dc-c-dataset-tags ds-u-margin-bottom--3 ds-u-padding--2 ds-u-border ds-u-border--1"
|
|
20
|
-
}, /*#__PURE__*/_react["default"].createElement("h2", {
|
|
21
|
-
className: "ds-u-color--primary ds-u-font-size--h3 ds-u-margin-top--0 ds-u-margin-bottom--2"
|
|
22
|
-
}, "Tags"), keywords && keywords.map(function (k) {
|
|
23
|
-
return /*#__PURE__*/_react["default"].createElement(_reactRouterDom.Link, {
|
|
24
|
-
key: k.identifier,
|
|
25
|
-
to: "/datasets?keyword[]=".concat(k.data),
|
|
26
|
-
className: "dc-c-dataset-tags--tag ds-u-color--base ds-u-font-size--small ds-u-text-decoration--none ds-u-margin-right--1 ds-u-margin-bottom--1 ds-u-padding-x--2 ds-u-padding-y--1 ds-u-radius"
|
|
27
|
-
}, k.data);
|
|
28
|
-
}));
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
DatasetTags.propTypes = {
|
|
32
|
-
keywords: _propTypes["default"].arrayOf(_propTypes["default"].shape({
|
|
33
|
-
data: _propTypes["default"].string.isRequired,
|
|
34
|
-
identifier: _propTypes["default"].string.isRequired
|
|
35
|
-
})).isRequired
|
|
36
|
-
};
|
|
37
|
-
var _default = DatasetTags;
|
|
38
|
-
exports["default"] = _default;
|
|
@@ -1,92 +0,0 @@
|
|
|
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"] = void 0;
|
|
9
|
-
|
|
10
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
-
|
|
12
|
-
var _react = _interopRequireDefault(require("react"));
|
|
13
|
-
|
|
14
|
-
var _reactRouterDom = require("react-router-dom");
|
|
15
|
-
|
|
16
|
-
var _designSystem = require("@cmsgov/design-system");
|
|
17
|
-
|
|
18
|
-
var Hero = function Hero(_ref) {
|
|
19
|
-
var title = _ref.title,
|
|
20
|
-
description = _ref.description,
|
|
21
|
-
searchUrl = _ref.searchUrl,
|
|
22
|
-
searchKey = _ref.searchKey,
|
|
23
|
-
textfieldLabel = _ref.textfieldLabel,
|
|
24
|
-
searchButtonText = _ref.searchButtonText;
|
|
25
|
-
var navigate = (0, _reactRouterDom.useNavigate)();
|
|
26
|
-
|
|
27
|
-
var _React$useState = _react["default"].useState(''),
|
|
28
|
-
_React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
|
|
29
|
-
searchValue = _React$useState2[0],
|
|
30
|
-
setSearchValue = _React$useState2[1];
|
|
31
|
-
|
|
32
|
-
function submitHero(e) {
|
|
33
|
-
e.preventDefault();
|
|
34
|
-
navigate("/".concat(searchUrl, "?").concat(searchKey, "=").concat(searchValue));
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
return /*#__PURE__*/_react["default"].createElement("section", {
|
|
38
|
-
className: "dc-c-hero ds-base ds-u-padding--2"
|
|
39
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
40
|
-
className: "ds-l-container"
|
|
41
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
42
|
-
className: "ds-l-row"
|
|
43
|
-
}, /*#__PURE__*/_react["default"].createElement("h1", {
|
|
44
|
-
className: "ds-text-heading--5xl ds-u-color--white ds-u-margin-y--1"
|
|
45
|
-
}, title), /*#__PURE__*/_react["default"].createElement("p", {
|
|
46
|
-
className: "ds-u-color--white ds-u-measure--wide"
|
|
47
|
-
}, description)), /*#__PURE__*/_react["default"].createElement("form", {
|
|
48
|
-
onSubmit: function onSubmit(e) {
|
|
49
|
-
return submitHero(e);
|
|
50
|
-
}
|
|
51
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
52
|
-
style: {
|
|
53
|
-
position: 'relative'
|
|
54
|
-
},
|
|
55
|
-
className: "ds-l-row ds-u-align-items--stretch ds-u-margin-y--4 ds-u-flex-wrap--nowrap"
|
|
56
|
-
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
57
|
-
className: "ds-u-padding--0 ds-u-margin-right--1",
|
|
58
|
-
style: {
|
|
59
|
-
flex: '1 1 100%',
|
|
60
|
-
maxWidth: '100%'
|
|
61
|
-
}
|
|
62
|
-
}, /*#__PURE__*/_react["default"].createElement(_designSystem.TextField, {
|
|
63
|
-
label: textfieldLabel,
|
|
64
|
-
labelClassName: "ds-u-visibility--screen-reader",
|
|
65
|
-
name: "search_text_input",
|
|
66
|
-
style: {
|
|
67
|
-
maxWidth: 'none',
|
|
68
|
-
height: '61px',
|
|
69
|
-
margin: '0 20px 0 0'
|
|
70
|
-
},
|
|
71
|
-
onChange: function onChange(e) {
|
|
72
|
-
return setSearchValue(e.target.value);
|
|
73
|
-
}
|
|
74
|
-
})), /*#__PURE__*/_react["default"].createElement(_designSystem.Button, {
|
|
75
|
-
className: "ds-u-margin-left--auto",
|
|
76
|
-
size: "big",
|
|
77
|
-
type: "submit"
|
|
78
|
-
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
79
|
-
className: "fas fa-search small-text ds-u-sm-display--none"
|
|
80
|
-
}), /*#__PURE__*/_react["default"].createElement("span", {
|
|
81
|
-
className: "full-text ds-u-display--none ds-u-sm-display--inline-block"
|
|
82
|
-
}, searchButtonText))))));
|
|
83
|
-
};
|
|
84
|
-
|
|
85
|
-
Hero.defaultProps = {
|
|
86
|
-
searchKey: 'fulltext',
|
|
87
|
-
searchUrl: 'datasets',
|
|
88
|
-
textfieldLabel: 'Search for a dataset',
|
|
89
|
-
searchButtonText: 'Search'
|
|
90
|
-
};
|
|
91
|
-
var _default = Hero;
|
|
92
|
-
exports["default"] = _default;
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
-
|
|
7
|
-
Object.defineProperty(exports, "__esModule", {
|
|
8
|
-
value: true
|
|
9
|
-
});
|
|
10
|
-
exports["default"] = void 0;
|
|
11
|
-
|
|
12
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
13
|
-
|
|
14
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
-
|
|
16
|
-
var _designSystem = require("@cmsgov/design-system");
|
|
17
|
-
|
|
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
|
-
|
|
20
|
-
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; }
|
|
21
|
-
|
|
22
|
-
var ManageColumns = function ManageColumns() {
|
|
23
|
-
var _useState = (0, _react.useState)(false),
|
|
24
|
-
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
25
|
-
modalOpen = _useState2[0],
|
|
26
|
-
setModalOpen = _useState2[1];
|
|
27
|
-
|
|
28
|
-
return /*#__PURE__*/_react["default"].createElement(_designSystem.Button, {
|
|
29
|
-
onClick: function onClick() {
|
|
30
|
-
return setModalOpen(!modalOpen);
|
|
31
|
-
}
|
|
32
|
-
}, "Manage Columns");
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
var _default = ManageColumns;
|
|
36
|
-
exports["default"] = _default;
|
|
@@ -1,55 +0,0 @@
|
|
|
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"] = void 0;
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireDefault(require("react"));
|
|
11
|
-
|
|
12
|
-
var _SubMenu = _interopRequireDefault(require("../SubMenu"));
|
|
13
|
-
|
|
14
|
-
var _NavLink = _interopRequireDefault(require("../NavLink"));
|
|
15
|
-
|
|
16
|
-
var NavBar = function NavBar(_ref) {
|
|
17
|
-
var links = _ref.links,
|
|
18
|
-
menuName = _ref.menuName,
|
|
19
|
-
menuId = _ref.menuId,
|
|
20
|
-
menuClasses = _ref.menuClasses,
|
|
21
|
-
linkClasses = _ref.linkClasses,
|
|
22
|
-
wrapLabel = _ref.wrapLabel;
|
|
23
|
-
return /*#__PURE__*/_react["default"].createElement("nav", {
|
|
24
|
-
className: "dc-c-".concat(menuId, "-menu"),
|
|
25
|
-
"aria-labelledby": "dc-c-".concat(menuId, "-menu--heading")
|
|
26
|
-
}, /*#__PURE__*/_react["default"].createElement("h2", {
|
|
27
|
-
id: "dc-c-".concat(menuId, "-menu--heading"),
|
|
28
|
-
className: "ds-u-visibility--screen-reader"
|
|
29
|
-
}, menuName), /*#__PURE__*/_react["default"].createElement("ul", {
|
|
30
|
-
className: menuClasses
|
|
31
|
-
}, links.map(function (link) {
|
|
32
|
-
if (link.submenu) {
|
|
33
|
-
return /*#__PURE__*/_react["default"].createElement(_SubMenu["default"], {
|
|
34
|
-
key: link.id,
|
|
35
|
-
link: link,
|
|
36
|
-
wrapLabel: wrapLabel,
|
|
37
|
-
linkClasses: linkClasses
|
|
38
|
-
});
|
|
39
|
-
} else {
|
|
40
|
-
return /*#__PURE__*/_react["default"].createElement("li", {
|
|
41
|
-
key: link.id
|
|
42
|
-
}, /*#__PURE__*/_react["default"].createElement(_NavLink["default"], {
|
|
43
|
-
link: link,
|
|
44
|
-
className: linkClasses,
|
|
45
|
-
wrapLabel: wrapLabel
|
|
46
|
-
}));
|
|
47
|
-
}
|
|
48
|
-
})));
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
NavBar.defaultProps = {
|
|
52
|
-
wrapLabel: false
|
|
53
|
-
};
|
|
54
|
-
var _default = NavBar;
|
|
55
|
-
exports["default"] = _default;
|
|
@@ -1,60 +0,0 @@
|
|
|
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"] = void 0;
|
|
9
|
-
|
|
10
|
-
var _react = _interopRequireDefault(require("react"));
|
|
11
|
-
|
|
12
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
13
|
-
|
|
14
|
-
var _reactRouterDom = require("react-router-dom");
|
|
15
|
-
|
|
16
|
-
var _validator = _interopRequireDefault(require("validator"));
|
|
17
|
-
|
|
18
|
-
var NavLink = function NavLink(_ref) {
|
|
19
|
-
var link = _ref.link,
|
|
20
|
-
_className = _ref.className,
|
|
21
|
-
wrapLabel = _ref.wrapLabel;
|
|
22
|
-
var innerHtml = wrapLabel ? /*#__PURE__*/_react["default"].createElement("span", null, link.label) : link.label;
|
|
23
|
-
|
|
24
|
-
if (_validator["default"].isURL(link.url, {
|
|
25
|
-
require_protocol: true
|
|
26
|
-
}) || link.nonReactLink) {
|
|
27
|
-
return /*#__PURE__*/_react["default"].createElement("a", {
|
|
28
|
-
className: _className,
|
|
29
|
-
href: link.url
|
|
30
|
-
}, innerHtml);
|
|
31
|
-
} else {
|
|
32
|
-
return /*#__PURE__*/_react["default"].createElement(_reactRouterDom.NavLink, {
|
|
33
|
-
className: function className(_ref2) {
|
|
34
|
-
var isActive = _ref2.isActive;
|
|
35
|
-
return isActive ? "dc-c-active-link ".concat(_className) : "".concat(_className);
|
|
36
|
-
},
|
|
37
|
-
to: link.url
|
|
38
|
-
}, innerHtml);
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
NavLink.defaultProps = {
|
|
43
|
-
wrapLabel: false,
|
|
44
|
-
className: null
|
|
45
|
-
};
|
|
46
|
-
NavLink.propTypes = {
|
|
47
|
-
link: _propTypes["default"].shape({
|
|
48
|
-
url: _propTypes["default"].string,
|
|
49
|
-
label: _propTypes["default"].string,
|
|
50
|
-
nonReactLink: _propTypes["default"].bool
|
|
51
|
-
}).isRequired,
|
|
52
|
-
className: _propTypes["default"].string,
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Will wrap the link label in a span for help with styling.
|
|
56
|
-
*/
|
|
57
|
-
wrapLabel: _propTypes["default"].bool
|
|
58
|
-
};
|
|
59
|
-
var _default = NavLink;
|
|
60
|
-
exports["default"] = _default;
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
var _react = _interopRequireDefault(require("react"));
|
|
6
|
-
|
|
7
|
-
var _react2 = require("@testing-library/react");
|
|
8
|
-
|
|
9
|
-
require("@testing-library/jest-dom/extend-expect");
|
|
10
|
-
|
|
11
|
-
var _jestAxe = require("jest-axe");
|
|
12
|
-
|
|
13
|
-
var _index = _interopRequireDefault(require("./index"));
|
|
14
|
-
|
|
15
|
-
expect.extend(_jestAxe.toHaveNoViolations);
|
|
16
|
-
describe('<NavLink />', function () {
|
|
17
|
-
test('Renders a relative link if no http protocol in url', function () {
|
|
18
|
-
(0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
19
|
-
link: {
|
|
20
|
-
url: '/about',
|
|
21
|
-
label: 'About'
|
|
22
|
-
}
|
|
23
|
-
}));
|
|
24
|
-
expect(_react2.screen.getByRole('link', 'About')).toHaveAttribute('href', '/about');
|
|
25
|
-
});
|
|
26
|
-
test('Renders a link if http protocol in url', function () {
|
|
27
|
-
(0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_index["default"], {
|
|
28
|
-
link: {
|
|
29
|
-
url: 'https://demo.getdkan.com',
|
|
30
|
-
label: 'DKAN Demo'
|
|
31
|
-
}
|
|
32
|
-
}));
|
|
33
|
-
expect(_react2.screen.getByRole('link', 'DKAN Demo')).toHaveAttribute('href', 'https://demo.getdkan.com');
|
|
34
|
-
});
|
|
35
|
-
});
|
|
@@ -1,263 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
-
|
|
7
|
-
Object.defineProperty(exports, "__esModule", {
|
|
8
|
-
value: true
|
|
9
|
-
});
|
|
10
|
-
exports["default"] = void 0;
|
|
11
|
-
|
|
12
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
-
|
|
14
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
-
|
|
16
|
-
var _designSystem = require("@cmsgov/design-system");
|
|
17
|
-
|
|
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
|
-
|
|
20
|
-
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; }
|
|
21
|
-
|
|
22
|
-
var Pagination = function Pagination(_ref) {
|
|
23
|
-
var totalPages = _ref.totalPages,
|
|
24
|
-
currentPage = _ref.currentPage,
|
|
25
|
-
buttonAction = _ref.buttonAction;
|
|
26
|
-
var maxLength = 7; // Expectation starts at 1
|
|
27
|
-
// only shows 7 buttons plus prev/next
|
|
28
|
-
|
|
29
|
-
function addFirst() {
|
|
30
|
-
// extra + 1 is number of siblings
|
|
31
|
-
if (currentPage > 1 + 1) {
|
|
32
|
-
return [{
|
|
33
|
-
id: 1,
|
|
34
|
-
text: 1
|
|
35
|
-
}];
|
|
36
|
-
} else {
|
|
37
|
-
return [];
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
function addLast() {
|
|
42
|
-
// extra + 1 is number of siblings
|
|
43
|
-
if (currentPage < totalPages) {
|
|
44
|
-
return [{
|
|
45
|
-
id: totalPages,
|
|
46
|
-
text: totalPages
|
|
47
|
-
}];
|
|
48
|
-
} else {
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
function addPrev() {
|
|
54
|
-
if (currentPage > 1) {
|
|
55
|
-
return [{
|
|
56
|
-
id: 'previous',
|
|
57
|
-
text: 'Previous'
|
|
58
|
-
}];
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return [{
|
|
62
|
-
id: 'previous',
|
|
63
|
-
text: 'Previous',
|
|
64
|
-
disabled: true
|
|
65
|
-
}];
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
function addNext() {
|
|
69
|
-
if (currentPage < totalPages) {
|
|
70
|
-
return [{
|
|
71
|
-
id: 'next',
|
|
72
|
-
text: 'Next'
|
|
73
|
-
}];
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
return [{
|
|
77
|
-
id: 'next',
|
|
78
|
-
text: 'Next',
|
|
79
|
-
disabled: true
|
|
80
|
-
}];
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
function buildSiblings() {
|
|
84
|
-
// add check if current page less than totalPages
|
|
85
|
-
var siblings = [{
|
|
86
|
-
id: currentPage,
|
|
87
|
-
text: currentPage,
|
|
88
|
-
currentPage: true
|
|
89
|
-
}];
|
|
90
|
-
|
|
91
|
-
if (currentPage > 1) {
|
|
92
|
-
siblings.unshift({
|
|
93
|
-
id: currentPage - 1,
|
|
94
|
-
text: currentPage - 1
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
if (currentPage < totalPages - 1) {
|
|
99
|
-
siblings.push({
|
|
100
|
-
id: currentPage + 1,
|
|
101
|
-
text: currentPage + 1
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return siblings;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
function buildPreSiblings() {
|
|
109
|
-
var preSiblings = [];
|
|
110
|
-
var remainingSpots = 0;
|
|
111
|
-
|
|
112
|
-
if (currentPage === 4) {
|
|
113
|
-
remainingSpots = 1;
|
|
114
|
-
preSiblings.push({
|
|
115
|
-
id: '2',
|
|
116
|
-
text: 2
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
if (currentPage > 4) {
|
|
121
|
-
remainingSpots = 1;
|
|
122
|
-
preSiblings.push({
|
|
123
|
-
id: 'predots',
|
|
124
|
-
text: '...'
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
if (currentPage > 4 && currentPage >= totalPages - 2) {
|
|
129
|
-
remainingSpots = 1;
|
|
130
|
-
preSiblings.push({
|
|
131
|
-
id: totalPages - 4,
|
|
132
|
-
text: totalPages - 4
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
if (currentPage > 4 && currentPage >= totalPages - 1) {
|
|
137
|
-
remainingSpots = 1;
|
|
138
|
-
preSiblings.push({
|
|
139
|
-
id: totalPages - 3,
|
|
140
|
-
text: totalPages - 3
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (currentPage > 4 && currentPage === totalPages) {
|
|
145
|
-
remainingSpots = 1;
|
|
146
|
-
preSiblings.push({
|
|
147
|
-
id: totalPages - 2,
|
|
148
|
-
text: totalPages - 2
|
|
149
|
-
});
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
return preSiblings;
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
function buildPostSiblings() {
|
|
156
|
-
var postSiblings = [];
|
|
157
|
-
var remainingSpots = maxLength - (currentPage + 1) - 1;
|
|
158
|
-
|
|
159
|
-
if (currentPage < 5) {
|
|
160
|
-
for (var spot = 1; spot < remainingSpots; spot++) {
|
|
161
|
-
// console.log('post-spot', spot)
|
|
162
|
-
postSiblings.push({
|
|
163
|
-
id: currentPage + 1 + spot,
|
|
164
|
-
text: currentPage + 1 + spot
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
postSiblings.push({
|
|
169
|
-
id: 'postdots',
|
|
170
|
-
text: '...'
|
|
171
|
-
});
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
if (currentPage >= 5 && currentPage < totalPages - 3) {
|
|
175
|
-
postSiblings.push({
|
|
176
|
-
id: 'postdots',
|
|
177
|
-
text: '...'
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
if (currentPage >= 5 && currentPage === totalPages - 3) {
|
|
182
|
-
postSiblings.push({
|
|
183
|
-
id: totalPages - 1,
|
|
184
|
-
text: totalPages - 1
|
|
185
|
-
});
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
return postSiblings;
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
function buttonValue(item) {
|
|
192
|
-
if (item === 'Previous') {
|
|
193
|
-
return currentPage - 1;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
if (item === 'Next') {
|
|
197
|
-
return currentPage + 1;
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
return item;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
function addAll() {
|
|
204
|
-
var items = (0, _toConsumableArray2["default"])(Array(totalPages));
|
|
205
|
-
return items.map(function (item, index) {
|
|
206
|
-
return {
|
|
207
|
-
id: index + 1,
|
|
208
|
-
text: index + 1
|
|
209
|
-
};
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
function buildAll() {
|
|
214
|
-
if (totalPages > 0 && totalPages <= maxLength) {
|
|
215
|
-
return [].concat((0, _toConsumableArray2["default"])(addPrev()), (0, _toConsumableArray2["default"])(addAll()), (0, _toConsumableArray2["default"])(addNext()));
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
if (totalPages > 0 && totalPages > maxLength) {
|
|
219
|
-
return [].concat((0, _toConsumableArray2["default"])(addPrev()), (0, _toConsumableArray2["default"])(addFirst()), (0, _toConsumableArray2["default"])(buildPreSiblings()), (0, _toConsumableArray2["default"])(buildSiblings()), (0, _toConsumableArray2["default"])(buildPostSiblings()), (0, _toConsumableArray2["default"])(addLast()), (0, _toConsumableArray2["default"])(addNext()));
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
return [];
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
226
|
-
className: "dc-pagination"
|
|
227
|
-
}, /*#__PURE__*/_react["default"].createElement("nav", null, /*#__PURE__*/_react["default"].createElement("ol", {
|
|
228
|
-
className: "ds-u-display--flex ds-u-flex-direction--row ds-u-padding-x--0"
|
|
229
|
-
}, buildAll().map(function (item) {
|
|
230
|
-
var buttonClass = '';
|
|
231
|
-
var liClass = '';
|
|
232
|
-
|
|
233
|
-
if (item.text === 'Previous') {
|
|
234
|
-
buttonClass = 'dc-pagination--previous__button';
|
|
235
|
-
liClass = 'dc-pagination--previous';
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
if (item.text === 'Next') {
|
|
239
|
-
buttonClass = 'dc-pagination--next__button';
|
|
240
|
-
liClass = 'dc-pagination--next';
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
if (item.currentPage || item.text === currentPage) {
|
|
244
|
-
buttonClass = 'dc-pagination-current__button';
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
return /*#__PURE__*/_react["default"].createElement("li", {
|
|
248
|
-
key: item.id,
|
|
249
|
-
className: liClass
|
|
250
|
-
}, item.id === 'postdots' || item.id === 'predots' ? /*#__PURE__*/_react["default"].createElement("span", null, item.text) : /*#__PURE__*/_react["default"].createElement(_designSystem.Button, {
|
|
251
|
-
className: buttonClass,
|
|
252
|
-
disabled: item.disabled ? item.disabled : false,
|
|
253
|
-
size: "small",
|
|
254
|
-
variation: "transparent",
|
|
255
|
-
onClick: function onClick() {
|
|
256
|
-
return buttonAction(buttonValue(item.text));
|
|
257
|
-
}
|
|
258
|
-
}, item.text));
|
|
259
|
-
}))));
|
|
260
|
-
};
|
|
261
|
-
|
|
262
|
-
var _default = Pagination;
|
|
263
|
-
exports["default"] = _default;
|