@times-components/ts-components 1.18.2 → 1.19.1
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/CHANGELOG.md +35 -0
- package/dist/components/article-flag/LiveArticleFlag.js +5 -4
- package/dist/components/article-flag/styles.d.ts +2 -2
- package/dist/components/article-flag/styles.js +5 -5
- package/dist/components/article-header/ArticleHeader.d.ts +7 -0
- package/dist/components/article-header/ArticleHeader.js +32 -0
- package/dist/components/article-header/ArticleHeader.stories.d.ts +1 -0
- package/dist/components/article-header/ArticleHeader.stories.js +20 -0
- package/dist/components/article-header/__tests__/ArticleHeader.test.d.ts +1 -0
- package/dist/components/article-header/__tests__/ArticleHeader.test.js +126 -0
- package/dist/components/article-header/styles.d.ts +16 -0
- package/dist/components/article-header/styles.js +76 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -1
- package/package.json +16 -15
- package/rnw.js +1 -1
- package/src/components/article-flag/LiveArticleFlag.tsx +6 -4
- package/src/components/article-flag/__tests__/__snapshots__/LiveArticleFlag.test.tsx.snap +24 -18
- package/src/components/article-flag/styles.ts +5 -4
- package/src/components/article-header/ArticleHeader.stories.tsx +30 -0
- package/src/components/article-header/ArticleHeader.tsx +83 -0
- package/src/components/article-header/__tests__/ArticleHeader.test.tsx +183 -0
- package/src/components/article-header/__tests__/__snapshots__/ArticleHeader.test.tsx.snap +106 -0
- package/src/components/article-header/styles.ts +86 -0
- package/src/index.ts +4 -0
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,41 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [1.19.1](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.19.0...@times-components/ts-components@1.19.1) (2022-02-22)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @times-components/ts-components
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# [1.19.0](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.18.4...@times-components/ts-components@1.19.0) (2022-02-22)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
### Features
|
|
18
|
+
|
|
19
|
+
* **TDP-563:** updated date-fns to use a single current version rathe… ([#2854](https://github.com/newsuk/times-components/issues/2854)) ([aca0dea](https://github.com/newsuk/times-components/commit/aca0deaa75f182f2b759ddfb262277d249aeff77))
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
## [1.18.4](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.18.3...@times-components/ts-components@1.18.4) (2022-02-16)
|
|
26
|
+
|
|
27
|
+
**Note:** Version bump only for package @times-components/ts-components
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
## [1.18.3](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.18.2...@times-components/ts-components@1.18.3) (2022-02-10)
|
|
34
|
+
|
|
35
|
+
**Note:** Version bump only for package @times-components/ts-components
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
|
|
6
41
|
## [1.18.2](https://github.com/newsuk/times-components/compare/@times-components/ts-components@1.18.1...@times-components/ts-components@1.18.2) (2022-02-10)
|
|
7
42
|
|
|
8
43
|
**Note:** Version bump only for package @times-components/ts-components
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { LiveArticleFlagContainer,
|
|
2
|
+
import { LiveArticleFlagContainer, LiveIconContainer, LiveArticleFlagText } from './styles';
|
|
3
3
|
export const BaseLiveArticleFlag = ({ title }) => (React.createElement(LiveArticleFlagContainer, null,
|
|
4
|
-
React.createElement(
|
|
5
|
-
React.createElement(
|
|
4
|
+
React.createElement(LiveIconContainer, null, '\u25a0'),
|
|
5
|
+
React.createElement("div", null,
|
|
6
|
+
React.createElement(LiveArticleFlagText, null, title))));
|
|
6
7
|
export const LiveArticleFlag = () => (React.createElement(BaseLiveArticleFlag, { title: "LIVE" }));
|
|
7
8
|
export const BreakingArticleFlag = () => (React.createElement(BaseLiveArticleFlag, { title: "BREAKING" }));
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTGl2ZUFydGljbGVGbGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXJ0aWNsZS1mbGFnL0xpdmVBcnRpY2xlRmxhZy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE1BQU0sT0FBTyxDQUFDO0FBQzFCLE9BQU8sRUFDTCx3QkFBd0IsRUFDeEIsaUJBQWlCLEVBQ2pCLG1CQUFtQixFQUNwQixNQUFNLFVBQVUsQ0FBQztBQUVsQixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBZ0MsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUM3RSxvQkFBQyx3QkFBd0I7SUFDdkIsb0JBQUMsaUJBQWlCLFFBQUUsUUFBUSxDQUFxQjtJQUNqRDtRQUNFLG9CQUFDLG1CQUFtQixRQUFFLEtBQUssQ0FBdUIsQ0FDOUMsQ0FDbUIsQ0FDNUIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBYSxHQUFHLEVBQUUsQ0FBQyxDQUM3QyxvQkFBQyxtQkFBbUIsSUFBQyxLQUFLLEVBQUMsTUFBTSxHQUFHLENBQ3JDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBYSxHQUFHLEVBQUUsQ0FBQyxDQUNqRCxvQkFBQyxtQkFBbUIsSUFBQyxLQUFLLEVBQUMsVUFBVSxHQUFHLENBQ3pDLENBQUMifQ==
|
|
@@ -2,9 +2,9 @@ import { FlagType } from './ArticleFlag';
|
|
|
2
2
|
export declare const ArticleFlagContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
3
3
|
export declare const LiveArticleFlagContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
4
4
|
export declare const ArticleFlagBullet: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
5
|
-
export declare const
|
|
5
|
+
export declare const LiveIconContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
6
6
|
export declare const ArticleFlagTextContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
7
|
-
export declare const
|
|
7
|
+
export declare const LiveArticleFlagText: import("styled-components").StyledComponent<"span", any, {}, never>;
|
|
8
8
|
export declare const FlagPadding: import("styled-components").StyledComponent<"div", any, {
|
|
9
9
|
allFlags: FlagType;
|
|
10
10
|
}, never>;
|
|
@@ -18,10 +18,10 @@ export const ArticleFlagBullet = styled.div `
|
|
|
18
18
|
width: 5px;
|
|
19
19
|
background-color: ${({ color }) => gqlRgbaToStyle(color) || color};
|
|
20
20
|
`;
|
|
21
|
-
export const
|
|
22
|
-
margin-right:
|
|
21
|
+
export const LiveIconContainer = styled.div `
|
|
22
|
+
margin-right: 8px;
|
|
23
23
|
color: #ffffff;
|
|
24
|
-
|
|
24
|
+
align-self: self-start;
|
|
25
25
|
`;
|
|
26
26
|
export const ArticleFlagTextContainer = styled.div `
|
|
27
27
|
font-family: TimesDigitalW04-RegularSC;
|
|
@@ -32,7 +32,7 @@ export const ArticleFlagTextContainer = styled.div `
|
|
|
32
32
|
margin-left: 5px;
|
|
33
33
|
color: ${({ color }) => gqlRgbaToStyle(color) || color};
|
|
34
34
|
`;
|
|
35
|
-
export const
|
|
35
|
+
export const LiveArticleFlagText = styled.span `
|
|
36
36
|
font-family: ${fonts.supporting};
|
|
37
37
|
color: #ffffff;
|
|
38
38
|
font-weight: 500;
|
|
@@ -53,4 +53,4 @@ export const FlagsContainer = styled.div `
|
|
|
53
53
|
margin-bottom: 15px;
|
|
54
54
|
margin-top: 5px;
|
|
55
55
|
`;
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXJ0aWNsZS1mbGFnL3N0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxtQkFBbUIsQ0FBQztBQUN2QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFckQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRXpELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUE7Ozs7Q0FJN0MsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUE7Ozs7O0NBS2pELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFBOzs7O3NCQUlyQixDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLO0NBQ2xFLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFBOzs7O0NBSTFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFBOzs7Ozs7O1dBT3ZDLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUs7Q0FDdkQsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUE7aUJBQzdCLEtBQUssQ0FBQyxVQUFVOzs7Ozs7Q0FNaEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUF3QjtrQkFDM0MsQ0FBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztDQUNyRSxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUE7Ozs7O0NBSzlCLENBQUM7QUFDRixNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQTs7O0NBR3ZDLENBQUMifQ==
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { format, differenceInSeconds, differenceInCalendarDays, formatDistanceStrict } from 'date-fns';
|
|
3
|
+
import { Container, Divider, Headline, TimeSincePublishing, TimeSincePublishingContainer, UpdatedDate, UpdatedTime, UpdatedTimeItems, UpdatesContainer, FlagContainer } from './styles';
|
|
4
|
+
import { BreakingArticleFlag } from '../article-flag/LiveArticleFlag';
|
|
5
|
+
const ArticleHeader = ({ updated, breaking, headline }) => {
|
|
6
|
+
const currentDateTime = new Date();
|
|
7
|
+
const updatedDate = new Date(updated);
|
|
8
|
+
const timeSincePublishing = formatDistanceStrict(updatedDate, currentDateTime, {
|
|
9
|
+
roundingMethod: 'floor'
|
|
10
|
+
}) + ' ago';
|
|
11
|
+
const diffInSeconds = differenceInSeconds(currentDateTime, updatedDate);
|
|
12
|
+
const isLessThan1Minute = diffInSeconds < 60;
|
|
13
|
+
const isLessThan1Hour = diffInSeconds < 60 * 60;
|
|
14
|
+
const isLessThan13Hours = diffInSeconds < 60 * 60 * 13;
|
|
15
|
+
const isDaysAgo = differenceInCalendarDays(currentDateTime, updatedDate) >= 1;
|
|
16
|
+
const isBreaking = breaking
|
|
17
|
+
? Boolean(breaking.toLowerCase() === 'true')
|
|
18
|
+
: false;
|
|
19
|
+
return (React.createElement(Container, { isBreaking: isBreaking && isLessThan1Hour },
|
|
20
|
+
React.createElement(UpdatesContainer, null,
|
|
21
|
+
React.createElement(UpdatedTimeItems, null,
|
|
22
|
+
isBreaking && isLessThan1Hour ? (React.createElement(FlagContainer, null,
|
|
23
|
+
React.createElement(BreakingArticleFlag, null))) : null,
|
|
24
|
+
!isLessThan1Minute && isLessThan13Hours ? (React.createElement(TimeSincePublishingContainer, null,
|
|
25
|
+
React.createElement(TimeSincePublishing, { isBreaking: isBreaking, "data-testId": "TimeSincePublishing" }, timeSincePublishing),
|
|
26
|
+
React.createElement(Divider, null))) : null,
|
|
27
|
+
React.createElement(UpdatedTime, { isLessThan13Hours: !isLessThan1Minute && isLessThan13Hours, "data-testId": "UpdatedTime" }, format(updatedDate, 'h.mmaaa'))),
|
|
28
|
+
isDaysAgo ? (React.createElement(UpdatedDate, { "data-testid": "UpdatedDate" }, format(updatedDate, 'MMMM d yyyy'))) : null),
|
|
29
|
+
headline && React.createElement(Headline, null, decodeURI(headline))));
|
|
30
|
+
};
|
|
31
|
+
export default ArticleHeader;
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXJ0aWNsZUhlYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2FydGljbGUtaGVhZGVyL0FydGljbGVIZWFkZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMxQixPQUFPLEVBQ0wsTUFBTSxFQUNOLG1CQUFtQixFQUNuQix3QkFBd0IsRUFDeEIsb0JBQW9CLEVBQ3JCLE1BQU0sVUFBVSxDQUFDO0FBRWxCLE9BQU8sRUFDTCxTQUFTLEVBQ1QsT0FBTyxFQUNQLFFBQVEsRUFDUixtQkFBbUIsRUFDbkIsNEJBQTRCLEVBQzVCLFdBQVcsRUFDWCxXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2hCLGdCQUFnQixFQUNoQixhQUFhLEVBQ2QsTUFBTSxVQUFVLENBQUM7QUFDbEIsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFdEUsTUFBTSxhQUFhLEdBSWQsQ0FBQyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRTtJQUN2QyxNQUFNLGVBQWUsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO0lBQ25DLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RDLE1BQU0sbUJBQW1CLEdBQ3ZCLG9CQUFvQixDQUFDLFdBQVcsRUFBRSxlQUFlLEVBQUU7UUFDakQsY0FBYyxFQUFFLE9BQU87S0FDeEIsQ0FBQyxHQUFHLE1BQU0sQ0FBQztJQUNkLE1BQU0sYUFBYSxHQUFHLG1CQUFtQixDQUFDLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUV4RSxNQUFNLGlCQUFpQixHQUFHLGFBQWEsR0FBRyxFQUFFLENBQUM7SUFDN0MsTUFBTSxlQUFlLEdBQUcsYUFBYSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUM7SUFDaEQsTUFBTSxpQkFBaUIsR0FBRyxhQUFhLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUM7SUFDdkQsTUFBTSxTQUFTLEdBQUcsd0JBQXdCLENBQUMsZUFBZSxFQUFFLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUU5RSxNQUFNLFVBQVUsR0FBRyxRQUFRO1FBQ3pCLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxLQUFLLE1BQU0sQ0FBQztRQUM1QyxDQUFDLENBQUMsS0FBSyxDQUFDO0lBRVYsT0FBTyxDQUNMLG9CQUFDLFNBQVMsSUFBQyxVQUFVLEVBQUUsVUFBVSxJQUFJLGVBQWU7UUFDbEQsb0JBQUMsZ0JBQWdCO1lBQ2Ysb0JBQUMsZ0JBQWdCO2dCQUNkLFVBQVUsSUFBSSxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQy9CLG9CQUFDLGFBQWE7b0JBQ1osb0JBQUMsbUJBQW1CLE9BQUcsQ0FDVCxDQUNqQixDQUFDLENBQUMsQ0FBQyxJQUFJO2dCQUNQLENBQUMsaUJBQWlCLElBQUksaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQ3pDLG9CQUFDLDRCQUE0QjtvQkFDM0Isb0JBQUMsbUJBQW1CLElBQ2xCLFVBQVUsRUFBRSxVQUFVLGlCQUNWLHFCQUFxQixJQUVoQyxtQkFBbUIsQ0FDQTtvQkFDdEIsb0JBQUMsT0FBTyxPQUFHLENBQ2tCLENBQ2hDLENBQUMsQ0FBQyxDQUFDLElBQUk7Z0JBQ1Isb0JBQUMsV0FBVyxJQUNWLGlCQUFpQixFQUFFLENBQUMsaUJBQWlCLElBQUksaUJBQWlCLGlCQUM5QyxhQUFhLElBRXhCLE1BQU0sQ0FBQyxXQUFXLEVBQUUsU0FBUyxDQUFDLENBQ25CLENBQ0c7WUFDbEIsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUNYLG9CQUFDLFdBQVcsbUJBQWEsYUFBYSxJQUNuQyxNQUFNLENBQUMsV0FBVyxFQUFFLGFBQWEsQ0FBQyxDQUN2QixDQUNmLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FDUztRQUNsQixRQUFRLElBQUksb0JBQUMsUUFBUSxRQUFFLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBWSxDQUM3QyxDQUNiLENBQUM7QUFDSixDQUFDLENBQUM7QUFFRixlQUFlLGFBQWEsQ0FBQyJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { storiesOf } from '@storybook/react';
|
|
3
|
+
import { date, select } from '@storybook/addon-knobs';
|
|
4
|
+
import { ArticleHarness } from '../../fixtures/article-harness/ArticleHarness';
|
|
5
|
+
import ArticleHeader from './ArticleHeader';
|
|
6
|
+
storiesOf('Typescript Component/Article Header', module)
|
|
7
|
+
.addDecorator((storyFn) => (React.createElement(ArticleHarness, null, storyFn())))
|
|
8
|
+
.add('Basic Article Header', () => {
|
|
9
|
+
const label = 'Updated Date/Time';
|
|
10
|
+
const defaultValue = new Date();
|
|
11
|
+
const groupId = 'Options';
|
|
12
|
+
const value = date(label, defaultValue, groupId);
|
|
13
|
+
const breakingOptions = {
|
|
14
|
+
True: 'true',
|
|
15
|
+
False: undefined
|
|
16
|
+
};
|
|
17
|
+
const updated = new Date(value).toISOString();
|
|
18
|
+
return (React.createElement(ArticleHeader, { updated: updated, breaking: select('Breaking', breakingOptions, undefined, groupId), headline: "This%20is%20the%20headline" }));
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXJ0aWNsZUhlYWRlci5zdG9yaWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXJ0aWNsZS1oZWFkZXIvQXJ0aWNsZUhlYWRlci5zdG9yaWVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssTUFBTSxPQUFPLENBQUM7QUFDMUIsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQy9FLE9BQU8sYUFBYSxNQUFNLGlCQUFpQixDQUFDO0FBRTVDLFNBQVMsQ0FBQyxxQ0FBcUMsRUFBRSxNQUFNLENBQUM7S0FDckQsWUFBWSxDQUFDLENBQUMsT0FBOEIsRUFBRSxFQUFFLENBQUMsQ0FDaEQsb0JBQUMsY0FBYyxRQUFFLE9BQU8sRUFBRSxDQUFrQixDQUM3QyxDQUFDO0tBQ0QsR0FBRyxDQUFDLHNCQUFzQixFQUFFLEdBQUcsRUFBRTtJQUNoQyxNQUFNLEtBQUssR0FBRyxtQkFBbUIsQ0FBQztJQUNsQyxNQUFNLFlBQVksR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO0lBQ2hDLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQztJQUMxQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNqRCxNQUFNLGVBQWUsR0FBRztRQUN0QixJQUFJLEVBQUUsTUFBTTtRQUNaLEtBQUssRUFBRSxTQUFTO0tBQ2pCLENBQUM7SUFFRixNQUFNLE9BQU8sR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUM5QyxPQUFPLENBQ0wsb0JBQUMsYUFBYSxJQUNaLE9BQU8sRUFBRSxPQUFPLEVBQ2hCLFFBQVEsRUFBRSxNQUFNLENBQUMsVUFBVSxFQUFFLGVBQWUsRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDLEVBQ2pFLFFBQVEsRUFBQyw0QkFBNEIsR0FDckMsQ0FDSCxDQUFDO0FBQ0osQ0FBQyxDQUFDLENBQUMifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import '@testing-library/jest-dom';
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { render } from '@testing-library/react';
|
|
3
|
+
import '@testing-library/jest-dom';
|
|
4
|
+
import ArticleHeader from '../ArticleHeader';
|
|
5
|
+
import MockDate from 'mockdate';
|
|
6
|
+
describe('ArticleHeader', () => {
|
|
7
|
+
describe('In one calendar day', () => {
|
|
8
|
+
const updated = '2021-12-31T06:30:00Z';
|
|
9
|
+
afterEach(() => MockDate.reset());
|
|
10
|
+
it('Within the first minute of update - Breaking', () => {
|
|
11
|
+
MockDate.set('2021-12-31T06:30:00Z');
|
|
12
|
+
const { baseElement, getByText, queryByTestId } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
13
|
+
expect(baseElement).toMatchSnapshot();
|
|
14
|
+
expect(getByText('BREAKING')).toBeVisible();
|
|
15
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
16
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
17
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
18
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
19
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
20
|
+
});
|
|
21
|
+
it('Within the first minute of update - Not Breaking', () => {
|
|
22
|
+
MockDate.set('2021-12-31T06:30:00Z');
|
|
23
|
+
const { baseElement, getByText, queryByTestId, queryByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "false", headline: "This%20is%20the%20headline" }));
|
|
24
|
+
expect(baseElement).toMatchSnapshot();
|
|
25
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
26
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
27
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
28
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
29
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
30
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
31
|
+
});
|
|
32
|
+
it('Within the first minute of update - No headline not breaking', () => {
|
|
33
|
+
MockDate.set('2021-12-31T06:30:00Z');
|
|
34
|
+
const { baseElement, getByText, queryByTestId, queryByText } = render(React.createElement(ArticleHeader, { updated: updated }));
|
|
35
|
+
expect(baseElement).toMatchSnapshot();
|
|
36
|
+
expect(queryByText('This is the headline')).toBeFalsy();
|
|
37
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
38
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
39
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
40
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
41
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
42
|
+
});
|
|
43
|
+
it('within an hour of updating', () => {
|
|
44
|
+
MockDate.set('2021-12-31T07:00:00Z');
|
|
45
|
+
const { getByText, queryByTestId } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
46
|
+
expect(getByText('BREAKING')).toBeVisible();
|
|
47
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
48
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
49
|
+
expect(queryByTestId('TimeSincePublishing')).toBeTruthy();
|
|
50
|
+
expect(getByText('30 minutes ago')).toBeVisible();
|
|
51
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
52
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
53
|
+
});
|
|
54
|
+
it('between 1 and 12 hours after update time', () => {
|
|
55
|
+
MockDate.set('2021-12-31T08:30:00Z');
|
|
56
|
+
const { getByText, queryByTestId, queryByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
57
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
58
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
59
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
60
|
+
expect(queryByTestId('TimeSincePublishing')).toBeTruthy();
|
|
61
|
+
expect(getByText('2 hours ago')).toBeVisible();
|
|
62
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
63
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
64
|
+
});
|
|
65
|
+
it('after 12 hours but on the same calendar day', () => {
|
|
66
|
+
MockDate.set('2021-12-31T19:30:00Z');
|
|
67
|
+
const { getByText, queryByTestId, queryByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
68
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
69
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
70
|
+
expect(getByText('6.30am')).toBeVisible();
|
|
71
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
72
|
+
expect(queryByTestId('UpdatedDate')).toBeFalsy();
|
|
73
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
describe('Across calendar days', () => {
|
|
77
|
+
const updated = '2021-12-31T23:30:00Z';
|
|
78
|
+
afterEach(() => MockDate.reset());
|
|
79
|
+
it('within an hour of updating but on a different calendar day', () => {
|
|
80
|
+
MockDate.set('2022-01-01T00:29:00Z');
|
|
81
|
+
const { getByTestId, queryByTestId, getByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
82
|
+
expect(getByText('BREAKING')).toBeVisible();
|
|
83
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
84
|
+
expect(getByText('11.30pm')).toBeVisible();
|
|
85
|
+
expect(getByTestId('TimeSincePublishing')).toBeTruthy();
|
|
86
|
+
expect(getByTestId('UpdatedDate')).toBeVisible();
|
|
87
|
+
expect(getByText('December 31 2021')).toBeVisible();
|
|
88
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
89
|
+
});
|
|
90
|
+
it('between 1-12 hours of updating but on a different calendar day', () => {
|
|
91
|
+
MockDate.set('2022-01-01T02:00:00Z');
|
|
92
|
+
const { getByTestId, queryByText, queryByTestId, getByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
93
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
94
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
95
|
+
expect(getByText('11.30pm')).toBeVisible();
|
|
96
|
+
expect(getByTestId('TimeSincePublishing')).toBeTruthy();
|
|
97
|
+
expect(getByText('2 hours ago')).toBeVisible();
|
|
98
|
+
expect(getByTestId('UpdatedDate')).toBeVisible();
|
|
99
|
+
expect(getByText('December 31 2021')).toBeVisible();
|
|
100
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
101
|
+
});
|
|
102
|
+
it('after 12 hours but on a different calendar day', () => {
|
|
103
|
+
MockDate.set('2022-01-01T14:30:00Z');
|
|
104
|
+
const { getByTestId, queryByText, queryByTestId, getByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
105
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
106
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
107
|
+
expect(getByText('11.30pm')).toBeVisible();
|
|
108
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
109
|
+
expect(getByTestId('UpdatedDate')).toBeVisible();
|
|
110
|
+
expect(getByText('December 31 2021')).toBeVisible();
|
|
111
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
112
|
+
});
|
|
113
|
+
it('after multiple calendar days', () => {
|
|
114
|
+
MockDate.set('2022-01-03T14:30:00Z');
|
|
115
|
+
const { getByTestId, queryByText, queryByTestId, getByText } = render(React.createElement(ArticleHeader, { updated: updated, breaking: "true", headline: "This%20is%20the%20headline" }));
|
|
116
|
+
expect(queryByText('BREAKING')).toBeFalsy();
|
|
117
|
+
expect(queryByTestId('UpdatedTime')).toBeTruthy();
|
|
118
|
+
expect(getByText('11.30pm')).toBeVisible();
|
|
119
|
+
expect(queryByTestId('TimeSincePublishing')).toBeFalsy();
|
|
120
|
+
expect(getByTestId('UpdatedDate')).toBeVisible();
|
|
121
|
+
expect(getByText('December 31 2021')).toBeVisible();
|
|
122
|
+
expect(getByText('This is the headline')).toBeVisible();
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ArticleHeader.test.js","sourceRoot":"","sources":["../../../../src/components/article-header/__tests__/ArticleHeader.test.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export declare const Container: import("styled-components").StyledComponent<"div", any, {
|
|
2
|
+
isBreaking: boolean;
|
|
3
|
+
}, never>;
|
|
4
|
+
export declare const UpdatesContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
5
|
+
export declare const TimeSincePublishingContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
6
|
+
export declare const TimeSincePublishing: import("styled-components").StyledComponent<"div", any, {
|
|
7
|
+
isBreaking?: boolean | undefined;
|
|
8
|
+
}, never>;
|
|
9
|
+
export declare const UpdatedTimeItems: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
10
|
+
export declare const UpdatedTime: import("styled-components").StyledComponent<"div", any, {
|
|
11
|
+
isLessThan13Hours?: boolean | undefined;
|
|
12
|
+
}, never>;
|
|
13
|
+
export declare const UpdatedDate: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
14
|
+
export declare const Divider: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
15
|
+
export declare const Headline: import("styled-components").StyledComponent<"h2", any, {}, never>;
|
|
16
|
+
export declare const FlagContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import styled, { css } from 'styled-components';
|
|
2
|
+
import { breakpoints, colours, fonts } from '@times-components/styleguide';
|
|
3
|
+
export const Container = styled.div `
|
|
4
|
+
display: flex;
|
|
5
|
+
flex-direction: column;
|
|
6
|
+
justify-content: center;
|
|
7
|
+
margin: 48px 10px 0 10px;
|
|
8
|
+
padding-top: ${({ isBreaking }) => (isBreaking ? '8px' : '5px')};
|
|
9
|
+
border-top: 2px solid #9f0000;
|
|
10
|
+
|
|
11
|
+
@media (min-width: ${breakpoints.medium}px) {
|
|
12
|
+
width: 80.8%;
|
|
13
|
+
margin: 64px 0 0 10%;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
@media (min-width: ${breakpoints.wide}px) {
|
|
17
|
+
width: 56.2%;
|
|
18
|
+
margin: 64px 0 0 22%;
|
|
19
|
+
}
|
|
20
|
+
`;
|
|
21
|
+
export const UpdatesContainer = styled.div `
|
|
22
|
+
display: flex;
|
|
23
|
+
flex-direction: row;
|
|
24
|
+
justify-content: space-between;
|
|
25
|
+
`;
|
|
26
|
+
export const TimeSincePublishingContainer = styled.div `
|
|
27
|
+
display: flex;
|
|
28
|
+
flex-direction: row;
|
|
29
|
+
`;
|
|
30
|
+
export const TimeSincePublishing = styled.div `
|
|
31
|
+
color: ${colours.functional.brandColour};
|
|
32
|
+
font-family: ${fonts.supporting};
|
|
33
|
+
font-size: 14px;
|
|
34
|
+
line-height: 18px;
|
|
35
|
+
`;
|
|
36
|
+
const updatedStyle = css `
|
|
37
|
+
color: ${colours.functional.secondary};
|
|
38
|
+
font-family: ${fonts.supporting};
|
|
39
|
+
font-size: 14px;
|
|
40
|
+
line-height: 18px;
|
|
41
|
+
`;
|
|
42
|
+
export const UpdatedTimeItems = styled.div `
|
|
43
|
+
display: flex;
|
|
44
|
+
justify-content: space-between;
|
|
45
|
+
align-items: baseline;
|
|
46
|
+
`;
|
|
47
|
+
export const UpdatedTime = styled.div `
|
|
48
|
+
${updatedStyle};
|
|
49
|
+
`;
|
|
50
|
+
export const UpdatedDate = styled.div `
|
|
51
|
+
${updatedStyle} justify-content: end;
|
|
52
|
+
padding: 0 4px 0 0;
|
|
53
|
+
`;
|
|
54
|
+
export const Divider = styled.div `
|
|
55
|
+
background-color: ${colours.functional.greyLabel};
|
|
56
|
+
width: 1px;
|
|
57
|
+
margin: 2px 8px 6px 12px;
|
|
58
|
+
`;
|
|
59
|
+
export const Headline = styled.h2 `
|
|
60
|
+
color: ${colours.functional.brandColour};
|
|
61
|
+
font-family: ${fonts.headline};
|
|
62
|
+
font-size: 28px;
|
|
63
|
+
line-height: 28px;
|
|
64
|
+
margin-top: 22px;
|
|
65
|
+
font-weight: 400;
|
|
66
|
+
|
|
67
|
+
@media (min-width: ${breakpoints.medium}px) {
|
|
68
|
+
font-size: 36px;
|
|
69
|
+
line-height: 36px;
|
|
70
|
+
margin-top: 20px;
|
|
71
|
+
}
|
|
72
|
+
`;
|
|
73
|
+
export const FlagContainer = styled.div `
|
|
74
|
+
margin-right: 8px;
|
|
75
|
+
`;
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvYXJ0aWNsZS1oZWFkZXIvc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTSxFQUFFLEVBQUUsR0FBRyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDaEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFM0UsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQXlCOzs7OztpQkFLM0MsQ0FBQyxFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7Ozt1QkFHMUMsV0FBVyxDQUFDLE1BQU07Ozs7O3VCQUtsQixXQUFXLENBQUMsSUFBSTs7OztDQUl0QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQTs7OztDQUl6QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQTs7O0NBR3JELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUEwQjtXQUM1RCxPQUFPLENBQUMsVUFBVSxDQUFDLFdBQVc7aUJBQ3hCLEtBQUssQ0FBQyxVQUFVOzs7Q0FHaEMsQ0FBQztBQUVGLE1BQU0sWUFBWSxHQUFHLEdBQUcsQ0FBQTtXQUNiLE9BQU8sQ0FBQyxVQUFVLENBQUMsU0FBUztpQkFDdEIsS0FBSyxDQUFDLFVBQVU7OztDQUdoQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQTs7OztDQUl6QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQWlDO0lBQ2xFLFlBQVk7Q0FDZixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUE7SUFDakMsWUFBWTs7Q0FFZixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUE7c0JBQ1gsT0FBTyxDQUFDLFVBQVUsQ0FBQyxTQUFTOzs7Q0FHakQsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsRUFBRSxDQUFBO1dBQ3RCLE9BQU8sQ0FBQyxVQUFVLENBQUMsV0FBVztpQkFDeEIsS0FBSyxDQUFDLFFBQVE7Ozs7Ozt1QkFNUixXQUFXLENBQUMsTUFBTTs7Ozs7Q0FLeEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFBOztDQUV0QyxDQUFDIn0=
|
package/dist/index.d.ts
CHANGED
|
@@ -25,3 +25,4 @@ export { AlgoliaSearchProvider, useAlgoliaSearch } from './helpers/algolia/Algol
|
|
|
25
25
|
export { HiddenDiv } from './components/common-styles';
|
|
26
26
|
export { InlineMessage } from './components/inline-message/InlineMessage';
|
|
27
27
|
export { InlineDialog } from './components/inline-dialog/InlineDialog';
|
|
28
|
+
export { default as ArticleHeader } from './components/article-header/ArticleHeader';
|
package/dist/index.js
CHANGED
|
@@ -31,4 +31,5 @@ export { AlgoliaSearchProvider, useAlgoliaSearch } from './helpers/algolia/Algol
|
|
|
31
31
|
export { HiddenDiv } from './components/common-styles';
|
|
32
32
|
export { InlineMessage } from './components/inline-message/InlineMessage';
|
|
33
33
|
export { InlineDialog } from './components/inline-dialog/InlineDialog';
|
|
34
|
-
|
|
34
|
+
export { default as ArticleHeader } from './components/article-header/ArticleHeader';
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscUJBQXFCO0FBQ3JCLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUMzRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3hFLE9BQU8sRUFDTCxvQkFBb0IsRUFDckIsTUFBTSxxRUFBcUUsQ0FBQztBQUM3RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDNUUsT0FBTyxFQUNMLG1CQUFtQixFQUNuQixlQUFlLEVBQ2hCLE1BQU0sMkNBQTJDLENBQUM7QUFDbkQsT0FBTyxFQUNMLFdBQVcsRUFDWCxZQUFZLEVBQ1osY0FBYyxFQUNkLGtCQUFrQixFQUNsQixvQkFBb0IsRUFDcEIsb0JBQW9CLEVBQ3BCLG1CQUFtQixFQUNwQixNQUFNLHVDQUF1QyxDQUFDO0FBRS9DLHdCQUF3QjtBQUN4QixPQUFPLEVBQ0wsa0JBQWtCLEVBQ25CLE1BQU0saURBQWlELENBQUM7QUFDekQsT0FBTyxFQUNMLG9CQUFvQixFQUNyQixNQUFNLG1EQUFtRCxDQUFDO0FBQzNELE9BQU8sRUFDTCxxQkFBcUIsRUFDdEIsTUFBTSxvREFBb0QsQ0FBQztBQUU1RCxtQkFBbUI7QUFDbkIsT0FBTyxFQUNMLG9CQUFvQixFQUNyQixNQUFNLDBEQUEwRCxDQUFDO0FBQ2xFLE9BQU8sRUFDTCxxQkFBcUIsRUFDdEIsTUFBTSw0REFBNEQsQ0FBQztBQUNwRSxPQUFPLEVBQ0wsbUJBQW1CLEVBQ3BCLE1BQU0sd0RBQXdELENBQUM7QUFDaEUsT0FBTyxFQUNMLHNCQUFzQixFQUN2QixNQUFNLCtEQUErRCxDQUFDO0FBQ3ZFLE9BQU8sRUFDTCxrQkFBa0IsRUFDbkIsTUFBTSxzREFBc0QsQ0FBQztBQUM5RCxPQUFPLEVBQ0wsZ0JBQWdCLEVBQ2pCLE1BQU0saURBQWlELENBQUM7QUFFekQsNkJBQTZCO0FBQzdCLE9BQU8sRUFDTCxtQkFBbUIsRUFDcEIsTUFBTSx3REFBd0QsQ0FBQztBQUNoRSxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2xCLE1BQU0sb0RBQW9ELENBQUM7QUFDNUQsT0FBTyxFQUNMLHdCQUF3QixFQUN6QixNQUFNLG1FQUFtRSxDQUFDO0FBQzNFLHlCQUF5QjtBQUN6QixPQUFPLEVBQ0wscUJBQXFCLEVBQ3RCLE1BQU0scURBQXFELENBQUM7QUFFN0QsVUFBVTtBQUNWLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQ0wsZ0JBQWdCLEVBQ2pCLE1BQU0sK0NBQStDLENBQUM7QUFDdkQsT0FBTyxFQUNMLHVCQUF1QixFQUN4QixNQUFNLDRDQUE0QyxDQUFDO0FBQ3BELE9BQU8sRUFDTCxxQkFBcUIsRUFDckIsZ0JBQWdCLEVBQ2pCLE1BQU0seUNBQXlDLENBQUM7QUFDakQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUUxRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFdkUsT0FBTyxFQUNMLE9BQU8sSUFBSSxhQUFhLEVBQ3pCLE1BQU0sMkNBQTJDLENBQUMifQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@times-components/ts-components",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.19.1",
|
|
4
4
|
"description": "Reuseable Typescript React Components",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"dev": "dist/index.js",
|
|
@@ -49,18 +49,19 @@
|
|
|
49
49
|
"node": ">=8.9"
|
|
50
50
|
},
|
|
51
51
|
"dependencies": {
|
|
52
|
-
"@times-components/button": "2.4.
|
|
53
|
-
"@times-components/date-publication": "0.
|
|
54
|
-
"@times-components/icons": "2.16.
|
|
55
|
-
"@times-components/image": "6.8.
|
|
56
|
-
"@times-components/link": "3.6.
|
|
57
|
-
"@times-components/provider": "1.29.
|
|
52
|
+
"@times-components/button": "2.4.71",
|
|
53
|
+
"@times-components/date-publication": "0.22.0",
|
|
54
|
+
"@times-components/icons": "2.16.10",
|
|
55
|
+
"@times-components/image": "6.8.15",
|
|
56
|
+
"@times-components/link": "3.6.51",
|
|
57
|
+
"@times-components/provider": "1.29.4",
|
|
58
58
|
"@times-components/provider-queries": "2.15.3",
|
|
59
|
-
"@times-components/related-articles": "6.6.
|
|
60
|
-
"@times-components/styleguide": "3.38.
|
|
61
|
-
"@times-components/ts-slices": "1.
|
|
62
|
-
"@times-components/utils": "6.5.
|
|
59
|
+
"@times-components/related-articles": "6.6.33",
|
|
60
|
+
"@times-components/styleguide": "3.38.29",
|
|
61
|
+
"@times-components/ts-slices": "1.3.0",
|
|
62
|
+
"@times-components/utils": "6.5.13",
|
|
63
63
|
"algoliasearch": "4.9.0",
|
|
64
|
+
"date-fns": "2.28.0",
|
|
64
65
|
"graphql": "14.2.1",
|
|
65
66
|
"isomorphic-unfetch": "3.1.0",
|
|
66
67
|
"lodash.get": "4.4.2",
|
|
@@ -78,9 +79,9 @@
|
|
|
78
79
|
"@storybook/addon-knobs": "5.3.18",
|
|
79
80
|
"@storybook/react": "5.3.18",
|
|
80
81
|
"@testing-library/jest-dom": "^5.12.0",
|
|
81
|
-
"@testing-library/react": "^
|
|
82
|
-
"@times-components/provider-test-tools": "1.22.
|
|
83
|
-
"@times-components/storybook": "4.1.
|
|
82
|
+
"@testing-library/react": "^12.1.2",
|
|
83
|
+
"@times-components/provider-test-tools": "1.22.3",
|
|
84
|
+
"@times-components/storybook": "4.1.73",
|
|
84
85
|
"@times-components/test-utils": "2.3.10",
|
|
85
86
|
"@types/graphql": "14.0.3",
|
|
86
87
|
"@types/jest": "24.9.1",
|
|
@@ -115,5 +116,5 @@
|
|
|
115
116
|
"@testing-library/jest-dom/extend-expect"
|
|
116
117
|
]
|
|
117
118
|
},
|
|
118
|
-
"gitHead": "
|
|
119
|
+
"gitHead": "40e3372ae5d4900d4da13fa9695682f480149fdd"
|
|
119
120
|
}
|