playbook_ui 12.37.0.pre.alpha.PLAY951collapsiblenav31062 → 12.37.0.pre.alpha.PLAY951collapsiblenav31073
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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_date/_date.tsx +7 -8
- data/app/pb_kits/playbook/pb_date/docs/_date_alignment.jsx +2 -2
- data/app/pb_kits/playbook/pb_date/docs/_date_default.jsx +29 -5
- data/app/pb_kits/playbook/pb_date/docs/_date_unstyled.jsx +2 -2
- data/app/pb_kits/playbook/pb_date/docs/_date_variants.jsx +5 -5
- data/app/pb_kits/playbook/pb_date_range_inline/_date_range_inline.tsx +45 -31
- data/app/pb_kits/playbook/pb_date_range_stacked/_date_range_stacked.tsx +5 -3
- data/app/pb_kits/playbook/pb_date_stacked/_date_stacked.tsx +24 -21
- data/app/pb_kits/playbook/pb_date_time/_date_time.tsx +1 -1
- data/app/pb_kits/playbook/pb_date_time/dateTime.test.js +1 -1
- data/app/pb_kits/playbook/pb_date_time_stacked/_date_time_stacked.tsx +2 -2
- data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.test.js +1 -1
- data/app/pb_kits/playbook/pb_date_year_stacked/_date_year_stacked.tsx +6 -8
- data/app/pb_kits/playbook/pb_kit/dateTime.ts +146 -63
- data/app/pb_kits/playbook/pb_label_value/_label_value.tsx +52 -31
- data/app/pb_kits/playbook/pb_message/_message.tsx +24 -24
- data/app/pb_kits/playbook/pb_nav/_collapsible_nav.scss +170 -46
- data/app/pb_kits/playbook/pb_nav/_horizontal_nav.scss +6 -0
- data/app/pb_kits/playbook/pb_nav/_item.tsx +9 -7
- data/app/pb_kits/playbook/pb_nav/_mixins.scss +5 -0
- data/app/pb_kits/playbook/pb_nav/_subtle_mixin.scss +0 -1
- data/app/pb_kits/playbook/pb_nav/_vertical_nav.scss +1 -1
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav.jsx +8 -2
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_custom.jsx +3 -2
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_emphasize.html.erb +3 -3
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_emphasize.jsx +12 -5
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_emphasize.md +1 -1
- data/app/pb_kits/playbook/pb_nav/item.rb +12 -8
- data/app/pb_kits/playbook/pb_time/_time.tsx +9 -11
- data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.tsx +46 -49
- data/app/pb_kits/playbook/pb_time_stacked/_time_stacked.tsx +4 -6
- data/app/pb_kits/playbook/pb_timestamp/_timestamp.tsx +11 -11
- data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.tsx +8 -11
- data/dist/playbook-rails.js +7 -7
- data/lib/playbook/version.rb +1 -1
- metadata +3 -3
- data/app/pb_kits/playbook/pb_logistic/_logistic.jsx +0 -120
@@ -1,90 +1,173 @@
|
|
1
|
+
const ABBR_DAYS = ['SU', 'M', 'T', 'W', 'TH', 'F', 'S']
|
1
2
|
|
2
|
-
|
3
|
-
import 'moment-strftime'
|
4
|
-
import 'moment-timezone'
|
3
|
+
const days = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"];
|
5
4
|
|
6
|
-
|
7
|
-
value: string | Date,
|
8
|
-
zone?: string,
|
9
|
-
}
|
5
|
+
const months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
|
10
6
|
|
11
|
-
const
|
12
|
-
|
13
|
-
export default class DateTime {
|
14
|
-
value: Moment & any
|
15
|
-
constructor({ value, zone = 'America/New_York' }: DateTimeType) {
|
16
|
-
this.value = this.convertToTimestampZone(value, zone)
|
17
|
-
}
|
7
|
+
const formatDate = (newDate: Date | string) => {
|
8
|
+
const isTimelessStringDate = typeof newDate === "string" && !newDate.includes("T")
|
18
9
|
|
19
|
-
|
20
|
-
|
10
|
+
if (isTimelessStringDate) {
|
11
|
+
const unhyphenatedDate = new Date((newDate as string).replace(/-/g, "/"))
|
12
|
+
return unhyphenatedDate
|
21
13
|
}
|
22
14
|
|
23
|
-
|
24
|
-
|
25
|
-
}
|
15
|
+
return new Date(newDate)
|
16
|
+
}
|
26
17
|
|
27
|
-
|
28
|
-
|
18
|
+
export const toMinute = (newDate: Date | string, timeZone?: string): string => {
|
19
|
+
const date = formatDate(newDate)
|
20
|
+
if (timeZone) {
|
21
|
+
return date.toLocaleTimeString(undefined, { timeZone, hour: "2-digit", minute: "2-digit" }).slice(3, 5);
|
22
|
+
} else {
|
23
|
+
return date.toLocaleTimeString(undefined, { hour: "2-digit", minute: "2-digit" }).slice(3, 5);
|
29
24
|
}
|
25
|
+
}
|
30
26
|
|
31
|
-
|
32
|
-
|
27
|
+
export const toHour = (newDate: Date | string, timeZone?: string): string => {
|
28
|
+
const date = formatDate(newDate)
|
29
|
+
if (timeZone) {
|
30
|
+
return date.toLocaleTimeString(undefined, { timeZone, hour: "numeric" }).split(' ')[0];
|
31
|
+
} else {
|
32
|
+
return date.toLocaleTimeString(undefined, { hour: "numeric" }).split(' ')[0];
|
33
33
|
}
|
34
|
+
}
|
34
35
|
|
35
|
-
|
36
|
-
|
37
|
-
|
36
|
+
export const toDay = (newDate: Date | string, timeZone?: string): number => {
|
37
|
+
if (timeZone) {
|
38
|
+
const date = new Date(formatDate(newDate).toLocaleString(undefined, { timeZone }));
|
39
|
+
return date.getDate()
|
40
|
+
} else {
|
41
|
+
const date = formatDate(newDate)
|
42
|
+
return date.getDate()
|
43
|
+
}
|
44
|
+
}
|
38
45
|
|
39
|
-
|
40
|
-
|
41
|
-
|
46
|
+
export const toDayAbbr = (newDate: Date | string): string => {
|
47
|
+
const date = formatDate(newDate)
|
48
|
+
return ABBR_DAYS[date.getUTCDay()]
|
49
|
+
}
|
42
50
|
|
43
|
-
|
44
|
-
|
45
|
-
|
51
|
+
export const toWeekday = (newDate: Date | string): string => {
|
52
|
+
const date = formatDate(newDate)
|
53
|
+
return days[date.getUTCDay()]
|
54
|
+
}
|
46
55
|
|
47
|
-
|
48
|
-
|
49
|
-
|
56
|
+
export const toMonth = (newDate: Date | string, timeZone?: string): string => {
|
57
|
+
if (timeZone) {
|
58
|
+
const date = new Date(formatDate(newDate).toLocaleString(undefined, { timeZone }));
|
59
|
+
return months[date.getUTCMonth()]
|
60
|
+
} else {
|
61
|
+
const date = formatDate(newDate)
|
62
|
+
return months[date.getUTCMonth()]
|
63
|
+
}
|
64
|
+
}
|
50
65
|
|
51
|
-
|
52
|
-
|
53
|
-
|
66
|
+
export const toMonthNum = (newDate: Date | string): number => {
|
67
|
+
const date = formatDate(newDate)
|
68
|
+
return date.getUTCMonth() +1
|
69
|
+
}
|
54
70
|
|
55
|
-
|
56
|
-
|
57
|
-
|
71
|
+
export const toYear = (newDate: Date | string, timeZone?: string): number => {
|
72
|
+
if (timeZone) {
|
73
|
+
const date = new Date(newDate.toLocaleString(undefined, { timeZone }));
|
74
|
+
return date.getUTCFullYear()
|
75
|
+
} else {
|
76
|
+
const date = new Date(newDate)
|
77
|
+
return date.getUTCFullYear()
|
78
|
+
}
|
79
|
+
}
|
58
80
|
|
59
|
-
|
60
|
-
|
81
|
+
export const toTime = (newDate: Date | string, timeZone?: string): string => {
|
82
|
+
const date = formatDate(newDate)
|
83
|
+
if (timeZone) {
|
84
|
+
return date.toLocaleTimeString(undefined, { timeZone, timeStyle: "short" }).split(' ')[0];
|
85
|
+
} else {
|
86
|
+
return date.toLocaleTimeString(undefined, { timeStyle: "short" }).split(' ')[0];
|
61
87
|
}
|
88
|
+
}
|
62
89
|
|
63
|
-
|
64
|
-
|
65
|
-
|
90
|
+
export const toMeridiem = (newDate: Date | string, timeZone?: string): string => {
|
91
|
+
const date = formatDate(newDate)
|
92
|
+
if (timeZone) {
|
93
|
+
return date.toLocaleString(undefined, { timeZone, hour12: true }).slice(-2).charAt(0).toLocaleLowerCase();
|
94
|
+
} else {
|
95
|
+
return date.toLocaleString(undefined, { hour12: true }).slice(-2).charAt(0).toLocaleLowerCase();
|
96
|
+
}
|
97
|
+
}
|
66
98
|
|
67
|
-
|
68
|
-
|
69
|
-
|
99
|
+
export const toTimeZone = (newDate: Date | string, timeZone?: string): string => {
|
100
|
+
const date = formatDate(newDate)
|
101
|
+
if (timeZone) {
|
102
|
+
return date.toLocaleString(undefined, { timeZone, timeZoneName: "short" }).split(' ')[3];
|
103
|
+
} else {
|
104
|
+
return date.toLocaleString(undefined, { timeZoneName: "short" }).split(' ')[3];
|
105
|
+
}
|
106
|
+
}
|
70
107
|
|
71
|
-
|
72
|
-
|
73
|
-
}
|
108
|
+
export const toTimeWithMeridiem = (newDate: Date | string, timeZone: string): string => {
|
109
|
+
const date = formatDate(newDate)
|
110
|
+
return `${toTime(date, timeZone)}${toMeridiem(date, timeZone)}`;
|
111
|
+
}
|
74
112
|
|
75
|
-
|
76
|
-
const
|
113
|
+
export const toIso = (newDate: Date | string): string => {
|
114
|
+
const date = formatDate(newDate)
|
115
|
+
return date.toISOString()
|
116
|
+
}
|
77
117
|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
118
|
+
export const fromNow = (newDate: Date | string): string => {
|
119
|
+
|
120
|
+
const startDate = formatDate(newDate).getTime()
|
121
|
+
const endDate = new Date().getTime()
|
122
|
+
const elapsedTime = endDate - startDate
|
123
|
+
let elapsedTimeString = `${Math.round(elapsedTime / (365.25 * 24 * 60 * 60 * 1000))} years ago.`; // 730+ days
|
124
|
+
|
125
|
+
const elapsedTimeData = [
|
126
|
+
{ min: 0, max: 44999, value: "a few seconds ago" }, // 0-44 seconds
|
127
|
+
{ min: 45000, max: 89999, value: "a minute ago" }, // 45-89 seconds
|
128
|
+
{ min: 90000, max: 2649999, value: `${Math.round(elapsedTime / 60000)} minutes ago`}, // 90s-44 minutes
|
129
|
+
{ min: 2650000, max: 7299999, value: "an hour ago" }, // 45-120 minutes
|
130
|
+
{ min: 7300000, max: 75699999, value: `${Math.round(elapsedTime / 3600000)} hours ago`}, // 2-21 hours
|
131
|
+
{ min: 75700000, max: 172899999, value: "a day ago" }, // 22-48 hours
|
132
|
+
{ min: 172900000, max: 2169999999, value: `${Math.round(elapsedTime / 86400000)} days ago`}, // 2-25 days
|
133
|
+
{ min: 2170000000, max: 5184999999, value: "a month ago"}, // 26-60 days
|
134
|
+
{ min: 5185000000, max: 27561699999, value: `${Math.round(elapsedTime / 30.44 * 24 * 60 * 60 * 1000)} months ago`}, // 60-319 days
|
135
|
+
{ min: 27561700000, max: 63072999999, value: "a year ago"}, // 320-730 days
|
136
|
+
];
|
137
|
+
|
138
|
+
for (const timeDate of elapsedTimeData) {
|
139
|
+
if (elapsedTime >= timeDate.min && elapsedTime <= timeDate.max) {
|
140
|
+
elapsedTimeString = timeDate.value;
|
141
|
+
break;
|
142
|
+
}
|
143
|
+
}
|
144
|
+
|
145
|
+
return elapsedTimeString
|
146
|
+
}
|
82
147
|
|
83
|
-
|
84
|
-
|
148
|
+
export const toCustomFormat = (newDate: Date | string, format = 'month_day'): string => {
|
149
|
+
const date = formatDate(newDate)
|
150
|
+
if (format == "month_day") {
|
151
|
+
return `${toMonthNum(date)}/${toDay(date)}`
|
152
|
+
} else {
|
153
|
+
return `${date.toLocaleString(undefined, { month: "short" })} ${toDay(date)}`
|
85
154
|
}
|
155
|
+
}
|
86
156
|
|
87
|
-
|
88
|
-
|
89
|
-
|
157
|
+
export default {
|
158
|
+
toMinute,
|
159
|
+
toHour,
|
160
|
+
toDay,
|
161
|
+
toDayAbbr,
|
162
|
+
toWeekday,
|
163
|
+
toMonth,
|
164
|
+
toMonthNum,
|
165
|
+
toYear,
|
166
|
+
toTime,
|
167
|
+
toMeridiem,
|
168
|
+
toTimeZone,
|
169
|
+
toTimeWithMeridiem,
|
170
|
+
toIso,
|
171
|
+
fromNow,
|
172
|
+
toCustomFormat,
|
90
173
|
}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
import React from "react";
|
2
2
|
import classnames from "classnames";
|
3
|
-
import DateTime from "../pb_kit/dateTime";
|
4
3
|
import { buildAriaProps, buildCss, buildDataProps } from "../utilities/props";
|
5
4
|
import { globalProps } from "../utilities/globalProps";
|
5
|
+
import DateTime from '../pb_kit/dateTime';
|
6
6
|
|
7
7
|
import Body from "../pb_body/_body";
|
8
8
|
import Caption from "../pb_caption/_caption";
|
@@ -26,9 +26,9 @@ type LabelValueProps = {
|
|
26
26
|
title?: string;
|
27
27
|
};
|
28
28
|
|
29
|
-
const dateString = (value:
|
30
|
-
const month =
|
31
|
-
const day =
|
29
|
+
const dateString = (value: Date) => {
|
30
|
+
const month = DateTime.toMonthNum(value);
|
31
|
+
const day = DateTime.toDay(value);
|
32
32
|
|
33
33
|
return ` · ${month}/${day}`;
|
34
34
|
};
|
@@ -52,7 +52,6 @@ const LabelValue = (props: LabelValueProps) => {
|
|
52
52
|
|
53
53
|
const ariaProps = buildAriaProps(aria);
|
54
54
|
const dataProps = buildDataProps(data);
|
55
|
-
const formattedDate = new DateTime({ value: date });
|
56
55
|
const variantClass = variant === "details" ? "details" : "";
|
57
56
|
const classes = classnames(
|
58
57
|
buildCss("pb_label_value_kit", variantClass),
|
@@ -62,59 +61,81 @@ const LabelValue = (props: LabelValueProps) => {
|
|
62
61
|
|
63
62
|
return (
|
64
63
|
<div
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
64
|
+
{...ariaProps}
|
65
|
+
{...dataProps}
|
66
|
+
className={classes}
|
67
|
+
id={id}
|
68
|
+
title={title}
|
70
69
|
>
|
71
|
-
<Caption dark={dark}
|
70
|
+
<Caption dark={dark}
|
71
|
+
text={label}
|
72
|
+
/>
|
72
73
|
{variant === "details" ? (
|
73
|
-
<Flex inline
|
74
|
+
<Flex inline
|
75
|
+
vertical="center"
|
76
|
+
>
|
74
77
|
{icon && (
|
75
|
-
<Body color="light"
|
76
|
-
|
78
|
+
<Body color="light"
|
79
|
+
dark={dark}
|
80
|
+
marginRight="xs"
|
81
|
+
>
|
82
|
+
<Icon dark={dark}
|
83
|
+
fixedWidth
|
84
|
+
icon={icon}
|
85
|
+
/>
|
77
86
|
</Body>
|
78
87
|
)}
|
79
88
|
{description && (
|
80
89
|
<Body
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
90
|
+
color="light"
|
91
|
+
dark={dark}
|
92
|
+
marginRight="xs"
|
93
|
+
text={description}
|
85
94
|
/>
|
86
95
|
)}
|
87
96
|
{active === true ? (
|
88
|
-
<Flex inline
|
97
|
+
<Flex inline
|
98
|
+
vertical="center"
|
99
|
+
>
|
89
100
|
{title && (
|
90
|
-
<Title dark={dark}
|
101
|
+
<Title dark={dark}
|
102
|
+
size={4}
|
103
|
+
text={title}
|
104
|
+
variant="link"
|
105
|
+
/>
|
91
106
|
)}
|
92
107
|
{date && (
|
93
108
|
<Title
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
109
|
+
dark={dark}
|
110
|
+
marginLeft="xs"
|
111
|
+
size={4}
|
112
|
+
text={" " + dateString(date)}
|
113
|
+
variant="link"
|
99
114
|
/>
|
100
115
|
)}
|
101
116
|
</Flex>
|
102
117
|
) : (
|
103
118
|
<>
|
104
|
-
{title && <Title dark={dark}
|
119
|
+
{title && <Title dark={dark}
|
120
|
+
size={4}
|
121
|
+
text={title}
|
122
|
+
/>
|
123
|
+
}
|
105
124
|
{date && (
|
106
125
|
<Title
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
126
|
+
dark={dark}
|
127
|
+
marginLeft="xs"
|
128
|
+
size={4}
|
129
|
+
text={" " + dateString(date)}
|
111
130
|
/>
|
112
131
|
)}
|
113
132
|
</>
|
114
133
|
)}
|
115
134
|
</Flex>
|
116
135
|
) : (
|
117
|
-
<Body dark={dark}
|
136
|
+
<Body dark={dark}
|
137
|
+
text={value}
|
138
|
+
/>
|
118
139
|
)}
|
119
140
|
</div>
|
120
141
|
);
|
@@ -25,7 +25,7 @@ type MessageProps = {
|
|
25
25
|
label?: string,
|
26
26
|
message: string,
|
27
27
|
timestamp?: string,
|
28
|
-
timestampObject?:
|
28
|
+
timestampObject?: Date,
|
29
29
|
timezone?: string,
|
30
30
|
alignTimestamp?: string,
|
31
31
|
}
|
@@ -62,50 +62,50 @@ const Message = (props: MessageProps) => {
|
|
62
62
|
|
63
63
|
return (
|
64
64
|
<div
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
65
|
+
{...ariaProps}
|
66
|
+
{...dataProps}
|
67
|
+
className={classes}
|
68
|
+
id={id}
|
69
69
|
>
|
70
70
|
{shouldDisplayAvatar &&
|
71
71
|
<Avatar
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
72
|
+
imageUrl={avatarUrl}
|
73
|
+
name={avatarName}
|
74
|
+
size="xs"
|
75
|
+
status={avatarStatus}
|
76
76
|
/>
|
77
77
|
}
|
78
78
|
<div className="content_wrapper">
|
79
79
|
<Flex
|
80
|
-
|
81
|
-
|
80
|
+
justify={alignTimestamp === 'left' ? 'none' : 'between'}
|
81
|
+
orientation="row"
|
82
82
|
>
|
83
83
|
{label &&
|
84
84
|
<Title
|
85
|
-
|
86
|
-
|
87
|
-
|
85
|
+
className="message_title"
|
86
|
+
size={4}
|
87
|
+
text={label}
|
88
88
|
/>
|
89
89
|
}
|
90
90
|
<Timestamp
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
91
|
+
className={`pull-${alignTimestamp} ${timestampObject ? 'message_humanized_time' : null}`}
|
92
|
+
text={timestamp}
|
93
|
+
timestamp={''}
|
94
|
+
timezone={timezone}
|
95
95
|
/>
|
96
96
|
{timestampObject &&
|
97
97
|
<Timestamp
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
98
|
+
className={`pull-${alignTimestamp} message_timestamp`}
|
99
|
+
text={''}
|
100
|
+
timestamp={timestampObject}
|
101
|
+
timezone={timezone}
|
102
102
|
/>
|
103
103
|
}
|
104
104
|
</Flex>
|
105
105
|
{message &&
|
106
106
|
<Body
|
107
|
-
|
108
|
-
|
107
|
+
className="pb_message_body"
|
108
|
+
text={message}
|
109
109
|
/>
|
110
110
|
}
|
111
111
|
{children}
|